diff --git a/browser/scripts/sweet.js b/browser/scripts/sweet.js index 0749a998..5d82377e 100644 --- a/browser/scripts/sweet.js +++ b/browser/scripts/sweet.js @@ -57,85 +57,87 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack Object.defineProperty(exports, "__esModule", { value: true }); - exports.compile = exports.parse = exports.expand = undefined; + exports.expand = expand; + exports.parse = parse; + exports.compile = compile; - var _shiftReader = __webpack_require__(3); + var _immutable = __webpack_require__(3); - var _shiftReader2 = _interopRequireDefault(_shiftReader); - - var _immutable = __webpack_require__(11); - - var _syntax = __webpack_require__(12); - - var _syntax2 = _interopRequireDefault(_syntax); - - var _env = __webpack_require__(31); - - var _env2 = _interopRequireDefault(_env); - - var _shiftReducer = __webpack_require__(33); + var _shiftReducer = __webpack_require__(4); var _shiftReducer2 = _interopRequireDefault(_shiftReducer); - var _parseReducer = __webpack_require__(37); + var _parseReducer = __webpack_require__(8); var _parseReducer2 = _interopRequireDefault(_parseReducer); - var _shiftCodegen = __webpack_require__(38); + var _shiftCodegen = __webpack_require__(12); var _shiftCodegen2 = _interopRequireDefault(_shiftCodegen); - var _scope = __webpack_require__(44); - - var _bindingMap = __webpack_require__(14); + var _bindingMap = __webpack_require__(22); var _bindingMap2 = _interopRequireDefault(_bindingMap); - var _terms = __webpack_require__(28); + var _terms = __webpack_require__(9); var _terms2 = _interopRequireDefault(_terms); - var _modules = __webpack_require__(46); + var _modules = __webpack_require__(36); - var _babelCore = __webpack_require__(75); + var _babelCore = __webpack_require__(73); - var _nodeModuleResolver = __webpack_require__(76); + var _nodeModuleResolver = __webpack_require__(74); var _nodeModuleResolver2 = _interopRequireDefault(_nodeModuleResolver); - var _nodeModuleLoader = __webpack_require__(77); + var _nodeModuleLoader = __webpack_require__(75); var _nodeModuleLoader2 = _interopRequireDefault(_nodeModuleLoader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - function expand_797(source_800) { - let options_801 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + function expand(source) { + let options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - let bindings_802 = new _bindingMap2.default(); - let modules_803 = new _modules.Modules({ bindings: bindings_802, cwd: options_801.cwd || process.cwd(), filename: options_801.filename, transform: options_801.transform || _babelCore.transform || function (c_806) { - return { code: c_806 }; - }, moduleResolver: options_801.moduleResolver || _nodeModuleResolver2.default, moduleLoader: options_801.moduleLoader || _nodeModuleLoader2.default }); - let compiledMod_804 = modules_803.compileEntrypoint(source_800, options_801.filename, options_801.enforcePragma); - let nativeImports_805 = compiledMod_804.importEntries.filter(imp_807 => !modules_803.has(imp_807.moduleSpecifier.val())); - return new _terms2.default("Module", { directives: (0, _immutable.List)(), items: nativeImports_805.concat(compiledMod_804.body).concat(compiledMod_804.exportEntries.interpose(new _terms2.default("EmptyStatement", {}))) }); + let bindings = new _bindingMap2.default(); + let modules = new _modules.Modules({ + bindings: bindings, + cwd: options.cwd || process.cwd(), + filename: options.filename, + transform: options.transform || _babelCore.transform || function (c) { + return { code: c }; + }, + moduleResolver: options.moduleResolver || _nodeModuleResolver2.default, + moduleLoader: options.moduleLoader || _nodeModuleLoader2.default + }); + let compiledMod = modules.compileEntrypoint(source, options.filename, options.enforcePragma); + let nativeImports = compiledMod.importEntries.filter(imp => !modules.has(imp.moduleSpecifier.val())); + return new _terms2.default("Module", { + directives: (0, _immutable.List)(), + items: nativeImports.concat(compiledMod.body).concat(compiledMod.exportEntries.interpose(new _terms2.default('EmptyStatement', {}))) + }); } - function parse_798(source_808, options_809) { - let includeImports_810 = arguments.length <= 2 || arguments[2] === undefined ? true : arguments[2]; - return (0, _shiftReducer2.default)(new _parseReducer2.default({ phase: 0 }), expand_797(source_808, options_809).gen({ includeImports: includeImports_810 })); + // not available in browser + + function parse(source, options) { + let includeImports = arguments.length <= 2 || arguments[2] === undefined ? true : arguments[2]; + + return (0, _shiftReducer2.default)(new _parseReducer2.default({ phase: 0 }), expand(source, options).gen(includeImports)); } - function compile_799(source_811) { - let options_812 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - let ast_813 = parse_798(source_811, options_812, options_812.includeImports); - let gen_814 = (0, _shiftCodegen2.default)(ast_813, new _shiftCodegen.FormattedCodeGen()); - return options_812.transform && !options_812.noBabel ? options_812.transform(gen_814, { babelrc: true, filename: options_812.filename }) : { code: gen_814 }; + function compile(source) { + let options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + + let ast = parse(source, options, options.includeImports); + let gen = (0, _shiftCodegen2.default)(ast, new _shiftCodegen.FormattedCodeGen()); + return options.transform && !options.noBabel ? options.transform(gen, { + babelrc: true, + filename: options.filename + }) : { code: gen }; } - exports.expand = expand_797; - exports.parse = parse_798; - exports.compile = compile_799; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L3N3ZWV0LmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7OztBQUNBOztBQUNBOzs7O0FBQ0E7Ozs7QUFDQTs7OztBQUNBOzs7O0FBQ0E7Ozs7QUFDQTs7QUFDQTs7OztBQUNBOzs7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7QUFDQTs7Ozs7O0FBQ0EsU0FBUyxVQUFULENBQW9CLFVBQXBCLEVBQWtEO0FBQUEsTUFBbEIsV0FBa0IseURBQUosRUFBSTs7QUFDaEQsTUFBSSxlQUFlLDBCQUFuQjtBQUNBLE1BQUksY0FBYyxxQkFBWSxFQUFDLFVBQVUsWUFBWCxFQUF5QixLQUFLLFlBQVksR0FBWixJQUFtQixRQUFRLEdBQVIsRUFBakQsRUFBZ0UsVUFBVSxZQUFZLFFBQXRGLEVBQWdHLFdBQVcsWUFBWSxTQUFaLDRCQUEyQyxVQUFVLEtBQVYsRUFBaUI7QUFDbk0sYUFBTyxFQUFDLE1BQU0sS0FBUCxFQUFQO0FBQ0QsS0FGNkIsRUFFM0IsZ0JBQWdCLFlBQVksY0FBWixnQ0FGVyxFQUVpQyxjQUFjLFlBQVksWUFBWiw4QkFGL0MsRUFBWixDQUFsQjtBQUdBLE1BQUksa0JBQWtCLFlBQVksaUJBQVosQ0FBOEIsVUFBOUIsRUFBMEMsWUFBWSxRQUF0RCxFQUFnRSxZQUFZLGFBQTVFLENBQXRCO0FBQ0EsTUFBSSxvQkFBb0IsZ0JBQWdCLGFBQWhCLENBQThCLE1BQTlCLENBQXFDLFdBQVcsQ0FBQyxZQUFZLEdBQVosQ0FBZ0IsUUFBUSxlQUFSLENBQXdCLEdBQXhCLEVBQWhCLENBQWpELENBQXhCO0FBQ0EsU0FBTyxvQkFBUyxRQUFULEVBQW1CLEVBQUMsWUFBWSxzQkFBYixFQUFxQixPQUFPLGtCQUFrQixNQUFsQixDQUF5QixnQkFBZ0IsSUFBekMsRUFBK0MsTUFBL0MsQ0FBc0QsZ0JBQWdCLGFBQWhCLENBQThCLFNBQTlCLENBQXdDLG9CQUFTLGdCQUFULEVBQTJCLEVBQTNCLENBQXhDLENBQXRELENBQTVCLEVBQW5CLENBQVA7QUFDRDtBQUNELFNBQVMsU0FBVCxDQUFtQixVQUFuQixFQUErQixXQUEvQixFQUF1RTtBQUFBLE1BQTNCLGtCQUEyQix5REFBTixJQUFNOztBQUNyRSxTQUFPLDRCQUFPLDJCQUFpQixFQUFDLE9BQU8sQ0FBUixFQUFqQixDQUFQLEVBQXFDLFdBQVcsVUFBWCxFQUF1QixXQUF2QixFQUFvQyxHQUFwQyxDQUF3QyxFQUFDLGdCQUFnQixrQkFBakIsRUFBeEMsQ0FBckMsQ0FBUDtBQUNEO0FBQ0QsU0FBUyxXQUFULENBQXFCLFVBQXJCLEVBQW1EO0FBQUEsTUFBbEIsV0FBa0IseURBQUosRUFBSTs7QUFDakQsTUFBSSxVQUFVLFVBQVUsVUFBVixFQUFzQixXQUF0QixFQUFtQyxZQUFZLGNBQS9DLENBQWQ7QUFDQSxNQUFJLFVBQVUsNEJBQVEsT0FBUixFQUFpQixvQ0FBakIsQ0FBZDtBQUNBLFNBQU8sWUFBWSxTQUFaLElBQXlCLENBQUMsWUFBWSxPQUF0QyxHQUFnRCxZQUFZLFNBQVosQ0FBc0IsT0FBdEIsRUFBK0IsRUFBQyxTQUFTLElBQVYsRUFBZ0IsVUFBVSxZQUFZLFFBQXRDLEVBQS9CLENBQWhELEdBQWtJLEVBQUMsTUFBTSxPQUFQLEVBQXpJO0FBQ0Q7UUFDcUIsTSxHQUFkLFU7UUFDYSxLLEdBQWIsUztRQUNlLE8sR0FBZixXIiwiZmlsZSI6InN3ZWV0LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWRlciBmcm9tIFwiLi9zaGlmdC1yZWFkZXJcIjtcbmltcG9ydCB7TGlzdH0gZnJvbSBcImltbXV0YWJsZVwiO1xuaW1wb3J0IFN5bnRheCBmcm9tIFwiLi9zeW50YXhcIjtcbmltcG9ydCBFbnYgZnJvbSBcIi4vZW52XCI7XG5pbXBvcnQgcmVkdWNlIGZyb20gXCJzaGlmdC1yZWR1Y2VyXCI7XG5pbXBvcnQgUGFyc2VSZWR1Y2VyIGZyb20gXCIuL3BhcnNlLXJlZHVjZXJcIjtcbmltcG9ydCBjb2RlZ2VuLCB7Rm9ybWF0dGVkQ29kZUdlbn0gZnJvbSBcInNoaWZ0LWNvZGVnZW5cIjtcbmltcG9ydCB7U2NvcGUsIGZyZXNoU2NvcGV9IGZyb20gXCIuL3Njb3BlXCI7XG5pbXBvcnQgQmluZGluZ01hcCBmcm9tIFwiLi9iaW5kaW5nLW1hcC5qc1wiO1xuaW1wb3J0IFRlcm0gZnJvbSBcIi4vdGVybXNcIjtcbmltcG9ydCB7TW9kdWxlc30gZnJvbSBcIi4vbW9kdWxlc1wiO1xuaW1wb3J0IHt0cmFuc2Zvcm0gYXMgYmFiZWxUcmFuc2Zvcm19IGZyb20gXCJiYWJlbC1jb3JlXCI7XG5pbXBvcnQgbm9kZVJlc29sdmVyIGZyb20gXCIuL25vZGUtbW9kdWxlLXJlc29sdmVyXCI7XG5pbXBvcnQgbm9kZUxvYWRlciBmcm9tIFwiLi9ub2RlLW1vZHVsZS1sb2FkZXJcIjtcbmZ1bmN0aW9uIGV4cGFuZF83OTcoc291cmNlXzgwMCwgb3B0aW9uc184MDEgPSB7fSkge1xuICBsZXQgYmluZGluZ3NfODAyID0gbmV3IEJpbmRpbmdNYXA7XG4gIGxldCBtb2R1bGVzXzgwMyA9IG5ldyBNb2R1bGVzKHtiaW5kaW5nczogYmluZGluZ3NfODAyLCBjd2Q6IG9wdGlvbnNfODAxLmN3ZCB8fCBwcm9jZXNzLmN3ZCgpLCBmaWxlbmFtZTogb3B0aW9uc184MDEuZmlsZW5hbWUsIHRyYW5zZm9ybTogb3B0aW9uc184MDEudHJhbnNmb3JtIHx8IGJhYmVsVHJhbnNmb3JtIHx8IGZ1bmN0aW9uIChjXzgwNikge1xuICAgIHJldHVybiB7Y29kZTogY184MDZ9O1xuICB9LCBtb2R1bGVSZXNvbHZlcjogb3B0aW9uc184MDEubW9kdWxlUmVzb2x2ZXIgfHwgbm9kZVJlc29sdmVyLCBtb2R1bGVMb2FkZXI6IG9wdGlvbnNfODAxLm1vZHVsZUxvYWRlciB8fCBub2RlTG9hZGVyfSk7XG4gIGxldCBjb21waWxlZE1vZF84MDQgPSBtb2R1bGVzXzgwMy5jb21waWxlRW50cnlwb2ludChzb3VyY2VfODAwLCBvcHRpb25zXzgwMS5maWxlbmFtZSwgb3B0aW9uc184MDEuZW5mb3JjZVByYWdtYSk7XG4gIGxldCBuYXRpdmVJbXBvcnRzXzgwNSA9IGNvbXBpbGVkTW9kXzgwNC5pbXBvcnRFbnRyaWVzLmZpbHRlcihpbXBfODA3ID0+ICFtb2R1bGVzXzgwMy5oYXMoaW1wXzgwNy5tb2R1bGVTcGVjaWZpZXIudmFsKCkpKTtcbiAgcmV0dXJuIG5ldyBUZXJtKFwiTW9kdWxlXCIsIHtkaXJlY3RpdmVzOiBMaXN0KCksIGl0ZW1zOiBuYXRpdmVJbXBvcnRzXzgwNS5jb25jYXQoY29tcGlsZWRNb2RfODA0LmJvZHkpLmNvbmNhdChjb21waWxlZE1vZF84MDQuZXhwb3J0RW50cmllcy5pbnRlcnBvc2UobmV3IFRlcm0oXCJFbXB0eVN0YXRlbWVudFwiLCB7fSkpKX0pO1xufVxuZnVuY3Rpb24gcGFyc2VfNzk4KHNvdXJjZV84MDgsIG9wdGlvbnNfODA5LCBpbmNsdWRlSW1wb3J0c184MTAgPSB0cnVlKSB7XG4gIHJldHVybiByZWR1Y2UobmV3IFBhcnNlUmVkdWNlcih7cGhhc2U6IDB9KSwgZXhwYW5kXzc5Nyhzb3VyY2VfODA4LCBvcHRpb25zXzgwOSkuZ2VuKHtpbmNsdWRlSW1wb3J0czogaW5jbHVkZUltcG9ydHNfODEwfSkpO1xufVxuZnVuY3Rpb24gY29tcGlsZV83OTkoc291cmNlXzgxMSwgb3B0aW9uc184MTIgPSB7fSkge1xuICBsZXQgYXN0XzgxMyA9IHBhcnNlXzc5OChzb3VyY2VfODExLCBvcHRpb25zXzgxMiwgb3B0aW9uc184MTIuaW5jbHVkZUltcG9ydHMpO1xuICBsZXQgZ2VuXzgxNCA9IGNvZGVnZW4oYXN0XzgxMywgbmV3IEZvcm1hdHRlZENvZGVHZW4pO1xuICByZXR1cm4gb3B0aW9uc184MTIudHJhbnNmb3JtICYmICFvcHRpb25zXzgxMi5ub0JhYmVsID8gb3B0aW9uc184MTIudHJhbnNmb3JtKGdlbl84MTQsIHtiYWJlbHJjOiB0cnVlLCBmaWxlbmFtZTogb3B0aW9uc184MTIuZmlsZW5hbWV9KSA6IHtjb2RlOiBnZW5fODE0fTtcbn1cbmV4cG9ydCB7ZXhwYW5kXzc5NyBhcyBleHBhbmR9O1xuZXhwb3J0IHtwYXJzZV83OTggYXMgcGFyc2V9O1xuZXhwb3J0IHtjb21waWxlXzc5OSBhcyBjb21waWxlfSJdfQ== + //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zd2VldC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztRQTZCZ0IsTSxHQUFBLE07UUFvQkEsSyxHQUFBLEs7UUFJQSxPLEdBQUEsTzs7QUFwRGhCOztBQUNBOzs7O0FBQ0E7Ozs7QUFDQTs7OztBQUVBOzs7O0FBRUE7Ozs7QUFDQTs7QUFJQTs7QUFDQTs7OztBQUNBOzs7Ozs7QUFjTyxTQUFTLE1BQVQsQ0FBZ0IsTUFBaEIsRUFBaUU7QUFBQSxNQUFqQyxPQUFpQyx5REFBVCxFQUFTOztBQUN0RSxNQUFJLFdBQVcsMEJBQWY7QUFDQSxNQUFJLFVBQVUscUJBQVk7QUFDeEIsc0JBRHdCO0FBRXhCLFNBQUssUUFBUSxHQUFSLElBQWUsUUFBUSxHQUFSLEVBRkk7QUFHeEIsY0FBVSxRQUFRLFFBSE07QUFJeEIsZUFBVyxRQUFRLFNBQVIsNEJBQXVDLFVBQVMsQ0FBVCxFQUFZO0FBQzVELGFBQU8sRUFBQyxNQUFNLENBQVAsRUFBUDtBQUNELEtBTnVCO0FBT3hCLG9CQUFnQixRQUFRLGNBQVIsZ0NBUFE7QUFReEIsa0JBQWMsUUFBUSxZQUFSO0FBUlUsR0FBWixDQUFkO0FBVUEsTUFBSSxjQUFjLFFBQVEsaUJBQVIsQ0FBMEIsTUFBMUIsRUFBa0MsUUFBUSxRQUExQyxFQUFvRCxRQUFRLGFBQTVELENBQWxCO0FBQ0EsTUFBSSxnQkFBZ0IsWUFBWSxhQUFaLENBQTBCLE1BQTFCLENBQWlDLE9BQU8sQ0FBQyxRQUFRLEdBQVIsQ0FBWSxJQUFJLGVBQUosQ0FBb0IsR0FBcEIsRUFBWixDQUF6QyxDQUFwQjtBQUNBLFNBQU8sb0JBQVMsUUFBVCxFQUFtQjtBQUN4QixnQkFBWSxzQkFEWTtBQUV4QixXQUFPLGNBQWMsTUFBZCxDQUFxQixZQUFZLElBQWpDLEVBQXVDLE1BQXZDLENBQThDLFlBQVksYUFBWixDQUEwQixTQUExQixDQUFvQyxvQkFBUyxnQkFBVCxFQUEyQixFQUEzQixDQUFwQyxDQUE5QztBQUZpQixHQUFuQixDQUFQO0FBSUQ7O0FBcENEOztBQXNDTyxTQUFTLEtBQVQsQ0FBZSxNQUFmLEVBQStCLE9BQS9CLEVBQTJGO0FBQUEsTUFBckMsY0FBcUMseURBQVgsSUFBVzs7QUFDaEcsU0FBTyw0QkFBTywyQkFBaUIsRUFBQyxPQUFPLENBQVIsRUFBakIsQ0FBUCxFQUFxQyxPQUFPLE1BQVAsRUFBZSxPQUFmLEVBQXdCLEdBQXhCLENBQTRCLGNBQTVCLENBQXJDLENBQVA7QUFDRDs7QUFFTSxTQUFTLE9BQVQsQ0FBaUIsTUFBakIsRUFBeUU7QUFBQSxNQUF4QyxPQUF3Qyx5REFBaEIsRUFBZ0I7O0FBQzlFLE1BQUksTUFBTSxNQUFNLE1BQU4sRUFBYyxPQUFkLEVBQXVCLFFBQVEsY0FBL0IsQ0FBVjtBQUNBLE1BQUksTUFBTSw0QkFBUSxHQUFSLEVBQWEsb0NBQWIsQ0FBVjtBQUNBLFNBQU8sUUFBUSxTQUFSLElBQXNCLENBQUMsUUFBUSxPQUEvQixHQUEwQyxRQUFRLFNBQVIsQ0FBa0IsR0FBbEIsRUFBdUI7QUFDdEUsYUFBUyxJQUQ2RDtBQUV0RSxjQUFVLFFBQVE7QUFGb0QsR0FBdkIsQ0FBMUMsR0FHRixFQUFFLE1BQU0sR0FBUixFQUhMO0FBSUQiLCJmaWxlIjoic3dlZXQuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBAZmxvd1xuaW1wb3J0IHsgTGlzdCB9IGZyb20gXCJpbW11dGFibGVcIjtcbmltcG9ydCByZWR1Y2UgZnJvbSBcInNoaWZ0LXJlZHVjZXJcIjtcbmltcG9ydCBQYXJzZVJlZHVjZXIgZnJvbSBcIi4vcGFyc2UtcmVkdWNlclwiO1xuaW1wb3J0IGNvZGVnZW4sIHsgRm9ybWF0dGVkQ29kZUdlbiB9IGZyb20gXCJzaGlmdC1jb2RlZ2VuXCI7XG5cbmltcG9ydCBCaW5kaW5nTWFwIGZyb20gXCIuL2JpbmRpbmctbWFwLmpzXCI7XG5cbmltcG9ydCBUZXJtIGZyb20gXCIuL3Rlcm1zXCI7XG5pbXBvcnQgeyBNb2R1bGVzIH0gZnJvbSAnLi9tb2R1bGVzJztcblxuLy8gbm90IGF2YWlsYWJsZSBpbiBicm93c2VyXG5cbmltcG9ydCB7IHRyYW5zZm9ybSBhcyBiYWJlbFRyYW5zZm9ybSB9IGZyb20gXCJiYWJlbC1jb3JlXCI7XG5pbXBvcnQgbm9kZVJlc29sdmVyIGZyb20gXCIuL25vZGUtbW9kdWxlLXJlc29sdmVyXCI7XG5pbXBvcnQgbm9kZUxvYWRlciBmcm9tIFwiLi9ub2RlLW1vZHVsZS1sb2FkZXJcIjtcblxudHlwZSBDb2RlT3V0cHV0ID0ge1xuICBjb2RlOiBzdHJpbmdcbn1cblxudHlwZSBTd2VldE9wdGlvbnMgPSB7XG4gIGluY2x1ZGVJbXBvcnRzPzogYm9vbGVhbjtcbiAgY3dkPzogc3RyaW5nO1xuICBlbmZvcmNlUHJhZ21hPzogYm9vbGVhbjtcbiAgZmlsZW5hbWU/OiBzdHJpbmc7XG4gIHRyYW5zZm9ybT86IChzOiBzdHJpbmcpID0+IHsgY29kZTogc3RyaW5nIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBleHBhbmQoc291cmNlOiBzdHJpbmcsIG9wdGlvbnM6IFN3ZWV0T3B0aW9ucyA9IHt9KTogYW55IHtcbiAgbGV0IGJpbmRpbmdzID0gbmV3IEJpbmRpbmdNYXAoKTtcbiAgbGV0IG1vZHVsZXMgPSBuZXcgTW9kdWxlcyh7XG4gICAgYmluZGluZ3MsXG4gICAgY3dkOiBvcHRpb25zLmN3ZCB8fCBwcm9jZXNzLmN3ZCgpLFxuICAgIGZpbGVuYW1lOiBvcHRpb25zLmZpbGVuYW1lLFxuICAgIHRyYW5zZm9ybTogb3B0aW9ucy50cmFuc2Zvcm0gfHwgYmFiZWxUcmFuc2Zvcm0gfHwgZnVuY3Rpb24oYykge1xuICAgICAgcmV0dXJuIHtjb2RlOiBjfTtcbiAgICB9LFxuICAgIG1vZHVsZVJlc29sdmVyOiBvcHRpb25zLm1vZHVsZVJlc29sdmVyIHx8IG5vZGVSZXNvbHZlcixcbiAgICBtb2R1bGVMb2FkZXI6IG9wdGlvbnMubW9kdWxlTG9hZGVyIHx8IG5vZGVMb2FkZXJcbiAgfSk7XG4gIGxldCBjb21waWxlZE1vZCA9IG1vZHVsZXMuY29tcGlsZUVudHJ5cG9pbnQoc291cmNlLCBvcHRpb25zLmZpbGVuYW1lLCBvcHRpb25zLmVuZm9yY2VQcmFnbWEpO1xuICBsZXQgbmF0aXZlSW1wb3J0cyA9IGNvbXBpbGVkTW9kLmltcG9ydEVudHJpZXMuZmlsdGVyKGltcCA9PiAhbW9kdWxlcy5oYXMoaW1wLm1vZHVsZVNwZWNpZmllci52YWwoKSkpO1xuICByZXR1cm4gbmV3IFRlcm0oXCJNb2R1bGVcIiwge1xuICAgIGRpcmVjdGl2ZXM6IExpc3QoKSxcbiAgICBpdGVtczogbmF0aXZlSW1wb3J0cy5jb25jYXQoY29tcGlsZWRNb2QuYm9keSkuY29uY2F0KGNvbXBpbGVkTW9kLmV4cG9ydEVudHJpZXMuaW50ZXJwb3NlKG5ldyBUZXJtKCdFbXB0eVN0YXRlbWVudCcsIHt9KSkpXG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcGFyc2Uoc291cmNlOiBzdHJpbmcsIG9wdGlvbnM6IFN3ZWV0T3B0aW9ucywgaW5jbHVkZUltcG9ydHM6IGJvb2xlYW4gPSB0cnVlKTogYW55IHtcbiAgcmV0dXJuIHJlZHVjZShuZXcgUGFyc2VSZWR1Y2VyKHtwaGFzZTogMH0pLCBleHBhbmQoc291cmNlLCBvcHRpb25zKS5nZW4oaW5jbHVkZUltcG9ydHMpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNvbXBpbGUoc291cmNlOiBzdHJpbmcsIG9wdGlvbnM6IFN3ZWV0T3B0aW9ucyA9IHt9KTogQ29kZU91dHB1dCB7XG4gIGxldCBhc3QgPSBwYXJzZShzb3VyY2UsIG9wdGlvbnMsIG9wdGlvbnMuaW5jbHVkZUltcG9ydHMpO1xuICBsZXQgZ2VuID0gY29kZWdlbihhc3QsIG5ldyBGb3JtYXR0ZWRDb2RlR2VuKCkpO1xuICByZXR1cm4gb3B0aW9ucy50cmFuc2Zvcm0gJiYgKCFvcHRpb25zLm5vQmFiZWwpID8gb3B0aW9ucy50cmFuc2Zvcm0oZ2VuLCB7XG4gICAgYmFiZWxyYzogdHJ1ZSxcbiAgICBmaWxlbmFtZTogb3B0aW9ucy5maWxlbmFtZVxuICB9KSA6IHsgY29kZTogZ2VuIH07XG59XG4iXX0= /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(2))) /***/ }, @@ -267,7416 +269,6316 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /* 3 */ /***/ function(module, exports, __webpack_require__) { - "use strict"; + /** + * Copyright (c) 2014-2015, Facebook, Inc. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. An additional grant + * of patent rights can be found in the PATENTS file in the same directory. + */ - Object.defineProperty(exports, "__esModule", { - value: true - }); + (function (global, factory) { + true ? module.exports = factory() : + typeof define === 'function' && define.amd ? define(factory) : + (global.Immutable = factory()); + }(this, function () { 'use strict';var SLICE$0 = Array.prototype.slice; - var _tokenizer = __webpack_require__(4); + function createClass(ctor, superClass) { + if (superClass) { + ctor.prototype = Object.create(superClass.prototype); + } + ctor.prototype.constructor = ctor; + } - var _tokenizer2 = _interopRequireDefault(_tokenizer); + function Iterable(value) { + return isIterable(value) ? value : Seq(value); + } - var _immutable = __webpack_require__(11); - var _syntax = __webpack_require__(12); + createClass(KeyedIterable, Iterable); + function KeyedIterable(value) { + return isKeyed(value) ? value : KeyedSeq(value); + } - var _syntax2 = _interopRequireDefault(_syntax); - var _ramdaFantasy = __webpack_require__(15); + createClass(IndexedIterable, Iterable); + function IndexedIterable(value) { + return isIndexed(value) ? value : IndexedSeq(value); + } - var _errors = __webpack_require__(13); - var _terms = __webpack_require__(28); + createClass(SetIterable, Iterable); + function SetIterable(value) { + return isIterable(value) && !isAssociative(value) ? value : SetSeq(value); + } - var _terms2 = _interopRequireDefault(_terms); - var _ramda = __webpack_require__(27); - var R = _interopRequireWildcard(_ramda); + function isIterable(maybeIterable) { + return !!(maybeIterable && maybeIterable[IS_ITERABLE_SENTINEL]); + } - function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + function isKeyed(maybeKeyed) { + return !!(maybeKeyed && maybeKeyed[IS_KEYED_SENTINEL]); + } - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + function isIndexed(maybeIndexed) { + return !!(maybeIndexed && maybeIndexed[IS_INDEXED_SENTINEL]); + } - const Just_662 = _ramdaFantasy.Maybe.Just; - const Nothing_663 = _ramdaFantasy.Maybe.Nothing; - const LSYNTAX_664 = { name: "left-syntax" }; - const RSYNTAX_665 = { name: "right-syntax" }; - const AT_666 = { klass: _tokenizer.TokenClass.Punctuator, name: "@" }; - const literalKeywords_667 = ["this", "null", "true", "false"]; - const isLeftBracket_668 = R.whereEq({ type: _tokenizer.TokenType.LBRACK }); - const isLeftBrace_669 = R.whereEq({ type: _tokenizer.TokenType.LBRACE }); - const isLeftParen_670 = R.whereEq({ type: _tokenizer.TokenType.LPAREN }); - const isRightBracket_671 = R.whereEq({ type: _tokenizer.TokenType.RBRACK }); - const isRightBrace_672 = R.whereEq({ type: _tokenizer.TokenType.RBRACE }); - const isRightParen_673 = R.whereEq({ type: _tokenizer.TokenType.RPAREN }); - const isEOS_674 = R.whereEq({ type: _tokenizer.TokenType.EOS }); - const isHash_675 = R.whereEq({ type: _tokenizer.TokenType.IDENTIFIER, value: "#" }); - const isLeftSyntax_676 = R.whereEq({ type: LSYNTAX_664 }); - const isRightSyntax_677 = R.whereEq({ type: RSYNTAX_665 }); - const isLeftDelimiter_678 = R.anyPass([isLeftBracket_668, isLeftBrace_669, isLeftParen_670, isLeftSyntax_676]); - const isRightDelimiter_679 = R.anyPass([isRightBracket_671, isRightBrace_672, isRightParen_673, isRightSyntax_677]); - const isMatchingDelimiters_680 = R.cond([[isLeftBracket_668, (__721, b_722) => isRightBracket_671(b_722)], [isLeftBrace_669, (__723, b_724) => isRightBrace_672(b_724)], [isLeftParen_670, (__725, b_726) => isRightParen_673(b_726)], [isLeftSyntax_676, (__727, b_728) => isRightSyntax_677(b_728)], [R.T, R.F]]); - const assignOps_681 = ["=", "+=", "-=", "*=", "/=", "%=", "<<=", ">>=", ">>>=", "&=", "|=", "^=", ","]; - const binaryOps_682 = ["+", "-", "*", "/", "%", "<<", ">>", ">>>", "&", "|", "^", "&&", "||", "?", ":", "===", "==", ">=", "<=", "<", ">", "!=", "!==", "instanceof"]; - const unaryOps_683 = ["++", "--", "~", "!", "delete", "void", "typeof", "yield", "throw", "new"]; - const isEmpty_684 = R.whereEq({ size: 0 }); - const isPunctuator_685 = s_729 => s_729.match("punctuator"); - const isKeyword_686 = s_730 => s_730.match("keyword"); - const isDelimiter_687 = s_731 => s_731.match("delimiter"); - const isParens_688 = s_732 => s_732.match("parens"); - const isBraces_689 = s_733 => s_733.match("braces"); - const isBrackets_690 = s_734 => s_734.match("brackets"); - const isIdentifier_691 = s_735 => s_735.match("identifier"); - const val_692 = s_736 => s_736.val(); - const isVal_693 = R.curry((v_737, s_738) => s_738.val() === v_737); - const isDot_694 = R.allPass([isPunctuator_685, isVal_693(".")]); - const isColon_695 = R.allPass([isPunctuator_685, isVal_693(":")]); - const isFunctionKeyword_696 = R.allPass([isKeyword_686, isVal_693("function")]); - const isOperator_697 = s_739 => (s_739.match("punctuator") || s_739.match("keyword")) && R.any(R.equals(s_739.val()), assignOps_681.concat(binaryOps_682).concat(unaryOps_683)); - const isNonLiteralKeyword_698 = R.allPass([isKeyword_686, s_740 => R.none(R.equals(s_740.val()), literalKeywords_667)]); - const isKeywordExprPrefix_699 = R.allPass([isKeyword_686, s_741 => R.any(R.equals(s_741.val()), ["instanceof", "typeof", "delete", "void", "yield", "throw", "new", "case"])]); - let last_700 = p_742 => p_742.last(); - let safeLast_701 = R.pipe(R.cond([[isEmpty_684, R.always(Nothing_663())], [R.T, R.compose(_ramdaFantasy.Maybe.of, last_700)]])); - let stuffTrue_702 = R.curry((p_743, b_744) => b_744 ? Just_662(p_743) : Nothing_663()); - let stuffFalse_703 = R.curry((p_745, b_746) => !b_746 ? Just_662(p_745) : Nothing_663()); - let isTopColon_704 = R.pipe(safeLast_701, R.map(isColon_695), _ramdaFantasy.Maybe.maybe(false, R.identity)); - let isTopPunctuator_705 = R.pipe(safeLast_701, R.map(isPunctuator_685), _ramdaFantasy.Maybe.maybe(false, R.identity)); - let isExprReturn_706 = R.curry((l_747, p_748) => { - let retKwd_749 = safeLast_701(p_748); - let maybeDot_750 = pop_717(p_748).chain(safeLast_701); - if (maybeDot_750.map(isDot_694).getOrElse(false)) { - return true; + function isAssociative(maybeAssociative) { + return isKeyed(maybeAssociative) || isIndexed(maybeAssociative); } - return retKwd_749.map(s_751 => { - return s_751.match("keyword") && s_751.val() === "return" && s_751.lineNumber() === l_747; - }).getOrElse(false); - }); - const isTopOperator_707 = R.pipe(safeLast_701, R.map(isOperator_697), _ramdaFantasy.Maybe.maybe(false, R.identity)); - const isTopKeywordExprPrefix_708 = R.pipe(safeLast_701, R.map(isKeywordExprPrefix_699), _ramdaFantasy.Maybe.maybe(false, R.identity)); - let isExprPrefix_709 = R.curry((l_752, b_753) => R.cond([[isEmpty_684, R.always(b_753)], [isTopColon_704, R.always(b_753)], [isTopKeywordExprPrefix_708, R.T], [isTopOperator_707, R.T], [isTopPunctuator_705, R.always(b_753)], [isExprReturn_706(l_752), R.T], [R.T, R.F]])); - let curly_710 = p_754 => safeLast_701(p_754).map(isBraces_689).chain(stuffTrue_702(p_754)); - let paren_711 = p_755 => safeLast_701(p_755).map(isParens_688).chain(stuffTrue_702(p_755)); - let func_712 = p_756 => safeLast_701(p_756).map(isFunctionKeyword_696).chain(stuffTrue_702(p_756)); - let ident_713 = p_757 => safeLast_701(p_757).map(isIdentifier_691).chain(stuffTrue_702(p_757)); - let nonLiteralKeyword_714 = p_758 => safeLast_701(p_758).map(isNonLiteralKeyword_698).chain(stuffTrue_702(p_758)); - let opt_715 = R.curry((a_759, b_760, p_761) => { - let result_762 = R.pipeK(a_759, b_760)(_ramdaFantasy.Maybe.of(p_761)); - return _ramdaFantasy.Maybe.isJust(result_762) ? result_762 : _ramdaFantasy.Maybe.of(p_761); - }); - let notDot_716 = R.ifElse(R.whereEq({ size: 0 }), Just_662, p_763 => safeLast_701(p_763).map(s_764 => !(s_764.match("punctuator") && s_764.val() === ".")).chain(stuffTrue_702(p_763))); - let pop_717 = R.compose(Just_662, p_765 => p_765.pop()); - const functionPrefix_718 = R.pipeK(curly_710, pop_717, paren_711, pop_717, opt_715(ident_713, pop_717), func_712); - const isRegexPrefix_719 = b_766 => R.anyPass([isEmpty_684, isTopPunctuator_705, R.pipe(_ramdaFantasy.Maybe.of, R.pipeK(nonLiteralKeyword_714, pop_717, notDot_716), _ramdaFantasy.Maybe.isJust), R.pipe(_ramdaFantasy.Maybe.of, R.pipeK(paren_711, pop_717, nonLiteralKeyword_714, pop_717, notDot_716), _ramdaFantasy.Maybe.isJust), R.pipe(_ramdaFantasy.Maybe.of, functionPrefix_718, R.chain(p_767 => { - return safeLast_701(p_767).map(s_768 => s_768.lineNumber()).chain(fnLine_769 => { - return pop_717(p_767).map(isExprPrefix_709(fnLine_769, b_766)); - }).chain(stuffFalse_703(p_767)); - }), _ramdaFantasy.Maybe.isJust), p_770 => { - let isCurly_771 = _ramdaFantasy.Maybe.isJust(safeLast_701(p_770).map(isBraces_689)); - let alreadyCheckedFunction_772 = R.pipe(_ramdaFantasy.Maybe.of, functionPrefix_718, _ramdaFantasy.Maybe.isJust)(p_770); - if (alreadyCheckedFunction_772) { - return false; + + function isOrdered(maybeOrdered) { + return !!(maybeOrdered && maybeOrdered[IS_ORDERED_SENTINEL]); } - return R.pipe(_ramdaFantasy.Maybe.of, R.chain(curly_710), R.chain(p_773 => { - return safeLast_701(p_773).map(s_774 => s_774.lineNumber()).chain(curlyLine_775 => { - return pop_717(p_773).map(isExprPrefix_709(curlyLine_775, b_766)); - }).chain(stuffFalse_703(p_773)); - }), _ramdaFantasy.Maybe.isJust)(p_770); - }]); - function lastEl_720(l_776) { - return l_776[l_776.length - 1]; - } - class Reader extends _tokenizer2.default { - constructor(strings_777, context_778, replacements_779) { - super(Array.isArray(strings_777) ? strings_777.join("") : strings_777); - this.delimStack = new Map(); - this.insideSyntaxTemplate = [false]; - this.context = context_778; - if (Array.isArray(strings_777)) { - let totalIndex = 0; - this.replacementIndex = R.reduce((acc_780, strRep_781) => { - acc_780.push({ index: totalIndex + strRep_781[0].length, replacement: strRep_781[1] }); - totalIndex += strRep_781[0].length; - return acc_780; - }, [], R.zip(strings_777, replacements_779)); - } + + Iterable.isIterable = isIterable; + Iterable.isKeyed = isKeyed; + Iterable.isIndexed = isIndexed; + Iterable.isAssociative = isAssociative; + Iterable.isOrdered = isOrdered; + + Iterable.Keyed = KeyedIterable; + Iterable.Indexed = IndexedIterable; + Iterable.Set = SetIterable; + + + var IS_ITERABLE_SENTINEL = '@@__IMMUTABLE_ITERABLE__@@'; + var IS_KEYED_SENTINEL = '@@__IMMUTABLE_KEYED__@@'; + var IS_INDEXED_SENTINEL = '@@__IMMUTABLE_INDEXED__@@'; + var IS_ORDERED_SENTINEL = '@@__IMMUTABLE_ORDERED__@@'; + + // Used for setting prototype methods that IE8 chokes on. + var DELETE = 'delete'; + + // Constants describing the size of trie nodes. + var SHIFT = 5; // Resulted in best performance after ______? + var SIZE = 1 << SHIFT; + var MASK = SIZE - 1; + + // A consistent shared value representing "not set" which equals nothing other + // than itself, and nothing that could be provided externally. + var NOT_SET = {}; + + // Boolean references, Rough equivalent of `bool &`. + var CHANGE_LENGTH = { value: false }; + var DID_ALTER = { value: false }; + + function MakeRef(ref) { + ref.value = false; + return ref; } - read() { - let stack_782 = arguments.length <= 0 || arguments[0] === undefined ? [] : arguments[0]; - let b_783 = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1]; - let singleDelimiter_784 = arguments.length <= 2 || arguments[2] === undefined ? false : arguments[2]; - let prefix_785 = (0, _immutable.List)(); - while (true) { - let tok = this.advance(prefix_785, b_783); - if (tok.scopesets || tok instanceof _terms2.default) { - stack_782.push(tok); - continue; - } - if (Array.isArray(tok)) { - Array.prototype.push.apply(stack_782, tok); - continue; - } - if (_immutable.List.isList(tok)) { - Array.prototype.push.apply(stack_782, tok.toArray()); - continue; - } - if (isEOS_674(tok)) { - if (stack_782[0] && isLeftDelimiter_678(stack_782[0].token)) { - throw this.createUnexpected(tok); - } - break; - } - if (isLeftDelimiter_678(tok)) { - if (isLeftSyntax_676(tok)) { - this.insideSyntaxTemplate.push(true); - } - let line = tok.slice.startLocation.line; - let innerB = isLeftBrace_669(tok) ? isExprPrefix_709(line, b_783)(prefix_785) : true; - let inner = this.read([new _syntax2.default(tok, this.context)], innerB, false); - let stx = new _syntax2.default(inner, this.context); - prefix_785 = prefix_785.concat(stx); - stack_782.push(stx); - if (singleDelimiter_784) { - break; - } - } else if (isRightDelimiter_679(tok)) { - if (stack_782[0] && !isMatchingDelimiters_680(stack_782[0].token, tok)) { - throw this.createUnexpected(tok); - } - let stx = new _syntax2.default(tok, this.context); - stack_782.push(stx); - if (lastEl_720(this.insideSyntaxTemplate) && isRightSyntax_677(tok)) { - this.insideSyntaxTemplate.pop(); - } - break; - } else { - let stx = new _syntax2.default(tok, this.context); - prefix_785 = prefix_785.concat(stx); - stack_782.push(stx); - } - } - return (0, _immutable.List)(stack_782); + function SetRef(ref) { + ref && (ref.value = true); } - advance(prefix_786, b_787) { - let startLocation_788 = this.getLocation(); - this.lastIndex = this.index; - this.lastLine = this.line; - this.lastLineStart = this.lineStart; - this.skipComment(); - this.startIndex = this.index; - this.startLine = this.line; - this.startLineStart = this.lineStart; - if (this.replacementIndex && this.replacementIndex[0] && this.index >= this.replacementIndex[0].index) { - let rep = this.replacementIndex[0].replacement; - this.replacementIndex.shift(); - return rep; - } - let charCode_789 = this.source.charCodeAt(this.index); - if (charCode_789 === 96) { - let element, - items = []; - let startLocation_788 = this.getLocation(); - let start = this.index; - this.index++; - if (lastEl_720(this.insideSyntaxTemplate)) { - let slice = this.getSlice(start, startLocation_788); - return { type: RSYNTAX_665, value: "`", slice: slice }; - } - do { - element = this.scanTemplateElement(); - items.push(element); - if (element.interp) { - element = this.read([], false, true); - (0, _errors.assert)(element.size === 1, "should only have read a single delimiter inside a template"); - items.push(element.get(0)); - } - } while (!element.tail); - return { type: _tokenizer.TokenType.TEMPLATE, items: (0, _immutable.List)(items), slice: this.getSlice(start, startLocation_788) }; - } else if (charCode_789 === 35) { - let startLocation_788 = this.getLocation(); - let start = this.index; - let slice = this.getSlice(start, startLocation_788); - this.index++; - if (this.source.charCodeAt(this.index) === 96) { - this.index++; - return { type: LSYNTAX_664, value: "#`", slice: slice }; - } - return { type: _tokenizer.TokenType.IDENTIFIER, value: "#", slice: slice }; - } else if (charCode_789 === 64) { - let startLocation_788 = this.getLocation(); - let start = this.index; - let slice = this.getSlice(start, startLocation_788); - this.index++; - return { type: AT_666, value: "@", slice: slice }; + + // A function which returns a value representing an "owner" for transient writes + // to tries. The return value will only ever equal itself, and will not equal + // the return of any subsequent call of this function. + function OwnerID() {} + + // http://jsperf.com/copy-array-inline + function arrCopy(arr, offset) { + offset = offset || 0; + var len = Math.max(0, arr.length - offset); + var newArr = new Array(len); + for (var ii = 0; ii < len; ii++) { + newArr[ii] = arr[ii + offset]; } - let lookahead_790 = super.advance(); - if (lookahead_790.type === _tokenizer.TokenType.DIV && isRegexPrefix_719(b_787)(prefix_786)) { - return super.scanRegExp("/"); + return newArr; + } + + function ensureSize(iter) { + if (iter.size === undefined) { + iter.size = iter.__iterate(returnTrue); } - return lookahead_790; + return iter.size; } - scanTemplateElement() { - let startLocation_791 = this.getLocation(); - let start_792 = this.index; - while (this.index < this.source.length) { - let ch = this.source.charCodeAt(this.index); - switch (ch) { - case 96: - let slice = this.getSlice(start_792, startLocation_791); - this.index++; - return { type: _tokenizer.TokenType.TEMPLATE, tail: true, interp: false, slice: slice }; - case 36: - if (this.source.charCodeAt(this.index + 1) === 123) { - let slice = this.getSlice(start_792, startLocation_791); - this.index += 1; - return { type: _tokenizer.TokenType.TEMPLATE, tail: false, interp: true, slice: slice }; - } - this.index++; - break; - case 92: - { - let octal = this.scanStringEscape("", null)[1]; - if (octal != null) { - throw this.createILLEGAL(); - } - break; - } - default: - this.index++; + + function wrapIndex(iter, index) { + // This implements "is array index" which the ECMAString spec defines as: + // + // A String property name P is an array index if and only if + // ToString(ToUint32(P)) is equal to P and ToUint32(P) is not equal + // to 2^32−1. + // + // http://www.ecma-international.org/ecma-262/6.0/#sec-array-exotic-objects + if (typeof index !== 'number') { + var uint32Index = index >>> 0; // N >>> 0 is shorthand for ToUint32 + if ('' + uint32Index !== index || uint32Index === 4294967295) { + return NaN; } + index = uint32Index; } - throw this.createILLEGAL(); + return index < 0 ? ensureSize(iter) + index : index; } - } - exports.default = Reader; - //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/shift-reader.js"],"names":[],"mappings":"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","file":"shift-reader.js","sourcesContent":["import Tokenizer from \"shift-parser/dist/tokenizer\";\nimport {TokenClass, TokenType} from \"shift-parser/dist/tokenizer\";\nimport {List} from \"immutable\";\nimport Syntax from \"./syntax\";\nimport {Maybe} from \"ramda-fantasy\";\nimport {assert} from \"./errors\";\nimport Term from \"./terms\";\nimport  * as R from \"ramda\";\nconst Just_662 = Maybe.Just;\nconst Nothing_663 = Maybe.Nothing;\nconst LSYNTAX_664 = {name: \"left-syntax\"};\nconst RSYNTAX_665 = {name: \"right-syntax\"};\nconst AT_666 = {klass: TokenClass.Punctuator, name: \"@\"};\nconst literalKeywords_667 = [\"this\", \"null\", \"true\", \"false\"];\nconst isLeftBracket_668 = R.whereEq({type: TokenType.LBRACK});\nconst isLeftBrace_669 = R.whereEq({type: TokenType.LBRACE});\nconst isLeftParen_670 = R.whereEq({type: TokenType.LPAREN});\nconst isRightBracket_671 = R.whereEq({type: TokenType.RBRACK});\nconst isRightBrace_672 = R.whereEq({type: TokenType.RBRACE});\nconst isRightParen_673 = R.whereEq({type: TokenType.RPAREN});\nconst isEOS_674 = R.whereEq({type: TokenType.EOS});\nconst isHash_675 = R.whereEq({type: TokenType.IDENTIFIER, value: \"#\"});\nconst isLeftSyntax_676 = R.whereEq({type: LSYNTAX_664});\nconst isRightSyntax_677 = R.whereEq({type: RSYNTAX_665});\nconst isLeftDelimiter_678 = R.anyPass([isLeftBracket_668, isLeftBrace_669, isLeftParen_670, isLeftSyntax_676]);\nconst isRightDelimiter_679 = R.anyPass([isRightBracket_671, isRightBrace_672, isRightParen_673, isRightSyntax_677]);\nconst isMatchingDelimiters_680 = R.cond([[isLeftBracket_668, (__721, b_722) => isRightBracket_671(b_722)], [isLeftBrace_669, (__723, b_724) => isRightBrace_672(b_724)], [isLeftParen_670, (__725, b_726) => isRightParen_673(b_726)], [isLeftSyntax_676, (__727, b_728) => isRightSyntax_677(b_728)], [R.T, R.F]]);\nconst assignOps_681 = [\"=\", \"+=\", \"-=\", \"*=\", \"/=\", \"%=\", \"<<=\", \">>=\", \">>>=\", \"&=\", \"|=\", \"^=\", \",\"];\nconst binaryOps_682 = [\"+\", \"-\", \"*\", \"/\", \"%\", \"<<\", \">>\", \">>>\", \"&\", \"|\", \"^\", \"&&\", \"||\", \"?\", \":\", \"===\", \"==\", \">=\", \"<=\", \"<\", \">\", \"!=\", \"!==\", \"instanceof\"];\nconst unaryOps_683 = [\"++\", \"--\", \"~\", \"!\", \"delete\", \"void\", \"typeof\", \"yield\", \"throw\", \"new\"];\nconst isEmpty_684 = R.whereEq({size: 0});\nconst isPunctuator_685 = s_729 => s_729.match(\"punctuator\");\nconst isKeyword_686 = s_730 => s_730.match(\"keyword\");\nconst isDelimiter_687 = s_731 => s_731.match(\"delimiter\");\nconst isParens_688 = s_732 => s_732.match(\"parens\");\nconst isBraces_689 = s_733 => s_733.match(\"braces\");\nconst isBrackets_690 = s_734 => s_734.match(\"brackets\");\nconst isIdentifier_691 = s_735 => s_735.match(\"identifier\");\nconst val_692 = s_736 => s_736.val();\nconst isVal_693 = R.curry((v_737, s_738) => s_738.val() === v_737);\nconst isDot_694 = R.allPass([isPunctuator_685, isVal_693(\".\")]);\nconst isColon_695 = R.allPass([isPunctuator_685, isVal_693(\":\")]);\nconst isFunctionKeyword_696 = R.allPass([isKeyword_686, isVal_693(\"function\")]);\nconst isOperator_697 = s_739 => (s_739.match(\"punctuator\") || s_739.match(\"keyword\")) && R.any(R.equals(s_739.val()), assignOps_681.concat(binaryOps_682).concat(unaryOps_683));\nconst isNonLiteralKeyword_698 = R.allPass([isKeyword_686, s_740 => R.none(R.equals(s_740.val()), literalKeywords_667)]);\nconst isKeywordExprPrefix_699 = R.allPass([isKeyword_686, s_741 => R.any(R.equals(s_741.val()), [\"instanceof\", \"typeof\", \"delete\", \"void\", \"yield\", \"throw\", \"new\", \"case\"])]);\nlet last_700 = p_742 => p_742.last();\nlet safeLast_701 = R.pipe(R.cond([[isEmpty_684, R.always(Nothing_663())], [R.T, R.compose(Maybe.of, last_700)]]));\nlet stuffTrue_702 = R.curry((p_743, b_744) => b_744 ? Just_662(p_743) : Nothing_663());\nlet stuffFalse_703 = R.curry((p_745, b_746) => !b_746 ? Just_662(p_745) : Nothing_663());\nlet isTopColon_704 = R.pipe(safeLast_701, R.map(isColon_695), Maybe.maybe(false, R.identity));\nlet isTopPunctuator_705 = R.pipe(safeLast_701, R.map(isPunctuator_685), Maybe.maybe(false, R.identity));\nlet isExprReturn_706 = R.curry((l_747, p_748) => {\n  let retKwd_749 = safeLast_701(p_748);\n  let maybeDot_750 = pop_717(p_748).chain(safeLast_701);\n  if (maybeDot_750.map(isDot_694).getOrElse(false)) {\n    return true;\n  }\n  return retKwd_749.map(s_751 => {\n    return s_751.match(\"keyword\") && s_751.val() === \"return\" && s_751.lineNumber() === l_747;\n  }).getOrElse(false);\n});\nconst isTopOperator_707 = R.pipe(safeLast_701, R.map(isOperator_697), Maybe.maybe(false, R.identity));\nconst isTopKeywordExprPrefix_708 = R.pipe(safeLast_701, R.map(isKeywordExprPrefix_699), Maybe.maybe(false, R.identity));\nlet isExprPrefix_709 = R.curry((l_752, b_753) => R.cond([[isEmpty_684, R.always(b_753)], [isTopColon_704, R.always(b_753)], [isTopKeywordExprPrefix_708, R.T], [isTopOperator_707, R.T], [isTopPunctuator_705, R.always(b_753)], [isExprReturn_706(l_752), R.T], [R.T, R.F]]));\nlet curly_710 = p_754 => safeLast_701(p_754).map(isBraces_689).chain(stuffTrue_702(p_754));\nlet paren_711 = p_755 => safeLast_701(p_755).map(isParens_688).chain(stuffTrue_702(p_755));\nlet func_712 = p_756 => safeLast_701(p_756).map(isFunctionKeyword_696).chain(stuffTrue_702(p_756));\nlet ident_713 = p_757 => safeLast_701(p_757).map(isIdentifier_691).chain(stuffTrue_702(p_757));\nlet nonLiteralKeyword_714 = p_758 => safeLast_701(p_758).map(isNonLiteralKeyword_698).chain(stuffTrue_702(p_758));\nlet opt_715 = R.curry((a_759, b_760, p_761) => {\n  let result_762 = R.pipeK(a_759, b_760)(Maybe.of(p_761));\n  return Maybe.isJust(result_762) ? result_762 : Maybe.of(p_761);\n});\nlet notDot_716 = R.ifElse(R.whereEq({size: 0}), Just_662, p_763 => safeLast_701(p_763).map(s_764 => !(s_764.match(\"punctuator\") && s_764.val() === \".\")).chain(stuffTrue_702(p_763)));\nlet pop_717 = R.compose(Just_662, p_765 => p_765.pop());\nconst functionPrefix_718 = R.pipeK(curly_710, pop_717, paren_711, pop_717, opt_715(ident_713, pop_717), func_712);\nconst isRegexPrefix_719 = b_766 => R.anyPass([isEmpty_684, isTopPunctuator_705, R.pipe(Maybe.of, R.pipeK(nonLiteralKeyword_714, pop_717, notDot_716), Maybe.isJust), R.pipe(Maybe.of, R.pipeK(paren_711, pop_717, nonLiteralKeyword_714, pop_717, notDot_716), Maybe.isJust), R.pipe(Maybe.of, functionPrefix_718, R.chain(p_767 => {\n  return safeLast_701(p_767).map(s_768 => s_768.lineNumber()).chain(fnLine_769 => {\n    return pop_717(p_767).map(isExprPrefix_709(fnLine_769, b_766));\n  }).chain(stuffFalse_703(p_767));\n}), Maybe.isJust), p_770 => {\n  let isCurly_771 = Maybe.isJust(safeLast_701(p_770).map(isBraces_689));\n  let alreadyCheckedFunction_772 = R.pipe(Maybe.of, functionPrefix_718, Maybe.isJust)(p_770);\n  if (alreadyCheckedFunction_772) {\n    return false;\n  }\n  return R.pipe(Maybe.of, R.chain(curly_710), R.chain(p_773 => {\n    return safeLast_701(p_773).map(s_774 => s_774.lineNumber()).chain(curlyLine_775 => {\n      return pop_717(p_773).map(isExprPrefix_709(curlyLine_775, b_766));\n    }).chain(stuffFalse_703(p_773));\n  }), Maybe.isJust)(p_770);\n}]);\nfunction lastEl_720(l_776) {\n  return l_776[l_776.length - 1];\n}\nexport default class Reader extends Tokenizer {\n  constructor(strings_777, context_778, replacements_779) {\n    super(Array.isArray(strings_777) ? strings_777.join(\"\") : strings_777);\n    this.delimStack = new Map;\n    this.insideSyntaxTemplate = [false];\n    this.context = context_778;\n    if (Array.isArray(strings_777)) {\n      let totalIndex = 0;\n      this.replacementIndex = R.reduce((acc_780, strRep_781) => {\n        acc_780.push({index: totalIndex + strRep_781[0].length, replacement: strRep_781[1]});\n        totalIndex += strRep_781[0].length;\n        return acc_780;\n      }, [], R.zip(strings_777, replacements_779));\n    }\n  }\n  read(stack_782 = [], b_783 = false, singleDelimiter_784 = false) {\n    let prefix_785 = List();\n    while (true) {\n      let tok = this.advance(prefix_785, b_783);\n      if (tok.scopesets || tok instanceof Term) {\n        stack_782.push(tok);\n        continue;\n      }\n      if (Array.isArray(tok)) {\n        Array.prototype.push.apply(stack_782, tok);\n        continue;\n      }\n      if (List.isList(tok)) {\n        Array.prototype.push.apply(stack_782, tok.toArray());\n        continue;\n      }\n      if (isEOS_674(tok)) {\n        if (stack_782[0] && isLeftDelimiter_678(stack_782[0].token)) {\n          throw this.createUnexpected(tok);\n        }\n        break;\n      }\n      if (isLeftDelimiter_678(tok)) {\n        if (isLeftSyntax_676(tok)) {\n          this.insideSyntaxTemplate.push(true);\n        }\n        let line = tok.slice.startLocation.line;\n        let innerB = isLeftBrace_669(tok) ? isExprPrefix_709(line, b_783)(prefix_785) : true;\n        let inner = this.read([new Syntax(tok, this.context)], innerB, false);\n        let stx = new Syntax(inner, this.context);\n        prefix_785 = prefix_785.concat(stx);\n        stack_782.push(stx);\n        if (singleDelimiter_784) {\n          break;\n        }\n      } else if (isRightDelimiter_679(tok)) {\n        if (stack_782[0] && !isMatchingDelimiters_680(stack_782[0].token, tok)) {\n          throw this.createUnexpected(tok);\n        }\n        let stx = new Syntax(tok, this.context);\n        stack_782.push(stx);\n        if (lastEl_720(this.insideSyntaxTemplate) && isRightSyntax_677(tok)) {\n          this.insideSyntaxTemplate.pop();\n        }\n        break;\n      } else {\n        let stx = new Syntax(tok, this.context);\n        prefix_785 = prefix_785.concat(stx);\n        stack_782.push(stx);\n      }\n    }\n    return List(stack_782);\n  }\n  advance(prefix_786, b_787) {\n    let startLocation_788 = this.getLocation();\n    this.lastIndex = this.index;\n    this.lastLine = this.line;\n    this.lastLineStart = this.lineStart;\n    this.skipComment();\n    this.startIndex = this.index;\n    this.startLine = this.line;\n    this.startLineStart = this.lineStart;\n    if (this.replacementIndex && this.replacementIndex[0] && this.index >= this.replacementIndex[0].index) {\n      let rep = this.replacementIndex[0].replacement;\n      this.replacementIndex.shift();\n      return rep;\n    }\n    let charCode_789 = this.source.charCodeAt(this.index);\n    if (charCode_789 === 96) {\n      let element, items = [];\n      let startLocation_788 = this.getLocation();\n      let start = this.index;\n      this.index++;\n      if (lastEl_720(this.insideSyntaxTemplate)) {\n        let slice = this.getSlice(start, startLocation_788);\n        return {type: RSYNTAX_665, value: \"`\", slice: slice};\n      }\n      do {\n        element = this.scanTemplateElement();\n        items.push(element);\n        if (element.interp) {\n          element = this.read([], false, true);\n          assert(element.size === 1, \"should only have read a single delimiter inside a template\");\n          items.push(element.get(0));\n        }\n      } while (!element.tail);\n      return {type: TokenType.TEMPLATE, items: List(items), slice: this.getSlice(start, startLocation_788)};\n    } else if (charCode_789 === 35) {\n      let startLocation_788 = this.getLocation();\n      let start = this.index;\n      let slice = this.getSlice(start, startLocation_788);\n      this.index++;\n      if (this.source.charCodeAt(this.index) === 96) {\n        this.index++;\n        return {type: LSYNTAX_664, value: \"#`\", slice: slice};\n      }\n      return {type: TokenType.IDENTIFIER, value: \"#\", slice: slice};\n    } else if (charCode_789 === 64) {\n      let startLocation_788 = this.getLocation();\n      let start = this.index;\n      let slice = this.getSlice(start, startLocation_788);\n      this.index++;\n      return {type: AT_666, value: \"@\", slice: slice};\n    }\n    let lookahead_790 = super.advance();\n    if (lookahead_790.type === TokenType.DIV && isRegexPrefix_719(b_787)(prefix_786)) {\n      return super.scanRegExp(\"/\");\n    }\n    return lookahead_790;\n  }\n  scanTemplateElement() {\n    let startLocation_791 = this.getLocation();\n    let start_792 = this.index;\n    while (this.index < this.source.length) {\n      let ch = this.source.charCodeAt(this.index);\n      switch (ch) {\n        case 96:\n          let slice = this.getSlice(start_792, startLocation_791);\n          this.index++;\n          return {type: TokenType.TEMPLATE, tail: true, interp: false, slice: slice};\n        case 36:\n          if (this.source.charCodeAt(this.index + 1) === 123) {\n            let slice = this.getSlice(start_792, startLocation_791);\n            this.index += 1;\n            return {type: TokenType.TEMPLATE, tail: false, interp: true, slice: slice};\n          }\n          this.index++;\n          break;\n        case 92:\n          {\n            let octal = this.scanStringEscape(\"\", null)[1];\n            if (octal != null) {\n              throw this.createILLEGAL();\n            }\n            break;\n          }\n        default:\n          this.index++;\n      }\n    }\n    throw this.createILLEGAL();\n  }\n}\n"]} - -/***/ }, -/* 4 */ -/***/ function(module, exports, __webpack_require__) { - "use strict"; + function returnTrue() { + return true; + } - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.JsError = exports.TokenType = exports.TokenClass = undefined; + function wholeSlice(begin, end, size) { + return (begin === 0 || (size !== undefined && begin <= -size)) && + (end === undefined || (size !== undefined && end >= size)); + } - var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); + function resolveBegin(begin, size) { + return resolveIndex(begin, size, 0); + } - var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); + function resolveEnd(end, size) { + return resolveIndex(end, size, size); + } - var _utils = __webpack_require__(5); + function resolveIndex(index, size, defaultIndex) { + return index === undefined ? + defaultIndex : + index < 0 ? + Math.max(0, size + index) : + size === undefined ? + index : + Math.min(size, index); + } - var _errors = __webpack_require__(10); + /* global Symbol */ - function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + var ITERATE_KEYS = 0; + var ITERATE_VALUES = 1; + var ITERATE_ENTRIES = 2; - function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + var REAL_ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator; + var FAUX_ITERATOR_SYMBOL = '@@iterator'; - function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } /** - * Copyright 2014 Shape Security, Inc. - * - * Licensed under the Apache License, Version 2.0 (the "License") - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ + var ITERATOR_SYMBOL = REAL_ITERATOR_SYMBOL || FAUX_ITERATOR_SYMBOL; - var TokenClass = exports.TokenClass = { - Eof: { name: "" }, - Ident: { name: "Identifier", isIdentifierName: true }, - Keyword: { name: "Keyword", isIdentifierName: true }, - NumericLiteral: { name: "Numeric" }, - TemplateElement: { name: "Template" }, - Punctuator: { name: "Punctuator" }, - StringLiteral: { name: "String" }, - RegularExpression: { name: "RegularExpression" }, - Illegal: { name: "Illegal" } - }; - var TokenType = exports.TokenType = { - EOS: { klass: TokenClass.Eof, name: "EOS" }, - LPAREN: { klass: TokenClass.Punctuator, name: "(" }, - RPAREN: { klass: TokenClass.Punctuator, name: ")" }, - LBRACK: { klass: TokenClass.Punctuator, name: "[" }, - RBRACK: { klass: TokenClass.Punctuator, name: "]" }, - LBRACE: { klass: TokenClass.Punctuator, name: "{" }, - RBRACE: { klass: TokenClass.Punctuator, name: "}" }, - COLON: { klass: TokenClass.Punctuator, name: ":" }, - SEMICOLON: { klass: TokenClass.Punctuator, name: ";" }, - PERIOD: { klass: TokenClass.Punctuator, name: "." }, - ELLIPSIS: { klass: TokenClass.Punctuator, name: "..." }, - ARROW: { klass: TokenClass.Punctuator, name: "=>" }, - CONDITIONAL: { klass: TokenClass.Punctuator, name: "?" }, - INC: { klass: TokenClass.Punctuator, name: "++" }, - DEC: { klass: TokenClass.Punctuator, name: "--" }, - ASSIGN: { klass: TokenClass.Punctuator, name: "=" }, - ASSIGN_BIT_OR: { klass: TokenClass.Punctuator, name: "|=" }, - ASSIGN_BIT_XOR: { klass: TokenClass.Punctuator, name: "^=" }, - ASSIGN_BIT_AND: { klass: TokenClass.Punctuator, name: "&=" }, - ASSIGN_SHL: { klass: TokenClass.Punctuator, name: "<<=" }, - ASSIGN_SHR: { klass: TokenClass.Punctuator, name: ">>=" }, - ASSIGN_SHR_UNSIGNED: { klass: TokenClass.Punctuator, name: ">>>=" }, - ASSIGN_ADD: { klass: TokenClass.Punctuator, name: "+=" }, - ASSIGN_SUB: { klass: TokenClass.Punctuator, name: "-=" }, - ASSIGN_MUL: { klass: TokenClass.Punctuator, name: "*=" }, - ASSIGN_DIV: { klass: TokenClass.Punctuator, name: "/=" }, - ASSIGN_MOD: { klass: TokenClass.Punctuator, name: "%=" }, - COMMA: { klass: TokenClass.Punctuator, name: "," }, - OR: { klass: TokenClass.Punctuator, name: "||" }, - AND: { klass: TokenClass.Punctuator, name: "&&" }, - BIT_OR: { klass: TokenClass.Punctuator, name: "|" }, - BIT_XOR: { klass: TokenClass.Punctuator, name: "^" }, - BIT_AND: { klass: TokenClass.Punctuator, name: "&" }, - SHL: { klass: TokenClass.Punctuator, name: "<<" }, - SHR: { klass: TokenClass.Punctuator, name: ">>" }, - SHR_UNSIGNED: { klass: TokenClass.Punctuator, name: ">>>" }, - ADD: { klass: TokenClass.Punctuator, name: "+" }, - SUB: { klass: TokenClass.Punctuator, name: "-" }, - MUL: { klass: TokenClass.Punctuator, name: "*" }, - DIV: { klass: TokenClass.Punctuator, name: "/" }, - MOD: { klass: TokenClass.Punctuator, name: "%" }, - EQ: { klass: TokenClass.Punctuator, name: "==" }, - NE: { klass: TokenClass.Punctuator, name: "!=" }, - EQ_STRICT: { klass: TokenClass.Punctuator, name: "===" }, - NE_STRICT: { klass: TokenClass.Punctuator, name: "!==" }, - LT: { klass: TokenClass.Punctuator, name: "<" }, - GT: { klass: TokenClass.Punctuator, name: ">" }, - LTE: { klass: TokenClass.Punctuator, name: "<=" }, - GTE: { klass: TokenClass.Punctuator, name: ">=" }, - INSTANCEOF: { klass: TokenClass.Keyword, name: "instanceof" }, - IN: { klass: TokenClass.Keyword, name: "in" }, - NOT: { klass: TokenClass.Punctuator, name: "!" }, - BIT_NOT: { klass: TokenClass.Punctuator, name: "~" }, - AWAIT: { klass: TokenClass.Keyword, name: "await" }, - DELETE: { klass: TokenClass.Keyword, name: "delete" }, - TYPEOF: { klass: TokenClass.Keyword, name: "typeof" }, - VOID: { klass: TokenClass.Keyword, name: "void" }, - BREAK: { klass: TokenClass.Keyword, name: "break" }, - CASE: { klass: TokenClass.Keyword, name: "case" }, - CATCH: { klass: TokenClass.Keyword, name: "catch" }, - CLASS: { klass: TokenClass.Keyword, name: "class" }, - CONTINUE: { klass: TokenClass.Keyword, name: "continue" }, - DEBUGGER: { klass: TokenClass.Keyword, name: "debugger" }, - DEFAULT: { klass: TokenClass.Keyword, name: "default" }, - DO: { klass: TokenClass.Keyword, name: "do" }, - ELSE: { klass: TokenClass.Keyword, name: "else" }, - EXPORT: { klass: TokenClass.Keyword, name: "export" }, - EXTENDS: { klass: TokenClass.Keyword, name: "extends" }, - FINALLY: { klass: TokenClass.Keyword, name: "finally" }, - FOR: { klass: TokenClass.Keyword, name: "for" }, - FUNCTION: { klass: TokenClass.Keyword, name: "function" }, - IF: { klass: TokenClass.Keyword, name: "if" }, - IMPORT: { klass: TokenClass.Keyword, name: "import" }, - LET: { klass: TokenClass.Keyword, name: "let" }, - NEW: { klass: TokenClass.Keyword, name: "new" }, - RETURN: { klass: TokenClass.Keyword, name: "return" }, - SUPER: { klass: TokenClass.Keyword, name: "super" }, - SWITCH: { klass: TokenClass.Keyword, name: "switch" }, - THIS: { klass: TokenClass.Keyword, name: "this" }, - THROW: { klass: TokenClass.Keyword, name: "throw" }, - TRY: { klass: TokenClass.Keyword, name: "try" }, - VAR: { klass: TokenClass.Keyword, name: "var" }, - WHILE: { klass: TokenClass.Keyword, name: "while" }, - WITH: { klass: TokenClass.Keyword, name: "with" }, - NULL: { klass: TokenClass.Keyword, name: "null" }, - TRUE: { klass: TokenClass.Keyword, name: "true" }, - FALSE: { klass: TokenClass.Keyword, name: "false" }, - YIELD: { klass: TokenClass.Keyword, name: "yield" }, - NUMBER: { klass: TokenClass.NumericLiteral, name: "" }, - STRING: { klass: TokenClass.StringLiteral, name: "" }, - REGEXP: { klass: TokenClass.RegularExpression, name: "" }, - IDENTIFIER: { klass: TokenClass.Ident, name: "" }, - CONST: { klass: TokenClass.Keyword, name: "const" }, - TEMPLATE: { klass: TokenClass.TemplateElement, name: "" }, - ILLEGAL: { klass: TokenClass.Illegal, name: "" } - }; + function Iterator(next) { + this.next = next; + } - var TT = TokenType; - var I = TT.ILLEGAL; - var F = false; - var T = true; + Iterator.prototype.toString = function() { + return '[Iterator]'; + }; - var ONE_CHAR_PUNCTUATOR = [I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, TT.NOT, I, I, I, TT.MOD, TT.BIT_AND, I, TT.LPAREN, TT.RPAREN, TT.MUL, TT.ADD, TT.COMMA, TT.SUB, TT.PERIOD, TT.DIV, I, I, I, I, I, I, I, I, I, I, TT.COLON, TT.SEMICOLON, TT.LT, TT.ASSIGN, TT.GT, TT.CONDITIONAL, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, TT.LBRACK, I, TT.RBRACK, TT.BIT_XOR, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, TT.LBRACE, TT.BIT_OR, TT.RBRACE, TT.BIT_NOT]; - var PUNCTUATOR_START = [F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, T, F, F, F, T, T, F, T, T, T, T, T, T, F, T, F, F, F, F, F, F, F, F, F, F, T, T, T, T, T, T, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, T, F, T, T, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, T, T, T, T, F]; + Iterator.KEYS = ITERATE_KEYS; + Iterator.VALUES = ITERATE_VALUES; + Iterator.ENTRIES = ITERATE_ENTRIES; - var JsError = exports.JsError = function (_Error) { - _inherits(JsError, _Error); + Iterator.prototype.inspect = + Iterator.prototype.toSource = function () { return this.toString(); } + Iterator.prototype[ITERATOR_SYMBOL] = function () { + return this; + }; - function JsError(index, line, column, msg) { - _classCallCheck(this, JsError); - var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(JsError).call(this, msg)); + function iteratorValue(type, k, v, iteratorResult) { + var value = type === 0 ? k : type === 1 ? v : [k, v]; + iteratorResult ? (iteratorResult.value = value) : (iteratorResult = { + value: value, done: false + }); + return iteratorResult; + } - _this.index = index; - _this.line = line; - _this.column = column; - _this.description = msg; - _this.message = "[" + line + ":" + column + "]: " + msg; - return _this; + function iteratorDone() { + return { value: undefined, done: true }; } - return JsError; - }(Error); + function hasIterator(maybeIterable) { + return !!getIteratorFn(maybeIterable); + } - function fromCodePoint(cp) { - if (cp <= 0xFFFF) return String.fromCharCode(cp); - var cu1 = String.fromCharCode(Math.floor((cp - 0x10000) / 0x400) + 0xD800); - var cu2 = String.fromCharCode((cp - 0x10000) % 0x400 + 0xDC00); - return cu1 + cu2; - } + function isIterator(maybeIterator) { + return maybeIterator && typeof maybeIterator.next === 'function'; + } - function decodeUtf16(lead, trail) { - return (lead - 0xD800) * 0x400 + (trail - 0xDC00) + 0x10000; - } + function getIterator(iterable) { + var iteratorFn = getIteratorFn(iterable); + return iteratorFn && iteratorFn.call(iterable); + } - var Tokenizer = function () { - function Tokenizer(source) { - _classCallCheck(this, Tokenizer); + function getIteratorFn(iterable) { + var iteratorFn = iterable && ( + (REAL_ITERATOR_SYMBOL && iterable[REAL_ITERATOR_SYMBOL]) || + iterable[FAUX_ITERATOR_SYMBOL] + ); + if (typeof iteratorFn === 'function') { + return iteratorFn; + } + } - this.source = source; - this.index = 0; - this.line = 0; - this.lineStart = 0; - this.startIndex = 0; - this.startLine = 0; - this.startLineStart = 0; - this.lastIndex = 0; - this.lastLine = 0; - this.lastLineStart = 0; - this.hasLineTerminatorBeforeNext = false; - this.tokenIndex = 0; + function isArrayLike(value) { + return value && typeof value.length === 'number'; } - _createClass(Tokenizer, [{ - key: "saveLexerState", - value: function saveLexerState() { - return { - source: this.source, - index: this.index, - line: this.line, - lineStart: this.lineStart, - startIndex: this.startIndex, - startLine: this.startLine, - startLineStart: this.startLineStart, - lastIndex: this.lastIndex, - lastLine: this.lastLine, - lastLineStart: this.lastLineStart, - lookahead: this.lookahead, - hasLineTerminatorBeforeNext: this.hasLineTerminatorBeforeNext, - tokenIndex: this.tokenIndex - }; + createClass(Seq, Iterable); + function Seq(value) { + return value === null || value === undefined ? emptySequence() : + isIterable(value) ? value.toSeq() : seqFromValue(value); } - }, { - key: "restoreLexerState", - value: function restoreLexerState(state) { - this.source = state.source; - this.index = state.index; - this.line = state.line; - this.lineStart = state.lineStart; - this.startIndex = state.startIndex; - this.startLine = state.startLine; - this.startLineStart = state.startLineStart; - this.lastIndex = state.lastIndex; - this.lastLine = state.lastLine; - this.lastLineStart = state.lastLineStart; - this.lookahead = state.lookahead; - this.hasLineTerminatorBeforeNext = state.hasLineTerminatorBeforeNext; - this.tokenIndex = state.tokenIndex; + + Seq.of = function(/*...values*/) { + return Seq(arguments); + }; + + Seq.prototype.toSeq = function() { + return this; + }; + + Seq.prototype.toString = function() { + return this.__toString('Seq {', '}'); + }; + + Seq.prototype.cacheResult = function() { + if (!this._cache && this.__iterateUncached) { + this._cache = this.entrySeq().toArray(); + this.size = this._cache.length; + } + return this; + }; + + // abstract __iterateUncached(fn, reverse) + + Seq.prototype.__iterate = function(fn, reverse) { + return seqIterate(this, fn, reverse, true); + }; + + // abstract __iteratorUncached(type, reverse) + + Seq.prototype.__iterator = function(type, reverse) { + return seqIterator(this, type, reverse, true); + }; + + + + createClass(KeyedSeq, Seq); + function KeyedSeq(value) { + return value === null || value === undefined ? + emptySequence().toKeyedSeq() : + isIterable(value) ? + (isKeyed(value) ? value.toSeq() : value.fromEntrySeq()) : + keyedSeqFromValue(value); } - }, { - key: "createILLEGAL", - value: function createILLEGAL() { - this.startIndex = this.index; - this.startLine = this.line; - this.startLineStart = this.lineStart; - return this.index < this.source.length ? this.createError(_errors.ErrorMessages.UNEXPECTED_ILLEGAL_TOKEN, this.source.charAt(this.index)) : this.createError(_errors.ErrorMessages.UNEXPECTED_EOS); + + KeyedSeq.prototype.toKeyedSeq = function() { + return this; + }; + + + + createClass(IndexedSeq, Seq); + function IndexedSeq(value) { + return value === null || value === undefined ? emptySequence() : + !isIterable(value) ? indexedSeqFromValue(value) : + isKeyed(value) ? value.entrySeq() : value.toIndexedSeq(); } - }, { - key: "createUnexpected", - value: function createUnexpected(token) { - switch (token.type.klass) { - case TokenClass.Eof: - return this.createError(_errors.ErrorMessages.UNEXPECTED_EOS); - case TokenClass.Ident: - return this.createError(_errors.ErrorMessages.UNEXPECTED_IDENTIFIER); - case TokenClass.Keyword: - return this.createError(_errors.ErrorMessages.UNEXPECTED_TOKEN, token.slice.text); - case TokenClass.NumericLiteral: - return this.createError(_errors.ErrorMessages.UNEXPECTED_NUMBER); - case TokenClass.TemplateElement: - return this.createError(_errors.ErrorMessages.UNEXPECTED_TEMPLATE); - case TokenClass.Punctuator: - return this.createError(_errors.ErrorMessages.UNEXPECTED_TOKEN, token.type.name); - case TokenClass.StringLiteral: - return this.createError(_errors.ErrorMessages.UNEXPECTED_STRING); - // the other token classes are RegularExpression and Illegal, but they cannot reach here - } + + IndexedSeq.of = function(/*...values*/) { + return IndexedSeq(arguments); + }; + + IndexedSeq.prototype.toIndexedSeq = function() { + return this; + }; + + IndexedSeq.prototype.toString = function() { + return this.__toString('Seq [', ']'); + }; + + IndexedSeq.prototype.__iterate = function(fn, reverse) { + return seqIterate(this, fn, reverse, false); + }; + + IndexedSeq.prototype.__iterator = function(type, reverse) { + return seqIterator(this, type, reverse, false); + }; + + + + createClass(SetSeq, Seq); + function SetSeq(value) { + return ( + value === null || value === undefined ? emptySequence() : + !isIterable(value) ? indexedSeqFromValue(value) : + isKeyed(value) ? value.entrySeq() : value + ).toSetSeq(); } - }, { - key: "createError", - value: function createError(message) { - var _arguments = arguments; - /* istanbul ignore next */ - var msg = message.replace(/\{(\d+)\}/g, function (_, n) { - return JSON.stringify(_arguments[+n + 1]); - }); - return new JsError(this.startIndex, this.startLine + 1, this.startIndex - this.startLineStart + 1, msg); + SetSeq.of = function(/*...values*/) { + return SetSeq(arguments); + }; + + SetSeq.prototype.toSetSeq = function() { + return this; + }; + + + + Seq.isSeq = isSeq; + Seq.Keyed = KeyedSeq; + Seq.Set = SetSeq; + Seq.Indexed = IndexedSeq; + + var IS_SEQ_SENTINEL = '@@__IMMUTABLE_SEQ__@@'; + + Seq.prototype[IS_SEQ_SENTINEL] = true; + + + + createClass(ArraySeq, IndexedSeq); + function ArraySeq(array) { + this._array = array; + this.size = array.length; } - }, { - key: "createErrorWithLocation", - value: function createErrorWithLocation(location, message) { - var _arguments2 = arguments; - /* istanbul ignore next */ - var msg = message.replace(/\{(\d+)\}/g, function (_, n) { - return JSON.stringify(_arguments2[+n + 2]); - }); - if (location.slice && location.slice.startLocation) { - location = location.slice.startLocation; + ArraySeq.prototype.get = function(index, notSetValue) { + return this.has(index) ? this._array[wrapIndex(this, index)] : notSetValue; + }; + + ArraySeq.prototype.__iterate = function(fn, reverse) { + var array = this._array; + var maxIndex = array.length - 1; + for (var ii = 0; ii <= maxIndex; ii++) { + if (fn(array[reverse ? maxIndex - ii : ii], ii, this) === false) { + return ii + 1; + } } - return new JsError(location.offset, location.line, location.column + 1, msg); + return ii; + }; + + ArraySeq.prototype.__iterator = function(type, reverse) { + var array = this._array; + var maxIndex = array.length - 1; + var ii = 0; + return new Iterator(function() + {return ii > maxIndex ? + iteratorDone() : + iteratorValue(type, ii, array[reverse ? maxIndex - ii++ : ii++])} + ); + }; + + + + createClass(ObjectSeq, KeyedSeq); + function ObjectSeq(object) { + var keys = Object.keys(object); + this._object = object; + this._keys = keys; + this.size = keys.length; } - }, { - key: "getKeyword", - value: function getKeyword(id) { - if (id.length === 1 || id.length > 10) { - return TokenType.IDENTIFIER; + + ObjectSeq.prototype.get = function(key, notSetValue) { + if (notSetValue !== undefined && !this.has(key)) { + return notSetValue; } + return this._object[key]; + }; - /* istanbul ignore next */ - switch (id.length) { - case 2: - switch (id.charAt(0)) { - case "i": - switch (id.charAt(1)) { - case "f": - return TokenType.IF; - case "n": - return TokenType.IN; - default: - break; - } - break; - case "d": - if (id.charAt(1) === "o") { - return TokenType.DO; - } - break; - } - break; - case 3: - switch (id.charAt(0)) { - case "v": - if (Tokenizer.cse2(id, "a", "r")) { - return TokenType.VAR; - } - break; - case "f": - if (Tokenizer.cse2(id, "o", "r")) { - return TokenType.FOR; - } - break; - case "n": - if (Tokenizer.cse2(id, "e", "w")) { - return TokenType.NEW; - } - break; - case "t": - if (Tokenizer.cse2(id, "r", "y")) { - return TokenType.TRY; - } - break; - case "l": - if (Tokenizer.cse2(id, "e", "t")) { - return TokenType.LET; - } - break; - } - break; - case 4: - switch (id.charAt(0)) { - case "t": - if (Tokenizer.cse3(id, "h", "i", "s")) { - return TokenType.THIS; - } else if (Tokenizer.cse3(id, "r", "u", "e")) { - return TokenType.TRUE; - } - break; - case "n": - if (Tokenizer.cse3(id, "u", "l", "l")) { - return TokenType.NULL; - } - break; - case "e": - if (Tokenizer.cse3(id, "l", "s", "e")) { - return TokenType.ELSE; - } - break; - case "c": - if (Tokenizer.cse3(id, "a", "s", "e")) { - return TokenType.CASE; - } - break; - case "v": - if (Tokenizer.cse3(id, "o", "i", "d")) { - return TokenType.VOID; - } - break; - case "w": - if (Tokenizer.cse3(id, "i", "t", "h")) { - return TokenType.WITH; - } - break; - } - break; - case 5: - switch (id.charAt(0)) { - case "a": - if (this.moduleIsTheGoalSymbol && Tokenizer.cse4(id, "w", "a", "i", "t")) { - return TokenType.AWAIT; - } - break; - case "w": - if (Tokenizer.cse4(id, "h", "i", "l", "e")) { - return TokenType.WHILE; - } - break; - case "b": - if (Tokenizer.cse4(id, "r", "e", "a", "k")) { - return TokenType.BREAK; - } - break; - case "f": - if (Tokenizer.cse4(id, "a", "l", "s", "e")) { - return TokenType.FALSE; - } - break; - case "c": - if (Tokenizer.cse4(id, "a", "t", "c", "h")) { - return TokenType.CATCH; - } else if (Tokenizer.cse4(id, "o", "n", "s", "t")) { - return TokenType.CONST; - } else if (Tokenizer.cse4(id, "l", "a", "s", "s")) { - return TokenType.CLASS; - } - break; - case "t": - if (Tokenizer.cse4(id, "h", "r", "o", "w")) { - return TokenType.THROW; - } - break; - case "y": - if (Tokenizer.cse4(id, "i", "e", "l", "d")) { - return TokenType.YIELD; - } - break; - case "s": - if (Tokenizer.cse4(id, "u", "p", "e", "r")) { - return TokenType.SUPER; - } - break; - } - break; - case 6: - switch (id.charAt(0)) { - case "r": - if (Tokenizer.cse5(id, "e", "t", "u", "r", "n")) { - return TokenType.RETURN; - } - break; - case "t": - if (Tokenizer.cse5(id, "y", "p", "e", "o", "f")) { - return TokenType.TYPEOF; - } - break; - case "d": - if (Tokenizer.cse5(id, "e", "l", "e", "t", "e")) { - return TokenType.DELETE; - } - break; - case "s": - if (Tokenizer.cse5(id, "w", "i", "t", "c", "h")) { - return TokenType.SWITCH; - } - break; - case "e": - if (Tokenizer.cse5(id, "x", "p", "o", "r", "t")) { - return TokenType.EXPORT; - } - break; - case "i": - if (Tokenizer.cse5(id, "m", "p", "o", "r", "t")) { - return TokenType.IMPORT; - } - break; - } - break; - case 7: - switch (id.charAt(0)) { - case "d": - if (Tokenizer.cse6(id, "e", "f", "a", "u", "l", "t")) { - return TokenType.DEFAULT; - } - break; - case "f": - if (Tokenizer.cse6(id, "i", "n", "a", "l", "l", "y")) { - return TokenType.FINALLY; - } - break; - case "e": - if (Tokenizer.cse6(id, "x", "t", "e", "n", "d", "s")) { - return TokenType.EXTENDS; - } - break; - } - break; - case 8: - switch (id.charAt(0)) { - case "f": - if (Tokenizer.cse7(id, "u", "n", "c", "t", "i", "o", "n")) { - return TokenType.FUNCTION; - } - break; - case "c": - if (Tokenizer.cse7(id, "o", "n", "t", "i", "n", "u", "e")) { - return TokenType.CONTINUE; - } - break; - case "d": - if (Tokenizer.cse7(id, "e", "b", "u", "g", "g", "e", "r")) { - return TokenType.DEBUGGER; - } - break; - } - break; - case 10: - if (id === "instanceof") { - return TokenType.INSTANCEOF; - } - break; + ObjectSeq.prototype.has = function(key) { + return this._object.hasOwnProperty(key); + }; + + ObjectSeq.prototype.__iterate = function(fn, reverse) { + var object = this._object; + var keys = this._keys; + var maxIndex = keys.length - 1; + for (var ii = 0; ii <= maxIndex; ii++) { + var key = keys[reverse ? maxIndex - ii : ii]; + if (fn(object[key], key, this) === false) { + return ii + 1; + } } - return TokenType.IDENTIFIER; + return ii; + }; + + ObjectSeq.prototype.__iterator = function(type, reverse) { + var object = this._object; + var keys = this._keys; + var maxIndex = keys.length - 1; + var ii = 0; + return new Iterator(function() { + var key = keys[reverse ? maxIndex - ii : ii]; + return ii++ > maxIndex ? + iteratorDone() : + iteratorValue(type, key, object[key]); + }); + }; + + ObjectSeq.prototype[IS_ORDERED_SENTINEL] = true; + + + createClass(IterableSeq, IndexedSeq); + function IterableSeq(iterable) { + this._iterable = iterable; + this.size = iterable.length || iterable.size; } - }, { - key: "skipSingleLineComment", - value: function skipSingleLineComment(offset) { - this.index += offset; - while (this.index < this.source.length) { - /** - * @type {Number} - */ - var chCode = this.source.charCodeAt(this.index); - this.index++; - if ((0, _utils.isLineTerminator)(chCode)) { - this.hasLineTerminatorBeforeNext = true; - if (chCode === 0xD /* "\r" */ && this.source.charCodeAt(this.index) === 0xA /*"\n" */) { - this.index++; - } - this.lineStart = this.index; - this.line++; - return; + + IterableSeq.prototype.__iterateUncached = function(fn, reverse) { + if (reverse) { + return this.cacheResult().__iterate(fn, reverse); + } + var iterable = this._iterable; + var iterator = getIterator(iterable); + var iterations = 0; + if (isIterator(iterator)) { + var step; + while (!(step = iterator.next()).done) { + if (fn(step.value, iterations++, this) === false) { + break; + } } } - } - }, { - key: "skipMultiLineComment", - value: function skipMultiLineComment() { - this.index += 2; - var length = this.source.length; - var isLineStart = false; - while (this.index < length) { - var chCode = this.source.charCodeAt(this.index); - if (chCode < 0x80) { - switch (chCode) { - case 42: - // "*" - // Block comment ends with "*/". - if (this.source.charAt(this.index + 1) === "/") { - this.index = this.index + 2; - return isLineStart; - } - this.index++; - break; - case 10: - // "\n" - isLineStart = true; - this.hasLineTerminatorBeforeNext = true; - this.index++; - this.lineStart = this.index; - this.line++; - break; - case 13: - // "\r": - isLineStart = true; - this.hasLineTerminatorBeforeNext = true; - if (this.source.charAt(this.index + 1) === "\n") { - this.index++; - } - this.index++; - this.lineStart = this.index; - this.line++; - break; - default: - this.index++; - } - } else if (chCode === 0x2028 || chCode === 0x2029) { - isLineStart = true; - this.hasLineTerminatorBeforeNext = true; - this.index++; - this.lineStart = this.index; - this.line++; - } else { - this.index++; - } + return iterations; + }; + + IterableSeq.prototype.__iteratorUncached = function(type, reverse) { + if (reverse) { + return this.cacheResult().__iterator(type, reverse); } - throw this.createILLEGAL(); - } - }, { - key: "skipComment", - value: function skipComment() { - this.hasLineTerminatorBeforeNext = false; + var iterable = this._iterable; + var iterator = getIterator(iterable); + if (!isIterator(iterator)) { + return new Iterator(iteratorDone); + } + var iterations = 0; + return new Iterator(function() { + var step = iterator.next(); + return step.done ? step : iteratorValue(type, iterations++, step.value); + }); + }; - var isLineStart = this.index === 0; - var length = this.source.length; - while (this.index < length) { - var chCode = this.source.charCodeAt(this.index); - if ((0, _utils.isWhiteSpace)(chCode)) { - this.index++; - } else if ((0, _utils.isLineTerminator)(chCode)) { - this.hasLineTerminatorBeforeNext = true; - this.index++; - if (chCode === 13 /* "\r" */ && this.source.charAt(this.index) === "\n") { - this.index++; - } - this.lineStart = this.index; - this.line++; - isLineStart = true; - } else if (chCode === 47 /* "/" */) { - if (this.index + 1 >= length) { - break; - } - chCode = this.source.charCodeAt(this.index + 1); - if (chCode === 47 /* "/" */) { - this.skipSingleLineComment(2); - isLineStart = true; - } else if (chCode === 42 /* "*" */) { - isLineStart = this.skipMultiLineComment() || isLineStart; - } else { - break; - } - } else if (!this.moduleIsTheGoalSymbol && isLineStart && chCode === 45 /* "-" */) { - if (this.index + 2 >= length) { - break; - } - // U+003E is ">" - if (this.source.charAt(this.index + 1) === "-" && this.source.charAt(this.index + 2) === ">") { - // "-->" is a single-line comment - this.skipSingleLineComment(3); - } else { - break; - } - } else if (!this.moduleIsTheGoalSymbol && chCode === 60 /* "<" */) { - if (this.source.slice(this.index + 1, this.index + 4) === "!--") { - this.skipSingleLineComment(4); - } else { - break; - } - } else { - break; - } - } + + createClass(IteratorSeq, IndexedSeq); + function IteratorSeq(iterator) { + this._iterator = iterator; + this._iteratorCache = []; } - }, { - key: "scanHexEscape2", - value: function scanHexEscape2() { - if (this.index + 2 > this.source.length) { - return -1; - } - var r1 = (0, _utils.getHexValue)(this.source.charAt(this.index)); - if (r1 === -1) { - return -1; - } - var r2 = (0, _utils.getHexValue)(this.source.charAt(this.index + 1)); - if (r2 === -1) { - return -1; + + IteratorSeq.prototype.__iterateUncached = function(fn, reverse) { + if (reverse) { + return this.cacheResult().__iterate(fn, reverse); } - this.index += 2; - return r1 << 4 | r2; - } - }, { - key: "scanUnicode", - value: function scanUnicode() { - if (this.source.charAt(this.index) === "{") { - //\u{HexDigits} - var i = this.index + 1; - var hexDigits = 0, - ch = void 0; - while (i < this.source.length) { - ch = this.source.charAt(i); - var hex = (0, _utils.getHexValue)(ch); - if (hex === -1) { - break; - } - hexDigits = hexDigits << 4 | hex; - if (hexDigits > 0x10FFFF) { - throw this.createILLEGAL(); - } - i++; - } - if (ch !== "}") { - throw this.createILLEGAL(); - } - if (i === this.index + 1) { - ++this.index; // This is so that the error is 'Unexpected "}"' instead of 'Unexpected "{"'. - throw this.createILLEGAL(); - } - this.index = i + 1; - return hexDigits; - } else { - //\uHex4Digits - if (this.index + 4 > this.source.length) { - return -1; - } - var r1 = (0, _utils.getHexValue)(this.source.charAt(this.index)); - if (r1 === -1) { - return -1; - } - var r2 = (0, _utils.getHexValue)(this.source.charAt(this.index + 1)); - if (r2 === -1) { - return -1; - } - var r3 = (0, _utils.getHexValue)(this.source.charAt(this.index + 2)); - if (r3 === -1) { - return -1; + var iterator = this._iterator; + var cache = this._iteratorCache; + var iterations = 0; + while (iterations < cache.length) { + if (fn(cache[iterations], iterations++, this) === false) { + return iterations; } - var r4 = (0, _utils.getHexValue)(this.source.charAt(this.index + 3)); - if (r4 === -1) { - return -1; + } + var step; + while (!(step = iterator.next()).done) { + var val = step.value; + cache[iterations] = val; + if (fn(val, iterations++, this) === false) { + break; } - this.index += 4; - return r1 << 12 | r2 << 8 | r3 << 4 | r4; } - } - }, { - key: "getEscapedIdentifier", - value: function getEscapedIdentifier() { - var id = ""; - var check = _utils.isIdentifierStart; + return iterations; + }; - while (this.index < this.source.length) { - var ch = this.source.charAt(this.index); - var code = ch.charCodeAt(0); - var start = this.index; - ++this.index; - if (ch === "\\") { - if (this.index >= this.source.length) { - throw this.createILLEGAL(); - } - if (this.source.charAt(this.index) !== "u") { - throw this.createILLEGAL(); - } - ++this.index; - code = this.scanUnicode(); - if (code < 0) { - throw this.createILLEGAL(); - } - ch = fromCodePoint(code); - } else if (0xD800 <= code && code <= 0xDBFF) { - if (this.index >= this.source.length) { - throw this.createILLEGAL(); - } - var lowSurrogateCode = this.source.charCodeAt(this.index); - ++this.index; - if (!(0xDC00 <= lowSurrogateCode && lowSurrogateCode <= 0xDFFF)) { - throw this.createILLEGAL(); - } - code = decodeUtf16(code, lowSurrogateCode); - ch = fromCodePoint(code); - } - if (!check(code)) { - if (id.length < 1) { - throw this.createILLEGAL(); - } - this.index = start; - return id; - } - check = _utils.isIdentifierPart; - id += ch; + IteratorSeq.prototype.__iteratorUncached = function(type, reverse) { + if (reverse) { + return this.cacheResult().__iterator(type, reverse); } - return id; - } - }, { - key: "getIdentifier", - value: function getIdentifier() { - var start = this.index; - var l = this.source.length; - var i = this.index; - var check = _utils.isIdentifierStart; - while (i < l) { - var ch = this.source.charAt(i); - var code = ch.charCodeAt(0); - if (ch === "\\" || 0xD800 <= code && code <= 0xDBFF) { - // Go back and try the hard one. - this.index = start; - return this.getEscapedIdentifier(); - } - if (!check(code)) { - this.index = i; - return this.source.slice(start, i); + var iterator = this._iterator; + var cache = this._iteratorCache; + var iterations = 0; + return new Iterator(function() { + if (iterations >= cache.length) { + var step = iterator.next(); + if (step.done) { + return step; + } + cache[iterations] = step.value; } - ++i; - check = _utils.isIdentifierPart; - } - this.index = i; - return this.source.slice(start, i); - } - }, { - key: "scanIdentifier", - value: function scanIdentifier() { - var startLocation = this.getLocation(); - var start = this.index; + return iteratorValue(type, iterations, cache[iterations++]); + }); + }; - // Backslash (U+005C) starts an escaped character. - var id = this.source.charAt(this.index) === "\\" ? this.getEscapedIdentifier() : this.getIdentifier(); - // There is no keyword or literal with only one character. - // Thus, it must be an identifier. - var slice = this.getSlice(start, startLocation); - slice.text = id; - return { type: this.getKeyword(id), value: id, slice: slice }; - } - }, { - key: "getLocation", - value: function getLocation() { - return { - line: this.startLine + 1, - column: this.startIndex - this.startLineStart, - offset: this.startIndex - }; - } - }, { - key: "getSlice", - value: function getSlice(start, startLocation) { - return { text: this.source.slice(start, this.index), start: start, startLocation: startLocation, end: this.index }; - } - }, { - key: "scanPunctuatorHelper", - value: function scanPunctuatorHelper() { - var ch1 = this.source.charAt(this.index); - switch (ch1) { - // Check for most common single-character punctuators. - case ".": - var ch2 = this.source.charAt(this.index + 1); - if (ch2 !== ".") return TokenType.PERIOD; - var ch3 = this.source.charAt(this.index + 2); - if (ch3 !== ".") return TokenType.PERIOD; - return TokenType.ELLIPSIS; - case "(": - return TokenType.LPAREN; - case ")": - case ";": - case ",": - return ONE_CHAR_PUNCTUATOR[ch1.charCodeAt(0)]; - case "{": - return TokenType.LBRACE; - case "}": - case "[": - case "]": - case ":": - case "?": - case "~": - return ONE_CHAR_PUNCTUATOR[ch1.charCodeAt(0)]; - default: - // "=" (U+003D) marks an assignment or comparison operator. - if (this.index + 1 < this.source.length && this.source.charAt(this.index + 1) === "=") { - switch (ch1) { - case "=": - if (this.index + 2 < this.source.length && this.source.charAt(this.index + 2) === "=") { - return TokenType.EQ_STRICT; - } - return TokenType.EQ; - case "!": - if (this.index + 2 < this.source.length && this.source.charAt(this.index + 2) === "=") { - return TokenType.NE_STRICT; - } - return TokenType.NE; - case "|": - return TokenType.ASSIGN_BIT_OR; - case "+": - return TokenType.ASSIGN_ADD; - case "-": - return TokenType.ASSIGN_SUB; - case "*": - return TokenType.ASSIGN_MUL; - case "<": - return TokenType.LTE; - case ">": - return TokenType.GTE; - case "/": - return TokenType.ASSIGN_DIV; - case "%": - return TokenType.ASSIGN_MOD; - case "^": - return TokenType.ASSIGN_BIT_XOR; - case "&": - return TokenType.ASSIGN_BIT_AND; - // istanbul ignore next - default: - break; //failed - } - } - } + // # pragma Helper functions - if (this.index + 1 < this.source.length) { - var _ch = this.source.charAt(this.index + 1); - if (ch1 === _ch) { - if (this.index + 2 < this.source.length) { - var _ch2 = this.source.charAt(this.index + 2); - if (ch1 === ">" && _ch2 === ">") { - // 4-character punctuator: >>>= - if (this.index + 3 < this.source.length && this.source.charAt(this.index + 3) === "=") { - return TokenType.ASSIGN_SHR_UNSIGNED; - } - return TokenType.SHR_UNSIGNED; - } + function isSeq(maybeSeq) { + return !!(maybeSeq && maybeSeq[IS_SEQ_SENTINEL]); + } - if (ch1 === "<" && _ch2 === "=") { - return TokenType.ASSIGN_SHL; - } + var EMPTY_SEQ; - if (ch1 === ">" && _ch2 === "=") { - return TokenType.ASSIGN_SHR; - } - } - // Other 2-character punctuators: ++ -- << >> && || - switch (ch1) { - case "+": - return TokenType.INC; - case "-": - return TokenType.DEC; - case "<": - return TokenType.SHL; - case ">": - return TokenType.SHR; - case "&": - return TokenType.AND; - case "|": - return TokenType.OR; - // istanbul ignore next - default: - break; //failed - } - } else if (ch1 === "=" && _ch === ">") { - return TokenType.ARROW; - } - } + function emptySequence() { + return EMPTY_SEQ || (EMPTY_SEQ = new ArraySeq([])); + } - return ONE_CHAR_PUNCTUATOR[ch1.charCodeAt(0)]; + function keyedSeqFromValue(value) { + var seq = + Array.isArray(value) ? new ArraySeq(value).fromEntrySeq() : + isIterator(value) ? new IteratorSeq(value).fromEntrySeq() : + hasIterator(value) ? new IterableSeq(value).fromEntrySeq() : + typeof value === 'object' ? new ObjectSeq(value) : + undefined; + if (!seq) { + throw new TypeError( + 'Expected Array or iterable object of [k, v] entries, '+ + 'or keyed object: ' + value + ); } + return seq; + } - // 7.7 Punctuators + function indexedSeqFromValue(value) { + var seq = maybeIndexedSeqFromValue(value); + if (!seq) { + throw new TypeError( + 'Expected Array or iterable object of values: ' + value + ); + } + return seq; + } - }, { - key: "scanPunctuator", - value: function scanPunctuator() { - var startLocation = this.getLocation(); - var start = this.index; - var subType = this.scanPunctuatorHelper(); - this.index += subType.name.length; - return { type: subType, value: subType.name, slice: this.getSlice(start, startLocation) }; + function seqFromValue(value) { + var seq = maybeIndexedSeqFromValue(value) || + (typeof value === 'object' && new ObjectSeq(value)); + if (!seq) { + throw new TypeError( + 'Expected Array or iterable object of values, or keyed object: ' + value + ); } - }, { - key: "scanHexLiteral", - value: function scanHexLiteral(start, startLocation) { - var i = this.index; - while (i < this.source.length) { - var ch = this.source.charAt(i); - var hex = (0, _utils.getHexValue)(ch); - if (hex === -1) { - break; - } - i++; - } + return seq; + } - if (this.index === i) { - throw this.createILLEGAL(); - } + function maybeIndexedSeqFromValue(value) { + return ( + isArrayLike(value) ? new ArraySeq(value) : + isIterator(value) ? new IteratorSeq(value) : + hasIterator(value) ? new IterableSeq(value) : + undefined + ); + } - if (i < this.source.length && (0, _utils.isIdentifierStart)(this.source.charCodeAt(i))) { - throw this.createILLEGAL(); + function seqIterate(seq, fn, reverse, useKeys) { + var cache = seq._cache; + if (cache) { + var maxIndex = cache.length - 1; + for (var ii = 0; ii <= maxIndex; ii++) { + var entry = cache[reverse ? maxIndex - ii : ii]; + if (fn(entry[1], useKeys ? entry[0] : ii, seq) === false) { + return ii + 1; + } } - - this.index = i; - - var slice = this.getSlice(start, startLocation); - return { type: TokenType.NUMBER, value: parseInt(slice.text.substr(2), 16), slice: slice }; + return ii; } - }, { - key: "scanBinaryLiteral", - value: function scanBinaryLiteral(start, startLocation) { - var offset = this.index - start; + return seq.__iterateUncached(fn, reverse); + } - while (this.index < this.source.length) { - var ch = this.source.charAt(this.index); - if (ch !== "0" && ch !== "1") { - break; - } - this.index++; - } + function seqIterator(seq, type, reverse, useKeys) { + var cache = seq._cache; + if (cache) { + var maxIndex = cache.length - 1; + var ii = 0; + return new Iterator(function() { + var entry = cache[reverse ? maxIndex - ii : ii]; + return ii++ > maxIndex ? + iteratorDone() : + iteratorValue(type, useKeys ? entry[0] : ii - 1, entry[1]); + }); + } + return seq.__iteratorUncached(type, reverse); + } - if (this.index - start <= offset) { - throw this.createILLEGAL(); - } + function fromJS(json, converter) { + return converter ? + fromJSWith(converter, json, '', {'': json}) : + fromJSDefault(json); + } - if (this.index < this.source.length && ((0, _utils.isIdentifierStart)(this.source.charCodeAt(this.index)) || (0, _utils.isDecimalDigit)(this.source.charCodeAt(this.index)))) { - throw this.createILLEGAL(); - } + function fromJSWith(converter, json, key, parentJSON) { + if (Array.isArray(json)) { + return converter.call(parentJSON, key, IndexedSeq(json).map(function(v, k) {return fromJSWith(converter, v, k, json)})); + } + if (isPlainObj(json)) { + return converter.call(parentJSON, key, KeyedSeq(json).map(function(v, k) {return fromJSWith(converter, v, k, json)})); + } + return json; + } - return { - type: TokenType.NUMBER, - value: parseInt(this.getSlice(start, startLocation).text.substr(offset), 2), - slice: this.getSlice(start, startLocation), - octal: false, - noctal: false - }; + function fromJSDefault(json) { + if (Array.isArray(json)) { + return IndexedSeq(json).map(fromJSDefault).toList(); } - }, { - key: "scanOctalLiteral", - value: function scanOctalLiteral(start, startLocation) { - while (this.index < this.source.length) { - var ch = this.source.charAt(this.index); - if ("0" <= ch && ch <= "7") { - this.index++; - } else if ((0, _utils.isIdentifierPart)(ch.charCodeAt(0))) { - throw this.createILLEGAL(); - } else { - break; - } - } + if (isPlainObj(json)) { + return KeyedSeq(json).map(fromJSDefault).toMap(); + } + return json; + } - if (this.index - start === 2) { - throw this.createILLEGAL(); - } + function isPlainObj(value) { + return value && (value.constructor === Object || value.constructor === undefined); + } - return { - type: TokenType.NUMBER, - value: parseInt(this.getSlice(start, startLocation).text.substr(2), 8), - slice: this.getSlice(start, startLocation), - octal: false, - noctal: false - }; + /** + * An extension of the "same-value" algorithm as [described for use by ES6 Map + * and Set](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map#Key_equality) + * + * NaN is considered the same as NaN, however -0 and 0 are considered the same + * value, which is different from the algorithm described by + * [`Object.is`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is). + * + * This is extended further to allow Objects to describe the values they + * represent, by way of `valueOf` or `equals` (and `hashCode`). + * + * Note: because of this extension, the key equality of Immutable.Map and the + * value equality of Immutable.Set will differ from ES6 Map and Set. + * + * ### Defining custom values + * + * The easiest way to describe the value an object represents is by implementing + * `valueOf`. For example, `Date` represents a value by returning a unix + * timestamp for `valueOf`: + * + * var date1 = new Date(1234567890000); // Fri Feb 13 2009 ... + * var date2 = new Date(1234567890000); + * date1.valueOf(); // 1234567890000 + * assert( date1 !== date2 ); + * assert( Immutable.is( date1, date2 ) ); + * + * Note: overriding `valueOf` may have other implications if you use this object + * where JavaScript expects a primitive, such as implicit string coercion. + * + * For more complex types, especially collections, implementing `valueOf` may + * not be performant. An alternative is to implement `equals` and `hashCode`. + * + * `equals` takes another object, presumably of similar type, and returns true + * if the it is equal. Equality is symmetrical, so the same result should be + * returned if this and the argument are flipped. + * + * assert( a.equals(b) === b.equals(a) ); + * + * `hashCode` returns a 32bit integer number representing the object which will + * be used to determine how to store the value object in a Map or Set. You must + * provide both or neither methods, one must not exist without the other. + * + * Also, an important relationship between these methods must be upheld: if two + * values are equal, they *must* return the same hashCode. If the values are not + * equal, they might have the same hashCode; this is called a hash collision, + * and while undesirable for performance reasons, it is acceptable. + * + * if (a.equals(b)) { + * assert( a.hashCode() === b.hashCode() ); + * } + * + * All Immutable collections implement `equals` and `hashCode`. + * + */ + function is(valueA, valueB) { + if (valueA === valueB || (valueA !== valueA && valueB !== valueB)) { + return true; } - }, { - key: "scanLegacyOctalLiteral", - value: function scanLegacyOctalLiteral(start, startLocation) { - var isOctal = true; - - while (this.index < this.source.length) { - var ch = this.source.charAt(this.index); - if ("0" <= ch && ch <= "7") { - this.index++; - } else if (ch === "8" || ch === "9") { - isOctal = false; - this.index++; - } else if ((0, _utils.isIdentifierPart)(ch.charCodeAt(0))) { - throw this.createILLEGAL(); - } else { - break; - } + if (!valueA || !valueB) { + return false; + } + if (typeof valueA.valueOf === 'function' && + typeof valueB.valueOf === 'function') { + valueA = valueA.valueOf(); + valueB = valueB.valueOf(); + if (valueA === valueB || (valueA !== valueA && valueB !== valueB)) { + return true; } - - var slice = this.getSlice(start, startLocation); - if (!isOctal) { - this.eatDecimalLiteralSuffix(); - return { - type: TokenType.NUMBER, - slice: slice, - value: +slice.text, - octal: true, - noctal: !isOctal - }; + if (!valueA || !valueB) { + return false; } + } + if (typeof valueA.equals === 'function' && + typeof valueB.equals === 'function' && + valueA.equals(valueB)) { + return true; + } + return false; + } - return { - type: TokenType.NUMBER, - slice: slice, - value: parseInt(slice.text.substr(1), 8), - octal: true, - noctal: !isOctal - }; + function deepEqual(a, b) { + if (a === b) { + return true; } - }, { - key: "scanNumericLiteral", - value: function scanNumericLiteral() { - var ch = this.source.charAt(this.index); - // assert(ch === "." || "0" <= ch && ch <= "9") - var startLocation = this.getLocation(); - var start = this.index; - if (ch === "0") { - this.index++; - if (this.index < this.source.length) { - ch = this.source.charAt(this.index); - if (ch === "x" || ch === "X") { - this.index++; - return this.scanHexLiteral(start, startLocation); - } else if (ch === "b" || ch === "B") { - this.index++; - return this.scanBinaryLiteral(start, startLocation); - } else if (ch === "o" || ch === "O") { - this.index++; - return this.scanOctalLiteral(start, startLocation); - } else if ("0" <= ch && ch <= "9") { - return this.scanLegacyOctalLiteral(start, startLocation); - } - } else { - var _slice = this.getSlice(start, startLocation); - return { - type: TokenType.NUMBER, - value: +_slice.text, - slice: _slice, - octal: false, - noctal: false - }; - } - } else if (ch !== ".") { - // Must be "1".."9" - ch = this.source.charAt(this.index); - while ("0" <= ch && ch <= "9") { - this.index++; - if (this.index === this.source.length) { - var _slice2 = this.getSlice(start, startLocation); - return { - type: TokenType.NUMBER, - value: +_slice2.text, - slice: _slice2, - octal: false, - noctal: false - }; - } - ch = this.source.charAt(this.index); - } - } + if ( + !isIterable(b) || + a.size !== undefined && b.size !== undefined && a.size !== b.size || + a.__hash !== undefined && b.__hash !== undefined && a.__hash !== b.__hash || + isKeyed(a) !== isKeyed(b) || + isIndexed(a) !== isIndexed(b) || + isOrdered(a) !== isOrdered(b) + ) { + return false; + } - this.eatDecimalLiteralSuffix(); + if (a.size === 0 && b.size === 0) { + return true; + } - if (this.index !== this.source.length && (0, _utils.isIdentifierStart)(this.source.charCodeAt(this.index))) { - throw this.createILLEGAL(); - } + var notAssociative = !isAssociative(a); - var slice = this.getSlice(start, startLocation); - return { - type: TokenType.NUMBER, - value: +slice.text, - slice: slice, - octal: false, - noctal: false - }; + if (isOrdered(a)) { + var entries = a.entries(); + return b.every(function(v, k) { + var entry = entries.next().value; + return entry && is(entry[1], v) && (notAssociative || is(entry[0], k)); + }) && entries.next().done; } - }, { - key: "eatDecimalLiteralSuffix", - value: function eatDecimalLiteralSuffix() { - var ch = this.source.charAt(this.index); - if (ch === ".") { - this.index++; - if (this.index === this.source.length) { - return; - } - ch = this.source.charAt(this.index); - while ("0" <= ch && ch <= "9") { - this.index++; - if (this.index === this.source.length) { - return; - } - ch = this.source.charAt(this.index); + var flipped = false; + + if (a.size === undefined) { + if (b.size === undefined) { + if (typeof a.cacheResult === 'function') { + a.cacheResult(); } + } else { + flipped = true; + var _ = a; + a = b; + b = _; } + } - // EOF not reached here - if (ch === "e" || ch === "E") { - this.index++; - if (this.index === this.source.length) { - throw this.createILLEGAL(); - } + var allEqual = true; + var bSize = b.__iterate(function(v, k) { + if (notAssociative ? !a.has(v) : + flipped ? !is(v, a.get(k, NOT_SET)) : !is(a.get(k, NOT_SET), v)) { + allEqual = false; + return false; + } + }); - ch = this.source.charAt(this.index); - if (ch === "+" || ch === "-") { - this.index++; - if (this.index === this.source.length) { - throw this.createILLEGAL(); - } - ch = this.source.charAt(this.index); - } + return allEqual && a.size === bSize; + } - if ("0" <= ch && ch <= "9") { - while ("0" <= ch && ch <= "9") { - this.index++; - if (this.index === this.source.length) { - break; - } - ch = this.source.charAt(this.index); - } - } else { - throw this.createILLEGAL(); - } - } - } - }, { - key: "scanStringEscape", - value: function scanStringEscape(str, octal) { - this.index++; - if (this.index === this.source.length) { - throw this.createILLEGAL(); + createClass(Repeat, IndexedSeq); + + function Repeat(value, times) { + if (!(this instanceof Repeat)) { + return new Repeat(value, times); } - var ch = this.source.charAt(this.index); - if (!(0, _utils.isLineTerminator)(ch.charCodeAt(0))) { - switch (ch) { - case "n": - str += "\n"; - this.index++; - break; - case "r": - str += "\r"; - this.index++; - break; - case "t": - str += "\t"; - this.index++; - break; - case "u": - case "x": - var unescaped = void 0; - this.index++; - if (this.index >= this.source.length) { - throw this.createILLEGAL(); - } - unescaped = ch === "u" ? this.scanUnicode() : this.scanHexEscape2(); - if (unescaped < 0) { - throw this.createILLEGAL(); - } - str += fromCodePoint(unescaped); - break; - case "b": - str += "\b"; - this.index++; - break; - case "f": - str += "\f"; - this.index++; - break; - case "v": - str += "\u000b"; - this.index++; - break; - default: - if ("0" <= ch && ch <= "7") { - var octalStart = this.index; - var octLen = 1; - // 3 digits are only allowed when string starts - // with 0, 1, 2, 3 - if ("0" <= ch && ch <= "3") { - octLen = 0; - } - var code = 0; - while (octLen < 3 && "0" <= ch && ch <= "7") { - this.index++; - if (octLen > 0 || ch !== "0") { - octal = this.source.slice(octalStart, this.index); - } - code *= 8; - code += ch - "0"; - octLen++; - if (this.index === this.source.length) { - throw this.createILLEGAL(); - } - ch = this.source.charAt(this.index); - } - str += String.fromCharCode(code); - } else if (ch === "8" || ch === "9") { - throw this.createILLEGAL(); - } else { - str += ch; - this.index++; - } - } - } else { - this.index++; - if (ch === "\r" && this.source.charAt(this.index) === "\n") { - this.index++; + this._value = value; + this.size = times === undefined ? Infinity : Math.max(0, times); + if (this.size === 0) { + if (EMPTY_REPEAT) { + return EMPTY_REPEAT; } - this.lineStart = this.index; - this.line++; + EMPTY_REPEAT = this; } - return [str, octal]; } - // 7.8.4 String Literals - }, { - key: "scanStringLiteral", - value: function scanStringLiteral() { - var str = ""; + Repeat.prototype.toString = function() { + if (this.size === 0) { + return 'Repeat []'; + } + return 'Repeat [ ' + this._value + ' ' + this.size + ' times ]'; + }; - var quote = this.source.charAt(this.index); - // assert((quote === "\"" || quote === """), "String literal must starts with a quote") + Repeat.prototype.get = function(index, notSetValue) { + return this.has(index) ? this._value : notSetValue; + }; - var startLocation = this.getLocation(); - var start = this.index; - this.index++; + Repeat.prototype.includes = function(searchValue) { + return is(this._value, searchValue); + }; - var octal = null; - while (this.index < this.source.length) { - var ch = this.source.charAt(this.index); - if (ch === quote) { - this.index++; - return { type: TokenType.STRING, slice: this.getSlice(start, startLocation), str: str, octal: octal }; - } else if (ch === "\\") { - var _scanStringEscape = this.scanStringEscape(str, octal); + Repeat.prototype.slice = function(begin, end) { + var size = this.size; + return wholeSlice(begin, end, size) ? this : + new Repeat(this._value, resolveEnd(end, size) - resolveBegin(begin, size)); + }; - var _scanStringEscape2 = _slicedToArray(_scanStringEscape, 2); + Repeat.prototype.reverse = function() { + return this; + }; - str = _scanStringEscape2[0]; - octal = _scanStringEscape2[1]; - } else if ((0, _utils.isLineTerminator)(ch.charCodeAt(0))) { - throw this.createILLEGAL(); - } else { - str += ch; - this.index++; - } + Repeat.prototype.indexOf = function(searchValue) { + if (is(this._value, searchValue)) { + return 0; } + return -1; + }; - throw this.createILLEGAL(); - } - }, { - key: "scanTemplateElement", - value: function scanTemplateElement() { - var startLocation = this.getLocation(); - var start = this.index; - this.index++; - while (this.index < this.source.length) { - var ch = this.source.charCodeAt(this.index); - switch (ch) { - case 0x60: - // ` - this.index++; - return { type: TokenType.TEMPLATE, tail: true, slice: this.getSlice(start, startLocation) }; - case 0x24: - // $ - if (this.source.charCodeAt(this.index + 1) === 0x7B) { - // { - this.index += 2; - return { type: TokenType.TEMPLATE, tail: false, slice: this.getSlice(start, startLocation) }; - } - this.index++; - break; - case 0x5C: - // \\ - { - var octal = this.scanStringEscape("", null)[1]; - if (octal != null) { - throw this.createILLEGAL(); - } - break; - } - default: - this.index++; - } + Repeat.prototype.lastIndexOf = function(searchValue) { + if (is(this._value, searchValue)) { + return this.size; } + return -1; + }; - throw this.createILLEGAL(); - } - }, { - key: "scanRegExp", - value: function scanRegExp(str) { - var startLocation = this.getLocation(); - var start = this.index; - - var terminated = false; - var classMarker = false; - while (this.index < this.source.length) { - var ch = this.source.charAt(this.index); - if (ch === "\\") { - str += ch; - this.index++; - ch = this.source.charAt(this.index); - // ECMA-262 7.8.5 - if ((0, _utils.isLineTerminator)(ch.charCodeAt(0))) { - throw this.createError(_errors.ErrorMessages.UNTERMINATED_REGEXP); - } - str += ch; - this.index++; - } else if ((0, _utils.isLineTerminator)(ch.charCodeAt(0))) { - throw this.createError(_errors.ErrorMessages.UNTERMINATED_REGEXP); - } else { - if (classMarker) { - if (ch === "]") { - classMarker = false; - } - } else { - if (ch === "/") { - terminated = true; - str += ch; - this.index++; - break; - } else if (ch === "[") { - classMarker = true; - } - } - str += ch; - this.index++; + Repeat.prototype.__iterate = function(fn, reverse) { + for (var ii = 0; ii < this.size; ii++) { + if (fn(this._value, ii, this) === false) { + return ii + 1; } } + return ii; + }; - if (!terminated) { - throw this.createError(_errors.ErrorMessages.UNTERMINATED_REGEXP); - } + Repeat.prototype.__iterator = function(type, reverse) {var this$0 = this; + var ii = 0; + return new Iterator(function() + {return ii < this$0.size ? iteratorValue(type, ii++, this$0._value) : iteratorDone()} + ); + }; - while (this.index < this.source.length) { - var _ch3 = this.source.charAt(this.index); - if (_ch3 === "\\") { - throw this.createError(_errors.ErrorMessages.INVALID_REGEXP_FLAGS); - } - if (!(0, _utils.isIdentifierPart)(_ch3.charCodeAt(0))) { - break; + Repeat.prototype.equals = function(other) { + return other instanceof Repeat ? + is(this._value, other._value) : + deepEqual(other); + }; + + + var EMPTY_REPEAT; + + function invariant(condition, error) { + if (!condition) throw new Error(error); + } + + createClass(Range, IndexedSeq); + + function Range(start, end, step) { + if (!(this instanceof Range)) { + return new Range(start, end, step); + } + invariant(step !== 0, 'Cannot step a Range by 0'); + start = start || 0; + if (end === undefined) { + end = Infinity; + } + step = step === undefined ? 1 : Math.abs(step); + if (end < start) { + step = -step; + } + this._start = start; + this._end = end; + this._step = step; + this.size = Math.max(0, Math.ceil((end - start) / step - 1) + 1); + if (this.size === 0) { + if (EMPTY_RANGE) { + return EMPTY_RANGE; } - this.index++; - str += _ch3; + EMPTY_RANGE = this; } - return { type: TokenType.REGEXP, value: str, slice: this.getSlice(start, startLocation) }; } - }, { - key: "advance", - value: function advance() { - var startLocation = this.getLocation(); - this.lastIndex = this.index; - this.lastLine = this.line; - this.lastLineStart = this.lineStart; + Range.prototype.toString = function() { + if (this.size === 0) { + return 'Range []'; + } + return 'Range [ ' + + this._start + '...' + this._end + + (this._step !== 1 ? ' by ' + this._step : '') + + ' ]'; + }; - this.skipComment(); + Range.prototype.get = function(index, notSetValue) { + return this.has(index) ? + this._start + wrapIndex(this, index) * this._step : + notSetValue; + }; - this.startIndex = this.index; - this.startLine = this.line; - this.startLineStart = this.lineStart; + Range.prototype.includes = function(searchValue) { + var possibleIndex = (searchValue - this._start) / this._step; + return possibleIndex >= 0 && + possibleIndex < this.size && + possibleIndex === Math.floor(possibleIndex); + }; - if (this.lastIndex === 0) { - this.lastIndex = this.index; - this.lastLine = this.line; - this.lastLineStart = this.lineStart; + Range.prototype.slice = function(begin, end) { + if (wholeSlice(begin, end, this.size)) { + return this; } - - if (this.index >= this.source.length) { - return { type: TokenType.EOS, slice: this.getSlice(this.index, startLocation) }; + begin = resolveBegin(begin, this.size); + end = resolveEnd(end, this.size); + if (end <= begin) { + return new Range(0, 0); } + return new Range(this.get(begin, this._end), this.get(end, this._end), this._step); + }; - var charCode = this.source.charCodeAt(this.index); - - if (charCode < 0x80) { - if (PUNCTUATOR_START[charCode]) { - return this.scanPunctuator(); + Range.prototype.indexOf = function(searchValue) { + var offsetValue = searchValue - this._start; + if (offsetValue % this._step === 0) { + var index = offsetValue / this._step; + if (index >= 0 && index < this.size) { + return index } + } + return -1; + }; - if ((0, _utils.isIdentifierStart)(charCode) || charCode === 0x5C /* backslash (\) */) { - return this.scanIdentifier(); - } + Range.prototype.lastIndexOf = function(searchValue) { + return this.indexOf(searchValue); + }; - // Dot (.) U+002E can also start a floating-point number, hence the need - // to check the next character. - if (charCode === 0x2E) { - if (this.index + 1 < this.source.length && (0, _utils.isDecimalDigit)(this.source.charCodeAt(this.index + 1))) { - return this.scanNumericLiteral(); - } - return this.scanPunctuator(); + Range.prototype.__iterate = function(fn, reverse) { + var maxIndex = this.size - 1; + var step = this._step; + var value = reverse ? this._start + maxIndex * step : this._start; + for (var ii = 0; ii <= maxIndex; ii++) { + if (fn(value, ii, this) === false) { + return ii + 1; } + value += reverse ? -step : step; + } + return ii; + }; - // String literal starts with single quote (U+0027) or double quote (U+0022). - if (charCode === 0x27 || charCode === 0x22) { - return this.scanStringLiteral(); - } + Range.prototype.__iterator = function(type, reverse) { + var maxIndex = this.size - 1; + var step = this._step; + var value = reverse ? this._start + maxIndex * step : this._start; + var ii = 0; + return new Iterator(function() { + var v = value; + value += reverse ? -step : step; + return ii > maxIndex ? iteratorDone() : iteratorValue(type, ii++, v); + }); + }; - // Template literal starts with back quote (U+0060) - if (charCode === 0x60) { - return this.scanTemplateElement(); - } + Range.prototype.equals = function(other) { + return other instanceof Range ? + this._start === other._start && + this._end === other._end && + this._step === other._step : + deepEqual(this, other); + }; - if (0x30 /* "0" */ <= charCode && charCode <= 0x39 /* "9" */) { - return this.scanNumericLiteral(); - } - // Slash (/) U+002F can also start a regex. - throw this.createILLEGAL(); - } else { - if ((0, _utils.isIdentifierStart)(charCode) || 0xD800 <= charCode && charCode <= 0xDBFF) { - return this.scanIdentifier(); - } + var EMPTY_RANGE; - throw this.createILLEGAL(); - } + createClass(Collection, Iterable); + function Collection() { + throw TypeError('Abstract'); } - }, { - key: "eof", - value: function eof() { - return this.lookahead.type === TokenType.EOS; + + + createClass(KeyedCollection, Collection);function KeyedCollection() {} + + createClass(IndexedCollection, Collection);function IndexedCollection() {} + + createClass(SetCollection, Collection);function SetCollection() {} + + + Collection.Keyed = KeyedCollection; + Collection.Indexed = IndexedCollection; + Collection.Set = SetCollection; + + var imul = + typeof Math.imul === 'function' && Math.imul(0xffffffff, 2) === -2 ? + Math.imul : + function imul(a, b) { + a = a | 0; // int + b = b | 0; // int + var c = a & 0xffff; + var d = b & 0xffff; + // Shift by 0 fixes the sign on the high part. + return (c * d) + ((((a >>> 16) * d + c * (b >>> 16)) << 16) >>> 0) | 0; // int + }; + + // v8 has an optimization for storing 31-bit signed numbers. + // Values which have either 00 or 11 as the high order bits qualify. + // This function drops the highest order bit in a signed number, maintaining + // the sign bit. + function smi(i32) { + return ((i32 >>> 1) & 0x40000000) | (i32 & 0xBFFFFFFF); + } + + function hash(o) { + if (o === false || o === null || o === undefined) { + return 0; } - }, { - key: "lex", - value: function lex() { - var prevToken = this.lookahead; - this.lookahead = this.advance(); - this.tokenIndex++; - return prevToken; + if (typeof o.valueOf === 'function') { + o = o.valueOf(); + if (o === false || o === null || o === undefined) { + return 0; + } } - }], [{ - key: "cse2", - value: function cse2(id, ch1, ch2) { - return id.charAt(1) === ch1 && id.charAt(2) === ch2; + if (o === true) { + return 1; } - }, { - key: "cse3", - value: function cse3(id, ch1, ch2, ch3) { - return id.charAt(1) === ch1 && id.charAt(2) === ch2 && id.charAt(3) === ch3; + var type = typeof o; + if (type === 'number') { + if (o !== o || o === Infinity) { + return 0; + } + var h = o | 0; + if (h !== o) { + h ^= o * 0xFFFFFFFF; + } + while (o > 0xFFFFFFFF) { + o /= 0xFFFFFFFF; + h ^= o; + } + return smi(h); } - }, { - key: "cse4", - value: function cse4(id, ch1, ch2, ch3, ch4) { - return id.charAt(1) === ch1 && id.charAt(2) === ch2 && id.charAt(3) === ch3 && id.charAt(4) === ch4; + if (type === 'string') { + return o.length > STRING_HASH_CACHE_MIN_STRLEN ? cachedHashString(o) : hashString(o); } - }, { - key: "cse5", - value: function cse5(id, ch1, ch2, ch3, ch4, ch5) { - return id.charAt(1) === ch1 && id.charAt(2) === ch2 && id.charAt(3) === ch3 && id.charAt(4) === ch4 && id.charAt(5) === ch5; + if (typeof o.hashCode === 'function') { + return o.hashCode(); } - }, { - key: "cse6", - value: function cse6(id, ch1, ch2, ch3, ch4, ch5, ch6) { - return id.charAt(1) === ch1 && id.charAt(2) === ch2 && id.charAt(3) === ch3 && id.charAt(4) === ch4 && id.charAt(5) === ch5 && id.charAt(6) === ch6; + if (type === 'object') { + return hashJSObj(o); } - }, { - key: "cse7", - value: function cse7(id, ch1, ch2, ch3, ch4, ch5, ch6, ch7) { - return id.charAt(1) === ch1 && id.charAt(2) === ch2 && id.charAt(3) === ch3 && id.charAt(4) === ch4 && id.charAt(5) === ch5 && id.charAt(6) === ch6 && id.charAt(7) === ch7; + if (typeof o.toString === 'function') { + return hashString(o.toString()); } - }]); + throw new Error('Value type ' + type + ' cannot be hashed.'); + } - return Tokenizer; - }(); + function cachedHashString(string) { + var hash = stringHashCache[string]; + if (hash === undefined) { + hash = hashString(string); + if (STRING_HASH_CACHE_SIZE === STRING_HASH_CACHE_MAX_SIZE) { + STRING_HASH_CACHE_SIZE = 0; + stringHashCache = {}; + } + STRING_HASH_CACHE_SIZE++; + stringHashCache[string] = hash; + } + return hash; + } - exports.default = Tokenizer; + // http://jsperf.com/hashing-strings + function hashString(string) { + // This is the hash from JVM + // The hash code for a string is computed as + // s[0] * 31 ^ (n - 1) + s[1] * 31 ^ (n - 2) + ... + s[n - 1], + // where s[i] is the ith character of the string and n is the length of + // the string. We "mod" the result to make it between 0 (inclusive) and 2^31 + // (exclusive) by dropping high bits. + var hash = 0; + for (var ii = 0; ii < string.length; ii++) { + hash = 31 * hash + string.charCodeAt(ii) | 0; + } + return smi(hash); + } -/***/ }, -/* 5 */ -/***/ function(module, exports, __webpack_require__) { + function hashJSObj(obj) { + var hash; + if (usingWeakMap) { + hash = weakMap.get(obj); + if (hash !== undefined) { + return hash; + } + } - "use strict"; + hash = obj[UID_HASH_KEY]; + if (hash !== undefined) { + return hash; + } - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.isDecimalDigit = exports.isLineTerminator = exports.isWhiteSpace = exports.isIdentifierPart = exports.isIdentifierStart = exports.isRestrictedWord = undefined; - exports.isStrictModeReservedWord = isStrictModeReservedWord; - exports.getHexValue = getHexValue; + if (!canDefineProperty) { + hash = obj.propertyIsEnumerable && obj.propertyIsEnumerable[UID_HASH_KEY]; + if (hash !== undefined) { + return hash; + } - var _esutils = __webpack_require__(6); + hash = getIENodeHash(obj); + if (hash !== undefined) { + return hash; + } + } - var isReservedWordES6 = _esutils.keyword.isReservedWordES6; /** - * Copyright 2014 Shape Security, Inc. - * - * Licensed under the Apache License, Version 2.0 (the "License") - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ + hash = ++objHashUID; + if (objHashUID & 0x40000000) { + objHashUID = 0; + } - var isRestrictedWord = _esutils.keyword.isRestrictedWord; - var isIdentifierStartES6 = _esutils.code.isIdentifierStartES6; - var isIdentifierPartES6 = _esutils.code.isIdentifierPartES6; - var isWhiteSpace = _esutils.code.isWhiteSpace; - var isLineTerminator = _esutils.code.isLineTerminator; - var isDecimalDigit = _esutils.code.isDecimalDigit; - exports.isRestrictedWord = isRestrictedWord; - exports.isIdentifierStart = isIdentifierStartES6; - exports.isIdentifierPart = isIdentifierPartES6; - exports.isWhiteSpace = isWhiteSpace; - exports.isLineTerminator = isLineTerminator; - exports.isDecimalDigit = isDecimalDigit; - function isStrictModeReservedWord(id) { - return isReservedWordES6(id, true); - } + if (usingWeakMap) { + weakMap.set(obj, hash); + } else if (isExtensible !== undefined && isExtensible(obj) === false) { + throw new Error('Non-extensible objects are not allowed as keys.'); + } else if (canDefineProperty) { + Object.defineProperty(obj, UID_HASH_KEY, { + 'enumerable': false, + 'configurable': false, + 'writable': false, + 'value': hash + }); + } else if (obj.propertyIsEnumerable !== undefined && + obj.propertyIsEnumerable === obj.constructor.prototype.propertyIsEnumerable) { + // Since we can't define a non-enumerable property on the object + // we'll hijack one of the less-used non-enumerable properties to + // save our hash on it. Since this is a function it will not show up in + // `JSON.stringify` which is what we want. + obj.propertyIsEnumerable = function() { + return this.constructor.prototype.propertyIsEnumerable.apply(this, arguments); + }; + obj.propertyIsEnumerable[UID_HASH_KEY] = hash; + } else if (obj.nodeType !== undefined) { + // At this point we couldn't get the IE `uniqueID` to use as a hash + // and we couldn't use a non-enumerable property to exploit the + // dontEnum bug so we simply add the `UID_HASH_KEY` on the node + // itself. + obj[UID_HASH_KEY] = hash; + } else { + throw new Error('Unable to set a non-enumerable property on object.'); + } - function getHexValue(rune) { - if ("0" <= rune && rune <= "9") { - return rune.charCodeAt(0) - 48; - } - if ("a" <= rune && rune <= "f") { - return rune.charCodeAt(0) - 87; - } - if ("A" <= rune && rune <= "F") { - return rune.charCodeAt(0) - 55; + return hash; } - return -1; - } - -/***/ }, -/* 6 */ -/***/ function(module, exports, __webpack_require__) { - - /* - Copyright (C) 2013 Yusuke Suzuki - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: + // Get references to ES5 object methods. + var isExtensible = Object.isExtensible; - * Redistributions of source code must retain the above copyright - notice, this list of conditions and the following disclaimer. - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - ARE DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY - DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - - - (function () { - 'use strict'; + // True if Object.defineProperty works as expected. IE8 fails this test. + var canDefineProperty = (function() { + try { + Object.defineProperty({}, '@', {}); + return true; + } catch (e) { + return false; + } + }()); - exports.ast = __webpack_require__(7); - exports.code = __webpack_require__(8); - exports.keyword = __webpack_require__(9); - }()); - /* vim: set sw=4 ts=4 et tw=80 : */ + // IE has a `uniqueID` property on DOM nodes. We can construct the hash from it + // and avoid memory leaks from the IE cloneNode bug. + function getIENodeHash(node) { + if (node && node.nodeType > 0) { + switch (node.nodeType) { + case 1: // Element + return node.uniqueID; + case 9: // Document + return node.documentElement && node.documentElement.uniqueID; + } + } + } + // If possible, use a WeakMap. + var usingWeakMap = typeof WeakMap === 'function'; + var weakMap; + if (usingWeakMap) { + weakMap = new WeakMap(); + } -/***/ }, -/* 7 */ -/***/ function(module, exports) { + var objHashUID = 0; - /* - Copyright (C) 2013 Yusuke Suzuki + var UID_HASH_KEY = '__immutablehash__'; + if (typeof Symbol === 'function') { + UID_HASH_KEY = Symbol(UID_HASH_KEY); + } - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: + var STRING_HASH_CACHE_MIN_STRLEN = 16; + var STRING_HASH_CACHE_MAX_SIZE = 255; + var STRING_HASH_CACHE_SIZE = 0; + var stringHashCache = {}; - * Redistributions of source code must retain the above copyright - notice, this list of conditions and the following disclaimer. - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. + function assertNotInfinite(size) { + invariant( + size !== Infinity, + 'Cannot perform this action with an infinite size.' + ); + } - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 'AS IS' - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - ARE DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY - DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ + createClass(Map, KeyedCollection); - (function () { - 'use strict'; + // @pragma Construction - function isExpression(node) { - if (node == null) { return false; } - switch (node.type) { - case 'ArrayExpression': - case 'AssignmentExpression': - case 'BinaryExpression': - case 'CallExpression': - case 'ConditionalExpression': - case 'FunctionExpression': - case 'Identifier': - case 'Literal': - case 'LogicalExpression': - case 'MemberExpression': - case 'NewExpression': - case 'ObjectExpression': - case 'SequenceExpression': - case 'ThisExpression': - case 'UnaryExpression': - case 'UpdateExpression': - return true; - } - return false; + function Map(value) { + return value === null || value === undefined ? emptyMap() : + isMap(value) && !isOrdered(value) ? value : + emptyMap().withMutations(function(map ) { + var iter = KeyedIterable(value); + assertNotInfinite(iter.size); + iter.forEach(function(v, k) {return map.set(k, v)}); + }); } - function isIterationStatement(node) { - if (node == null) { return false; } - switch (node.type) { - case 'DoWhileStatement': - case 'ForInStatement': - case 'ForStatement': - case 'WhileStatement': - return true; + Map.of = function() {var keyValues = SLICE$0.call(arguments, 0); + return emptyMap().withMutations(function(map ) { + for (var i = 0; i < keyValues.length; i += 2) { + if (i + 1 >= keyValues.length) { + throw new Error('Missing value for key: ' + keyValues[i]); + } + map.set(keyValues[i], keyValues[i + 1]); } - return false; - } + }); + }; - function isStatement(node) { - if (node == null) { return false; } - switch (node.type) { - case 'BlockStatement': - case 'BreakStatement': - case 'ContinueStatement': - case 'DebuggerStatement': - case 'DoWhileStatement': - case 'EmptyStatement': - case 'ExpressionStatement': - case 'ForInStatement': - case 'ForStatement': - case 'IfStatement': - case 'LabeledStatement': - case 'ReturnStatement': - case 'SwitchStatement': - case 'ThrowStatement': - case 'TryStatement': - case 'VariableDeclaration': - case 'WhileStatement': - case 'WithStatement': - return true; - } - return false; - } + Map.prototype.toString = function() { + return this.__toString('Map {', '}'); + }; - function isSourceElement(node) { - return isStatement(node) || node != null && node.type === 'FunctionDeclaration'; - } + // @pragma Access - function trailingStatement(node) { - switch (node.type) { - case 'IfStatement': - if (node.alternate != null) { - return node.alternate; - } - return node.consequent; + Map.prototype.get = function(k, notSetValue) { + return this._root ? + this._root.get(0, undefined, k, notSetValue) : + notSetValue; + }; - case 'LabeledStatement': - case 'ForStatement': - case 'ForInStatement': - case 'WhileStatement': - case 'WithStatement': - return node.body; - } - return null; - } + // @pragma Modification - function isProblematicIfStatement(node) { - var current; + Map.prototype.set = function(k, v) { + return updateMap(this, k, v); + }; - if (node.type !== 'IfStatement') { - return false; - } - if (node.alternate == null) { - return false; - } - current = node.consequent; - do { - if (current.type === 'IfStatement') { - if (current.alternate == null) { - return true; - } - } - current = trailingStatement(current); - } while (current); + Map.prototype.setIn = function(keyPath, v) { + return this.updateIn(keyPath, NOT_SET, function() {return v}); + }; - return false; - } + Map.prototype.remove = function(k) { + return updateMap(this, k, NOT_SET); + }; - module.exports = { - isExpression: isExpression, - isStatement: isStatement, - isIterationStatement: isIterationStatement, - isSourceElement: isSourceElement, - isProblematicIfStatement: isProblematicIfStatement, + Map.prototype.deleteIn = function(keyPath) { + return this.updateIn(keyPath, function() {return NOT_SET}); + }; - trailingStatement: trailingStatement + Map.prototype.update = function(k, notSetValue, updater) { + return arguments.length === 1 ? + k(this) : + this.updateIn([k], notSetValue, updater); }; - }()); - /* vim: set sw=4 ts=4 et tw=80 : */ + Map.prototype.updateIn = function(keyPath, notSetValue, updater) { + if (!updater) { + updater = notSetValue; + notSetValue = undefined; + } + var updatedValue = updateInDeepMap( + this, + forceIterator(keyPath), + notSetValue, + updater + ); + return updatedValue === NOT_SET ? undefined : updatedValue; + }; -/***/ }, -/* 8 */ -/***/ function(module, exports) { + Map.prototype.clear = function() { + if (this.size === 0) { + return this; + } + if (this.__ownerID) { + this.size = 0; + this._root = null; + this.__hash = undefined; + this.__altered = true; + return this; + } + return emptyMap(); + }; - /* - Copyright (C) 2013-2014 Yusuke Suzuki - Copyright (C) 2014 Ivan Nikulin + // @pragma Composition - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: + Map.prototype.merge = function(/*...iters*/) { + return mergeIntoMapWith(this, undefined, arguments); + }; - * Redistributions of source code must retain the above copyright - notice, this list of conditions and the following disclaimer. - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. + Map.prototype.mergeWith = function(merger) {var iters = SLICE$0.call(arguments, 1); + return mergeIntoMapWith(this, merger, iters); + }; - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - ARE DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY - DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ + Map.prototype.mergeIn = function(keyPath) {var iters = SLICE$0.call(arguments, 1); + return this.updateIn( + keyPath, + emptyMap(), + function(m ) {return typeof m.merge === 'function' ? + m.merge.apply(m, iters) : + iters[iters.length - 1]} + ); + }; - (function () { - 'use strict'; + Map.prototype.mergeDeep = function(/*...iters*/) { + return mergeIntoMapWith(this, deepMerger, arguments); + }; - var ES6Regex, ES5Regex, NON_ASCII_WHITESPACES, IDENTIFIER_START, IDENTIFIER_PART, ch; + Map.prototype.mergeDeepWith = function(merger) {var iters = SLICE$0.call(arguments, 1); + return mergeIntoMapWith(this, deepMergerWith(merger), iters); + }; - // See `tools/generate-identifier-regex.js`. - ES5Regex = { - // ECMAScript 5.1/Unicode v7.0.0 NonAsciiIdentifierStart: - NonAsciiIdentifierStart: /[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0-\u08B2\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA78E\uA790-\uA7AD\uA7B0\uA7B1\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB5F\uAB64\uAB65\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]/, - // ECMAScript 5.1/Unicode v7.0.0 NonAsciiIdentifierPart: - NonAsciiIdentifierPart: /[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u08A0-\u08B2\u08E4-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58\u0C59\u0C60-\u0C63\u0C66-\u0C6F\u0C81-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D01-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D57\u0D60-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1380-\u138F\u13A0-\u13F4\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19D9\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1CD0-\u1CD2\u1CD4-\u1CF6\u1CF8\u1CF9\u1D00-\u1DF5\u1DFC-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u200C\u200D\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u2E2F\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099\u309A\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA69D\uA69F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA78E\uA790-\uA7AD\uA7B0\uA7B1\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C4\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB5F\uAB64\uAB65\uABC0-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2D\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]/ + Map.prototype.mergeDeepIn = function(keyPath) {var iters = SLICE$0.call(arguments, 1); + return this.updateIn( + keyPath, + emptyMap(), + function(m ) {return typeof m.mergeDeep === 'function' ? + m.mergeDeep.apply(m, iters) : + iters[iters.length - 1]} + ); }; - ES6Regex = { - // ECMAScript 6/Unicode v7.0.0 NonAsciiIdentifierStart: - NonAsciiIdentifierStart: /[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0-\u08B2\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2118-\u211D\u2124\u2126\u2128\u212A-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309B-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA78E\uA790-\uA7AD\uA7B0\uA7B1\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB5F\uAB64\uAB65\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF30-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDE00-\uDE11\uDE13-\uDE2B\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF5D-\uDF61]|\uD805[\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDE00-\uDE2F\uDE44\uDE80-\uDEAA]|\uD806[\uDCA0-\uDCDF\uDCFF\uDEC0-\uDEF8]|\uD808[\uDC00-\uDF98]|\uD809[\uDC00-\uDC6E]|[\uD80C\uD840-\uD868\uD86A-\uD86C][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50\uDF93-\uDF9F]|\uD82C[\uDC00\uDC01]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD83A[\uDC00-\uDCC4]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D]|\uD87E[\uDC00-\uDE1D]/, - // ECMAScript 6/Unicode v7.0.0 NonAsciiIdentifierPart: - NonAsciiIdentifierPart: /[\xAA\xB5\xB7\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u08A0-\u08B2\u08E4-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58\u0C59\u0C60-\u0C63\u0C66-\u0C6F\u0C81-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D01-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D57\u0D60-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1369-\u1371\u1380-\u138F\u13A0-\u13F4\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19DA\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1CD0-\u1CD2\u1CD4-\u1CF6\u1CF8\u1CF9\u1D00-\u1DF5\u1DFC-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u200C\u200D\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2118-\u211D\u2124\u2126\u2128\u212A-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA69D\uA69F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA78E\uA790-\uA7AD\uA7B0\uA7B1\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C4\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB5F\uAB64\uAB65\uABC0-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2D\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDDFD\uDE80-\uDE9C\uDEA0-\uDED0\uDEE0\uDF00-\uDF1F\uDF30-\uDF4A\uDF50-\uDF7A\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00-\uDE03\uDE05\uDE06\uDE0C-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE38-\uDE3A\uDE3F\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE6\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48]|\uD804[\uDC00-\uDC46\uDC66-\uDC6F\uDC7F-\uDCBA\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD00-\uDD34\uDD36-\uDD3F\uDD50-\uDD73\uDD76\uDD80-\uDDC4\uDDD0-\uDDDA\uDE00-\uDE11\uDE13-\uDE37\uDEB0-\uDEEA\uDEF0-\uDEF9\uDF01-\uDF03\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3C-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF57\uDF5D-\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC80-\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDB5\uDDB8-\uDDC0\uDE00-\uDE40\uDE44\uDE50-\uDE59\uDE80-\uDEB7\uDEC0-\uDEC9]|\uD806[\uDCA0-\uDCE9\uDCFF\uDEC0-\uDEF8]|\uD808[\uDC00-\uDF98]|\uD809[\uDC00-\uDC6E]|[\uD80C\uD840-\uD868\uD86A-\uD86C][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDED0-\uDEED\uDEF0-\uDEF4\uDF00-\uDF36\uDF40-\uDF43\uDF50-\uDF59\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50-\uDF7E\uDF8F-\uDF9F]|\uD82C[\uDC00\uDC01]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD83A[\uDC00-\uDCC4\uDCD0-\uDCD6]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D]|\uD87E[\uDC00-\uDE1D]|\uDB40[\uDD00-\uDDEF]/ + Map.prototype.sort = function(comparator) { + // Late binding + return OrderedMap(sortFactory(this, comparator)); }; - function isDecimalDigit(ch) { - return 0x30 <= ch && ch <= 0x39; // 0..9 - } + Map.prototype.sortBy = function(mapper, comparator) { + // Late binding + return OrderedMap(sortFactory(this, comparator, mapper)); + }; - function isHexDigit(ch) { - return 0x30 <= ch && ch <= 0x39 || // 0..9 - 0x61 <= ch && ch <= 0x66 || // a..f - 0x41 <= ch && ch <= 0x46; // A..F - } + // @pragma Mutability - function isOctalDigit(ch) { - return ch >= 0x30 && ch <= 0x37; // 0..7 - } + Map.prototype.withMutations = function(fn) { + var mutable = this.asMutable(); + fn(mutable); + return mutable.wasAltered() ? mutable.__ensureOwner(this.__ownerID) : this; + }; - // 7.2 White Space + Map.prototype.asMutable = function() { + return this.__ownerID ? this : this.__ensureOwner(new OwnerID()); + }; - NON_ASCII_WHITESPACES = [ - 0x1680, 0x180E, - 0x2000, 0x2001, 0x2002, 0x2003, 0x2004, 0x2005, 0x2006, 0x2007, 0x2008, 0x2009, 0x200A, - 0x202F, 0x205F, - 0x3000, - 0xFEFF - ]; + Map.prototype.asImmutable = function() { + return this.__ensureOwner(); + }; - function isWhiteSpace(ch) { - return ch === 0x20 || ch === 0x09 || ch === 0x0B || ch === 0x0C || ch === 0xA0 || - ch >= 0x1680 && NON_ASCII_WHITESPACES.indexOf(ch) >= 0; - } + Map.prototype.wasAltered = function() { + return this.__altered; + }; - // 7.3 Line Terminators + Map.prototype.__iterator = function(type, reverse) { + return new MapIterator(this, type, reverse); + }; - function isLineTerminator(ch) { - return ch === 0x0A || ch === 0x0D || ch === 0x2028 || ch === 0x2029; - } + Map.prototype.__iterate = function(fn, reverse) {var this$0 = this; + var iterations = 0; + this._root && this._root.iterate(function(entry ) { + iterations++; + return fn(entry[1], entry[0], this$0); + }, reverse); + return iterations; + }; - // 7.6 Identifier Names and Identifiers + Map.prototype.__ensureOwner = function(ownerID) { + if (ownerID === this.__ownerID) { + return this; + } + if (!ownerID) { + this.__ownerID = ownerID; + this.__altered = false; + return this; + } + return makeMap(this.size, this._root, ownerID, this.__hash); + }; - function fromCodePoint(cp) { - if (cp <= 0xFFFF) { return String.fromCharCode(cp); } - var cu1 = String.fromCharCode(Math.floor((cp - 0x10000) / 0x400) + 0xD800); - var cu2 = String.fromCharCode(((cp - 0x10000) % 0x400) + 0xDC00); - return cu1 + cu2; - } - IDENTIFIER_START = new Array(0x80); - for(ch = 0; ch < 0x80; ++ch) { - IDENTIFIER_START[ch] = - ch >= 0x61 && ch <= 0x7A || // a..z - ch >= 0x41 && ch <= 0x5A || // A..Z - ch === 0x24 || ch === 0x5F; // $ (dollar) and _ (underscore) - } + function isMap(maybeMap) { + return !!(maybeMap && maybeMap[IS_MAP_SENTINEL]); + } - IDENTIFIER_PART = new Array(0x80); - for(ch = 0; ch < 0x80; ++ch) { - IDENTIFIER_PART[ch] = - ch >= 0x61 && ch <= 0x7A || // a..z - ch >= 0x41 && ch <= 0x5A || // A..Z - ch >= 0x30 && ch <= 0x39 || // 0..9 - ch === 0x24 || ch === 0x5F; // $ (dollar) and _ (underscore) - } + Map.isMap = isMap; - function isIdentifierStartES5(ch) { - return ch < 0x80 ? IDENTIFIER_START[ch] : ES5Regex.NonAsciiIdentifierStart.test(fromCodePoint(ch)); - } + var IS_MAP_SENTINEL = '@@__IMMUTABLE_MAP__@@'; - function isIdentifierPartES5(ch) { - return ch < 0x80 ? IDENTIFIER_PART[ch] : ES5Regex.NonAsciiIdentifierPart.test(fromCodePoint(ch)); - } + var MapPrototype = Map.prototype; + MapPrototype[IS_MAP_SENTINEL] = true; + MapPrototype[DELETE] = MapPrototype.remove; + MapPrototype.removeIn = MapPrototype.deleteIn; - function isIdentifierStartES6(ch) { - return ch < 0x80 ? IDENTIFIER_START[ch] : ES6Regex.NonAsciiIdentifierStart.test(fromCodePoint(ch)); - } - function isIdentifierPartES6(ch) { - return ch < 0x80 ? IDENTIFIER_PART[ch] : ES6Regex.NonAsciiIdentifierPart.test(fromCodePoint(ch)); - } + // #pragma Trie Nodes - module.exports = { - isDecimalDigit: isDecimalDigit, - isHexDigit: isHexDigit, - isOctalDigit: isOctalDigit, - isWhiteSpace: isWhiteSpace, - isLineTerminator: isLineTerminator, - isIdentifierStartES5: isIdentifierStartES5, - isIdentifierPartES5: isIdentifierPartES5, - isIdentifierStartES6: isIdentifierStartES6, - isIdentifierPartES6: isIdentifierPartES6 - }; - }()); - /* vim: set sw=4 ts=4 et tw=80 : */ -/***/ }, -/* 9 */ -/***/ function(module, exports, __webpack_require__) { + function ArrayMapNode(ownerID, entries) { + this.ownerID = ownerID; + this.entries = entries; + } - /* - Copyright (C) 2013 Yusuke Suzuki + ArrayMapNode.prototype.get = function(shift, keyHash, key, notSetValue) { + var entries = this.entries; + for (var ii = 0, len = entries.length; ii < len; ii++) { + if (is(key, entries[ii][0])) { + return entries[ii][1]; + } + } + return notSetValue; + }; - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: + ArrayMapNode.prototype.update = function(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) { + var removed = value === NOT_SET; - * Redistributions of source code must retain the above copyright - notice, this list of conditions and the following disclaimer. - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. + var entries = this.entries; + var idx = 0; + for (var len = entries.length; idx < len; idx++) { + if (is(key, entries[idx][0])) { + break; + } + } + var exists = idx < len; - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - ARE DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY - DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ + if (exists ? entries[idx][1] === value : removed) { + return this; + } - (function () { - 'use strict'; + SetRef(didAlter); + (removed || !exists) && SetRef(didChangeSize); - var code = __webpack_require__(8); + if (removed && entries.length === 1) { + return; // undefined + } - function isStrictModeReservedWordES6(id) { - switch (id) { - case 'implements': - case 'interface': - case 'package': - case 'private': - case 'protected': - case 'public': - case 'static': - case 'let': - return true; - default: - return false; - } - } + if (!exists && !removed && entries.length >= MAX_ARRAY_MAP_SIZE) { + return createNodes(ownerID, entries, key, value); + } - function isKeywordES5(id, strict) { - // yield should not be treated as keyword under non-strict mode. - if (!strict && id === 'yield') { - return false; - } - return isKeywordES6(id, strict); - } + var isEditable = ownerID && ownerID === this.ownerID; + var newEntries = isEditable ? entries : arrCopy(entries); - function isKeywordES6(id, strict) { - if (strict && isStrictModeReservedWordES6(id)) { - return true; + if (exists) { + if (removed) { + idx === len - 1 ? newEntries.pop() : (newEntries[idx] = newEntries.pop()); + } else { + newEntries[idx] = [key, value]; } + } else { + newEntries.push([key, value]); + } - switch (id.length) { - case 2: - return (id === 'if') || (id === 'in') || (id === 'do'); - case 3: - return (id === 'var') || (id === 'for') || (id === 'new') || (id === 'try'); - case 4: - return (id === 'this') || (id === 'else') || (id === 'case') || - (id === 'void') || (id === 'with') || (id === 'enum'); - case 5: - return (id === 'while') || (id === 'break') || (id === 'catch') || - (id === 'throw') || (id === 'const') || (id === 'yield') || - (id === 'class') || (id === 'super'); - case 6: - return (id === 'return') || (id === 'typeof') || (id === 'delete') || - (id === 'switch') || (id === 'export') || (id === 'import'); - case 7: - return (id === 'default') || (id === 'finally') || (id === 'extends'); - case 8: - return (id === 'function') || (id === 'continue') || (id === 'debugger'); - case 10: - return (id === 'instanceof'); - default: - return false; - } - } + if (isEditable) { + this.entries = newEntries; + return this; + } - function isReservedWordES5(id, strict) { - return id === 'null' || id === 'true' || id === 'false' || isKeywordES5(id, strict); - } + return new ArrayMapNode(ownerID, newEntries); + }; - function isReservedWordES6(id, strict) { - return id === 'null' || id === 'true' || id === 'false' || isKeywordES6(id, strict); - } - function isRestrictedWord(id) { - return id === 'eval' || id === 'arguments'; + + + function BitmapIndexedNode(ownerID, bitmap, nodes) { + this.ownerID = ownerID; + this.bitmap = bitmap; + this.nodes = nodes; } - function isIdentifierNameES5(id) { - var i, iz, ch; + BitmapIndexedNode.prototype.get = function(shift, keyHash, key, notSetValue) { + if (keyHash === undefined) { + keyHash = hash(key); + } + var bit = (1 << ((shift === 0 ? keyHash : keyHash >>> shift) & MASK)); + var bitmap = this.bitmap; + return (bitmap & bit) === 0 ? notSetValue : + this.nodes[popCount(bitmap & (bit - 1))].get(shift + SHIFT, keyHash, key, notSetValue); + }; - if (id.length === 0) { return false; } + BitmapIndexedNode.prototype.update = function(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) { + if (keyHash === undefined) { + keyHash = hash(key); + } + var keyHashFrag = (shift === 0 ? keyHash : keyHash >>> shift) & MASK; + var bit = 1 << keyHashFrag; + var bitmap = this.bitmap; + var exists = (bitmap & bit) !== 0; - ch = id.charCodeAt(0); - if (!code.isIdentifierStartES5(ch)) { - return false; - } + if (!exists && value === NOT_SET) { + return this; + } - for (i = 1, iz = id.length; i < iz; ++i) { - ch = id.charCodeAt(i); - if (!code.isIdentifierPartES5(ch)) { - return false; - } - } - return true; - } + var idx = popCount(bitmap & (bit - 1)); + var nodes = this.nodes; + var node = exists ? nodes[idx] : undefined; + var newNode = updateNode(node, ownerID, shift + SHIFT, keyHash, key, value, didChangeSize, didAlter); - function decodeUtf16(lead, trail) { - return (lead - 0xD800) * 0x400 + (trail - 0xDC00) + 0x10000; - } + if (newNode === node) { + return this; + } - function isIdentifierNameES6(id) { - var i, iz, ch, lowCh, check; + if (!exists && newNode && nodes.length >= MAX_BITMAP_INDEXED_SIZE) { + return expandNodes(ownerID, nodes, bitmap, keyHashFrag, newNode); + } - if (id.length === 0) { return false; } + if (exists && !newNode && nodes.length === 2 && isLeafNode(nodes[idx ^ 1])) { + return nodes[idx ^ 1]; + } - check = code.isIdentifierStartES6; - for (i = 0, iz = id.length; i < iz; ++i) { - ch = id.charCodeAt(i); - if (0xD800 <= ch && ch <= 0xDBFF) { - ++i; - if (i >= iz) { return false; } - lowCh = id.charCodeAt(i); - if (!(0xDC00 <= lowCh && lowCh <= 0xDFFF)) { - return false; - } - ch = decodeUtf16(ch, lowCh); - } - if (!check(ch)) { - return false; - } - check = code.isIdentifierPartES6; - } - return true; - } + if (exists && newNode && nodes.length === 1 && isLeafNode(newNode)) { + return newNode; + } - function isIdentifierES5(id, strict) { - return isIdentifierNameES5(id) && !isReservedWordES5(id, strict); - } + var isEditable = ownerID && ownerID === this.ownerID; + var newBitmap = exists ? newNode ? bitmap : bitmap ^ bit : bitmap | bit; + var newNodes = exists ? newNode ? + setIn(nodes, idx, newNode, isEditable) : + spliceOut(nodes, idx, isEditable) : + spliceIn(nodes, idx, newNode, isEditable); - function isIdentifierES6(id, strict) { - return isIdentifierNameES6(id) && !isReservedWordES6(id, strict); + if (isEditable) { + this.bitmap = newBitmap; + this.nodes = newNodes; + return this; + } + + return new BitmapIndexedNode(ownerID, newBitmap, newNodes); + }; + + + + + function HashArrayMapNode(ownerID, count, nodes) { + this.ownerID = ownerID; + this.count = count; + this.nodes = nodes; } - module.exports = { - isKeywordES5: isKeywordES5, - isKeywordES6: isKeywordES6, - isReservedWordES5: isReservedWordES5, - isReservedWordES6: isReservedWordES6, - isRestrictedWord: isRestrictedWord, - isIdentifierNameES5: isIdentifierNameES5, - isIdentifierNameES6: isIdentifierNameES6, - isIdentifierES5: isIdentifierES5, - isIdentifierES6: isIdentifierES6 + HashArrayMapNode.prototype.get = function(shift, keyHash, key, notSetValue) { + if (keyHash === undefined) { + keyHash = hash(key); + } + var idx = (shift === 0 ? keyHash : keyHash >>> shift) & MASK; + var node = this.nodes[idx]; + return node ? node.get(shift + SHIFT, keyHash, key, notSetValue) : notSetValue; }; - }()); - /* vim: set sw=4 ts=4 et tw=80 : */ + HashArrayMapNode.prototype.update = function(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) { + if (keyHash === undefined) { + keyHash = hash(key); + } + var idx = (shift === 0 ? keyHash : keyHash >>> shift) & MASK; + var removed = value === NOT_SET; + var nodes = this.nodes; + var node = nodes[idx]; -/***/ }, -/* 10 */ -/***/ function(module, exports) { + if (removed && !node) { + return this; + } - "use strict"; + var newNode = updateNode(node, ownerID, shift + SHIFT, keyHash, key, value, didChangeSize, didAlter); + if (newNode === node) { + return this; + } - Object.defineProperty(exports, "__esModule", { - value: true - }); - /** - * Copyright 2014 Shape Security, Inc. - * - * Licensed under the Apache License, Version 2.0 (the "License") - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ + var newCount = this.count; + if (!node) { + newCount++; + } else if (!newNode) { + newCount--; + if (newCount < MIN_HASH_ARRAY_MAP_SIZE) { + return packNodes(ownerID, nodes, newCount, idx); + } + } - var ErrorMessages = exports.ErrorMessages = { - UNEXPECTED_TOKEN: "Unexpected token {0}", - UNEXPECTED_ILLEGAL_TOKEN: "Unexpected {0}", - UNEXPECTED_NUMBER: "Unexpected number", - UNEXPECTED_STRING: "Unexpected string", - UNEXPECTED_IDENTIFIER: "Unexpected identifier", - UNEXPECTED_RESERVED_WORD: "Unexpected reserved word", - UNEXPECTED_TEMPLATE: "Unexpected template", - UNEXPECTED_EOS: "Unexpected end of input", - UNEXPECTED_LINE_TERMINATOR: "Unexpected line terminator", - NEWLINE_AFTER_THROW: "Illegal newline after throw", - UNTERMINATED_REGEXP: "Invalid regular expression: missing /", - INVALID_REGEXP_FLAGS: "Invalid regular expression flags", - INVALID_LHS_IN_ASSIGNMENT: "Invalid left-hand side in assignment", - INVALID_LHS_IN_FOR_IN: "Invalid left-hand side in for-in", - INVALID_LHS_IN_FOR_OF: "Invalid left-hand side in for-of", - INVALID_UPDATE_OPERAND: "Increment/decrement target must be an identifier or member expression", - MULTIPLE_DEFAULTS_IN_SWITCH: "More than one default clause in switch statement", - NO_CATCH_OR_FINALLY: "Missing catch or finally after try", - ILLEGAL_RETURN: "Illegal return statement", - ILLEGAL_ARROW_FUNCTION_PARAMS: "Illegal arrow function parameter list", - INVALID_VAR_INIT_FOR_IN: "Invalid variable declaration in for-in statement", - INVALID_VAR_INIT_FOR_OF: "Invalid variable declaration in for-of statement", - ILLEGAL_PROPERTY: "Illegal property initializer" - }; + var isEditable = ownerID && ownerID === this.ownerID; + var newNodes = setIn(nodes, idx, newNode, isEditable); -/***/ }, -/* 11 */ -/***/ function(module, exports, __webpack_require__) { + if (isEditable) { + this.count = newCount; + this.nodes = newNodes; + return this; + } - /** - * Copyright (c) 2014-2015, Facebook, Inc. - * All rights reserved. - * - * This source code is licensed under the BSD-style license found in the - * LICENSE file in the root directory of this source tree. An additional grant - * of patent rights can be found in the PATENTS file in the same directory. - */ + return new HashArrayMapNode(ownerID, newCount, newNodes); + }; - (function (global, factory) { - true ? module.exports = factory() : - typeof define === 'function' && define.amd ? define(factory) : - (global.Immutable = factory()); - }(this, function () { 'use strict';var SLICE$0 = Array.prototype.slice; - function createClass(ctor, superClass) { - if (superClass) { - ctor.prototype = Object.create(superClass.prototype); - } - ctor.prototype.constructor = ctor; - } - function Iterable(value) { - return isIterable(value) ? value : Seq(value); + + function HashCollisionNode(ownerID, keyHash, entries) { + this.ownerID = ownerID; + this.keyHash = keyHash; + this.entries = entries; } + HashCollisionNode.prototype.get = function(shift, keyHash, key, notSetValue) { + var entries = this.entries; + for (var ii = 0, len = entries.length; ii < len; ii++) { + if (is(key, entries[ii][0])) { + return entries[ii][1]; + } + } + return notSetValue; + }; - createClass(KeyedIterable, Iterable); - function KeyedIterable(value) { - return isKeyed(value) ? value : KeyedSeq(value); - } + HashCollisionNode.prototype.update = function(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) { + if (keyHash === undefined) { + keyHash = hash(key); + } + var removed = value === NOT_SET; - createClass(IndexedIterable, Iterable); - function IndexedIterable(value) { - return isIndexed(value) ? value : IndexedSeq(value); - } + if (keyHash !== this.keyHash) { + if (removed) { + return this; + } + SetRef(didAlter); + SetRef(didChangeSize); + return mergeIntoNode(this, ownerID, shift, keyHash, [key, value]); + } + var entries = this.entries; + var idx = 0; + for (var len = entries.length; idx < len; idx++) { + if (is(key, entries[idx][0])) { + break; + } + } + var exists = idx < len; - createClass(SetIterable, Iterable); - function SetIterable(value) { - return isIterable(value) && !isAssociative(value) ? value : SetSeq(value); - } + if (exists ? entries[idx][1] === value : removed) { + return this; + } + SetRef(didAlter); + (removed || !exists) && SetRef(didChangeSize); + if (removed && len === 2) { + return new ValueNode(ownerID, this.keyHash, entries[idx ^ 1]); + } - function isIterable(maybeIterable) { - return !!(maybeIterable && maybeIterable[IS_ITERABLE_SENTINEL]); - } + var isEditable = ownerID && ownerID === this.ownerID; + var newEntries = isEditable ? entries : arrCopy(entries); - function isKeyed(maybeKeyed) { - return !!(maybeKeyed && maybeKeyed[IS_KEYED_SENTINEL]); - } + if (exists) { + if (removed) { + idx === len - 1 ? newEntries.pop() : (newEntries[idx] = newEntries.pop()); + } else { + newEntries[idx] = [key, value]; + } + } else { + newEntries.push([key, value]); + } - function isIndexed(maybeIndexed) { - return !!(maybeIndexed && maybeIndexed[IS_INDEXED_SENTINEL]); - } + if (isEditable) { + this.entries = newEntries; + return this; + } - function isAssociative(maybeAssociative) { - return isKeyed(maybeAssociative) || isIndexed(maybeAssociative); - } + return new HashCollisionNode(ownerID, this.keyHash, newEntries); + }; - function isOrdered(maybeOrdered) { - return !!(maybeOrdered && maybeOrdered[IS_ORDERED_SENTINEL]); - } - Iterable.isIterable = isIterable; - Iterable.isKeyed = isKeyed; - Iterable.isIndexed = isIndexed; - Iterable.isAssociative = isAssociative; - Iterable.isOrdered = isOrdered; - Iterable.Keyed = KeyedIterable; - Iterable.Indexed = IndexedIterable; - Iterable.Set = SetIterable; + function ValueNode(ownerID, keyHash, entry) { + this.ownerID = ownerID; + this.keyHash = keyHash; + this.entry = entry; + } - var IS_ITERABLE_SENTINEL = '@@__IMMUTABLE_ITERABLE__@@'; - var IS_KEYED_SENTINEL = '@@__IMMUTABLE_KEYED__@@'; - var IS_INDEXED_SENTINEL = '@@__IMMUTABLE_INDEXED__@@'; - var IS_ORDERED_SENTINEL = '@@__IMMUTABLE_ORDERED__@@'; + ValueNode.prototype.get = function(shift, keyHash, key, notSetValue) { + return is(key, this.entry[0]) ? this.entry[1] : notSetValue; + }; - // Used for setting prototype methods that IE8 chokes on. - var DELETE = 'delete'; + ValueNode.prototype.update = function(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) { + var removed = value === NOT_SET; + var keyMatch = is(key, this.entry[0]); + if (keyMatch ? value === this.entry[1] : removed) { + return this; + } - // Constants describing the size of trie nodes. - var SHIFT = 5; // Resulted in best performance after ______? - var SIZE = 1 << SHIFT; - var MASK = SIZE - 1; + SetRef(didAlter); - // A consistent shared value representing "not set" which equals nothing other - // than itself, and nothing that could be provided externally. - var NOT_SET = {}; + if (removed) { + SetRef(didChangeSize); + return; // undefined + } - // Boolean references, Rough equivalent of `bool &`. - var CHANGE_LENGTH = { value: false }; - var DID_ALTER = { value: false }; + if (keyMatch) { + if (ownerID && ownerID === this.ownerID) { + this.entry[1] = value; + return this; + } + return new ValueNode(ownerID, this.keyHash, [key, value]); + } - function MakeRef(ref) { - ref.value = false; - return ref; - } + SetRef(didChangeSize); + return mergeIntoNode(this, ownerID, shift, hash(key), [key, value]); + }; - function SetRef(ref) { - ref && (ref.value = true); - } - // A function which returns a value representing an "owner" for transient writes - // to tries. The return value will only ever equal itself, and will not equal - // the return of any subsequent call of this function. - function OwnerID() {} - // http://jsperf.com/copy-array-inline - function arrCopy(arr, offset) { - offset = offset || 0; - var len = Math.max(0, arr.length - offset); - var newArr = new Array(len); - for (var ii = 0; ii < len; ii++) { - newArr[ii] = arr[ii + offset]; - } - return newArr; - } + // #pragma Iterators - function ensureSize(iter) { - if (iter.size === undefined) { - iter.size = iter.__iterate(returnTrue); + ArrayMapNode.prototype.iterate = + HashCollisionNode.prototype.iterate = function (fn, reverse) { + var entries = this.entries; + for (var ii = 0, maxIndex = entries.length - 1; ii <= maxIndex; ii++) { + if (fn(entries[reverse ? maxIndex - ii : ii]) === false) { + return false; + } } - return iter.size; } - function wrapIndex(iter, index) { - // This implements "is array index" which the ECMAString spec defines as: - // - // A String property name P is an array index if and only if - // ToString(ToUint32(P)) is equal to P and ToUint32(P) is not equal - // to 2^32−1. - // - // http://www.ecma-international.org/ecma-262/6.0/#sec-array-exotic-objects - if (typeof index !== 'number') { - var uint32Index = index >>> 0; // N >>> 0 is shorthand for ToUint32 - if ('' + uint32Index !== index || uint32Index === 4294967295) { - return NaN; + BitmapIndexedNode.prototype.iterate = + HashArrayMapNode.prototype.iterate = function (fn, reverse) { + var nodes = this.nodes; + for (var ii = 0, maxIndex = nodes.length - 1; ii <= maxIndex; ii++) { + var node = nodes[reverse ? maxIndex - ii : ii]; + if (node && node.iterate(fn, reverse) === false) { + return false; } - index = uint32Index; } - return index < 0 ? ensureSize(iter) + index : index; } - function returnTrue() { - return true; + ValueNode.prototype.iterate = function (fn, reverse) { + return fn(this.entry); } - function wholeSlice(begin, end, size) { - return (begin === 0 || (size !== undefined && begin <= -size)) && - (end === undefined || (size !== undefined && end >= size)); + createClass(MapIterator, Iterator); + + function MapIterator(map, type, reverse) { + this._type = type; + this._reverse = reverse; + this._stack = map._root && mapIteratorFrame(map._root); + } + + MapIterator.prototype.next = function() { + var type = this._type; + var stack = this._stack; + while (stack) { + var node = stack.node; + var index = stack.index++; + var maxIndex; + if (node.entry) { + if (index === 0) { + return mapIteratorValue(type, node.entry); + } + } else if (node.entries) { + maxIndex = node.entries.length - 1; + if (index <= maxIndex) { + return mapIteratorValue(type, node.entries[this._reverse ? maxIndex - index : index]); + } + } else { + maxIndex = node.nodes.length - 1; + if (index <= maxIndex) { + var subNode = node.nodes[this._reverse ? maxIndex - index : index]; + if (subNode) { + if (subNode.entry) { + return mapIteratorValue(type, subNode.entry); + } + stack = this._stack = mapIteratorFrame(subNode, stack); + } + continue; + } + } + stack = this._stack = this._stack.__prev; + } + return iteratorDone(); + }; + + + function mapIteratorValue(type, entry) { + return iteratorValue(type, entry[0], entry[1]); } - function resolveBegin(begin, size) { - return resolveIndex(begin, size, 0); + function mapIteratorFrame(node, prev) { + return { + node: node, + index: 0, + __prev: prev + }; } - function resolveEnd(end, size) { - return resolveIndex(end, size, size); + function makeMap(size, root, ownerID, hash) { + var map = Object.create(MapPrototype); + map.size = size; + map._root = root; + map.__ownerID = ownerID; + map.__hash = hash; + map.__altered = false; + return map; } - function resolveIndex(index, size, defaultIndex) { - return index === undefined ? - defaultIndex : - index < 0 ? - Math.max(0, size + index) : - size === undefined ? - index : - Math.min(size, index); + var EMPTY_MAP; + function emptyMap() { + return EMPTY_MAP || (EMPTY_MAP = makeMap(0)); } - /* global Symbol */ + function updateMap(map, k, v) { + var newRoot; + var newSize; + if (!map._root) { + if (v === NOT_SET) { + return map; + } + newSize = 1; + newRoot = new ArrayMapNode(map.__ownerID, [[k, v]]); + } else { + var didChangeSize = MakeRef(CHANGE_LENGTH); + var didAlter = MakeRef(DID_ALTER); + newRoot = updateNode(map._root, map.__ownerID, 0, undefined, k, v, didChangeSize, didAlter); + if (!didAlter.value) { + return map; + } + newSize = map.size + (didChangeSize.value ? v === NOT_SET ? -1 : 1 : 0); + } + if (map.__ownerID) { + map.size = newSize; + map._root = newRoot; + map.__hash = undefined; + map.__altered = true; + return map; + } + return newRoot ? makeMap(newSize, newRoot) : emptyMap(); + } - var ITERATE_KEYS = 0; - var ITERATE_VALUES = 1; - var ITERATE_ENTRIES = 2; + function updateNode(node, ownerID, shift, keyHash, key, value, didChangeSize, didAlter) { + if (!node) { + if (value === NOT_SET) { + return node; + } + SetRef(didAlter); + SetRef(didChangeSize); + return new ValueNode(ownerID, keyHash, [key, value]); + } + return node.update(ownerID, shift, keyHash, key, value, didChangeSize, didAlter); + } - var REAL_ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator; - var FAUX_ITERATOR_SYMBOL = '@@iterator'; + function isLeafNode(node) { + return node.constructor === ValueNode || node.constructor === HashCollisionNode; + } - var ITERATOR_SYMBOL = REAL_ITERATOR_SYMBOL || FAUX_ITERATOR_SYMBOL; + function mergeIntoNode(node, ownerID, shift, keyHash, entry) { + if (node.keyHash === keyHash) { + return new HashCollisionNode(ownerID, keyHash, [node.entry, entry]); + } + + var idx1 = (shift === 0 ? node.keyHash : node.keyHash >>> shift) & MASK; + var idx2 = (shift === 0 ? keyHash : keyHash >>> shift) & MASK; + var newNode; + var nodes = idx1 === idx2 ? + [mergeIntoNode(node, ownerID, shift + SHIFT, keyHash, entry)] : + ((newNode = new ValueNode(ownerID, keyHash, entry)), idx1 < idx2 ? [node, newNode] : [newNode, node]); - function Iterator(next) { - this.next = next; + return new BitmapIndexedNode(ownerID, (1 << idx1) | (1 << idx2), nodes); + } + + function createNodes(ownerID, entries, key, value) { + if (!ownerID) { + ownerID = new OwnerID(); + } + var node = new ValueNode(ownerID, hash(key), [key, value]); + for (var ii = 0; ii < entries.length; ii++) { + var entry = entries[ii]; + node = node.update(ownerID, 0, undefined, entry[0], entry[1]); } + return node; + } - Iterator.prototype.toString = function() { - return '[Iterator]'; - }; + function packNodes(ownerID, nodes, count, excluding) { + var bitmap = 0; + var packedII = 0; + var packedNodes = new Array(count); + for (var ii = 0, bit = 1, len = nodes.length; ii < len; ii++, bit <<= 1) { + var node = nodes[ii]; + if (node !== undefined && ii !== excluding) { + bitmap |= bit; + packedNodes[packedII++] = node; + } + } + return new BitmapIndexedNode(ownerID, bitmap, packedNodes); + } + function expandNodes(ownerID, nodes, bitmap, including, node) { + var count = 0; + var expandedNodes = new Array(SIZE); + for (var ii = 0; bitmap !== 0; ii++, bitmap >>>= 1) { + expandedNodes[ii] = bitmap & 1 ? nodes[count++] : undefined; + } + expandedNodes[including] = node; + return new HashArrayMapNode(ownerID, count + 1, expandedNodes); + } - Iterator.KEYS = ITERATE_KEYS; - Iterator.VALUES = ITERATE_VALUES; - Iterator.ENTRIES = ITERATE_ENTRIES; + function mergeIntoMapWith(map, merger, iterables) { + var iters = []; + for (var ii = 0; ii < iterables.length; ii++) { + var value = iterables[ii]; + var iter = KeyedIterable(value); + if (!isIterable(value)) { + iter = iter.map(function(v ) {return fromJS(v)}); + } + iters.push(iter); + } + return mergeIntoCollectionWith(map, merger, iters); + } - Iterator.prototype.inspect = - Iterator.prototype.toSource = function () { return this.toString(); } - Iterator.prototype[ITERATOR_SYMBOL] = function () { - return this; - }; + function deepMerger(existing, value, key) { + return existing && existing.mergeDeep && isIterable(value) ? + existing.mergeDeep(value) : + is(existing, value) ? existing : value; + } + function deepMergerWith(merger) { + return function(existing, value, key) { + if (existing && existing.mergeDeepWith && isIterable(value)) { + return existing.mergeDeepWith(merger, value); + } + var nextValue = merger(existing, value, key); + return is(existing, nextValue) ? existing : nextValue; + }; + } - function iteratorValue(type, k, v, iteratorResult) { - var value = type === 0 ? k : type === 1 ? v : [k, v]; - iteratorResult ? (iteratorResult.value = value) : (iteratorResult = { - value: value, done: false + function mergeIntoCollectionWith(collection, merger, iters) { + iters = iters.filter(function(x ) {return x.size !== 0}); + if (iters.length === 0) { + return collection; + } + if (collection.size === 0 && !collection.__ownerID && iters.length === 1) { + return collection.constructor(iters[0]); + } + return collection.withMutations(function(collection ) { + var mergeIntoMap = merger ? + function(value, key) { + collection.update(key, NOT_SET, function(existing ) + {return existing === NOT_SET ? value : merger(existing, value, key)} + ); + } : + function(value, key) { + collection.set(key, value); + } + for (var ii = 0; ii < iters.length; ii++) { + iters[ii].forEach(mergeIntoMap); + } }); - return iteratorResult; } - function iteratorDone() { - return { value: undefined, done: true }; + function updateInDeepMap(existing, keyPathIter, notSetValue, updater) { + var isNotSet = existing === NOT_SET; + var step = keyPathIter.next(); + if (step.done) { + var existingValue = isNotSet ? notSetValue : existing; + var newValue = updater(existingValue); + return newValue === existingValue ? existing : newValue; + } + invariant( + isNotSet || (existing && existing.set), + 'invalid keyPath' + ); + var key = step.value; + var nextExisting = isNotSet ? NOT_SET : existing.get(key, NOT_SET); + var nextUpdated = updateInDeepMap( + nextExisting, + keyPathIter, + notSetValue, + updater + ); + return nextUpdated === nextExisting ? existing : + nextUpdated === NOT_SET ? existing.remove(key) : + (isNotSet ? emptyMap() : existing).set(key, nextUpdated); } - function hasIterator(maybeIterable) { - return !!getIteratorFn(maybeIterable); + function popCount(x) { + x = x - ((x >> 1) & 0x55555555); + x = (x & 0x33333333) + ((x >> 2) & 0x33333333); + x = (x + (x >> 4)) & 0x0f0f0f0f; + x = x + (x >> 8); + x = x + (x >> 16); + return x & 0x7f; } - function isIterator(maybeIterator) { - return maybeIterator && typeof maybeIterator.next === 'function'; + function setIn(array, idx, val, canEdit) { + var newArray = canEdit ? array : arrCopy(array); + newArray[idx] = val; + return newArray; } - function getIterator(iterable) { - var iteratorFn = getIteratorFn(iterable); - return iteratorFn && iteratorFn.call(iterable); + function spliceIn(array, idx, val, canEdit) { + var newLen = array.length + 1; + if (canEdit && idx + 1 === newLen) { + array[idx] = val; + return array; + } + var newArray = new Array(newLen); + var after = 0; + for (var ii = 0; ii < newLen; ii++) { + if (ii === idx) { + newArray[ii] = val; + after = -1; + } else { + newArray[ii] = array[ii + after]; + } + } + return newArray; } - function getIteratorFn(iterable) { - var iteratorFn = iterable && ( - (REAL_ITERATOR_SYMBOL && iterable[REAL_ITERATOR_SYMBOL]) || - iterable[FAUX_ITERATOR_SYMBOL] - ); - if (typeof iteratorFn === 'function') { - return iteratorFn; + function spliceOut(array, idx, canEdit) { + var newLen = array.length - 1; + if (canEdit && idx === newLen) { + array.pop(); + return array; + } + var newArray = new Array(newLen); + var after = 0; + for (var ii = 0; ii < newLen; ii++) { + if (ii === idx) { + after = 1; + } + newArray[ii] = array[ii + after]; } + return newArray; } - function isArrayLike(value) { - return value && typeof value.length === 'number'; - } + var MAX_ARRAY_MAP_SIZE = SIZE / 4; + var MAX_BITMAP_INDEXED_SIZE = SIZE / 2; + var MIN_HASH_ARRAY_MAP_SIZE = SIZE / 4; - createClass(Seq, Iterable); - function Seq(value) { - return value === null || value === undefined ? emptySequence() : - isIterable(value) ? value.toSeq() : seqFromValue(value); + createClass(List, IndexedCollection); + + // @pragma Construction + + function List(value) { + var empty = emptyList(); + if (value === null || value === undefined) { + return empty; + } + if (isList(value)) { + return value; + } + var iter = IndexedIterable(value); + var size = iter.size; + if (size === 0) { + return empty; + } + assertNotInfinite(size); + if (size > 0 && size < SIZE) { + return makeList(0, size, SHIFT, null, new VNode(iter.toArray())); + } + return empty.withMutations(function(list ) { + list.setSize(size); + iter.forEach(function(v, i) {return list.set(i, v)}); + }); } - Seq.of = function(/*...values*/) { - return Seq(arguments); + List.of = function(/*...values*/) { + return this(arguments); }; - Seq.prototype.toSeq = function() { - return this; + List.prototype.toString = function() { + return this.__toString('List [', ']'); }; - Seq.prototype.toString = function() { - return this.__toString('Seq {', '}'); - }; + // @pragma Access - Seq.prototype.cacheResult = function() { - if (!this._cache && this.__iterateUncached) { - this._cache = this.entrySeq().toArray(); - this.size = this._cache.length; + List.prototype.get = function(index, notSetValue) { + index = wrapIndex(this, index); + if (index >= 0 && index < this.size) { + index += this._origin; + var node = listNodeFor(this, index); + return node && node.array[index & MASK]; } - return this; + return notSetValue; }; - // abstract __iterateUncached(fn, reverse) + // @pragma Modification - Seq.prototype.__iterate = function(fn, reverse) { - return seqIterate(this, fn, reverse, true); + List.prototype.set = function(index, value) { + return updateList(this, index, value); }; - // abstract __iteratorUncached(type, reverse) - - Seq.prototype.__iterator = function(type, reverse) { - return seqIterator(this, type, reverse, true); + List.prototype.remove = function(index) { + return !this.has(index) ? this : + index === 0 ? this.shift() : + index === this.size - 1 ? this.pop() : + this.splice(index, 1); }; + List.prototype.insert = function(index, value) { + return this.splice(index, 0, value); + }; + List.prototype.clear = function() { + if (this.size === 0) { + return this; + } + if (this.__ownerID) { + this.size = this._origin = this._capacity = 0; + this._level = SHIFT; + this._root = this._tail = null; + this.__hash = undefined; + this.__altered = true; + return this; + } + return emptyList(); + }; - createClass(KeyedSeq, Seq); - function KeyedSeq(value) { - return value === null || value === undefined ? - emptySequence().toKeyedSeq() : - isIterable(value) ? - (isKeyed(value) ? value.toSeq() : value.fromEntrySeq()) : - keyedSeqFromValue(value); - } + List.prototype.push = function(/*...values*/) { + var values = arguments; + var oldSize = this.size; + return this.withMutations(function(list ) { + setListBounds(list, 0, oldSize + values.length); + for (var ii = 0; ii < values.length; ii++) { + list.set(oldSize + ii, values[ii]); + } + }); + }; - KeyedSeq.prototype.toKeyedSeq = function() { - return this; + List.prototype.pop = function() { + return setListBounds(this, 0, -1); }; + List.prototype.unshift = function(/*...values*/) { + var values = arguments; + return this.withMutations(function(list ) { + setListBounds(list, -values.length); + for (var ii = 0; ii < values.length; ii++) { + list.set(ii, values[ii]); + } + }); + }; + List.prototype.shift = function() { + return setListBounds(this, 1); + }; - createClass(IndexedSeq, Seq); - function IndexedSeq(value) { - return value === null || value === undefined ? emptySequence() : - !isIterable(value) ? indexedSeqFromValue(value) : - isKeyed(value) ? value.entrySeq() : value.toIndexedSeq(); - } + // @pragma Composition - IndexedSeq.of = function(/*...values*/) { - return IndexedSeq(arguments); + List.prototype.merge = function(/*...iters*/) { + return mergeIntoListWith(this, undefined, arguments); }; - IndexedSeq.prototype.toIndexedSeq = function() { - return this; + List.prototype.mergeWith = function(merger) {var iters = SLICE$0.call(arguments, 1); + return mergeIntoListWith(this, merger, iters); }; - IndexedSeq.prototype.toString = function() { - return this.__toString('Seq [', ']'); + List.prototype.mergeDeep = function(/*...iters*/) { + return mergeIntoListWith(this, deepMerger, arguments); }; - IndexedSeq.prototype.__iterate = function(fn, reverse) { - return seqIterate(this, fn, reverse, false); + List.prototype.mergeDeepWith = function(merger) {var iters = SLICE$0.call(arguments, 1); + return mergeIntoListWith(this, deepMergerWith(merger), iters); }; - IndexedSeq.prototype.__iterator = function(type, reverse) { - return seqIterator(this, type, reverse, false); + List.prototype.setSize = function(size) { + return setListBounds(this, 0, size); }; + // @pragma Iteration - - createClass(SetSeq, Seq); - function SetSeq(value) { - return ( - value === null || value === undefined ? emptySequence() : - !isIterable(value) ? indexedSeqFromValue(value) : - isKeyed(value) ? value.entrySeq() : value - ).toSetSeq(); - } - - SetSeq.of = function(/*...values*/) { - return SetSeq(arguments); + List.prototype.slice = function(begin, end) { + var size = this.size; + if (wholeSlice(begin, end, size)) { + return this; + } + return setListBounds( + this, + resolveBegin(begin, size), + resolveEnd(end, size) + ); }; - SetSeq.prototype.toSetSeq = function() { - return this; + List.prototype.__iterator = function(type, reverse) { + var index = 0; + var values = iterateList(this, reverse); + return new Iterator(function() { + var value = values(); + return value === DONE ? + iteratorDone() : + iteratorValue(type, index++, value); + }); }; + List.prototype.__iterate = function(fn, reverse) { + var index = 0; + var values = iterateList(this, reverse); + var value; + while ((value = values()) !== DONE) { + if (fn(value, index++, this) === false) { + break; + } + } + return index; + }; + List.prototype.__ensureOwner = function(ownerID) { + if (ownerID === this.__ownerID) { + return this; + } + if (!ownerID) { + this.__ownerID = ownerID; + return this; + } + return makeList(this._origin, this._capacity, this._level, this._root, this._tail, ownerID, this.__hash); + }; - Seq.isSeq = isSeq; - Seq.Keyed = KeyedSeq; - Seq.Set = SetSeq; - Seq.Indexed = IndexedSeq; - var IS_SEQ_SENTINEL = '@@__IMMUTABLE_SEQ__@@'; + function isList(maybeList) { + return !!(maybeList && maybeList[IS_LIST_SENTINEL]); + } - Seq.prototype[IS_SEQ_SENTINEL] = true; + List.isList = isList; + + var IS_LIST_SENTINEL = '@@__IMMUTABLE_LIST__@@'; + + var ListPrototype = List.prototype; + ListPrototype[IS_LIST_SENTINEL] = true; + ListPrototype[DELETE] = ListPrototype.remove; + ListPrototype.setIn = MapPrototype.setIn; + ListPrototype.deleteIn = + ListPrototype.removeIn = MapPrototype.removeIn; + ListPrototype.update = MapPrototype.update; + ListPrototype.updateIn = MapPrototype.updateIn; + ListPrototype.mergeIn = MapPrototype.mergeIn; + ListPrototype.mergeDeepIn = MapPrototype.mergeDeepIn; + ListPrototype.withMutations = MapPrototype.withMutations; + ListPrototype.asMutable = MapPrototype.asMutable; + ListPrototype.asImmutable = MapPrototype.asImmutable; + ListPrototype.wasAltered = MapPrototype.wasAltered; - createClass(ArraySeq, IndexedSeq); - function ArraySeq(array) { - this._array = array; - this.size = array.length; + function VNode(array, ownerID) { + this.array = array; + this.ownerID = ownerID; } - ArraySeq.prototype.get = function(index, notSetValue) { - return this.has(index) ? this._array[wrapIndex(this, index)] : notSetValue; - }; + // TODO: seems like these methods are very similar - ArraySeq.prototype.__iterate = function(fn, reverse) { - var array = this._array; - var maxIndex = array.length - 1; - for (var ii = 0; ii <= maxIndex; ii++) { - if (fn(array[reverse ? maxIndex - ii : ii], ii, this) === false) { - return ii + 1; + VNode.prototype.removeBefore = function(ownerID, level, index) { + if (index === level ? 1 << level : 0 || this.array.length === 0) { + return this; + } + var originIndex = (index >>> level) & MASK; + if (originIndex >= this.array.length) { + return new VNode([], ownerID); + } + var removingFirst = originIndex === 0; + var newChild; + if (level > 0) { + var oldChild = this.array[originIndex]; + newChild = oldChild && oldChild.removeBefore(ownerID, level - SHIFT, index); + if (newChild === oldChild && removingFirst) { + return this; } } - return ii; - }; - - ArraySeq.prototype.__iterator = function(type, reverse) { - var array = this._array; - var maxIndex = array.length - 1; - var ii = 0; - return new Iterator(function() - {return ii > maxIndex ? - iteratorDone() : - iteratorValue(type, ii, array[reverse ? maxIndex - ii++ : ii++])} - ); + if (removingFirst && !newChild) { + return this; + } + var editable = editableVNode(this, ownerID); + if (!removingFirst) { + for (var ii = 0; ii < originIndex; ii++) { + editable.array[ii] = undefined; + } + } + if (newChild) { + editable.array[originIndex] = newChild; + } + return editable; }; + VNode.prototype.removeAfter = function(ownerID, level, index) { + if (index === (level ? 1 << level : 0) || this.array.length === 0) { + return this; + } + var sizeIndex = ((index - 1) >>> level) & MASK; + if (sizeIndex >= this.array.length) { + return this; + } + var newChild; + if (level > 0) { + var oldChild = this.array[sizeIndex]; + newChild = oldChild && oldChild.removeAfter(ownerID, level - SHIFT, index); + if (newChild === oldChild && sizeIndex === this.array.length - 1) { + return this; + } + } - createClass(ObjectSeq, KeyedSeq); - function ObjectSeq(object) { - var keys = Object.keys(object); - this._object = object; - this._keys = keys; - this.size = keys.length; - } - - ObjectSeq.prototype.get = function(key, notSetValue) { - if (notSetValue !== undefined && !this.has(key)) { - return notSetValue; + var editable = editableVNode(this, ownerID); + editable.array.splice(sizeIndex + 1); + if (newChild) { + editable.array[sizeIndex] = newChild; } - return this._object[key]; + return editable; }; - ObjectSeq.prototype.has = function(key) { - return this._object.hasOwnProperty(key); - }; - ObjectSeq.prototype.__iterate = function(fn, reverse) { - var object = this._object; - var keys = this._keys; - var maxIndex = keys.length - 1; - for (var ii = 0; ii <= maxIndex; ii++) { - var key = keys[reverse ? maxIndex - ii : ii]; - if (fn(object[key], key, this) === false) { - return ii + 1; - } - } - return ii; - }; - ObjectSeq.prototype.__iterator = function(type, reverse) { - var object = this._object; - var keys = this._keys; - var maxIndex = keys.length - 1; - var ii = 0; - return new Iterator(function() { - var key = keys[reverse ? maxIndex - ii : ii]; - return ii++ > maxIndex ? - iteratorDone() : - iteratorValue(type, key, object[key]); - }); - }; + var DONE = {}; - ObjectSeq.prototype[IS_ORDERED_SENTINEL] = true; + function iterateList(list, reverse) { + var left = list._origin; + var right = list._capacity; + var tailPos = getTailOffset(right); + var tail = list._tail; + return iterateNodeOrLeaf(list._root, list._level, 0); - createClass(IterableSeq, IndexedSeq); - function IterableSeq(iterable) { - this._iterable = iterable; - this.size = iterable.length || iterable.size; + function iterateNodeOrLeaf(node, level, offset) { + return level === 0 ? + iterateLeaf(node, offset) : + iterateNode(node, level, offset); } - IterableSeq.prototype.__iterateUncached = function(fn, reverse) { - if (reverse) { - return this.cacheResult().__iterate(fn, reverse); + function iterateLeaf(node, offset) { + var array = offset === tailPos ? tail && tail.array : node && node.array; + var from = offset > left ? 0 : left - offset; + var to = right - offset; + if (to > SIZE) { + to = SIZE; } - var iterable = this._iterable; - var iterator = getIterator(iterable); - var iterations = 0; - if (isIterator(iterator)) { - var step; - while (!(step = iterator.next()).done) { - if (fn(step.value, iterations++, this) === false) { - break; - } + return function() { + if (from === to) { + return DONE; } - } - return iterations; - }; + var idx = reverse ? --to : from++; + return array && array[idx]; + }; + } - IterableSeq.prototype.__iteratorUncached = function(type, reverse) { - if (reverse) { - return this.cacheResult().__iterator(type, reverse); - } - var iterable = this._iterable; - var iterator = getIterator(iterable); - if (!isIterator(iterator)) { - return new Iterator(iteratorDone); + function iterateNode(node, level, offset) { + var values; + var array = node && node.array; + var from = offset > left ? 0 : (left - offset) >> level; + var to = ((right - offset) >> level) + 1; + if (to > SIZE) { + to = SIZE; } - var iterations = 0; - return new Iterator(function() { - var step = iterator.next(); - return step.done ? step : iteratorValue(type, iterations++, step.value); - }); - }; + return function() { + do { + if (values) { + var value = values(); + if (value !== DONE) { + return value; + } + values = null; + } + if (from === to) { + return DONE; + } + var idx = reverse ? --to : from++; + values = iterateNodeOrLeaf( + array && array[idx], level - SHIFT, offset + (idx << level) + ); + } while (true); + }; + } + } + + function makeList(origin, capacity, level, root, tail, ownerID, hash) { + var list = Object.create(ListPrototype); + list.size = capacity - origin; + list._origin = origin; + list._capacity = capacity; + list._level = level; + list._root = root; + list._tail = tail; + list.__ownerID = ownerID; + list.__hash = hash; + list.__altered = false; + return list; + } + var EMPTY_LIST; + function emptyList() { + return EMPTY_LIST || (EMPTY_LIST = makeList(0, 0, SHIFT)); + } + function updateList(list, index, value) { + index = wrapIndex(list, index); - createClass(IteratorSeq, IndexedSeq); - function IteratorSeq(iterator) { - this._iterator = iterator; - this._iteratorCache = []; + if (index !== index) { + return list; } - IteratorSeq.prototype.__iterateUncached = function(fn, reverse) { - if (reverse) { - return this.cacheResult().__iterate(fn, reverse); - } - var iterator = this._iterator; - var cache = this._iteratorCache; - var iterations = 0; - while (iterations < cache.length) { - if (fn(cache[iterations], iterations++, this) === false) { - return iterations; - } - } - var step; - while (!(step = iterator.next()).done) { - var val = step.value; - cache[iterations] = val; - if (fn(val, iterations++, this) === false) { - break; - } - } - return iterations; - }; - - IteratorSeq.prototype.__iteratorUncached = function(type, reverse) { - if (reverse) { - return this.cacheResult().__iterator(type, reverse); - } - var iterator = this._iterator; - var cache = this._iteratorCache; - var iterations = 0; - return new Iterator(function() { - if (iterations >= cache.length) { - var step = iterator.next(); - if (step.done) { - return step; - } - cache[iterations] = step.value; - } - return iteratorValue(type, iterations, cache[iterations++]); + if (index >= list.size || index < 0) { + return list.withMutations(function(list ) { + index < 0 ? + setListBounds(list, index).set(0, value) : + setListBounds(list, 0, index + 1).set(index, value) }); - }; - + } + index += list._origin; + var newTail = list._tail; + var newRoot = list._root; + var didAlter = MakeRef(DID_ALTER); + if (index >= getTailOffset(list._capacity)) { + newTail = updateVNode(newTail, list.__ownerID, 0, index, value, didAlter); + } else { + newRoot = updateVNode(newRoot, list.__ownerID, list._level, index, value, didAlter); + } - // # pragma Helper functions + if (!didAlter.value) { + return list; + } - function isSeq(maybeSeq) { - return !!(maybeSeq && maybeSeq[IS_SEQ_SENTINEL]); + if (list.__ownerID) { + list._root = newRoot; + list._tail = newTail; + list.__hash = undefined; + list.__altered = true; + return list; + } + return makeList(list._origin, list._capacity, list._level, newRoot, newTail); } - var EMPTY_SEQ; + function updateVNode(node, ownerID, level, index, value, didAlter) { + var idx = (index >>> level) & MASK; + var nodeHas = node && idx < node.array.length; + if (!nodeHas && value === undefined) { + return node; + } - function emptySequence() { - return EMPTY_SEQ || (EMPTY_SEQ = new ArraySeq([])); - } + var newNode; - function keyedSeqFromValue(value) { - var seq = - Array.isArray(value) ? new ArraySeq(value).fromEntrySeq() : - isIterator(value) ? new IteratorSeq(value).fromEntrySeq() : - hasIterator(value) ? new IterableSeq(value).fromEntrySeq() : - typeof value === 'object' ? new ObjectSeq(value) : - undefined; - if (!seq) { - throw new TypeError( - 'Expected Array or iterable object of [k, v] entries, '+ - 'or keyed object: ' + value - ); + if (level > 0) { + var lowerNode = node && node.array[idx]; + var newLowerNode = updateVNode(lowerNode, ownerID, level - SHIFT, index, value, didAlter); + if (newLowerNode === lowerNode) { + return node; + } + newNode = editableVNode(node, ownerID); + newNode.array[idx] = newLowerNode; + return newNode; } - return seq; - } - function indexedSeqFromValue(value) { - var seq = maybeIndexedSeqFromValue(value); - if (!seq) { - throw new TypeError( - 'Expected Array or iterable object of values: ' + value - ); + if (nodeHas && node.array[idx] === value) { + return node; } - return seq; - } - function seqFromValue(value) { - var seq = maybeIndexedSeqFromValue(value) || - (typeof value === 'object' && new ObjectSeq(value)); - if (!seq) { - throw new TypeError( - 'Expected Array or iterable object of values, or keyed object: ' + value - ); + SetRef(didAlter); + + newNode = editableVNode(node, ownerID); + if (value === undefined && idx === newNode.array.length - 1) { + newNode.array.pop(); + } else { + newNode.array[idx] = value; } - return seq; + return newNode; } - function maybeIndexedSeqFromValue(value) { - return ( - isArrayLike(value) ? new ArraySeq(value) : - isIterator(value) ? new IteratorSeq(value) : - hasIterator(value) ? new IterableSeq(value) : - undefined - ); + function editableVNode(node, ownerID) { + if (ownerID && node && ownerID === node.ownerID) { + return node; + } + return new VNode(node ? node.array.slice() : [], ownerID); } - function seqIterate(seq, fn, reverse, useKeys) { - var cache = seq._cache; - if (cache) { - var maxIndex = cache.length - 1; - for (var ii = 0; ii <= maxIndex; ii++) { - var entry = cache[reverse ? maxIndex - ii : ii]; - if (fn(entry[1], useKeys ? entry[0] : ii, seq) === false) { - return ii + 1; - } + function listNodeFor(list, rawIndex) { + if (rawIndex >= getTailOffset(list._capacity)) { + return list._tail; + } + if (rawIndex < 1 << (list._level + SHIFT)) { + var node = list._root; + var level = list._level; + while (node && level > 0) { + node = node.array[(rawIndex >>> level) & MASK]; + level -= SHIFT; } - return ii; + return node; } - return seq.__iterateUncached(fn, reverse); } - function seqIterator(seq, type, reverse, useKeys) { - var cache = seq._cache; - if (cache) { - var maxIndex = cache.length - 1; - var ii = 0; - return new Iterator(function() { - var entry = cache[reverse ? maxIndex - ii : ii]; - return ii++ > maxIndex ? - iteratorDone() : - iteratorValue(type, useKeys ? entry[0] : ii - 1, entry[1]); - }); + function setListBounds(list, begin, end) { + // Sanitize begin & end using this shorthand for ToInt32(argument) + // http://www.ecma-international.org/ecma-262/6.0/#sec-toint32 + if (begin !== undefined) { + begin = begin | 0; + } + if (end !== undefined) { + end = end | 0; + } + var owner = list.__ownerID || new OwnerID(); + var oldOrigin = list._origin; + var oldCapacity = list._capacity; + var newOrigin = oldOrigin + begin; + var newCapacity = end === undefined ? oldCapacity : end < 0 ? oldCapacity + end : oldOrigin + end; + if (newOrigin === oldOrigin && newCapacity === oldCapacity) { + return list; } - return seq.__iteratorUncached(type, reverse); - } - function fromJS(json, converter) { - return converter ? - fromJSWith(converter, json, '', {'': json}) : - fromJSDefault(json); - } + // If it's going to end after it starts, it's empty. + if (newOrigin >= newCapacity) { + return list.clear(); + } - function fromJSWith(converter, json, key, parentJSON) { - if (Array.isArray(json)) { - return converter.call(parentJSON, key, IndexedSeq(json).map(function(v, k) {return fromJSWith(converter, v, k, json)})); + var newLevel = list._level; + var newRoot = list._root; + + // New origin might need creating a higher root. + var offsetShift = 0; + while (newOrigin + offsetShift < 0) { + newRoot = new VNode(newRoot && newRoot.array.length ? [undefined, newRoot] : [], owner); + newLevel += SHIFT; + offsetShift += 1 << newLevel; } - if (isPlainObj(json)) { - return converter.call(parentJSON, key, KeyedSeq(json).map(function(v, k) {return fromJSWith(converter, v, k, json)})); + if (offsetShift) { + newOrigin += offsetShift; + oldOrigin += offsetShift; + newCapacity += offsetShift; + oldCapacity += offsetShift; } - return json; - } - function fromJSDefault(json) { - if (Array.isArray(json)) { - return IndexedSeq(json).map(fromJSDefault).toList(); - } - if (isPlainObj(json)) { - return KeyedSeq(json).map(fromJSDefault).toMap(); + var oldTailOffset = getTailOffset(oldCapacity); + var newTailOffset = getTailOffset(newCapacity); + + // New size might need creating a higher root. + while (newTailOffset >= 1 << (newLevel + SHIFT)) { + newRoot = new VNode(newRoot && newRoot.array.length ? [newRoot] : [], owner); + newLevel += SHIFT; } - return json; - } - function isPlainObj(value) { - return value && (value.constructor === Object || value.constructor === undefined); - } + // Locate or create the new tail. + var oldTail = list._tail; + var newTail = newTailOffset < oldTailOffset ? + listNodeFor(list, newCapacity - 1) : + newTailOffset > oldTailOffset ? new VNode([], owner) : oldTail; - /** - * An extension of the "same-value" algorithm as [described for use by ES6 Map - * and Set](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map#Key_equality) - * - * NaN is considered the same as NaN, however -0 and 0 are considered the same - * value, which is different from the algorithm described by - * [`Object.is`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is). - * - * This is extended further to allow Objects to describe the values they - * represent, by way of `valueOf` or `equals` (and `hashCode`). - * - * Note: because of this extension, the key equality of Immutable.Map and the - * value equality of Immutable.Set will differ from ES6 Map and Set. - * - * ### Defining custom values - * - * The easiest way to describe the value an object represents is by implementing - * `valueOf`. For example, `Date` represents a value by returning a unix - * timestamp for `valueOf`: - * - * var date1 = new Date(1234567890000); // Fri Feb 13 2009 ... - * var date2 = new Date(1234567890000); - * date1.valueOf(); // 1234567890000 - * assert( date1 !== date2 ); - * assert( Immutable.is( date1, date2 ) ); - * - * Note: overriding `valueOf` may have other implications if you use this object - * where JavaScript expects a primitive, such as implicit string coercion. - * - * For more complex types, especially collections, implementing `valueOf` may - * not be performant. An alternative is to implement `equals` and `hashCode`. - * - * `equals` takes another object, presumably of similar type, and returns true - * if the it is equal. Equality is symmetrical, so the same result should be - * returned if this and the argument are flipped. - * - * assert( a.equals(b) === b.equals(a) ); - * - * `hashCode` returns a 32bit integer number representing the object which will - * be used to determine how to store the value object in a Map or Set. You must - * provide both or neither methods, one must not exist without the other. - * - * Also, an important relationship between these methods must be upheld: if two - * values are equal, they *must* return the same hashCode. If the values are not - * equal, they might have the same hashCode; this is called a hash collision, - * and while undesirable for performance reasons, it is acceptable. - * - * if (a.equals(b)) { - * assert( a.hashCode() === b.hashCode() ); - * } - * - * All Immutable collections implement `equals` and `hashCode`. - * - */ - function is(valueA, valueB) { - if (valueA === valueB || (valueA !== valueA && valueB !== valueB)) { - return true; + // Merge Tail into tree. + if (oldTail && newTailOffset > oldTailOffset && newOrigin < oldCapacity && oldTail.array.length) { + newRoot = editableVNode(newRoot, owner); + var node = newRoot; + for (var level = newLevel; level > SHIFT; level -= SHIFT) { + var idx = (oldTailOffset >>> level) & MASK; + node = node.array[idx] = editableVNode(node.array[idx], owner); + } + node.array[(oldTailOffset >>> SHIFT) & MASK] = oldTail; } - if (!valueA || !valueB) { - return false; + + // If the size has been reduced, there's a chance the tail needs to be trimmed. + if (newCapacity < oldCapacity) { + newTail = newTail && newTail.removeAfter(owner, 0, newCapacity); } - if (typeof valueA.valueOf === 'function' && - typeof valueB.valueOf === 'function') { - valueA = valueA.valueOf(); - valueB = valueB.valueOf(); - if (valueA === valueB || (valueA !== valueA && valueB !== valueB)) { - return true; + + // If the new origin is within the tail, then we do not need a root. + if (newOrigin >= newTailOffset) { + newOrigin -= newTailOffset; + newCapacity -= newTailOffset; + newLevel = SHIFT; + newRoot = null; + newTail = newTail && newTail.removeBefore(owner, 0, newOrigin); + + // Otherwise, if the root has been trimmed, garbage collect. + } else if (newOrigin > oldOrigin || newTailOffset < oldTailOffset) { + offsetShift = 0; + + // Identify the new top root node of the subtree of the old root. + while (newRoot) { + var beginIndex = (newOrigin >>> newLevel) & MASK; + if (beginIndex !== (newTailOffset >>> newLevel) & MASK) { + break; + } + if (beginIndex) { + offsetShift += (1 << newLevel) * beginIndex; + } + newLevel -= SHIFT; + newRoot = newRoot.array[beginIndex]; } - if (!valueA || !valueB) { - return false; + + // Trim the new sides of the new root. + if (newRoot && newOrigin > oldOrigin) { + newRoot = newRoot.removeBefore(owner, newLevel, newOrigin - offsetShift); + } + if (newRoot && newTailOffset < oldTailOffset) { + newRoot = newRoot.removeAfter(owner, newLevel, newTailOffset - offsetShift); + } + if (offsetShift) { + newOrigin -= offsetShift; + newCapacity -= offsetShift; } } - if (typeof valueA.equals === 'function' && - typeof valueB.equals === 'function' && - valueA.equals(valueB)) { - return true; + + if (list.__ownerID) { + list.size = newCapacity - newOrigin; + list._origin = newOrigin; + list._capacity = newCapacity; + list._level = newLevel; + list._root = newRoot; + list._tail = newTail; + list.__hash = undefined; + list.__altered = true; + return list; } - return false; + return makeList(newOrigin, newCapacity, newLevel, newRoot, newTail); } - function deepEqual(a, b) { - if (a === b) { - return true; + function mergeIntoListWith(list, merger, iterables) { + var iters = []; + var maxSize = 0; + for (var ii = 0; ii < iterables.length; ii++) { + var value = iterables[ii]; + var iter = IndexedIterable(value); + if (iter.size > maxSize) { + maxSize = iter.size; + } + if (!isIterable(value)) { + iter = iter.map(function(v ) {return fromJS(v)}); + } + iters.push(iter); } - - if ( - !isIterable(b) || - a.size !== undefined && b.size !== undefined && a.size !== b.size || - a.__hash !== undefined && b.__hash !== undefined && a.__hash !== b.__hash || - isKeyed(a) !== isKeyed(b) || - isIndexed(a) !== isIndexed(b) || - isOrdered(a) !== isOrdered(b) - ) { - return false; + if (maxSize > list.size) { + list = list.setSize(maxSize); } + return mergeIntoCollectionWith(list, merger, iters); + } - if (a.size === 0 && b.size === 0) { - return true; - } + function getTailOffset(size) { + return size < SIZE ? 0 : (((size - 1) >>> SHIFT) << SHIFT); + } - var notAssociative = !isAssociative(a); + createClass(OrderedMap, Map); - if (isOrdered(a)) { - var entries = a.entries(); - return b.every(function(v, k) { - var entry = entries.next().value; - return entry && is(entry[1], v) && (notAssociative || is(entry[0], k)); - }) && entries.next().done; + // @pragma Construction + + function OrderedMap(value) { + return value === null || value === undefined ? emptyOrderedMap() : + isOrderedMap(value) ? value : + emptyOrderedMap().withMutations(function(map ) { + var iter = KeyedIterable(value); + assertNotInfinite(iter.size); + iter.forEach(function(v, k) {return map.set(k, v)}); + }); } - var flipped = false; + OrderedMap.of = function(/*...values*/) { + return this(arguments); + }; - if (a.size === undefined) { - if (b.size === undefined) { - if (typeof a.cacheResult === 'function') { - a.cacheResult(); - } - } else { - flipped = true; - var _ = a; - a = b; - b = _; - } - } + OrderedMap.prototype.toString = function() { + return this.__toString('OrderedMap {', '}'); + }; - var allEqual = true; - var bSize = b.__iterate(function(v, k) { - if (notAssociative ? !a.has(v) : - flipped ? !is(v, a.get(k, NOT_SET)) : !is(a.get(k, NOT_SET), v)) { - allEqual = false; - return false; - } - }); + // @pragma Access - return allEqual && a.size === bSize; - } + OrderedMap.prototype.get = function(k, notSetValue) { + var index = this._map.get(k); + return index !== undefined ? this._list.get(index)[1] : notSetValue; + }; - createClass(Repeat, IndexedSeq); + // @pragma Modification - function Repeat(value, times) { - if (!(this instanceof Repeat)) { - return new Repeat(value, times); - } - this._value = value; - this.size = times === undefined ? Infinity : Math.max(0, times); + OrderedMap.prototype.clear = function() { if (this.size === 0) { - if (EMPTY_REPEAT) { - return EMPTY_REPEAT; - } - EMPTY_REPEAT = this; + return this; } - } - - Repeat.prototype.toString = function() { - if (this.size === 0) { - return 'Repeat []'; + if (this.__ownerID) { + this.size = 0; + this._map.clear(); + this._list.clear(); + return this; } - return 'Repeat [ ' + this._value + ' ' + this.size + ' times ]'; + return emptyOrderedMap(); }; - Repeat.prototype.get = function(index, notSetValue) { - return this.has(index) ? this._value : notSetValue; + OrderedMap.prototype.set = function(k, v) { + return updateOrderedMap(this, k, v); }; - Repeat.prototype.includes = function(searchValue) { - return is(this._value, searchValue); + OrderedMap.prototype.remove = function(k) { + return updateOrderedMap(this, k, NOT_SET); }; - Repeat.prototype.slice = function(begin, end) { - var size = this.size; - return wholeSlice(begin, end, size) ? this : - new Repeat(this._value, resolveEnd(end, size) - resolveBegin(begin, size)); + OrderedMap.prototype.wasAltered = function() { + return this._map.wasAltered() || this._list.wasAltered(); }; - Repeat.prototype.reverse = function() { - return this; + OrderedMap.prototype.__iterate = function(fn, reverse) {var this$0 = this; + return this._list.__iterate( + function(entry ) {return entry && fn(entry[1], entry[0], this$0)}, + reverse + ); }; - Repeat.prototype.indexOf = function(searchValue) { - if (is(this._value, searchValue)) { - return 0; - } - return -1; + OrderedMap.prototype.__iterator = function(type, reverse) { + return this._list.fromEntrySeq().__iterator(type, reverse); }; - Repeat.prototype.lastIndexOf = function(searchValue) { - if (is(this._value, searchValue)) { - return this.size; + OrderedMap.prototype.__ensureOwner = function(ownerID) { + if (ownerID === this.__ownerID) { + return this; } - return -1; - }; - - Repeat.prototype.__iterate = function(fn, reverse) { - for (var ii = 0; ii < this.size; ii++) { - if (fn(this._value, ii, this) === false) { - return ii + 1; - } + var newMap = this._map.__ensureOwner(ownerID); + var newList = this._list.__ensureOwner(ownerID); + if (!ownerID) { + this.__ownerID = ownerID; + this._map = newMap; + this._list = newList; + return this; } - return ii; + return makeOrderedMap(newMap, newList, ownerID, this.__hash); }; - Repeat.prototype.__iterator = function(type, reverse) {var this$0 = this; - var ii = 0; - return new Iterator(function() - {return ii < this$0.size ? iteratorValue(type, ii++, this$0._value) : iteratorDone()} - ); - }; - Repeat.prototype.equals = function(other) { - return other instanceof Repeat ? - is(this._value, other._value) : - deepEqual(other); - }; + function isOrderedMap(maybeOrderedMap) { + return isMap(maybeOrderedMap) && isOrdered(maybeOrderedMap); + } + OrderedMap.isOrderedMap = isOrderedMap; - var EMPTY_REPEAT; + OrderedMap.prototype[IS_ORDERED_SENTINEL] = true; + OrderedMap.prototype[DELETE] = OrderedMap.prototype.remove; - function invariant(condition, error) { - if (!condition) throw new Error(error); + + + function makeOrderedMap(map, list, ownerID, hash) { + var omap = Object.create(OrderedMap.prototype); + omap.size = map ? map.size : 0; + omap._map = map; + omap._list = list; + omap.__ownerID = ownerID; + omap.__hash = hash; + return omap; } - createClass(Range, IndexedSeq); + var EMPTY_ORDERED_MAP; + function emptyOrderedMap() { + return EMPTY_ORDERED_MAP || (EMPTY_ORDERED_MAP = makeOrderedMap(emptyMap(), emptyList())); + } - function Range(start, end, step) { - if (!(this instanceof Range)) { - return new Range(start, end, step); - } - invariant(step !== 0, 'Cannot step a Range by 0'); - start = start || 0; - if (end === undefined) { - end = Infinity; + function updateOrderedMap(omap, k, v) { + var map = omap._map; + var list = omap._list; + var i = map.get(k); + var has = i !== undefined; + var newMap; + var newList; + if (v === NOT_SET) { // removed + if (!has) { + return omap; } - step = step === undefined ? 1 : Math.abs(step); - if (end < start) { - step = -step; + if (list.size >= SIZE && list.size >= map.size * 2) { + newList = list.filter(function(entry, idx) {return entry !== undefined && i !== idx}); + newMap = newList.toKeyedSeq().map(function(entry ) {return entry[0]}).flip().toMap(); + if (omap.__ownerID) { + newMap.__ownerID = newList.__ownerID = omap.__ownerID; + } + } else { + newMap = map.remove(k); + newList = i === list.size - 1 ? list.pop() : list.set(i, undefined); } - this._start = start; - this._end = end; - this._step = step; - this.size = Math.max(0, Math.ceil((end - start) / step - 1) + 1); - if (this.size === 0) { - if (EMPTY_RANGE) { - return EMPTY_RANGE; + } else { + if (has) { + if (v === list.get(i)[1]) { + return omap; } - EMPTY_RANGE = this; + newMap = map; + newList = list.set(i, [k, v]); + } else { + newMap = map.set(k, list.size); + newList = list.set(list.size, [k, v]); } } + if (omap.__ownerID) { + omap.size = newMap.size; + omap._map = newMap; + omap._list = newList; + omap.__hash = undefined; + return omap; + } + return makeOrderedMap(newMap, newList); + } - Range.prototype.toString = function() { - if (this.size === 0) { - return 'Range []'; - } - return 'Range [ ' + - this._start + '...' + this._end + - (this._step !== 1 ? ' by ' + this._step : '') + - ' ]'; + createClass(ToKeyedSequence, KeyedSeq); + function ToKeyedSequence(indexed, useKeys) { + this._iter = indexed; + this._useKeys = useKeys; + this.size = indexed.size; + } + + ToKeyedSequence.prototype.get = function(key, notSetValue) { + return this._iter.get(key, notSetValue); }; - Range.prototype.get = function(index, notSetValue) { - return this.has(index) ? - this._start + wrapIndex(this, index) * this._step : - notSetValue; + ToKeyedSequence.prototype.has = function(key) { + return this._iter.has(key); }; - Range.prototype.includes = function(searchValue) { - var possibleIndex = (searchValue - this._start) / this._step; - return possibleIndex >= 0 && - possibleIndex < this.size && - possibleIndex === Math.floor(possibleIndex); + ToKeyedSequence.prototype.valueSeq = function() { + return this._iter.valueSeq(); }; - Range.prototype.slice = function(begin, end) { - if (wholeSlice(begin, end, this.size)) { - return this; - } - begin = resolveBegin(begin, this.size); - end = resolveEnd(end, this.size); - if (end <= begin) { - return new Range(0, 0); + ToKeyedSequence.prototype.reverse = function() {var this$0 = this; + var reversedSequence = reverseFactory(this, true); + if (!this._useKeys) { + reversedSequence.valueSeq = function() {return this$0._iter.toSeq().reverse()}; } - return new Range(this.get(begin, this._end), this.get(end, this._end), this._step); + return reversedSequence; }; - Range.prototype.indexOf = function(searchValue) { - var offsetValue = searchValue - this._start; - if (offsetValue % this._step === 0) { - var index = offsetValue / this._step; - if (index >= 0 && index < this.size) { - return index - } + ToKeyedSequence.prototype.map = function(mapper, context) {var this$0 = this; + var mappedSequence = mapFactory(this, mapper, context); + if (!this._useKeys) { + mappedSequence.valueSeq = function() {return this$0._iter.toSeq().map(mapper, context)}; } - return -1; + return mappedSequence; }; - Range.prototype.lastIndexOf = function(searchValue) { - return this.indexOf(searchValue); + ToKeyedSequence.prototype.__iterate = function(fn, reverse) {var this$0 = this; + var ii; + return this._iter.__iterate( + this._useKeys ? + function(v, k) {return fn(v, k, this$0)} : + ((ii = reverse ? resolveSize(this) : 0), + function(v ) {return fn(v, reverse ? --ii : ii++, this$0)}), + reverse + ); }; - Range.prototype.__iterate = function(fn, reverse) { - var maxIndex = this.size - 1; - var step = this._step; - var value = reverse ? this._start + maxIndex * step : this._start; - for (var ii = 0; ii <= maxIndex; ii++) { - if (fn(value, ii, this) === false) { - return ii + 1; - } - value += reverse ? -step : step; + ToKeyedSequence.prototype.__iterator = function(type, reverse) { + if (this._useKeys) { + return this._iter.__iterator(type, reverse); } - return ii; - }; - - Range.prototype.__iterator = function(type, reverse) { - var maxIndex = this.size - 1; - var step = this._step; - var value = reverse ? this._start + maxIndex * step : this._start; - var ii = 0; + var iterator = this._iter.__iterator(ITERATE_VALUES, reverse); + var ii = reverse ? resolveSize(this) : 0; return new Iterator(function() { - var v = value; - value += reverse ? -step : step; - return ii > maxIndex ? iteratorDone() : iteratorValue(type, ii++, v); + var step = iterator.next(); + return step.done ? step : + iteratorValue(type, reverse ? --ii : ii++, step.value, step); }); }; - Range.prototype.equals = function(other) { - return other instanceof Range ? - this._start === other._start && - this._end === other._end && - this._step === other._step : - deepEqual(this, other); - }; - + ToKeyedSequence.prototype[IS_ORDERED_SENTINEL] = true; - var EMPTY_RANGE; - createClass(Collection, Iterable); - function Collection() { - throw TypeError('Abstract'); + createClass(ToIndexedSequence, IndexedSeq); + function ToIndexedSequence(iter) { + this._iter = iter; + this.size = iter.size; } + ToIndexedSequence.prototype.includes = function(value) { + return this._iter.includes(value); + }; - createClass(KeyedCollection, Collection);function KeyedCollection() {} - - createClass(IndexedCollection, Collection);function IndexedCollection() {} - - createClass(SetCollection, Collection);function SetCollection() {} + ToIndexedSequence.prototype.__iterate = function(fn, reverse) {var this$0 = this; + var iterations = 0; + return this._iter.__iterate(function(v ) {return fn(v, iterations++, this$0)}, reverse); + }; - - Collection.Keyed = KeyedCollection; - Collection.Indexed = IndexedCollection; - Collection.Set = SetCollection; - - var imul = - typeof Math.imul === 'function' && Math.imul(0xffffffff, 2) === -2 ? - Math.imul : - function imul(a, b) { - a = a | 0; // int - b = b | 0; // int - var c = a & 0xffff; - var d = b & 0xffff; - // Shift by 0 fixes the sign on the high part. - return (c * d) + ((((a >>> 16) * d + c * (b >>> 16)) << 16) >>> 0) | 0; // int + ToIndexedSequence.prototype.__iterator = function(type, reverse) { + var iterator = this._iter.__iterator(ITERATE_VALUES, reverse); + var iterations = 0; + return new Iterator(function() { + var step = iterator.next(); + return step.done ? step : + iteratorValue(type, iterations++, step.value, step) + }); }; - // v8 has an optimization for storing 31-bit signed numbers. - // Values which have either 00 or 11 as the high order bits qualify. - // This function drops the highest order bit in a signed number, maintaining - // the sign bit. - function smi(i32) { - return ((i32 >>> 1) & 0x40000000) | (i32 & 0xBFFFFFFF); - } - function hash(o) { - if (o === false || o === null || o === undefined) { - return 0; - } - if (typeof o.valueOf === 'function') { - o = o.valueOf(); - if (o === false || o === null || o === undefined) { - return 0; - } - } - if (o === true) { - return 1; - } - var type = typeof o; - if (type === 'number') { - if (o !== o || o === Infinity) { - return 0; - } - var h = o | 0; - if (h !== o) { - h ^= o * 0xFFFFFFFF; - } - while (o > 0xFFFFFFFF) { - o /= 0xFFFFFFFF; - h ^= o; - } - return smi(h); - } - if (type === 'string') { - return o.length > STRING_HASH_CACHE_MIN_STRLEN ? cachedHashString(o) : hashString(o); - } - if (typeof o.hashCode === 'function') { - return o.hashCode(); - } - if (type === 'object') { - return hashJSObj(o); - } - if (typeof o.toString === 'function') { - return hashString(o.toString()); - } - throw new Error('Value type ' + type + ' cannot be hashed.'); - } - function cachedHashString(string) { - var hash = stringHashCache[string]; - if (hash === undefined) { - hash = hashString(string); - if (STRING_HASH_CACHE_SIZE === STRING_HASH_CACHE_MAX_SIZE) { - STRING_HASH_CACHE_SIZE = 0; - stringHashCache = {}; - } - STRING_HASH_CACHE_SIZE++; - stringHashCache[string] = hash; + createClass(ToSetSequence, SetSeq); + function ToSetSequence(iter) { + this._iter = iter; + this.size = iter.size; } - return hash; - } - // http://jsperf.com/hashing-strings - function hashString(string) { - // This is the hash from JVM - // The hash code for a string is computed as - // s[0] * 31 ^ (n - 1) + s[1] * 31 ^ (n - 2) + ... + s[n - 1], - // where s[i] is the ith character of the string and n is the length of - // the string. We "mod" the result to make it between 0 (inclusive) and 2^31 - // (exclusive) by dropping high bits. - var hash = 0; - for (var ii = 0; ii < string.length; ii++) { - hash = 31 * hash + string.charCodeAt(ii) | 0; - } - return smi(hash); - } + ToSetSequence.prototype.has = function(key) { + return this._iter.includes(key); + }; - function hashJSObj(obj) { - var hash; - if (usingWeakMap) { - hash = weakMap.get(obj); - if (hash !== undefined) { - return hash; - } - } + ToSetSequence.prototype.__iterate = function(fn, reverse) {var this$0 = this; + return this._iter.__iterate(function(v ) {return fn(v, v, this$0)}, reverse); + }; - hash = obj[UID_HASH_KEY]; - if (hash !== undefined) { - return hash; - } + ToSetSequence.prototype.__iterator = function(type, reverse) { + var iterator = this._iter.__iterator(ITERATE_VALUES, reverse); + return new Iterator(function() { + var step = iterator.next(); + return step.done ? step : + iteratorValue(type, step.value, step.value, step); + }); + }; - if (!canDefineProperty) { - hash = obj.propertyIsEnumerable && obj.propertyIsEnumerable[UID_HASH_KEY]; - if (hash !== undefined) { - return hash; - } - hash = getIENodeHash(obj); - if (hash !== undefined) { - return hash; - } - } - hash = ++objHashUID; - if (objHashUID & 0x40000000) { - objHashUID = 0; + createClass(FromEntriesSequence, KeyedSeq); + function FromEntriesSequence(entries) { + this._iter = entries; + this.size = entries.size; } - if (usingWeakMap) { - weakMap.set(obj, hash); - } else if (isExtensible !== undefined && isExtensible(obj) === false) { - throw new Error('Non-extensible objects are not allowed as keys.'); - } else if (canDefineProperty) { - Object.defineProperty(obj, UID_HASH_KEY, { - 'enumerable': false, - 'configurable': false, - 'writable': false, - 'value': hash + FromEntriesSequence.prototype.entrySeq = function() { + return this._iter.toSeq(); + }; + + FromEntriesSequence.prototype.__iterate = function(fn, reverse) {var this$0 = this; + return this._iter.__iterate(function(entry ) { + // Check if entry exists first so array access doesn't throw for holes + // in the parent iteration. + if (entry) { + validateEntry(entry); + var indexedIterable = isIterable(entry); + return fn( + indexedIterable ? entry.get(1) : entry[1], + indexedIterable ? entry.get(0) : entry[0], + this$0 + ); + } + }, reverse); + }; + + FromEntriesSequence.prototype.__iterator = function(type, reverse) { + var iterator = this._iter.__iterator(ITERATE_VALUES, reverse); + return new Iterator(function() { + while (true) { + var step = iterator.next(); + if (step.done) { + return step; + } + var entry = step.value; + // Check if entry exists first so array access doesn't throw for holes + // in the parent iteration. + if (entry) { + validateEntry(entry); + var indexedIterable = isIterable(entry); + return iteratorValue( + type, + indexedIterable ? entry.get(0) : entry[0], + indexedIterable ? entry.get(1) : entry[1], + step + ); + } + } }); - } else if (obj.propertyIsEnumerable !== undefined && - obj.propertyIsEnumerable === obj.constructor.prototype.propertyIsEnumerable) { - // Since we can't define a non-enumerable property on the object - // we'll hijack one of the less-used non-enumerable properties to - // save our hash on it. Since this is a function it will not show up in - // `JSON.stringify` which is what we want. - obj.propertyIsEnumerable = function() { - return this.constructor.prototype.propertyIsEnumerable.apply(this, arguments); - }; - obj.propertyIsEnumerable[UID_HASH_KEY] = hash; - } else if (obj.nodeType !== undefined) { - // At this point we couldn't get the IE `uniqueID` to use as a hash - // and we couldn't use a non-enumerable property to exploit the - // dontEnum bug so we simply add the `UID_HASH_KEY` on the node - // itself. - obj[UID_HASH_KEY] = hash; - } else { - throw new Error('Unable to set a non-enumerable property on object.'); - } + }; - return hash; - } - // Get references to ES5 object methods. - var isExtensible = Object.isExtensible; + ToIndexedSequence.prototype.cacheResult = + ToKeyedSequence.prototype.cacheResult = + ToSetSequence.prototype.cacheResult = + FromEntriesSequence.prototype.cacheResult = + cacheResultThrough; - // True if Object.defineProperty works as expected. IE8 fails this test. - var canDefineProperty = (function() { - try { - Object.defineProperty({}, '@', {}); - return true; - } catch (e) { - return false; - } - }()); - // IE has a `uniqueID` property on DOM nodes. We can construct the hash from it - // and avoid memory leaks from the IE cloneNode bug. - function getIENodeHash(node) { - if (node && node.nodeType > 0) { - switch (node.nodeType) { - case 1: // Element - return node.uniqueID; - case 9: // Document - return node.documentElement && node.documentElement.uniqueID; + function flipFactory(iterable) { + var flipSequence = makeSequence(iterable); + flipSequence._iter = iterable; + flipSequence.size = iterable.size; + flipSequence.flip = function() {return iterable}; + flipSequence.reverse = function () { + var reversedSequence = iterable.reverse.apply(this); // super.reverse() + reversedSequence.flip = function() {return iterable.reverse()}; + return reversedSequence; + }; + flipSequence.has = function(key ) {return iterable.includes(key)}; + flipSequence.includes = function(key ) {return iterable.has(key)}; + flipSequence.cacheResult = cacheResultThrough; + flipSequence.__iterateUncached = function (fn, reverse) {var this$0 = this; + return iterable.__iterate(function(v, k) {return fn(k, v, this$0) !== false}, reverse); + } + flipSequence.__iteratorUncached = function(type, reverse) { + if (type === ITERATE_ENTRIES) { + var iterator = iterable.__iterator(type, reverse); + return new Iterator(function() { + var step = iterator.next(); + if (!step.done) { + var k = step.value[0]; + step.value[0] = step.value[1]; + step.value[1] = k; + } + return step; + }); } + return iterable.__iterator( + type === ITERATE_VALUES ? ITERATE_KEYS : ITERATE_VALUES, + reverse + ); } + return flipSequence; } - // If possible, use a WeakMap. - var usingWeakMap = typeof WeakMap === 'function'; - var weakMap; - if (usingWeakMap) { - weakMap = new WeakMap(); - } - - var objHashUID = 0; - var UID_HASH_KEY = '__immutablehash__'; - if (typeof Symbol === 'function') { - UID_HASH_KEY = Symbol(UID_HASH_KEY); + function mapFactory(iterable, mapper, context) { + var mappedSequence = makeSequence(iterable); + mappedSequence.size = iterable.size; + mappedSequence.has = function(key ) {return iterable.has(key)}; + mappedSequence.get = function(key, notSetValue) { + var v = iterable.get(key, NOT_SET); + return v === NOT_SET ? + notSetValue : + mapper.call(context, v, key, iterable); + }; + mappedSequence.__iterateUncached = function (fn, reverse) {var this$0 = this; + return iterable.__iterate( + function(v, k, c) {return fn(mapper.call(context, v, k, c), k, this$0) !== false}, + reverse + ); + } + mappedSequence.__iteratorUncached = function (type, reverse) { + var iterator = iterable.__iterator(ITERATE_ENTRIES, reverse); + return new Iterator(function() { + var step = iterator.next(); + if (step.done) { + return step; + } + var entry = step.value; + var key = entry[0]; + return iteratorValue( + type, + key, + mapper.call(context, entry[1], key, iterable), + step + ); + }); + } + return mappedSequence; } - var STRING_HASH_CACHE_MIN_STRLEN = 16; - var STRING_HASH_CACHE_MAX_SIZE = 255; - var STRING_HASH_CACHE_SIZE = 0; - var stringHashCache = {}; - function assertNotInfinite(size) { - invariant( - size !== Infinity, - 'Cannot perform this action with an infinite size.' - ); + function reverseFactory(iterable, useKeys) { + var reversedSequence = makeSequence(iterable); + reversedSequence._iter = iterable; + reversedSequence.size = iterable.size; + reversedSequence.reverse = function() {return iterable}; + if (iterable.flip) { + reversedSequence.flip = function () { + var flipSequence = flipFactory(iterable); + flipSequence.reverse = function() {return iterable.flip()}; + return flipSequence; + }; + } + reversedSequence.get = function(key, notSetValue) + {return iterable.get(useKeys ? key : -1 - key, notSetValue)}; + reversedSequence.has = function(key ) + {return iterable.has(useKeys ? key : -1 - key)}; + reversedSequence.includes = function(value ) {return iterable.includes(value)}; + reversedSequence.cacheResult = cacheResultThrough; + reversedSequence.__iterate = function (fn, reverse) {var this$0 = this; + return iterable.__iterate(function(v, k) {return fn(v, k, this$0)}, !reverse); + }; + reversedSequence.__iterator = + function(type, reverse) {return iterable.__iterator(type, !reverse)}; + return reversedSequence; } - createClass(Map, KeyedCollection); - - // @pragma Construction - function Map(value) { - return value === null || value === undefined ? emptyMap() : - isMap(value) && !isOrdered(value) ? value : - emptyMap().withMutations(function(map ) { - var iter = KeyedIterable(value); - assertNotInfinite(iter.size); - iter.forEach(function(v, k) {return map.set(k, v)}); - }); + function filterFactory(iterable, predicate, context, useKeys) { + var filterSequence = makeSequence(iterable); + if (useKeys) { + filterSequence.has = function(key ) { + var v = iterable.get(key, NOT_SET); + return v !== NOT_SET && !!predicate.call(context, v, key, iterable); + }; + filterSequence.get = function(key, notSetValue) { + var v = iterable.get(key, NOT_SET); + return v !== NOT_SET && predicate.call(context, v, key, iterable) ? + v : notSetValue; + }; } - - Map.of = function() {var keyValues = SLICE$0.call(arguments, 0); - return emptyMap().withMutations(function(map ) { - for (var i = 0; i < keyValues.length; i += 2) { - if (i + 1 >= keyValues.length) { - throw new Error('Missing value for key: ' + keyValues[i]); + filterSequence.__iterateUncached = function (fn, reverse) {var this$0 = this; + var iterations = 0; + iterable.__iterate(function(v, k, c) { + if (predicate.call(context, v, k, c)) { + iterations++; + return fn(v, useKeys ? k : iterations - 1, this$0); + } + }, reverse); + return iterations; + }; + filterSequence.__iteratorUncached = function (type, reverse) { + var iterator = iterable.__iterator(ITERATE_ENTRIES, reverse); + var iterations = 0; + return new Iterator(function() { + while (true) { + var step = iterator.next(); + if (step.done) { + return step; + } + var entry = step.value; + var key = entry[0]; + var value = entry[1]; + if (predicate.call(context, value, key, iterable)) { + return iteratorValue(type, useKeys ? key : iterations++, value, step); } - map.set(keyValues[i], keyValues[i + 1]); } }); - }; - - Map.prototype.toString = function() { - return this.__toString('Map {', '}'); - }; - - // @pragma Access - - Map.prototype.get = function(k, notSetValue) { - return this._root ? - this._root.get(0, undefined, k, notSetValue) : - notSetValue; - }; + } + return filterSequence; + } - // @pragma Modification - Map.prototype.set = function(k, v) { - return updateMap(this, k, v); - }; + function countByFactory(iterable, grouper, context) { + var groups = Map().asMutable(); + iterable.__iterate(function(v, k) { + groups.update( + grouper.call(context, v, k, iterable), + 0, + function(a ) {return a + 1} + ); + }); + return groups.asImmutable(); + } - Map.prototype.setIn = function(keyPath, v) { - return this.updateIn(keyPath, NOT_SET, function() {return v}); - }; - Map.prototype.remove = function(k) { - return updateMap(this, k, NOT_SET); - }; + function groupByFactory(iterable, grouper, context) { + var isKeyedIter = isKeyed(iterable); + var groups = (isOrdered(iterable) ? OrderedMap() : Map()).asMutable(); + iterable.__iterate(function(v, k) { + groups.update( + grouper.call(context, v, k, iterable), + function(a ) {return (a = a || [], a.push(isKeyedIter ? [k, v] : v), a)} + ); + }); + var coerce = iterableClass(iterable); + return groups.map(function(arr ) {return reify(iterable, coerce(arr))}); + } - Map.prototype.deleteIn = function(keyPath) { - return this.updateIn(keyPath, function() {return NOT_SET}); - }; - Map.prototype.update = function(k, notSetValue, updater) { - return arguments.length === 1 ? - k(this) : - this.updateIn([k], notSetValue, updater); - }; + function sliceFactory(iterable, begin, end, useKeys) { + var originalSize = iterable.size; - Map.prototype.updateIn = function(keyPath, notSetValue, updater) { - if (!updater) { - updater = notSetValue; - notSetValue = undefined; + // Sanitize begin & end using this shorthand for ToInt32(argument) + // http://www.ecma-international.org/ecma-262/6.0/#sec-toint32 + if (begin !== undefined) { + begin = begin | 0; + } + if (end !== undefined) { + if (end === Infinity) { + end = originalSize; + } else { + end = end | 0; } - var updatedValue = updateInDeepMap( - this, - forceIterator(keyPath), - notSetValue, - updater - ); - return updatedValue === NOT_SET ? undefined : updatedValue; - }; + } - Map.prototype.clear = function() { - if (this.size === 0) { - return this; - } - if (this.__ownerID) { - this.size = 0; - this._root = null; - this.__hash = undefined; - this.__altered = true; - return this; - } - return emptyMap(); - }; + if (wholeSlice(begin, end, originalSize)) { + return iterable; + } - // @pragma Composition + var resolvedBegin = resolveBegin(begin, originalSize); + var resolvedEnd = resolveEnd(end, originalSize); - Map.prototype.merge = function(/*...iters*/) { - return mergeIntoMapWith(this, undefined, arguments); - }; - - Map.prototype.mergeWith = function(merger) {var iters = SLICE$0.call(arguments, 1); - return mergeIntoMapWith(this, merger, iters); - }; - - Map.prototype.mergeIn = function(keyPath) {var iters = SLICE$0.call(arguments, 1); - return this.updateIn( - keyPath, - emptyMap(), - function(m ) {return typeof m.merge === 'function' ? - m.merge.apply(m, iters) : - iters[iters.length - 1]} - ); - }; + // begin or end will be NaN if they were provided as negative numbers and + // this iterable's size is unknown. In that case, cache first so there is + // a known size and these do not resolve to NaN. + if (resolvedBegin !== resolvedBegin || resolvedEnd !== resolvedEnd) { + return sliceFactory(iterable.toSeq().cacheResult(), begin, end, useKeys); + } - Map.prototype.mergeDeep = function(/*...iters*/) { - return mergeIntoMapWith(this, deepMerger, arguments); - }; + // Note: resolvedEnd is undefined when the original sequence's length is + // unknown and this slice did not supply an end and should contain all + // elements after resolvedBegin. + // In that case, resolvedSize will be NaN and sliceSize will remain undefined. + var resolvedSize = resolvedEnd - resolvedBegin; + var sliceSize; + if (resolvedSize === resolvedSize) { + sliceSize = resolvedSize < 0 ? 0 : resolvedSize; + } - Map.prototype.mergeDeepWith = function(merger) {var iters = SLICE$0.call(arguments, 1); - return mergeIntoMapWith(this, deepMergerWith(merger), iters); - }; + var sliceSeq = makeSequence(iterable); - Map.prototype.mergeDeepIn = function(keyPath) {var iters = SLICE$0.call(arguments, 1); - return this.updateIn( - keyPath, - emptyMap(), - function(m ) {return typeof m.mergeDeep === 'function' ? - m.mergeDeep.apply(m, iters) : - iters[iters.length - 1]} - ); - }; + // If iterable.size is undefined, the size of the realized sliceSeq is + // unknown at this point unless the number of items to slice is 0 + sliceSeq.size = sliceSize === 0 ? sliceSize : iterable.size && sliceSize || undefined; - Map.prototype.sort = function(comparator) { - // Late binding - return OrderedMap(sortFactory(this, comparator)); - }; + if (!useKeys && isSeq(iterable) && sliceSize >= 0) { + sliceSeq.get = function (index, notSetValue) { + index = wrapIndex(this, index); + return index >= 0 && index < sliceSize ? + iterable.get(index + resolvedBegin, notSetValue) : + notSetValue; + } + } - Map.prototype.sortBy = function(mapper, comparator) { - // Late binding - return OrderedMap(sortFactory(this, comparator, mapper)); + sliceSeq.__iterateUncached = function(fn, reverse) {var this$0 = this; + if (sliceSize === 0) { + return 0; + } + if (reverse) { + return this.cacheResult().__iterate(fn, reverse); + } + var skipped = 0; + var isSkipping = true; + var iterations = 0; + iterable.__iterate(function(v, k) { + if (!(isSkipping && (isSkipping = skipped++ < resolvedBegin))) { + iterations++; + return fn(v, useKeys ? k : iterations - 1, this$0) !== false && + iterations !== sliceSize; + } + }); + return iterations; }; - // @pragma Mutability + sliceSeq.__iteratorUncached = function(type, reverse) { + if (sliceSize !== 0 && reverse) { + return this.cacheResult().__iterator(type, reverse); + } + // Don't bother instantiating parent iterator if taking 0. + var iterator = sliceSize !== 0 && iterable.__iterator(type, reverse); + var skipped = 0; + var iterations = 0; + return new Iterator(function() { + while (skipped++ < resolvedBegin) { + iterator.next(); + } + if (++iterations > sliceSize) { + return iteratorDone(); + } + var step = iterator.next(); + if (useKeys || type === ITERATE_VALUES) { + return step; + } else if (type === ITERATE_KEYS) { + return iteratorValue(type, iterations - 1, undefined, step); + } else { + return iteratorValue(type, iterations - 1, step.value[1], step); + } + }); + } - Map.prototype.withMutations = function(fn) { - var mutable = this.asMutable(); - fn(mutable); - return mutable.wasAltered() ? mutable.__ensureOwner(this.__ownerID) : this; - }; + return sliceSeq; + } - Map.prototype.asMutable = function() { - return this.__ownerID ? this : this.__ensureOwner(new OwnerID()); - }; - Map.prototype.asImmutable = function() { - return this.__ensureOwner(); + function takeWhileFactory(iterable, predicate, context) { + var takeSequence = makeSequence(iterable); + takeSequence.__iterateUncached = function(fn, reverse) {var this$0 = this; + if (reverse) { + return this.cacheResult().__iterate(fn, reverse); + } + var iterations = 0; + iterable.__iterate(function(v, k, c) + {return predicate.call(context, v, k, c) && ++iterations && fn(v, k, this$0)} + ); + return iterations; }; - - Map.prototype.wasAltered = function() { - return this.__altered; + takeSequence.__iteratorUncached = function(type, reverse) {var this$0 = this; + if (reverse) { + return this.cacheResult().__iterator(type, reverse); + } + var iterator = iterable.__iterator(ITERATE_ENTRIES, reverse); + var iterating = true; + return new Iterator(function() { + if (!iterating) { + return iteratorDone(); + } + var step = iterator.next(); + if (step.done) { + return step; + } + var entry = step.value; + var k = entry[0]; + var v = entry[1]; + if (!predicate.call(context, v, k, this$0)) { + iterating = false; + return iteratorDone(); + } + return type === ITERATE_ENTRIES ? step : + iteratorValue(type, k, v, step); + }); }; + return takeSequence; + } - Map.prototype.__iterator = function(type, reverse) { - return new MapIterator(this, type, reverse); - }; - Map.prototype.__iterate = function(fn, reverse) {var this$0 = this; + function skipWhileFactory(iterable, predicate, context, useKeys) { + var skipSequence = makeSequence(iterable); + skipSequence.__iterateUncached = function (fn, reverse) {var this$0 = this; + if (reverse) { + return this.cacheResult().__iterate(fn, reverse); + } + var isSkipping = true; var iterations = 0; - this._root && this._root.iterate(function(entry ) { - iterations++; - return fn(entry[1], entry[0], this$0); - }, reverse); + iterable.__iterate(function(v, k, c) { + if (!(isSkipping && (isSkipping = predicate.call(context, v, k, c)))) { + iterations++; + return fn(v, useKeys ? k : iterations - 1, this$0); + } + }); return iterations; }; - - Map.prototype.__ensureOwner = function(ownerID) { - if (ownerID === this.__ownerID) { - return this; - } - if (!ownerID) { - this.__ownerID = ownerID; - this.__altered = false; - return this; + skipSequence.__iteratorUncached = function(type, reverse) {var this$0 = this; + if (reverse) { + return this.cacheResult().__iterator(type, reverse); } - return makeMap(this.size, this._root, ownerID, this.__hash); + var iterator = iterable.__iterator(ITERATE_ENTRIES, reverse); + var skipping = true; + var iterations = 0; + return new Iterator(function() { + var step, k, v; + do { + step = iterator.next(); + if (step.done) { + if (useKeys || type === ITERATE_VALUES) { + return step; + } else if (type === ITERATE_KEYS) { + return iteratorValue(type, iterations++, undefined, step); + } else { + return iteratorValue(type, iterations++, step.value[1], step); + } + } + var entry = step.value; + k = entry[0]; + v = entry[1]; + skipping && (skipping = predicate.call(context, v, k, this$0)); + } while (skipping); + return type === ITERATE_ENTRIES ? step : + iteratorValue(type, k, v, step); + }); }; + return skipSequence; + } - function isMap(maybeMap) { - return !!(maybeMap && maybeMap[IS_MAP_SENTINEL]); - } + function concatFactory(iterable, values) { + var isKeyedIterable = isKeyed(iterable); + var iters = [iterable].concat(values).map(function(v ) { + if (!isIterable(v)) { + v = isKeyedIterable ? + keyedSeqFromValue(v) : + indexedSeqFromValue(Array.isArray(v) ? v : [v]); + } else if (isKeyedIterable) { + v = KeyedIterable(v); + } + return v; + }).filter(function(v ) {return v.size !== 0}); - Map.isMap = isMap; + if (iters.length === 0) { + return iterable; + } - var IS_MAP_SENTINEL = '@@__IMMUTABLE_MAP__@@'; + if (iters.length === 1) { + var singleton = iters[0]; + if (singleton === iterable || + isKeyedIterable && isKeyed(singleton) || + isIndexed(iterable) && isIndexed(singleton)) { + return singleton; + } + } - var MapPrototype = Map.prototype; - MapPrototype[IS_MAP_SENTINEL] = true; - MapPrototype[DELETE] = MapPrototype.remove; - MapPrototype.removeIn = MapPrototype.deleteIn; + var concatSeq = new ArraySeq(iters); + if (isKeyedIterable) { + concatSeq = concatSeq.toKeyedSeq(); + } else if (!isIndexed(iterable)) { + concatSeq = concatSeq.toSetSeq(); + } + concatSeq = concatSeq.flatten(true); + concatSeq.size = iters.reduce( + function(sum, seq) { + if (sum !== undefined) { + var size = seq.size; + if (size !== undefined) { + return sum + size; + } + } + }, + 0 + ); + return concatSeq; + } - // #pragma Trie Nodes + function flattenFactory(iterable, depth, useKeys) { + var flatSequence = makeSequence(iterable); + flatSequence.__iterateUncached = function(fn, reverse) { + var iterations = 0; + var stopped = false; + function flatDeep(iter, currentDepth) {var this$0 = this; + iter.__iterate(function(v, k) { + if ((!depth || currentDepth < depth) && isIterable(v)) { + flatDeep(v, currentDepth + 1); + } else if (fn(v, useKeys ? k : iterations++, this$0) === false) { + stopped = true; + } + return !stopped; + }, reverse); + } + flatDeep(iterable, 0); + return iterations; + } + flatSequence.__iteratorUncached = function(type, reverse) { + var iterator = iterable.__iterator(type, reverse); + var stack = []; + var iterations = 0; + return new Iterator(function() { + while (iterator) { + var step = iterator.next(); + if (step.done !== false) { + iterator = stack.pop(); + continue; + } + var v = step.value; + if (type === ITERATE_ENTRIES) { + v = v[1]; + } + if ((!depth || stack.length < depth) && isIterable(v)) { + stack.push(iterator); + iterator = v.__iterator(type, reverse); + } else { + return useKeys ? step : iteratorValue(type, iterations++, v, step); + } + } + return iteratorDone(); + }); + } + return flatSequence; + } + function flatMapFactory(iterable, mapper, context) { + var coerce = iterableClass(iterable); + return iterable.toSeq().map( + function(v, k) {return coerce(mapper.call(context, v, k, iterable))} + ).flatten(true); + } - function ArrayMapNode(ownerID, entries) { - this.ownerID = ownerID; - this.entries = entries; - } - ArrayMapNode.prototype.get = function(shift, keyHash, key, notSetValue) { - var entries = this.entries; - for (var ii = 0, len = entries.length; ii < len; ii++) { - if (is(key, entries[ii][0])) { - return entries[ii][1]; + function interposeFactory(iterable, separator) { + var interposedSequence = makeSequence(iterable); + interposedSequence.size = iterable.size && iterable.size * 2 -1; + interposedSequence.__iterateUncached = function(fn, reverse) {var this$0 = this; + var iterations = 0; + iterable.__iterate(function(v, k) + {return (!iterations || fn(separator, iterations++, this$0) !== false) && + fn(v, iterations++, this$0) !== false}, + reverse + ); + return iterations; + }; + interposedSequence.__iteratorUncached = function(type, reverse) { + var iterator = iterable.__iterator(ITERATE_VALUES, reverse); + var iterations = 0; + var step; + return new Iterator(function() { + if (!step || iterations % 2) { + step = iterator.next(); + if (step.done) { + return step; + } } - } - return notSetValue; + return iterations % 2 ? + iteratorValue(type, iterations++, separator) : + iteratorValue(type, iterations++, step.value, step); + }); }; + return interposedSequence; + } - ArrayMapNode.prototype.update = function(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) { - var removed = value === NOT_SET; - - var entries = this.entries; - var idx = 0; - for (var len = entries.length; idx < len; idx++) { - if (is(key, entries[idx][0])) { - break; - } - } - var exists = idx < len; - if (exists ? entries[idx][1] === value : removed) { - return this; - } + function sortFactory(iterable, comparator, mapper) { + if (!comparator) { + comparator = defaultComparator; + } + var isKeyedIterable = isKeyed(iterable); + var index = 0; + var entries = iterable.toSeq().map( + function(v, k) {return [k, v, index++, mapper ? mapper(v, k, iterable) : v]} + ).toArray(); + entries.sort(function(a, b) {return comparator(a[3], b[3]) || a[2] - b[2]}).forEach( + isKeyedIterable ? + function(v, i) { entries[i].length = 2; } : + function(v, i) { entries[i] = v[1]; } + ); + return isKeyedIterable ? KeyedSeq(entries) : + isIndexed(iterable) ? IndexedSeq(entries) : + SetSeq(entries); + } - SetRef(didAlter); - (removed || !exists) && SetRef(didChangeSize); - if (removed && entries.length === 1) { - return; // undefined - } + function maxFactory(iterable, comparator, mapper) { + if (!comparator) { + comparator = defaultComparator; + } + if (mapper) { + var entry = iterable.toSeq() + .map(function(v, k) {return [v, mapper(v, k, iterable)]}) + .reduce(function(a, b) {return maxCompare(comparator, a[1], b[1]) ? b : a}); + return entry && entry[0]; + } else { + return iterable.reduce(function(a, b) {return maxCompare(comparator, a, b) ? b : a}); + } + } - if (!exists && !removed && entries.length >= MAX_ARRAY_MAP_SIZE) { - return createNodes(ownerID, entries, key, value); - } + function maxCompare(comparator, a, b) { + var comp = comparator(b, a); + // b is considered the new max if the comparator declares them equal, but + // they are not equal and b is in fact a nullish value. + return (comp === 0 && b !== a && (b === undefined || b === null || b !== b)) || comp > 0; + } - var isEditable = ownerID && ownerID === this.ownerID; - var newEntries = isEditable ? entries : arrCopy(entries); - if (exists) { - if (removed) { - idx === len - 1 ? newEntries.pop() : (newEntries[idx] = newEntries.pop()); - } else { - newEntries[idx] = [key, value]; + function zipWithFactory(keyIter, zipper, iters) { + var zipSequence = makeSequence(keyIter); + zipSequence.size = new ArraySeq(iters).map(function(i ) {return i.size}).min(); + // Note: this a generic base implementation of __iterate in terms of + // __iterator which may be more generically useful in the future. + zipSequence.__iterate = function(fn, reverse) { + /* generic: + var iterator = this.__iterator(ITERATE_ENTRIES, reverse); + var step; + var iterations = 0; + while (!(step = iterator.next()).done) { + iterations++; + if (fn(step.value[1], step.value[0], this) === false) { + break; } - } else { - newEntries.push([key, value]); } - - if (isEditable) { - this.entries = newEntries; - return this; + return iterations; + */ + // indexed: + var iterator = this.__iterator(ITERATE_VALUES, reverse); + var step; + var iterations = 0; + while (!(step = iterator.next()).done) { + if (fn(step.value, iterations++, this) === false) { + break; + } } - - return new ArrayMapNode(ownerID, newEntries); + return iterations; + }; + zipSequence.__iteratorUncached = function(type, reverse) { + var iterators = iters.map(function(i ) + {return (i = Iterable(i), getIterator(reverse ? i.reverse() : i))} + ); + var iterations = 0; + var isDone = false; + return new Iterator(function() { + var steps; + if (!isDone) { + steps = iterators.map(function(i ) {return i.next()}); + isDone = steps.some(function(s ) {return s.done}); + } + if (isDone) { + return iteratorDone(); + } + return iteratorValue( + type, + iterations++, + zipper.apply(null, steps.map(function(s ) {return s.value})) + ); + }); }; + return zipSequence + } + // #pragma Helper Functions + function reify(iter, seq) { + return isSeq(iter) ? seq : iter.constructor(seq); + } - function BitmapIndexedNode(ownerID, bitmap, nodes) { - this.ownerID = ownerID; - this.bitmap = bitmap; - this.nodes = nodes; + function validateEntry(entry) { + if (entry !== Object(entry)) { + throw new TypeError('Expected [K, V] tuple: ' + entry); } + } - BitmapIndexedNode.prototype.get = function(shift, keyHash, key, notSetValue) { - if (keyHash === undefined) { - keyHash = hash(key); - } - var bit = (1 << ((shift === 0 ? keyHash : keyHash >>> shift) & MASK)); - var bitmap = this.bitmap; - return (bitmap & bit) === 0 ? notSetValue : - this.nodes[popCount(bitmap & (bit - 1))].get(shift + SHIFT, keyHash, key, notSetValue); - }; + function resolveSize(iter) { + assertNotInfinite(iter.size); + return ensureSize(iter); + } - BitmapIndexedNode.prototype.update = function(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) { - if (keyHash === undefined) { - keyHash = hash(key); - } - var keyHashFrag = (shift === 0 ? keyHash : keyHash >>> shift) & MASK; - var bit = 1 << keyHashFrag; - var bitmap = this.bitmap; - var exists = (bitmap & bit) !== 0; + function iterableClass(iterable) { + return isKeyed(iterable) ? KeyedIterable : + isIndexed(iterable) ? IndexedIterable : + SetIterable; + } - if (!exists && value === NOT_SET) { - return this; - } + function makeSequence(iterable) { + return Object.create( + ( + isKeyed(iterable) ? KeyedSeq : + isIndexed(iterable) ? IndexedSeq : + SetSeq + ).prototype + ); + } - var idx = popCount(bitmap & (bit - 1)); - var nodes = this.nodes; - var node = exists ? nodes[idx] : undefined; - var newNode = updateNode(node, ownerID, shift + SHIFT, keyHash, key, value, didChangeSize, didAlter); + function cacheResultThrough() { + if (this._iter.cacheResult) { + this._iter.cacheResult(); + this.size = this._iter.size; + return this; + } else { + return Seq.prototype.cacheResult.call(this); + } + } - if (newNode === node) { - return this; - } + function defaultComparator(a, b) { + return a > b ? 1 : a < b ? -1 : 0; + } - if (!exists && newNode && nodes.length >= MAX_BITMAP_INDEXED_SIZE) { - return expandNodes(ownerID, nodes, bitmap, keyHashFrag, newNode); + function forceIterator(keyPath) { + var iter = getIterator(keyPath); + if (!iter) { + // Array might not be iterable in this environment, so we need a fallback + // to our wrapped type. + if (!isArrayLike(keyPath)) { + throw new TypeError('Expected iterable or array-like: ' + keyPath); } + iter = getIterator(Iterable(keyPath)); + } + return iter; + } - if (exists && !newNode && nodes.length === 2 && isLeafNode(nodes[idx ^ 1])) { - return nodes[idx ^ 1]; - } + createClass(Record, KeyedCollection); - if (exists && newNode && nodes.length === 1 && isLeafNode(newNode)) { - return newNode; - } + function Record(defaultValues, name) { + var hasInitialized; - var isEditable = ownerID && ownerID === this.ownerID; - var newBitmap = exists ? newNode ? bitmap : bitmap ^ bit : bitmap | bit; - var newNodes = exists ? newNode ? - setIn(nodes, idx, newNode, isEditable) : - spliceOut(nodes, idx, isEditable) : - spliceIn(nodes, idx, newNode, isEditable); + var RecordType = function Record(values) { + if (values instanceof RecordType) { + return values; + } + if (!(this instanceof RecordType)) { + return new RecordType(values); + } + if (!hasInitialized) { + hasInitialized = true; + var keys = Object.keys(defaultValues); + setProps(RecordTypePrototype, keys); + RecordTypePrototype.size = keys.length; + RecordTypePrototype._name = name; + RecordTypePrototype._keys = keys; + RecordTypePrototype._defaultValues = defaultValues; + } + this._map = Map(values); + }; - if (isEditable) { - this.bitmap = newBitmap; - this.nodes = newNodes; - return this; - } + var RecordTypePrototype = RecordType.prototype = Object.create(RecordPrototype); + RecordTypePrototype.constructor = RecordType; - return new BitmapIndexedNode(ownerID, newBitmap, newNodes); + return RecordType; + } + + Record.prototype.toString = function() { + return this.__toString(recordName(this) + ' {', '}'); }; + // @pragma Access + Record.prototype.has = function(k) { + return this._defaultValues.hasOwnProperty(k); + }; + Record.prototype.get = function(k, notSetValue) { + if (!this.has(k)) { + return notSetValue; + } + var defaultVal = this._defaultValues[k]; + return this._map ? this._map.get(k, defaultVal) : defaultVal; + }; - function HashArrayMapNode(ownerID, count, nodes) { - this.ownerID = ownerID; - this.count = count; - this.nodes = nodes; - } + // @pragma Modification - HashArrayMapNode.prototype.get = function(shift, keyHash, key, notSetValue) { - if (keyHash === undefined) { - keyHash = hash(key); + Record.prototype.clear = function() { + if (this.__ownerID) { + this._map && this._map.clear(); + return this; } - var idx = (shift === 0 ? keyHash : keyHash >>> shift) & MASK; - var node = this.nodes[idx]; - return node ? node.get(shift + SHIFT, keyHash, key, notSetValue) : notSetValue; + var RecordType = this.constructor; + return RecordType._empty || (RecordType._empty = makeRecord(this, emptyMap())); }; - HashArrayMapNode.prototype.update = function(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) { - if (keyHash === undefined) { - keyHash = hash(key); + Record.prototype.set = function(k, v) { + if (!this.has(k)) { + throw new Error('Cannot set unknown key "' + k + '" on ' + recordName(this)); } - var idx = (shift === 0 ? keyHash : keyHash >>> shift) & MASK; - var removed = value === NOT_SET; - var nodes = this.nodes; - var node = nodes[idx]; - - if (removed && !node) { + if (this._map && !this._map.has(k)) { + var defaultVal = this._defaultValues[k]; + if (v === defaultVal) { + return this; + } + } + var newMap = this._map && this._map.set(k, v); + if (this.__ownerID || newMap === this._map) { return this; } + return makeRecord(this, newMap); + }; - var newNode = updateNode(node, ownerID, shift + SHIFT, keyHash, key, value, didChangeSize, didAlter); - if (newNode === node) { + Record.prototype.remove = function(k) { + if (!this.has(k)) { return this; } - - var newCount = this.count; - if (!node) { - newCount++; - } else if (!newNode) { - newCount--; - if (newCount < MIN_HASH_ARRAY_MAP_SIZE) { - return packNodes(ownerID, nodes, newCount, idx); - } + var newMap = this._map && this._map.remove(k); + if (this.__ownerID || newMap === this._map) { + return this; } + return makeRecord(this, newMap); + }; - var isEditable = ownerID && ownerID === this.ownerID; - var newNodes = setIn(nodes, idx, newNode, isEditable); + Record.prototype.wasAltered = function() { + return this._map.wasAltered(); + }; - if (isEditable) { - this.count = newCount; - this.nodes = newNodes; + Record.prototype.__iterator = function(type, reverse) {var this$0 = this; + return KeyedIterable(this._defaultValues).map(function(_, k) {return this$0.get(k)}).__iterator(type, reverse); + }; + + Record.prototype.__iterate = function(fn, reverse) {var this$0 = this; + return KeyedIterable(this._defaultValues).map(function(_, k) {return this$0.get(k)}).__iterate(fn, reverse); + }; + + Record.prototype.__ensureOwner = function(ownerID) { + if (ownerID === this.__ownerID) { return this; } - - return new HashArrayMapNode(ownerID, newCount, newNodes); + var newMap = this._map && this._map.__ensureOwner(ownerID); + if (!ownerID) { + this.__ownerID = ownerID; + this._map = newMap; + return this; + } + return makeRecord(this, newMap, ownerID); }; + var RecordPrototype = Record.prototype; + RecordPrototype[DELETE] = RecordPrototype.remove; + RecordPrototype.deleteIn = + RecordPrototype.removeIn = MapPrototype.removeIn; + RecordPrototype.merge = MapPrototype.merge; + RecordPrototype.mergeWith = MapPrototype.mergeWith; + RecordPrototype.mergeIn = MapPrototype.mergeIn; + RecordPrototype.mergeDeep = MapPrototype.mergeDeep; + RecordPrototype.mergeDeepWith = MapPrototype.mergeDeepWith; + RecordPrototype.mergeDeepIn = MapPrototype.mergeDeepIn; + RecordPrototype.setIn = MapPrototype.setIn; + RecordPrototype.update = MapPrototype.update; + RecordPrototype.updateIn = MapPrototype.updateIn; + RecordPrototype.withMutations = MapPrototype.withMutations; + RecordPrototype.asMutable = MapPrototype.asMutable; + RecordPrototype.asImmutable = MapPrototype.asImmutable; - function HashCollisionNode(ownerID, keyHash, entries) { - this.ownerID = ownerID; - this.keyHash = keyHash; - this.entries = entries; + function makeRecord(likeRecord, map, ownerID) { + var record = Object.create(Object.getPrototypeOf(likeRecord)); + record._map = map; + record.__ownerID = ownerID; + return record; + } + + function recordName(record) { + return record._name || record.constructor.name || 'Record'; + } + + function setProps(prototype, names) { + try { + names.forEach(setProp.bind(undefined, prototype)); + } catch (error) { + // Object.defineProperty failed. Probably IE8. } + } - HashCollisionNode.prototype.get = function(shift, keyHash, key, notSetValue) { - var entries = this.entries; - for (var ii = 0, len = entries.length; ii < len; ii++) { - if (is(key, entries[ii][0])) { - return entries[ii][1]; - } + function setProp(prototype, name) { + Object.defineProperty(prototype, name, { + get: function() { + return this.get(name); + }, + set: function(value) { + invariant(this.__ownerID, 'Cannot set on an immutable record.'); + this.set(name, value); } - return notSetValue; + }); + } + + createClass(Set, SetCollection); + + // @pragma Construction + + function Set(value) { + return value === null || value === undefined ? emptySet() : + isSet(value) && !isOrdered(value) ? value : + emptySet().withMutations(function(set ) { + var iter = SetIterable(value); + assertNotInfinite(iter.size); + iter.forEach(function(v ) {return set.add(v)}); + }); + } + + Set.of = function(/*...values*/) { + return this(arguments); }; - HashCollisionNode.prototype.update = function(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) { - if (keyHash === undefined) { - keyHash = hash(key); - } + Set.fromKeys = function(value) { + return this(KeyedIterable(value).keySeq()); + }; - var removed = value === NOT_SET; + Set.prototype.toString = function() { + return this.__toString('Set {', '}'); + }; - if (keyHash !== this.keyHash) { - if (removed) { - return this; - } - SetRef(didAlter); - SetRef(didChangeSize); - return mergeIntoNode(this, ownerID, shift, keyHash, [key, value]); - } + // @pragma Access - var entries = this.entries; - var idx = 0; - for (var len = entries.length; idx < len; idx++) { - if (is(key, entries[idx][0])) { - break; - } - } - var exists = idx < len; + Set.prototype.has = function(value) { + return this._map.has(value); + }; - if (exists ? entries[idx][1] === value : removed) { - return this; - } + // @pragma Modification - SetRef(didAlter); - (removed || !exists) && SetRef(didChangeSize); + Set.prototype.add = function(value) { + return updateSet(this, this._map.set(value, true)); + }; - if (removed && len === 2) { - return new ValueNode(ownerID, this.keyHash, entries[idx ^ 1]); - } + Set.prototype.remove = function(value) { + return updateSet(this, this._map.remove(value)); + }; - var isEditable = ownerID && ownerID === this.ownerID; - var newEntries = isEditable ? entries : arrCopy(entries); + Set.prototype.clear = function() { + return updateSet(this, this._map.clear()); + }; - if (exists) { - if (removed) { - idx === len - 1 ? newEntries.pop() : (newEntries[idx] = newEntries.pop()); - } else { - newEntries[idx] = [key, value]; + // @pragma Composition + + Set.prototype.union = function() {var iters = SLICE$0.call(arguments, 0); + iters = iters.filter(function(x ) {return x.size !== 0}); + if (iters.length === 0) { + return this; + } + if (this.size === 0 && !this.__ownerID && iters.length === 1) { + return this.constructor(iters[0]); + } + return this.withMutations(function(set ) { + for (var ii = 0; ii < iters.length; ii++) { + SetIterable(iters[ii]).forEach(function(value ) {return set.add(value)}); } - } else { - newEntries.push([key, value]); + }); + }; + + Set.prototype.intersect = function() {var iters = SLICE$0.call(arguments, 0); + if (iters.length === 0) { + return this; } + iters = iters.map(function(iter ) {return SetIterable(iter)}); + var originalSet = this; + return this.withMutations(function(set ) { + originalSet.forEach(function(value ) { + if (!iters.every(function(iter ) {return iter.includes(value)})) { + set.remove(value); + } + }); + }); + }; - if (isEditable) { - this.entries = newEntries; + Set.prototype.subtract = function() {var iters = SLICE$0.call(arguments, 0); + if (iters.length === 0) { return this; } + iters = iters.map(function(iter ) {return SetIterable(iter)}); + var originalSet = this; + return this.withMutations(function(set ) { + originalSet.forEach(function(value ) { + if (iters.some(function(iter ) {return iter.includes(value)})) { + set.remove(value); + } + }); + }); + }; - return new HashCollisionNode(ownerID, this.keyHash, newEntries); + Set.prototype.merge = function() { + return this.union.apply(this, arguments); + }; + + Set.prototype.mergeWith = function(merger) {var iters = SLICE$0.call(arguments, 1); + return this.union.apply(this, iters); }; + Set.prototype.sort = function(comparator) { + // Late binding + return OrderedSet(sortFactory(this, comparator)); + }; + Set.prototype.sortBy = function(mapper, comparator) { + // Late binding + return OrderedSet(sortFactory(this, comparator, mapper)); + }; + Set.prototype.wasAltered = function() { + return this._map.wasAltered(); + }; - function ValueNode(ownerID, keyHash, entry) { - this.ownerID = ownerID; - this.keyHash = keyHash; - this.entry = entry; - } + Set.prototype.__iterate = function(fn, reverse) {var this$0 = this; + return this._map.__iterate(function(_, k) {return fn(k, k, this$0)}, reverse); + }; - ValueNode.prototype.get = function(shift, keyHash, key, notSetValue) { - return is(key, this.entry[0]) ? this.entry[1] : notSetValue; + Set.prototype.__iterator = function(type, reverse) { + return this._map.map(function(_, k) {return k}).__iterator(type, reverse); }; - ValueNode.prototype.update = function(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) { - var removed = value === NOT_SET; - var keyMatch = is(key, this.entry[0]); - if (keyMatch ? value === this.entry[1] : removed) { + Set.prototype.__ensureOwner = function(ownerID) { + if (ownerID === this.__ownerID) { return this; } - - SetRef(didAlter); - - if (removed) { - SetRef(didChangeSize); - return; // undefined + var newMap = this._map.__ensureOwner(ownerID); + if (!ownerID) { + this.__ownerID = ownerID; + this._map = newMap; + return this; } + return this.__make(newMap, ownerID); + }; - if (keyMatch) { - if (ownerID && ownerID === this.ownerID) { - this.entry[1] = value; - return this; - } - return new ValueNode(ownerID, this.keyHash, [key, value]); - } - SetRef(didChangeSize); - return mergeIntoNode(this, ownerID, shift, hash(key), [key, value]); - }; + function isSet(maybeSet) { + return !!(maybeSet && maybeSet[IS_SET_SENTINEL]); + } + Set.isSet = isSet; + var IS_SET_SENTINEL = '@@__IMMUTABLE_SET__@@'; - // #pragma Iterators + var SetPrototype = Set.prototype; + SetPrototype[IS_SET_SENTINEL] = true; + SetPrototype[DELETE] = SetPrototype.remove; + SetPrototype.mergeDeep = SetPrototype.merge; + SetPrototype.mergeDeepWith = SetPrototype.mergeWith; + SetPrototype.withMutations = MapPrototype.withMutations; + SetPrototype.asMutable = MapPrototype.asMutable; + SetPrototype.asImmutable = MapPrototype.asImmutable; - ArrayMapNode.prototype.iterate = - HashCollisionNode.prototype.iterate = function (fn, reverse) { - var entries = this.entries; - for (var ii = 0, maxIndex = entries.length - 1; ii <= maxIndex; ii++) { - if (fn(entries[reverse ? maxIndex - ii : ii]) === false) { - return false; - } + SetPrototype.__empty = emptySet; + SetPrototype.__make = makeSet; + + function updateSet(set, newMap) { + if (set.__ownerID) { + set.size = newMap.size; + set._map = newMap; + return set; } + return newMap === set._map ? set : + newMap.size === 0 ? set.__empty() : + set.__make(newMap); } - BitmapIndexedNode.prototype.iterate = - HashArrayMapNode.prototype.iterate = function (fn, reverse) { - var nodes = this.nodes; - for (var ii = 0, maxIndex = nodes.length - 1; ii <= maxIndex; ii++) { - var node = nodes[reverse ? maxIndex - ii : ii]; - if (node && node.iterate(fn, reverse) === false) { - return false; - } - } + function makeSet(map, ownerID) { + var set = Object.create(SetPrototype); + set.size = map ? map.size : 0; + set._map = map; + set.__ownerID = ownerID; + return set; } - ValueNode.prototype.iterate = function (fn, reverse) { - return fn(this.entry); + var EMPTY_SET; + function emptySet() { + return EMPTY_SET || (EMPTY_SET = makeSet(emptyMap())); } - createClass(MapIterator, Iterator); + createClass(OrderedSet, Set); - function MapIterator(map, type, reverse) { - this._type = type; - this._reverse = reverse; - this._stack = map._root && mapIteratorFrame(map._root); + // @pragma Construction + + function OrderedSet(value) { + return value === null || value === undefined ? emptyOrderedSet() : + isOrderedSet(value) ? value : + emptyOrderedSet().withMutations(function(set ) { + var iter = SetIterable(value); + assertNotInfinite(iter.size); + iter.forEach(function(v ) {return set.add(v)}); + }); } - MapIterator.prototype.next = function() { - var type = this._type; - var stack = this._stack; - while (stack) { - var node = stack.node; - var index = stack.index++; - var maxIndex; - if (node.entry) { - if (index === 0) { - return mapIteratorValue(type, node.entry); - } - } else if (node.entries) { - maxIndex = node.entries.length - 1; - if (index <= maxIndex) { - return mapIteratorValue(type, node.entries[this._reverse ? maxIndex - index : index]); - } - } else { - maxIndex = node.nodes.length - 1; - if (index <= maxIndex) { - var subNode = node.nodes[this._reverse ? maxIndex - index : index]; - if (subNode) { - if (subNode.entry) { - return mapIteratorValue(type, subNode.entry); - } - stack = this._stack = mapIteratorFrame(subNode, stack); - } - continue; - } - } - stack = this._stack = this._stack.__prev; - } - return iteratorDone(); + OrderedSet.of = function(/*...values*/) { + return this(arguments); }; - - function mapIteratorValue(type, entry) { - return iteratorValue(type, entry[0], entry[1]); - } - - function mapIteratorFrame(node, prev) { - return { - node: node, - index: 0, - __prev: prev + OrderedSet.fromKeys = function(value) { + return this(KeyedIterable(value).keySeq()); }; - } - - function makeMap(size, root, ownerID, hash) { - var map = Object.create(MapPrototype); - map.size = size; - map._root = root; - map.__ownerID = ownerID; - map.__hash = hash; - map.__altered = false; - return map; - } - - var EMPTY_MAP; - function emptyMap() { - return EMPTY_MAP || (EMPTY_MAP = makeMap(0)); - } - - function updateMap(map, k, v) { - var newRoot; - var newSize; - if (!map._root) { - if (v === NOT_SET) { - return map; - } - newSize = 1; - newRoot = new ArrayMapNode(map.__ownerID, [[k, v]]); - } else { - var didChangeSize = MakeRef(CHANGE_LENGTH); - var didAlter = MakeRef(DID_ALTER); - newRoot = updateNode(map._root, map.__ownerID, 0, undefined, k, v, didChangeSize, didAlter); - if (!didAlter.value) { - return map; - } - newSize = map.size + (didChangeSize.value ? v === NOT_SET ? -1 : 1 : 0); - } - if (map.__ownerID) { - map.size = newSize; - map._root = newRoot; - map.__hash = undefined; - map.__altered = true; - return map; - } - return newRoot ? makeMap(newSize, newRoot) : emptyMap(); - } - - function updateNode(node, ownerID, shift, keyHash, key, value, didChangeSize, didAlter) { - if (!node) { - if (value === NOT_SET) { - return node; - } - SetRef(didAlter); - SetRef(didChangeSize); - return new ValueNode(ownerID, keyHash, [key, value]); - } - return node.update(ownerID, shift, keyHash, key, value, didChangeSize, didAlter); - } - - function isLeafNode(node) { - return node.constructor === ValueNode || node.constructor === HashCollisionNode; - } - - function mergeIntoNode(node, ownerID, shift, keyHash, entry) { - if (node.keyHash === keyHash) { - return new HashCollisionNode(ownerID, keyHash, [node.entry, entry]); - } - - var idx1 = (shift === 0 ? node.keyHash : node.keyHash >>> shift) & MASK; - var idx2 = (shift === 0 ? keyHash : keyHash >>> shift) & MASK; - - var newNode; - var nodes = idx1 === idx2 ? - [mergeIntoNode(node, ownerID, shift + SHIFT, keyHash, entry)] : - ((newNode = new ValueNode(ownerID, keyHash, entry)), idx1 < idx2 ? [node, newNode] : [newNode, node]); - - return new BitmapIndexedNode(ownerID, (1 << idx1) | (1 << idx2), nodes); - } - - function createNodes(ownerID, entries, key, value) { - if (!ownerID) { - ownerID = new OwnerID(); - } - var node = new ValueNode(ownerID, hash(key), [key, value]); - for (var ii = 0; ii < entries.length; ii++) { - var entry = entries[ii]; - node = node.update(ownerID, 0, undefined, entry[0], entry[1]); - } - return node; - } - - function packNodes(ownerID, nodes, count, excluding) { - var bitmap = 0; - var packedII = 0; - var packedNodes = new Array(count); - for (var ii = 0, bit = 1, len = nodes.length; ii < len; ii++, bit <<= 1) { - var node = nodes[ii]; - if (node !== undefined && ii !== excluding) { - bitmap |= bit; - packedNodes[packedII++] = node; - } - } - return new BitmapIndexedNode(ownerID, bitmap, packedNodes); - } - - function expandNodes(ownerID, nodes, bitmap, including, node) { - var count = 0; - var expandedNodes = new Array(SIZE); - for (var ii = 0; bitmap !== 0; ii++, bitmap >>>= 1) { - expandedNodes[ii] = bitmap & 1 ? nodes[count++] : undefined; - } - expandedNodes[including] = node; - return new HashArrayMapNode(ownerID, count + 1, expandedNodes); - } - - function mergeIntoMapWith(map, merger, iterables) { - var iters = []; - for (var ii = 0; ii < iterables.length; ii++) { - var value = iterables[ii]; - var iter = KeyedIterable(value); - if (!isIterable(value)) { - iter = iter.map(function(v ) {return fromJS(v)}); - } - iters.push(iter); - } - return mergeIntoCollectionWith(map, merger, iters); - } - - function deepMerger(existing, value, key) { - return existing && existing.mergeDeep && isIterable(value) ? - existing.mergeDeep(value) : - is(existing, value) ? existing : value; - } - function deepMergerWith(merger) { - return function(existing, value, key) { - if (existing && existing.mergeDeepWith && isIterable(value)) { - return existing.mergeDeepWith(merger, value); - } - var nextValue = merger(existing, value, key); - return is(existing, nextValue) ? existing : nextValue; + OrderedSet.prototype.toString = function() { + return this.__toString('OrderedSet {', '}'); }; - } - function mergeIntoCollectionWith(collection, merger, iters) { - iters = iters.filter(function(x ) {return x.size !== 0}); - if (iters.length === 0) { - return collection; - } - if (collection.size === 0 && !collection.__ownerID && iters.length === 1) { - return collection.constructor(iters[0]); - } - return collection.withMutations(function(collection ) { - var mergeIntoMap = merger ? - function(value, key) { - collection.update(key, NOT_SET, function(existing ) - {return existing === NOT_SET ? value : merger(existing, value, key)} - ); - } : - function(value, key) { - collection.set(key, value); - } - for (var ii = 0; ii < iters.length; ii++) { - iters[ii].forEach(mergeIntoMap); - } - }); - } - function updateInDeepMap(existing, keyPathIter, notSetValue, updater) { - var isNotSet = existing === NOT_SET; - var step = keyPathIter.next(); - if (step.done) { - var existingValue = isNotSet ? notSetValue : existing; - var newValue = updater(existingValue); - return newValue === existingValue ? existing : newValue; - } - invariant( - isNotSet || (existing && existing.set), - 'invalid keyPath' - ); - var key = step.value; - var nextExisting = isNotSet ? NOT_SET : existing.get(key, NOT_SET); - var nextUpdated = updateInDeepMap( - nextExisting, - keyPathIter, - notSetValue, - updater - ); - return nextUpdated === nextExisting ? existing : - nextUpdated === NOT_SET ? existing.remove(key) : - (isNotSet ? emptyMap() : existing).set(key, nextUpdated); + function isOrderedSet(maybeOrderedSet) { + return isSet(maybeOrderedSet) && isOrdered(maybeOrderedSet); } - function popCount(x) { - x = x - ((x >> 1) & 0x55555555); - x = (x & 0x33333333) + ((x >> 2) & 0x33333333); - x = (x + (x >> 4)) & 0x0f0f0f0f; - x = x + (x >> 8); - x = x + (x >> 16); - return x & 0x7f; - } + OrderedSet.isOrderedSet = isOrderedSet; - function setIn(array, idx, val, canEdit) { - var newArray = canEdit ? array : arrCopy(array); - newArray[idx] = val; - return newArray; - } + var OrderedSetPrototype = OrderedSet.prototype; + OrderedSetPrototype[IS_ORDERED_SENTINEL] = true; - function spliceIn(array, idx, val, canEdit) { - var newLen = array.length + 1; - if (canEdit && idx + 1 === newLen) { - array[idx] = val; - return array; - } - var newArray = new Array(newLen); - var after = 0; - for (var ii = 0; ii < newLen; ii++) { - if (ii === idx) { - newArray[ii] = val; - after = -1; - } else { - newArray[ii] = array[ii + after]; - } - } - return newArray; - } + OrderedSetPrototype.__empty = emptyOrderedSet; + OrderedSetPrototype.__make = makeOrderedSet; - function spliceOut(array, idx, canEdit) { - var newLen = array.length - 1; - if (canEdit && idx === newLen) { - array.pop(); - return array; - } - var newArray = new Array(newLen); - var after = 0; - for (var ii = 0; ii < newLen; ii++) { - if (ii === idx) { - after = 1; - } - newArray[ii] = array[ii + after]; - } - return newArray; + function makeOrderedSet(map, ownerID) { + var set = Object.create(OrderedSetPrototype); + set.size = map ? map.size : 0; + set._map = map; + set.__ownerID = ownerID; + return set; } - var MAX_ARRAY_MAP_SIZE = SIZE / 4; - var MAX_BITMAP_INDEXED_SIZE = SIZE / 2; - var MIN_HASH_ARRAY_MAP_SIZE = SIZE / 4; + var EMPTY_ORDERED_SET; + function emptyOrderedSet() { + return EMPTY_ORDERED_SET || (EMPTY_ORDERED_SET = makeOrderedSet(emptyOrderedMap())); + } - createClass(List, IndexedCollection); + createClass(Stack, IndexedCollection); // @pragma Construction - function List(value) { - var empty = emptyList(); - if (value === null || value === undefined) { - return empty; - } - if (isList(value)) { - return value; - } - var iter = IndexedIterable(value); - var size = iter.size; - if (size === 0) { - return empty; - } - assertNotInfinite(size); - if (size > 0 && size < SIZE) { - return makeList(0, size, SHIFT, null, new VNode(iter.toArray())); - } - return empty.withMutations(function(list ) { - list.setSize(size); - iter.forEach(function(v, i) {return list.set(i, v)}); - }); + function Stack(value) { + return value === null || value === undefined ? emptyStack() : + isStack(value) ? value : + emptyStack().unshiftAll(value); } - List.of = function(/*...values*/) { + Stack.of = function(/*...values*/) { return this(arguments); }; - List.prototype.toString = function() { - return this.__toString('List [', ']'); + Stack.prototype.toString = function() { + return this.__toString('Stack [', ']'); }; // @pragma Access - List.prototype.get = function(index, notSetValue) { + Stack.prototype.get = function(index, notSetValue) { + var head = this._head; index = wrapIndex(this, index); - if (index >= 0 && index < this.size) { - index += this._origin; - var node = listNodeFor(this, index); - return node && node.array[index & MASK]; + while (head && index--) { + head = head.next; } - return notSetValue; - }; - - // @pragma Modification - - List.prototype.set = function(index, value) { - return updateList(this, index, value); + return head ? head.value : notSetValue; }; - List.prototype.remove = function(index) { - return !this.has(index) ? this : - index === 0 ? this.shift() : - index === this.size - 1 ? this.pop() : - this.splice(index, 1); + Stack.prototype.peek = function() { + return this._head && this._head.value; }; - List.prototype.insert = function(index, value) { - return this.splice(index, 0, value); - }; + // @pragma Modification - List.prototype.clear = function() { - if (this.size === 0) { + Stack.prototype.push = function(/*...values*/) { + if (arguments.length === 0) { return this; } + var newSize = this.size + arguments.length; + var head = this._head; + for (var ii = arguments.length - 1; ii >= 0; ii--) { + head = { + value: arguments[ii], + next: head + }; + } if (this.__ownerID) { - this.size = this._origin = this._capacity = 0; - this._level = SHIFT; - this._root = this._tail = null; + this.size = newSize; + this._head = head; this.__hash = undefined; this.__altered = true; return this; } - return emptyList(); - }; - - List.prototype.push = function(/*...values*/) { - var values = arguments; - var oldSize = this.size; - return this.withMutations(function(list ) { - setListBounds(list, 0, oldSize + values.length); - for (var ii = 0; ii < values.length; ii++) { - list.set(oldSize + ii, values[ii]); - } - }); - }; - - List.prototype.pop = function() { - return setListBounds(this, 0, -1); + return makeStack(newSize, head); }; - List.prototype.unshift = function(/*...values*/) { - var values = arguments; - return this.withMutations(function(list ) { - setListBounds(list, -values.length); - for (var ii = 0; ii < values.length; ii++) { - list.set(ii, values[ii]); - } + Stack.prototype.pushAll = function(iter) { + iter = IndexedIterable(iter); + if (iter.size === 0) { + return this; + } + assertNotInfinite(iter.size); + var newSize = this.size; + var head = this._head; + iter.reverse().forEach(function(value ) { + newSize++; + head = { + value: value, + next: head + }; }); + if (this.__ownerID) { + this.size = newSize; + this._head = head; + this.__hash = undefined; + this.__altered = true; + return this; + } + return makeStack(newSize, head); }; - List.prototype.shift = function() { - return setListBounds(this, 1); - }; - - // @pragma Composition - - List.prototype.merge = function(/*...iters*/) { - return mergeIntoListWith(this, undefined, arguments); - }; - - List.prototype.mergeWith = function(merger) {var iters = SLICE$0.call(arguments, 1); - return mergeIntoListWith(this, merger, iters); + Stack.prototype.pop = function() { + return this.slice(1); }; - List.prototype.mergeDeep = function(/*...iters*/) { - return mergeIntoListWith(this, deepMerger, arguments); + Stack.prototype.unshift = function(/*...values*/) { + return this.push.apply(this, arguments); }; - List.prototype.mergeDeepWith = function(merger) {var iters = SLICE$0.call(arguments, 1); - return mergeIntoListWith(this, deepMergerWith(merger), iters); + Stack.prototype.unshiftAll = function(iter) { + return this.pushAll(iter); }; - List.prototype.setSize = function(size) { - return setListBounds(this, 0, size); + Stack.prototype.shift = function() { + return this.pop.apply(this, arguments); }; - // @pragma Iteration - - List.prototype.slice = function(begin, end) { - var size = this.size; - if (wholeSlice(begin, end, size)) { + Stack.prototype.clear = function() { + if (this.size === 0) { return this; } - return setListBounds( - this, - resolveBegin(begin, size), - resolveEnd(end, size) - ); - }; - - List.prototype.__iterator = function(type, reverse) { - var index = 0; - var values = iterateList(this, reverse); - return new Iterator(function() { - var value = values(); - return value === DONE ? - iteratorDone() : - iteratorValue(type, index++, value); - }); + if (this.__ownerID) { + this.size = 0; + this._head = undefined; + this.__hash = undefined; + this.__altered = true; + return this; + } + return emptyStack(); }; - List.prototype.__iterate = function(fn, reverse) { - var index = 0; - var values = iterateList(this, reverse); - var value; - while ((value = values()) !== DONE) { - if (fn(value, index++, this) === false) { - break; - } + Stack.prototype.slice = function(begin, end) { + if (wholeSlice(begin, end, this.size)) { + return this; } - return index; + var resolvedBegin = resolveBegin(begin, this.size); + var resolvedEnd = resolveEnd(end, this.size); + if (resolvedEnd !== this.size) { + // super.slice(begin, end); + return IndexedCollection.prototype.slice.call(this, begin, end); + } + var newSize = this.size - resolvedBegin; + var head = this._head; + while (resolvedBegin--) { + head = head.next; + } + if (this.__ownerID) { + this.size = newSize; + this._head = head; + this.__hash = undefined; + this.__altered = true; + return this; + } + return makeStack(newSize, head); }; - List.prototype.__ensureOwner = function(ownerID) { + // @pragma Mutability + + Stack.prototype.__ensureOwner = function(ownerID) { if (ownerID === this.__ownerID) { return this; } if (!ownerID) { this.__ownerID = ownerID; + this.__altered = false; return this; } - return makeList(this._origin, this._capacity, this._level, this._root, this._tail, ownerID, this.__hash); + return makeStack(this.size, this._head, ownerID, this.__hash); }; + // @pragma Iteration - function isList(maybeList) { - return !!(maybeList && maybeList[IS_LIST_SENTINEL]); - } - - List.isList = isList; - - var IS_LIST_SENTINEL = '@@__IMMUTABLE_LIST__@@'; - - var ListPrototype = List.prototype; - ListPrototype[IS_LIST_SENTINEL] = true; - ListPrototype[DELETE] = ListPrototype.remove; - ListPrototype.setIn = MapPrototype.setIn; - ListPrototype.deleteIn = - ListPrototype.removeIn = MapPrototype.removeIn; - ListPrototype.update = MapPrototype.update; - ListPrototype.updateIn = MapPrototype.updateIn; - ListPrototype.mergeIn = MapPrototype.mergeIn; - ListPrototype.mergeDeepIn = MapPrototype.mergeDeepIn; - ListPrototype.withMutations = MapPrototype.withMutations; - ListPrototype.asMutable = MapPrototype.asMutable; - ListPrototype.asImmutable = MapPrototype.asImmutable; - ListPrototype.wasAltered = MapPrototype.wasAltered; - - - - function VNode(array, ownerID) { - this.array = array; - this.ownerID = ownerID; - } - - // TODO: seems like these methods are very similar - - VNode.prototype.removeBefore = function(ownerID, level, index) { - if (index === level ? 1 << level : 0 || this.array.length === 0) { - return this; - } - var originIndex = (index >>> level) & MASK; - if (originIndex >= this.array.length) { - return new VNode([], ownerID); - } - var removingFirst = originIndex === 0; - var newChild; - if (level > 0) { - var oldChild = this.array[originIndex]; - newChild = oldChild && oldChild.removeBefore(ownerID, level - SHIFT, index); - if (newChild === oldChild && removingFirst) { - return this; - } - } - if (removingFirst && !newChild) { - return this; + Stack.prototype.__iterate = function(fn, reverse) { + if (reverse) { + return this.reverse().__iterate(fn); } - var editable = editableVNode(this, ownerID); - if (!removingFirst) { - for (var ii = 0; ii < originIndex; ii++) { - editable.array[ii] = undefined; + var iterations = 0; + var node = this._head; + while (node) { + if (fn(node.value, iterations++, this) === false) { + break; } + node = node.next; } - if (newChild) { - editable.array[originIndex] = newChild; - } - return editable; + return iterations; }; - VNode.prototype.removeAfter = function(ownerID, level, index) { - if (index === (level ? 1 << level : 0) || this.array.length === 0) { - return this; - } - var sizeIndex = ((index - 1) >>> level) & MASK; - if (sizeIndex >= this.array.length) { - return this; + Stack.prototype.__iterator = function(type, reverse) { + if (reverse) { + return this.reverse().__iterator(type); } - - var newChild; - if (level > 0) { - var oldChild = this.array[sizeIndex]; - newChild = oldChild && oldChild.removeAfter(ownerID, level - SHIFT, index); - if (newChild === oldChild && sizeIndex === this.array.length - 1) { - return this; + var iterations = 0; + var node = this._head; + return new Iterator(function() { + if (node) { + var value = node.value; + node = node.next; + return iteratorValue(type, iterations++, value); } - } - - var editable = editableVNode(this, ownerID); - editable.array.splice(sizeIndex + 1); - if (newChild) { - editable.array[sizeIndex] = newChild; - } - return editable; + return iteratorDone(); + }); }; + function isStack(maybeStack) { + return !!(maybeStack && maybeStack[IS_STACK_SENTINEL]); + } - var DONE = {}; - - function iterateList(list, reverse) { - var left = list._origin; - var right = list._capacity; - var tailPos = getTailOffset(right); - var tail = list._tail; + Stack.isStack = isStack; - return iterateNodeOrLeaf(list._root, list._level, 0); + var IS_STACK_SENTINEL = '@@__IMMUTABLE_STACK__@@'; - function iterateNodeOrLeaf(node, level, offset) { - return level === 0 ? - iterateLeaf(node, offset) : - iterateNode(node, level, offset); - } + var StackPrototype = Stack.prototype; + StackPrototype[IS_STACK_SENTINEL] = true; + StackPrototype.withMutations = MapPrototype.withMutations; + StackPrototype.asMutable = MapPrototype.asMutable; + StackPrototype.asImmutable = MapPrototype.asImmutable; + StackPrototype.wasAltered = MapPrototype.wasAltered; - function iterateLeaf(node, offset) { - var array = offset === tailPos ? tail && tail.array : node && node.array; - var from = offset > left ? 0 : left - offset; - var to = right - offset; - if (to > SIZE) { - to = SIZE; - } - return function() { - if (from === to) { - return DONE; - } - var idx = reverse ? --to : from++; - return array && array[idx]; - }; - } - function iterateNode(node, level, offset) { - var values; - var array = node && node.array; - var from = offset > left ? 0 : (left - offset) >> level; - var to = ((right - offset) >> level) + 1; - if (to > SIZE) { - to = SIZE; - } - return function() { - do { - if (values) { - var value = values(); - if (value !== DONE) { - return value; - } - values = null; - } - if (from === to) { - return DONE; - } - var idx = reverse ? --to : from++; - values = iterateNodeOrLeaf( - array && array[idx], level - SHIFT, offset + (idx << level) - ); - } while (true); - }; - } + function makeStack(size, head, ownerID, hash) { + var map = Object.create(StackPrototype); + map.size = size; + map._head = head; + map.__ownerID = ownerID; + map.__hash = hash; + map.__altered = false; + return map; } - function makeList(origin, capacity, level, root, tail, ownerID, hash) { - var list = Object.create(ListPrototype); - list.size = capacity - origin; - list._origin = origin; - list._capacity = capacity; - list._level = level; - list._root = root; - list._tail = tail; - list.__ownerID = ownerID; - list.__hash = hash; - list.__altered = false; - return list; + var EMPTY_STACK; + function emptyStack() { + return EMPTY_STACK || (EMPTY_STACK = makeStack(0)); } - var EMPTY_LIST; - function emptyList() { - return EMPTY_LIST || (EMPTY_LIST = makeList(0, 0, SHIFT)); + /** + * Contributes additional methods to a constructor + */ + function mixin(ctor, methods) { + var keyCopier = function(key ) { ctor.prototype[key] = methods[key]; }; + Object.keys(methods).forEach(keyCopier); + Object.getOwnPropertySymbols && + Object.getOwnPropertySymbols(methods).forEach(keyCopier); + return ctor; } - function updateList(list, index, value) { - index = wrapIndex(list, index); + Iterable.Iterator = Iterator; - if (index !== index) { - return list; - } + mixin(Iterable, { - if (index >= list.size || index < 0) { - return list.withMutations(function(list ) { - index < 0 ? - setListBounds(list, index).set(0, value) : - setListBounds(list, 0, index + 1).set(index, value) - }); - } + // ### Conversion to other types - index += list._origin; + toArray: function() { + assertNotInfinite(this.size); + var array = new Array(this.size || 0); + this.valueSeq().__iterate(function(v, i) { array[i] = v; }); + return array; + }, - var newTail = list._tail; - var newRoot = list._root; - var didAlter = MakeRef(DID_ALTER); - if (index >= getTailOffset(list._capacity)) { - newTail = updateVNode(newTail, list.__ownerID, 0, index, value, didAlter); - } else { - newRoot = updateVNode(newRoot, list.__ownerID, list._level, index, value, didAlter); - } + toIndexedSeq: function() { + return new ToIndexedSequence(this); + }, - if (!didAlter.value) { - return list; - } + toJS: function() { + return this.toSeq().map( + function(value ) {return value && typeof value.toJS === 'function' ? value.toJS() : value} + ).__toJS(); + }, - if (list.__ownerID) { - list._root = newRoot; - list._tail = newTail; - list.__hash = undefined; - list.__altered = true; - return list; - } - return makeList(list._origin, list._capacity, list._level, newRoot, newTail); - } + toJSON: function() { + return this.toSeq().map( + function(value ) {return value && typeof value.toJSON === 'function' ? value.toJSON() : value} + ).__toJS(); + }, - function updateVNode(node, ownerID, level, index, value, didAlter) { - var idx = (index >>> level) & MASK; - var nodeHas = node && idx < node.array.length; - if (!nodeHas && value === undefined) { - return node; - } + toKeyedSeq: function() { + return new ToKeyedSequence(this, true); + }, - var newNode; + toMap: function() { + // Use Late Binding here to solve the circular dependency. + return Map(this.toKeyedSeq()); + }, - if (level > 0) { - var lowerNode = node && node.array[idx]; - var newLowerNode = updateVNode(lowerNode, ownerID, level - SHIFT, index, value, didAlter); - if (newLowerNode === lowerNode) { - return node; - } - newNode = editableVNode(node, ownerID); - newNode.array[idx] = newLowerNode; - return newNode; - } + toObject: function() { + assertNotInfinite(this.size); + var object = {}; + this.__iterate(function(v, k) { object[k] = v; }); + return object; + }, - if (nodeHas && node.array[idx] === value) { - return node; - } + toOrderedMap: function() { + // Use Late Binding here to solve the circular dependency. + return OrderedMap(this.toKeyedSeq()); + }, - SetRef(didAlter); + toOrderedSet: function() { + // Use Late Binding here to solve the circular dependency. + return OrderedSet(isKeyed(this) ? this.valueSeq() : this); + }, - newNode = editableVNode(node, ownerID); - if (value === undefined && idx === newNode.array.length - 1) { - newNode.array.pop(); - } else { - newNode.array[idx] = value; - } - return newNode; - } + toSet: function() { + // Use Late Binding here to solve the circular dependency. + return Set(isKeyed(this) ? this.valueSeq() : this); + }, - function editableVNode(node, ownerID) { - if (ownerID && node && ownerID === node.ownerID) { - return node; - } - return new VNode(node ? node.array.slice() : [], ownerID); - } + toSetSeq: function() { + return new ToSetSequence(this); + }, - function listNodeFor(list, rawIndex) { - if (rawIndex >= getTailOffset(list._capacity)) { - return list._tail; - } - if (rawIndex < 1 << (list._level + SHIFT)) { - var node = list._root; - var level = list._level; - while (node && level > 0) { - node = node.array[(rawIndex >>> level) & MASK]; - level -= SHIFT; - } - return node; - } - } + toSeq: function() { + return isIndexed(this) ? this.toIndexedSeq() : + isKeyed(this) ? this.toKeyedSeq() : + this.toSetSeq(); + }, - function setListBounds(list, begin, end) { - // Sanitize begin & end using this shorthand for ToInt32(argument) - // http://www.ecma-international.org/ecma-262/6.0/#sec-toint32 - if (begin !== undefined) { - begin = begin | 0; - } - if (end !== undefined) { - end = end | 0; - } - var owner = list.__ownerID || new OwnerID(); - var oldOrigin = list._origin; - var oldCapacity = list._capacity; - var newOrigin = oldOrigin + begin; - var newCapacity = end === undefined ? oldCapacity : end < 0 ? oldCapacity + end : oldOrigin + end; - if (newOrigin === oldOrigin && newCapacity === oldCapacity) { - return list; - } + toStack: function() { + // Use Late Binding here to solve the circular dependency. + return Stack(isKeyed(this) ? this.valueSeq() : this); + }, - // If it's going to end after it starts, it's empty. - if (newOrigin >= newCapacity) { - return list.clear(); - } + toList: function() { + // Use Late Binding here to solve the circular dependency. + return List(isKeyed(this) ? this.valueSeq() : this); + }, - var newLevel = list._level; - var newRoot = list._root; - // New origin might need creating a higher root. - var offsetShift = 0; - while (newOrigin + offsetShift < 0) { - newRoot = new VNode(newRoot && newRoot.array.length ? [undefined, newRoot] : [], owner); - newLevel += SHIFT; - offsetShift += 1 << newLevel; - } - if (offsetShift) { - newOrigin += offsetShift; - oldOrigin += offsetShift; - newCapacity += offsetShift; - oldCapacity += offsetShift; - } + // ### Common JavaScript methods and properties - var oldTailOffset = getTailOffset(oldCapacity); - var newTailOffset = getTailOffset(newCapacity); + toString: function() { + return '[Iterable]'; + }, - // New size might need creating a higher root. - while (newTailOffset >= 1 << (newLevel + SHIFT)) { - newRoot = new VNode(newRoot && newRoot.array.length ? [newRoot] : [], owner); - newLevel += SHIFT; - } + __toString: function(head, tail) { + if (this.size === 0) { + return head + tail; + } + return head + ' ' + this.toSeq().map(this.__toStringMapper).join(', ') + ' ' + tail; + }, - // Locate or create the new tail. - var oldTail = list._tail; - var newTail = newTailOffset < oldTailOffset ? - listNodeFor(list, newCapacity - 1) : - newTailOffset > oldTailOffset ? new VNode([], owner) : oldTail; - // Merge Tail into tree. - if (oldTail && newTailOffset > oldTailOffset && newOrigin < oldCapacity && oldTail.array.length) { - newRoot = editableVNode(newRoot, owner); - var node = newRoot; - for (var level = newLevel; level > SHIFT; level -= SHIFT) { - var idx = (oldTailOffset >>> level) & MASK; - node = node.array[idx] = editableVNode(node.array[idx], owner); - } - node.array[(oldTailOffset >>> SHIFT) & MASK] = oldTail; - } + // ### ES6 Collection methods (ES6 Array and Map) - // If the size has been reduced, there's a chance the tail needs to be trimmed. - if (newCapacity < oldCapacity) { - newTail = newTail && newTail.removeAfter(owner, 0, newCapacity); - } + concat: function() {var values = SLICE$0.call(arguments, 0); + return reify(this, concatFactory(this, values)); + }, - // If the new origin is within the tail, then we do not need a root. - if (newOrigin >= newTailOffset) { - newOrigin -= newTailOffset; - newCapacity -= newTailOffset; - newLevel = SHIFT; - newRoot = null; - newTail = newTail && newTail.removeBefore(owner, 0, newOrigin); + includes: function(searchValue) { + return this.some(function(value ) {return is(value, searchValue)}); + }, - // Otherwise, if the root has been trimmed, garbage collect. - } else if (newOrigin > oldOrigin || newTailOffset < oldTailOffset) { - offsetShift = 0; + entries: function() { + return this.__iterator(ITERATE_ENTRIES); + }, - // Identify the new top root node of the subtree of the old root. - while (newRoot) { - var beginIndex = (newOrigin >>> newLevel) & MASK; - if (beginIndex !== (newTailOffset >>> newLevel) & MASK) { - break; - } - if (beginIndex) { - offsetShift += (1 << newLevel) * beginIndex; + every: function(predicate, context) { + assertNotInfinite(this.size); + var returnValue = true; + this.__iterate(function(v, k, c) { + if (!predicate.call(context, v, k, c)) { + returnValue = false; + return false; } - newLevel -= SHIFT; - newRoot = newRoot.array[beginIndex]; - } + }); + return returnValue; + }, - // Trim the new sides of the new root. - if (newRoot && newOrigin > oldOrigin) { - newRoot = newRoot.removeBefore(owner, newLevel, newOrigin - offsetShift); - } - if (newRoot && newTailOffset < oldTailOffset) { - newRoot = newRoot.removeAfter(owner, newLevel, newTailOffset - offsetShift); - } - if (offsetShift) { - newOrigin -= offsetShift; - newCapacity -= offsetShift; - } - } + filter: function(predicate, context) { + return reify(this, filterFactory(this, predicate, context, true)); + }, - if (list.__ownerID) { - list.size = newCapacity - newOrigin; - list._origin = newOrigin; - list._capacity = newCapacity; - list._level = newLevel; - list._root = newRoot; - list._tail = newTail; - list.__hash = undefined; - list.__altered = true; - return list; - } - return makeList(newOrigin, newCapacity, newLevel, newRoot, newTail); - } + find: function(predicate, context, notSetValue) { + var entry = this.findEntry(predicate, context); + return entry ? entry[1] : notSetValue; + }, - function mergeIntoListWith(list, merger, iterables) { - var iters = []; - var maxSize = 0; - for (var ii = 0; ii < iterables.length; ii++) { - var value = iterables[ii]; - var iter = IndexedIterable(value); - if (iter.size > maxSize) { - maxSize = iter.size; - } - if (!isIterable(value)) { - iter = iter.map(function(v ) {return fromJS(v)}); - } - iters.push(iter); - } - if (maxSize > list.size) { - list = list.setSize(maxSize); - } - return mergeIntoCollectionWith(list, merger, iters); - } + forEach: function(sideEffect, context) { + assertNotInfinite(this.size); + return this.__iterate(context ? sideEffect.bind(context) : sideEffect); + }, - function getTailOffset(size) { - return size < SIZE ? 0 : (((size - 1) >>> SHIFT) << SHIFT); - } + join: function(separator) { + assertNotInfinite(this.size); + separator = separator !== undefined ? '' + separator : ','; + var joined = ''; + var isFirst = true; + this.__iterate(function(v ) { + isFirst ? (isFirst = false) : (joined += separator); + joined += v !== null && v !== undefined ? v.toString() : ''; + }); + return joined; + }, - createClass(OrderedMap, Map); + keys: function() { + return this.__iterator(ITERATE_KEYS); + }, - // @pragma Construction + map: function(mapper, context) { + return reify(this, mapFactory(this, mapper, context)); + }, - function OrderedMap(value) { - return value === null || value === undefined ? emptyOrderedMap() : - isOrderedMap(value) ? value : - emptyOrderedMap().withMutations(function(map ) { - var iter = KeyedIterable(value); - assertNotInfinite(iter.size); - iter.forEach(function(v, k) {return map.set(k, v)}); - }); - } + reduce: function(reducer, initialReduction, context) { + assertNotInfinite(this.size); + var reduction; + var useFirst; + if (arguments.length < 2) { + useFirst = true; + } else { + reduction = initialReduction; + } + this.__iterate(function(v, k, c) { + if (useFirst) { + useFirst = false; + reduction = v; + } else { + reduction = reducer.call(context, reduction, v, k, c); + } + }); + return reduction; + }, - OrderedMap.of = function(/*...values*/) { - return this(arguments); - }; + reduceRight: function(reducer, initialReduction, context) { + var reversed = this.toKeyedSeq().reverse(); + return reversed.reduce.apply(reversed, arguments); + }, - OrderedMap.prototype.toString = function() { - return this.__toString('OrderedMap {', '}'); - }; + reverse: function() { + return reify(this, reverseFactory(this, true)); + }, - // @pragma Access + slice: function(begin, end) { + return reify(this, sliceFactory(this, begin, end, true)); + }, - OrderedMap.prototype.get = function(k, notSetValue) { - var index = this._map.get(k); - return index !== undefined ? this._list.get(index)[1] : notSetValue; - }; + some: function(predicate, context) { + return !this.every(not(predicate), context); + }, - // @pragma Modification + sort: function(comparator) { + return reify(this, sortFactory(this, comparator)); + }, - OrderedMap.prototype.clear = function() { - if (this.size === 0) { - return this; - } - if (this.__ownerID) { - this.size = 0; - this._map.clear(); - this._list.clear(); - return this; - } - return emptyOrderedMap(); - }; + values: function() { + return this.__iterator(ITERATE_VALUES); + }, - OrderedMap.prototype.set = function(k, v) { - return updateOrderedMap(this, k, v); - }; - OrderedMap.prototype.remove = function(k) { - return updateOrderedMap(this, k, NOT_SET); - }; + // ### More sequential methods - OrderedMap.prototype.wasAltered = function() { - return this._map.wasAltered() || this._list.wasAltered(); - }; + butLast: function() { + return this.slice(0, -1); + }, - OrderedMap.prototype.__iterate = function(fn, reverse) {var this$0 = this; - return this._list.__iterate( - function(entry ) {return entry && fn(entry[1], entry[0], this$0)}, - reverse + isEmpty: function() { + return this.size !== undefined ? this.size === 0 : !this.some(function() {return true}); + }, + + count: function(predicate, context) { + return ensureSize( + predicate ? this.toSeq().filter(predicate, context) : this ); - }; + }, - OrderedMap.prototype.__iterator = function(type, reverse) { - return this._list.fromEntrySeq().__iterator(type, reverse); - }; + countBy: function(grouper, context) { + return countByFactory(this, grouper, context); + }, - OrderedMap.prototype.__ensureOwner = function(ownerID) { - if (ownerID === this.__ownerID) { - return this; - } - var newMap = this._map.__ensureOwner(ownerID); - var newList = this._list.__ensureOwner(ownerID); - if (!ownerID) { - this.__ownerID = ownerID; - this._map = newMap; - this._list = newList; - return this; + equals: function(other) { + return deepEqual(this, other); + }, + + entrySeq: function() { + var iterable = this; + if (iterable._cache) { + // We cache as an entries array, so we can just return the cache! + return new ArraySeq(iterable._cache); } - return makeOrderedMap(newMap, newList, ownerID, this.__hash); - }; + var entriesSequence = iterable.toSeq().map(entryMapper).toIndexedSeq(); + entriesSequence.fromEntrySeq = function() {return iterable.toSeq()}; + return entriesSequence; + }, + filterNot: function(predicate, context) { + return this.filter(not(predicate), context); + }, - function isOrderedMap(maybeOrderedMap) { - return isMap(maybeOrderedMap) && isOrdered(maybeOrderedMap); - } + findEntry: function(predicate, context, notSetValue) { + var found = notSetValue; + this.__iterate(function(v, k, c) { + if (predicate.call(context, v, k, c)) { + found = [k, v]; + return false; + } + }); + return found; + }, - OrderedMap.isOrderedMap = isOrderedMap; + findKey: function(predicate, context) { + var entry = this.findEntry(predicate, context); + return entry && entry[0]; + }, - OrderedMap.prototype[IS_ORDERED_SENTINEL] = true; - OrderedMap.prototype[DELETE] = OrderedMap.prototype.remove; + findLast: function(predicate, context, notSetValue) { + return this.toKeyedSeq().reverse().find(predicate, context, notSetValue); + }, + findLastEntry: function(predicate, context, notSetValue) { + return this.toKeyedSeq().reverse().findEntry(predicate, context, notSetValue); + }, + findLastKey: function(predicate, context) { + return this.toKeyedSeq().reverse().findKey(predicate, context); + }, - function makeOrderedMap(map, list, ownerID, hash) { - var omap = Object.create(OrderedMap.prototype); - omap.size = map ? map.size : 0; - omap._map = map; - omap._list = list; - omap.__ownerID = ownerID; - omap.__hash = hash; - return omap; - } + first: function() { + return this.find(returnTrue); + }, - var EMPTY_ORDERED_MAP; - function emptyOrderedMap() { - return EMPTY_ORDERED_MAP || (EMPTY_ORDERED_MAP = makeOrderedMap(emptyMap(), emptyList())); - } + flatMap: function(mapper, context) { + return reify(this, flatMapFactory(this, mapper, context)); + }, - function updateOrderedMap(omap, k, v) { - var map = omap._map; - var list = omap._list; - var i = map.get(k); - var has = i !== undefined; - var newMap; - var newList; - if (v === NOT_SET) { // removed - if (!has) { - return omap; - } - if (list.size >= SIZE && list.size >= map.size * 2) { - newList = list.filter(function(entry, idx) {return entry !== undefined && i !== idx}); - newMap = newList.toKeyedSeq().map(function(entry ) {return entry[0]}).flip().toMap(); - if (omap.__ownerID) { - newMap.__ownerID = newList.__ownerID = omap.__ownerID; - } - } else { - newMap = map.remove(k); - newList = i === list.size - 1 ? list.pop() : list.set(i, undefined); - } - } else { - if (has) { - if (v === list.get(i)[1]) { - return omap; + flatten: function(depth) { + return reify(this, flattenFactory(this, depth, true)); + }, + + fromEntrySeq: function() { + return new FromEntriesSequence(this); + }, + + get: function(searchKey, notSetValue) { + return this.find(function(_, key) {return is(key, searchKey)}, undefined, notSetValue); + }, + + getIn: function(searchKeyPath, notSetValue) { + var nested = this; + // Note: in an ES6 environment, we would prefer: + // for (var key of searchKeyPath) { + var iter = forceIterator(searchKeyPath); + var step; + while (!(step = iter.next()).done) { + var key = step.value; + nested = nested && nested.get ? nested.get(key, NOT_SET) : NOT_SET; + if (nested === NOT_SET) { + return notSetValue; } - newMap = map; - newList = list.set(i, [k, v]); - } else { - newMap = map.set(k, list.size); - newList = list.set(list.size, [k, v]); } - } - if (omap.__ownerID) { - omap.size = newMap.size; - omap._map = newMap; - omap._list = newList; - omap.__hash = undefined; - return omap; - } - return makeOrderedMap(newMap, newList); - } + return nested; + }, - createClass(ToKeyedSequence, KeyedSeq); - function ToKeyedSequence(indexed, useKeys) { - this._iter = indexed; - this._useKeys = useKeys; - this.size = indexed.size; - } + groupBy: function(grouper, context) { + return groupByFactory(this, grouper, context); + }, - ToKeyedSequence.prototype.get = function(key, notSetValue) { - return this._iter.get(key, notSetValue); - }; + has: function(searchKey) { + return this.get(searchKey, NOT_SET) !== NOT_SET; + }, - ToKeyedSequence.prototype.has = function(key) { - return this._iter.has(key); - }; + hasIn: function(searchKeyPath) { + return this.getIn(searchKeyPath, NOT_SET) !== NOT_SET; + }, - ToKeyedSequence.prototype.valueSeq = function() { - return this._iter.valueSeq(); - }; + isSubset: function(iter) { + iter = typeof iter.includes === 'function' ? iter : Iterable(iter); + return this.every(function(value ) {return iter.includes(value)}); + }, - ToKeyedSequence.prototype.reverse = function() {var this$0 = this; - var reversedSequence = reverseFactory(this, true); - if (!this._useKeys) { - reversedSequence.valueSeq = function() {return this$0._iter.toSeq().reverse()}; - } - return reversedSequence; - }; + isSuperset: function(iter) { + iter = typeof iter.isSubset === 'function' ? iter : Iterable(iter); + return iter.isSubset(this); + }, - ToKeyedSequence.prototype.map = function(mapper, context) {var this$0 = this; - var mappedSequence = mapFactory(this, mapper, context); - if (!this._useKeys) { - mappedSequence.valueSeq = function() {return this$0._iter.toSeq().map(mapper, context)}; - } - return mappedSequence; - }; + keyOf: function(searchValue) { + return this.findKey(function(value ) {return is(value, searchValue)}); + }, - ToKeyedSequence.prototype.__iterate = function(fn, reverse) {var this$0 = this; - var ii; - return this._iter.__iterate( - this._useKeys ? - function(v, k) {return fn(v, k, this$0)} : - ((ii = reverse ? resolveSize(this) : 0), - function(v ) {return fn(v, reverse ? --ii : ii++, this$0)}), - reverse - ); - }; + keySeq: function() { + return this.toSeq().map(keyMapper).toIndexedSeq(); + }, - ToKeyedSequence.prototype.__iterator = function(type, reverse) { - if (this._useKeys) { - return this._iter.__iterator(type, reverse); - } - var iterator = this._iter.__iterator(ITERATE_VALUES, reverse); - var ii = reverse ? resolveSize(this) : 0; - return new Iterator(function() { - var step = iterator.next(); - return step.done ? step : - iteratorValue(type, reverse ? --ii : ii++, step.value, step); - }); - }; + last: function() { + return this.toSeq().reverse().first(); + }, - ToKeyedSequence.prototype[IS_ORDERED_SENTINEL] = true; + lastKeyOf: function(searchValue) { + return this.toKeyedSeq().reverse().keyOf(searchValue); + }, + max: function(comparator) { + return maxFactory(this, comparator); + }, - createClass(ToIndexedSequence, IndexedSeq); - function ToIndexedSequence(iter) { - this._iter = iter; - this.size = iter.size; - } + maxBy: function(mapper, comparator) { + return maxFactory(this, comparator, mapper); + }, - ToIndexedSequence.prototype.includes = function(value) { - return this._iter.includes(value); - }; + min: function(comparator) { + return maxFactory(this, comparator ? neg(comparator) : defaultNegComparator); + }, - ToIndexedSequence.prototype.__iterate = function(fn, reverse) {var this$0 = this; - var iterations = 0; - return this._iter.__iterate(function(v ) {return fn(v, iterations++, this$0)}, reverse); - }; + minBy: function(mapper, comparator) { + return maxFactory(this, comparator ? neg(comparator) : defaultNegComparator, mapper); + }, - ToIndexedSequence.prototype.__iterator = function(type, reverse) { - var iterator = this._iter.__iterator(ITERATE_VALUES, reverse); - var iterations = 0; - return new Iterator(function() { - var step = iterator.next(); - return step.done ? step : - iteratorValue(type, iterations++, step.value, step) - }); - }; + rest: function() { + return this.slice(1); + }, + + skip: function(amount) { + return this.slice(Math.max(0, amount)); + }, + skipLast: function(amount) { + return reify(this, this.toSeq().reverse().skip(amount).reverse()); + }, + skipWhile: function(predicate, context) { + return reify(this, skipWhileFactory(this, predicate, context, true)); + }, - createClass(ToSetSequence, SetSeq); - function ToSetSequence(iter) { - this._iter = iter; - this.size = iter.size; - } + skipUntil: function(predicate, context) { + return this.skipWhile(not(predicate), context); + }, - ToSetSequence.prototype.has = function(key) { - return this._iter.includes(key); - }; + sortBy: function(mapper, comparator) { + return reify(this, sortFactory(this, comparator, mapper)); + }, - ToSetSequence.prototype.__iterate = function(fn, reverse) {var this$0 = this; - return this._iter.__iterate(function(v ) {return fn(v, v, this$0)}, reverse); - }; + take: function(amount) { + return this.slice(0, Math.max(0, amount)); + }, - ToSetSequence.prototype.__iterator = function(type, reverse) { - var iterator = this._iter.__iterator(ITERATE_VALUES, reverse); - return new Iterator(function() { - var step = iterator.next(); - return step.done ? step : - iteratorValue(type, step.value, step.value, step); - }); - }; + takeLast: function(amount) { + return reify(this, this.toSeq().reverse().take(amount).reverse()); + }, + takeWhile: function(predicate, context) { + return reify(this, takeWhileFactory(this, predicate, context)); + }, + takeUntil: function(predicate, context) { + return this.takeWhile(not(predicate), context); + }, - createClass(FromEntriesSequence, KeyedSeq); - function FromEntriesSequence(entries) { - this._iter = entries; - this.size = entries.size; + valueSeq: function() { + return this.toIndexedSeq(); + }, + + + // ### Hashable Object + + hashCode: function() { + return this.__hash || (this.__hash = hashIterable(this)); } - FromEntriesSequence.prototype.entrySeq = function() { - return this._iter.toSeq(); - }; - FromEntriesSequence.prototype.__iterate = function(fn, reverse) {var this$0 = this; - return this._iter.__iterate(function(entry ) { - // Check if entry exists first so array access doesn't throw for holes - // in the parent iteration. - if (entry) { - validateEntry(entry); - var indexedIterable = isIterable(entry); - return fn( - indexedIterable ? entry.get(1) : entry[1], - indexedIterable ? entry.get(0) : entry[0], - this$0 - ); - } - }, reverse); - }; + // ### Internal - FromEntriesSequence.prototype.__iterator = function(type, reverse) { - var iterator = this._iter.__iterator(ITERATE_VALUES, reverse); - return new Iterator(function() { - while (true) { - var step = iterator.next(); - if (step.done) { - return step; - } - var entry = step.value; - // Check if entry exists first so array access doesn't throw for holes - // in the parent iteration. - if (entry) { - validateEntry(entry); - var indexedIterable = isIterable(entry); - return iteratorValue( - type, - indexedIterable ? entry.get(0) : entry[0], - indexedIterable ? entry.get(1) : entry[1], - step - ); - } - } - }); - }; + // abstract __iterate(fn, reverse) + // abstract __iterator(type, reverse) + }); - ToIndexedSequence.prototype.cacheResult = - ToKeyedSequence.prototype.cacheResult = - ToSetSequence.prototype.cacheResult = - FromEntriesSequence.prototype.cacheResult = - cacheResultThrough; + // var IS_ITERABLE_SENTINEL = '@@__IMMUTABLE_ITERABLE__@@'; + // var IS_KEYED_SENTINEL = '@@__IMMUTABLE_KEYED__@@'; + // var IS_INDEXED_SENTINEL = '@@__IMMUTABLE_INDEXED__@@'; + // var IS_ORDERED_SENTINEL = '@@__IMMUTABLE_ORDERED__@@'; + var IterablePrototype = Iterable.prototype; + IterablePrototype[IS_ITERABLE_SENTINEL] = true; + IterablePrototype[ITERATOR_SYMBOL] = IterablePrototype.values; + IterablePrototype.__toJS = IterablePrototype.toArray; + IterablePrototype.__toStringMapper = quoteString; + IterablePrototype.inspect = + IterablePrototype.toSource = function() { return this.toString(); }; + IterablePrototype.chain = IterablePrototype.flatMap; + IterablePrototype.contains = IterablePrototype.includes; - function flipFactory(iterable) { - var flipSequence = makeSequence(iterable); - flipSequence._iter = iterable; - flipSequence.size = iterable.size; - flipSequence.flip = function() {return iterable}; - flipSequence.reverse = function () { - var reversedSequence = iterable.reverse.apply(this); // super.reverse() - reversedSequence.flip = function() {return iterable.reverse()}; - return reversedSequence; - }; - flipSequence.has = function(key ) {return iterable.includes(key)}; - flipSequence.includes = function(key ) {return iterable.has(key)}; - flipSequence.cacheResult = cacheResultThrough; - flipSequence.__iterateUncached = function (fn, reverse) {var this$0 = this; - return iterable.__iterate(function(v, k) {return fn(k, v, this$0) !== false}, reverse); - } - flipSequence.__iteratorUncached = function(type, reverse) { - if (type === ITERATE_ENTRIES) { - var iterator = iterable.__iterator(type, reverse); - return new Iterator(function() { - var step = iterator.next(); - if (!step.done) { - var k = step.value[0]; - step.value[0] = step.value[1]; - step.value[1] = k; - } - return step; - }); - } - return iterable.__iterator( - type === ITERATE_VALUES ? ITERATE_KEYS : ITERATE_VALUES, - reverse - ); - } - return flipSequence; - } + mixin(KeyedIterable, { + // ### More sequential methods - function mapFactory(iterable, mapper, context) { - var mappedSequence = makeSequence(iterable); - mappedSequence.size = iterable.size; - mappedSequence.has = function(key ) {return iterable.has(key)}; - mappedSequence.get = function(key, notSetValue) { - var v = iterable.get(key, NOT_SET); - return v === NOT_SET ? - notSetValue : - mapper.call(context, v, key, iterable); - }; - mappedSequence.__iterateUncached = function (fn, reverse) {var this$0 = this; - return iterable.__iterate( - function(v, k, c) {return fn(mapper.call(context, v, k, c), k, this$0) !== false}, - reverse - ); - } - mappedSequence.__iteratorUncached = function (type, reverse) { - var iterator = iterable.__iterator(ITERATE_ENTRIES, reverse); - return new Iterator(function() { - var step = iterator.next(); - if (step.done) { - return step; - } - var entry = step.value; - var key = entry[0]; - return iteratorValue( - type, - key, - mapper.call(context, entry[1], key, iterable), - step - ); - }); - } - return mappedSequence; - } + flip: function() { + return reify(this, flipFactory(this)); + }, + mapEntries: function(mapper, context) {var this$0 = this; + var iterations = 0; + return reify(this, + this.toSeq().map( + function(v, k) {return mapper.call(context, [k, v], iterations++, this$0)} + ).fromEntrySeq() + ); + }, - function reverseFactory(iterable, useKeys) { - var reversedSequence = makeSequence(iterable); - reversedSequence._iter = iterable; - reversedSequence.size = iterable.size; - reversedSequence.reverse = function() {return iterable}; - if (iterable.flip) { - reversedSequence.flip = function () { - var flipSequence = flipFactory(iterable); - flipSequence.reverse = function() {return iterable.flip()}; - return flipSequence; - }; + mapKeys: function(mapper, context) {var this$0 = this; + return reify(this, + this.toSeq().flip().map( + function(k, v) {return mapper.call(context, k, v, this$0)} + ).flip() + ); } - reversedSequence.get = function(key, notSetValue) - {return iterable.get(useKeys ? key : -1 - key, notSetValue)}; - reversedSequence.has = function(key ) - {return iterable.has(useKeys ? key : -1 - key)}; - reversedSequence.includes = function(value ) {return iterable.includes(value)}; - reversedSequence.cacheResult = cacheResultThrough; - reversedSequence.__iterate = function (fn, reverse) {var this$0 = this; - return iterable.__iterate(function(v, k) {return fn(v, k, this$0)}, !reverse); - }; - reversedSequence.__iterator = - function(type, reverse) {return iterable.__iterator(type, !reverse)}; - return reversedSequence; - } + }); - function filterFactory(iterable, predicate, context, useKeys) { - var filterSequence = makeSequence(iterable); - if (useKeys) { - filterSequence.has = function(key ) { - var v = iterable.get(key, NOT_SET); - return v !== NOT_SET && !!predicate.call(context, v, key, iterable); - }; - filterSequence.get = function(key, notSetValue) { - var v = iterable.get(key, NOT_SET); - return v !== NOT_SET && predicate.call(context, v, key, iterable) ? - v : notSetValue; - }; - } - filterSequence.__iterateUncached = function (fn, reverse) {var this$0 = this; - var iterations = 0; - iterable.__iterate(function(v, k, c) { - if (predicate.call(context, v, k, c)) { - iterations++; - return fn(v, useKeys ? k : iterations - 1, this$0); - } - }, reverse); - return iterations; - }; - filterSequence.__iteratorUncached = function (type, reverse) { - var iterator = iterable.__iterator(ITERATE_ENTRIES, reverse); - var iterations = 0; - return new Iterator(function() { - while (true) { - var step = iterator.next(); - if (step.done) { - return step; - } - var entry = step.value; - var key = entry[0]; - var value = entry[1]; - if (predicate.call(context, value, key, iterable)) { - return iteratorValue(type, useKeys ? key : iterations++, value, step); - } - } - }); - } - return filterSequence; - } + var KeyedIterablePrototype = KeyedIterable.prototype; + KeyedIterablePrototype[IS_KEYED_SENTINEL] = true; + KeyedIterablePrototype[ITERATOR_SYMBOL] = IterablePrototype.entries; + KeyedIterablePrototype.__toJS = IterablePrototype.toObject; + KeyedIterablePrototype.__toStringMapper = function(v, k) {return JSON.stringify(k) + ': ' + quoteString(v)}; - function countByFactory(iterable, grouper, context) { - var groups = Map().asMutable(); - iterable.__iterate(function(v, k) { - groups.update( - grouper.call(context, v, k, iterable), - 0, - function(a ) {return a + 1} - ); - }); - return groups.asImmutable(); - } + mixin(IndexedIterable, { - function groupByFactory(iterable, grouper, context) { - var isKeyedIter = isKeyed(iterable); - var groups = (isOrdered(iterable) ? OrderedMap() : Map()).asMutable(); - iterable.__iterate(function(v, k) { - groups.update( - grouper.call(context, v, k, iterable), - function(a ) {return (a = a || [], a.push(isKeyedIter ? [k, v] : v), a)} - ); - }); - var coerce = iterableClass(iterable); - return groups.map(function(arr ) {return reify(iterable, coerce(arr))}); - } + // ### Conversion to other types + toKeyedSeq: function() { + return new ToKeyedSequence(this, false); + }, - function sliceFactory(iterable, begin, end, useKeys) { - var originalSize = iterable.size; - // Sanitize begin & end using this shorthand for ToInt32(argument) - // http://www.ecma-international.org/ecma-262/6.0/#sec-toint32 - if (begin !== undefined) { - begin = begin | 0; - } - if (end !== undefined) { - if (end === Infinity) { - end = originalSize; - } else { - end = end | 0; - } - } + // ### ES6 Collection methods (ES6 Array and Map) - if (wholeSlice(begin, end, originalSize)) { - return iterable; - } + filter: function(predicate, context) { + return reify(this, filterFactory(this, predicate, context, false)); + }, - var resolvedBegin = resolveBegin(begin, originalSize); - var resolvedEnd = resolveEnd(end, originalSize); + findIndex: function(predicate, context) { + var entry = this.findEntry(predicate, context); + return entry ? entry[0] : -1; + }, - // begin or end will be NaN if they were provided as negative numbers and - // this iterable's size is unknown. In that case, cache first so there is - // a known size and these do not resolve to NaN. - if (resolvedBegin !== resolvedBegin || resolvedEnd !== resolvedEnd) { - return sliceFactory(iterable.toSeq().cacheResult(), begin, end, useKeys); - } + indexOf: function(searchValue) { + var key = this.keyOf(searchValue); + return key === undefined ? -1 : key; + }, - // Note: resolvedEnd is undefined when the original sequence's length is - // unknown and this slice did not supply an end and should contain all - // elements after resolvedBegin. - // In that case, resolvedSize will be NaN and sliceSize will remain undefined. - var resolvedSize = resolvedEnd - resolvedBegin; - var sliceSize; - if (resolvedSize === resolvedSize) { - sliceSize = resolvedSize < 0 ? 0 : resolvedSize; - } + lastIndexOf: function(searchValue) { + var key = this.lastKeyOf(searchValue); + return key === undefined ? -1 : key; + }, - var sliceSeq = makeSequence(iterable); + reverse: function() { + return reify(this, reverseFactory(this, false)); + }, - // If iterable.size is undefined, the size of the realized sliceSeq is - // unknown at this point unless the number of items to slice is 0 - sliceSeq.size = sliceSize === 0 ? sliceSize : iterable.size && sliceSize || undefined; + slice: function(begin, end) { + return reify(this, sliceFactory(this, begin, end, false)); + }, - if (!useKeys && isSeq(iterable) && sliceSize >= 0) { - sliceSeq.get = function (index, notSetValue) { - index = wrapIndex(this, index); - return index >= 0 && index < sliceSize ? - iterable.get(index + resolvedBegin, notSetValue) : - notSetValue; + splice: function(index, removeNum /*, ...values*/) { + var numArgs = arguments.length; + removeNum = Math.max(removeNum | 0, 0); + if (numArgs === 0 || (numArgs === 2 && !removeNum)) { + return this; } - } + // If index is negative, it should resolve relative to the size of the + // collection. However size may be expensive to compute if not cached, so + // only call count() if the number is in fact negative. + index = resolveBegin(index, index < 0 ? this.count() : this.size); + var spliced = this.slice(0, index); + return reify( + this, + numArgs === 1 ? + spliced : + spliced.concat(arrCopy(arguments, 2), this.slice(index + removeNum)) + ); + }, - sliceSeq.__iterateUncached = function(fn, reverse) {var this$0 = this; - if (sliceSize === 0) { - return 0; - } - if (reverse) { - return this.cacheResult().__iterate(fn, reverse); - } - var skipped = 0; - var isSkipping = true; - var iterations = 0; - iterable.__iterate(function(v, k) { - if (!(isSkipping && (isSkipping = skipped++ < resolvedBegin))) { - iterations++; - return fn(v, useKeys ? k : iterations - 1, this$0) !== false && - iterations !== sliceSize; - } - }); - return iterations; - }; - sliceSeq.__iteratorUncached = function(type, reverse) { - if (sliceSize !== 0 && reverse) { - return this.cacheResult().__iterator(type, reverse); - } - // Don't bother instantiating parent iterator if taking 0. - var iterator = sliceSize !== 0 && iterable.__iterator(type, reverse); - var skipped = 0; - var iterations = 0; - return new Iterator(function() { - while (skipped++ < resolvedBegin) { - iterator.next(); - } - if (++iterations > sliceSize) { - return iteratorDone(); - } - var step = iterator.next(); - if (useKeys || type === ITERATE_VALUES) { - return step; - } else if (type === ITERATE_KEYS) { - return iteratorValue(type, iterations - 1, undefined, step); - } else { - return iteratorValue(type, iterations - 1, step.value[1], step); - } - }); - } + // ### More collection methods - return sliceSeq; - } + findLastIndex: function(predicate, context) { + var entry = this.findLastEntry(predicate, context); + return entry ? entry[0] : -1; + }, + + first: function() { + return this.get(0); + }, + flatten: function(depth) { + return reify(this, flattenFactory(this, depth, false)); + }, - function takeWhileFactory(iterable, predicate, context) { - var takeSequence = makeSequence(iterable); - takeSequence.__iterateUncached = function(fn, reverse) {var this$0 = this; - if (reverse) { - return this.cacheResult().__iterate(fn, reverse); - } - var iterations = 0; - iterable.__iterate(function(v, k, c) - {return predicate.call(context, v, k, c) && ++iterations && fn(v, k, this$0)} + get: function(index, notSetValue) { + index = wrapIndex(this, index); + return (index < 0 || (this.size === Infinity || + (this.size !== undefined && index > this.size))) ? + notSetValue : + this.find(function(_, key) {return key === index}, undefined, notSetValue); + }, + + has: function(index) { + index = wrapIndex(this, index); + return index >= 0 && (this.size !== undefined ? + this.size === Infinity || index < this.size : + this.indexOf(index) !== -1 ); - return iterations; - }; - takeSequence.__iteratorUncached = function(type, reverse) {var this$0 = this; - if (reverse) { - return this.cacheResult().__iterator(type, reverse); - } - var iterator = iterable.__iterator(ITERATE_ENTRIES, reverse); - var iterating = true; - return new Iterator(function() { - if (!iterating) { - return iteratorDone(); - } - var step = iterator.next(); - if (step.done) { - return step; - } - var entry = step.value; - var k = entry[0]; - var v = entry[1]; - if (!predicate.call(context, v, k, this$0)) { - iterating = false; - return iteratorDone(); - } - return type === ITERATE_ENTRIES ? step : - iteratorValue(type, k, v, step); - }); - }; - return takeSequence; - } + }, + interpose: function(separator) { + return reify(this, interposeFactory(this, separator)); + }, - function skipWhileFactory(iterable, predicate, context, useKeys) { - var skipSequence = makeSequence(iterable); - skipSequence.__iterateUncached = function (fn, reverse) {var this$0 = this; - if (reverse) { - return this.cacheResult().__iterate(fn, reverse); - } - var isSkipping = true; - var iterations = 0; - iterable.__iterate(function(v, k, c) { - if (!(isSkipping && (isSkipping = predicate.call(context, v, k, c)))) { - iterations++; - return fn(v, useKeys ? k : iterations - 1, this$0); - } - }); - return iterations; - }; - skipSequence.__iteratorUncached = function(type, reverse) {var this$0 = this; - if (reverse) { - return this.cacheResult().__iterator(type, reverse); + interleave: function(/*...iterables*/) { + var iterables = [this].concat(arrCopy(arguments)); + var zipped = zipWithFactory(this.toSeq(), IndexedSeq.of, iterables); + var interleaved = zipped.flatten(true); + if (zipped.size) { + interleaved.size = zipped.size * iterables.length; } - var iterator = iterable.__iterator(ITERATE_ENTRIES, reverse); - var skipping = true; - var iterations = 0; - return new Iterator(function() { - var step, k, v; - do { - step = iterator.next(); - if (step.done) { - if (useKeys || type === ITERATE_VALUES) { - return step; - } else if (type === ITERATE_KEYS) { - return iteratorValue(type, iterations++, undefined, step); - } else { - return iteratorValue(type, iterations++, step.value[1], step); - } - } - var entry = step.value; - k = entry[0]; - v = entry[1]; - skipping && (skipping = predicate.call(context, v, k, this$0)); - } while (skipping); - return type === ITERATE_ENTRIES ? step : - iteratorValue(type, k, v, step); - }); - }; - return skipSequence; - } + return reify(this, interleaved); + }, + keySeq: function() { + return Range(0, this.size); + }, - function concatFactory(iterable, values) { - var isKeyedIterable = isKeyed(iterable); - var iters = [iterable].concat(values).map(function(v ) { - if (!isIterable(v)) { - v = isKeyedIterable ? - keyedSeqFromValue(v) : - indexedSeqFromValue(Array.isArray(v) ? v : [v]); - } else if (isKeyedIterable) { - v = KeyedIterable(v); - } - return v; - }).filter(function(v ) {return v.size !== 0}); + last: function() { + return this.get(-1); + }, - if (iters.length === 0) { - return iterable; - } + skipWhile: function(predicate, context) { + return reify(this, skipWhileFactory(this, predicate, context, false)); + }, - if (iters.length === 1) { - var singleton = iters[0]; - if (singleton === iterable || - isKeyedIterable && isKeyed(singleton) || - isIndexed(iterable) && isIndexed(singleton)) { - return singleton; - } - } + zip: function(/*, ...iterables */) { + var iterables = [this].concat(arrCopy(arguments)); + return reify(this, zipWithFactory(this, defaultZipper, iterables)); + }, - var concatSeq = new ArraySeq(iters); - if (isKeyedIterable) { - concatSeq = concatSeq.toKeyedSeq(); - } else if (!isIndexed(iterable)) { - concatSeq = concatSeq.toSetSeq(); + zipWith: function(zipper/*, ...iterables */) { + var iterables = arrCopy(arguments); + iterables[0] = this; + return reify(this, zipWithFactory(this, zipper, iterables)); } - concatSeq = concatSeq.flatten(true); - concatSeq.size = iters.reduce( - function(sum, seq) { - if (sum !== undefined) { - var size = seq.size; - if (size !== undefined) { - return sum + size; - } - } - }, - 0 - ); - return concatSeq; - } + }); - function flattenFactory(iterable, depth, useKeys) { - var flatSequence = makeSequence(iterable); - flatSequence.__iterateUncached = function(fn, reverse) { - var iterations = 0; - var stopped = false; - function flatDeep(iter, currentDepth) {var this$0 = this; - iter.__iterate(function(v, k) { - if ((!depth || currentDepth < depth) && isIterable(v)) { - flatDeep(v, currentDepth + 1); - } else if (fn(v, useKeys ? k : iterations++, this$0) === false) { - stopped = true; - } - return !stopped; - }, reverse); - } - flatDeep(iterable, 0); - return iterations; - } - flatSequence.__iteratorUncached = function(type, reverse) { - var iterator = iterable.__iterator(type, reverse); - var stack = []; - var iterations = 0; - return new Iterator(function() { - while (iterator) { - var step = iterator.next(); - if (step.done !== false) { - iterator = stack.pop(); - continue; - } - var v = step.value; - if (type === ITERATE_ENTRIES) { - v = v[1]; - } - if ((!depth || stack.length < depth) && isIterable(v)) { - stack.push(iterator); - iterator = v.__iterator(type, reverse); - } else { - return useKeys ? step : iteratorValue(type, iterations++, v, step); - } - } - return iteratorDone(); - }); - } - return flatSequence; - } + IndexedIterable.prototype[IS_INDEXED_SENTINEL] = true; + IndexedIterable.prototype[IS_ORDERED_SENTINEL] = true; - function flatMapFactory(iterable, mapper, context) { - var coerce = iterableClass(iterable); - return iterable.toSeq().map( - function(v, k) {return coerce(mapper.call(context, v, k, iterable))} - ).flatten(true); - } + mixin(SetIterable, { - function interposeFactory(iterable, separator) { - var interposedSequence = makeSequence(iterable); - interposedSequence.size = iterable.size && iterable.size * 2 -1; - interposedSequence.__iterateUncached = function(fn, reverse) {var this$0 = this; - var iterations = 0; - iterable.__iterate(function(v, k) - {return (!iterations || fn(separator, iterations++, this$0) !== false) && - fn(v, iterations++, this$0) !== false}, - reverse - ); - return iterations; - }; - interposedSequence.__iteratorUncached = function(type, reverse) { - var iterator = iterable.__iterator(ITERATE_VALUES, reverse); - var iterations = 0; - var step; - return new Iterator(function() { - if (!step || iterations % 2) { - step = iterator.next(); - if (step.done) { - return step; - } - } - return iterations % 2 ? - iteratorValue(type, iterations++, separator) : - iteratorValue(type, iterations++, step.value, step); - }); - }; - return interposedSequence; - } + // ### ES6 Collection methods (ES6 Array and Map) + get: function(value, notSetValue) { + return this.has(value) ? value : notSetValue; + }, - function sortFactory(iterable, comparator, mapper) { - if (!comparator) { - comparator = defaultComparator; - } - var isKeyedIterable = isKeyed(iterable); - var index = 0; - var entries = iterable.toSeq().map( - function(v, k) {return [k, v, index++, mapper ? mapper(v, k, iterable) : v]} - ).toArray(); - entries.sort(function(a, b) {return comparator(a[3], b[3]) || a[2] - b[2]}).forEach( - isKeyedIterable ? - function(v, i) { entries[i].length = 2; } : - function(v, i) { entries[i] = v[1]; } - ); - return isKeyedIterable ? KeyedSeq(entries) : - isIndexed(iterable) ? IndexedSeq(entries) : - SetSeq(entries); - } + includes: function(value) { + return this.has(value); + }, - function maxFactory(iterable, comparator, mapper) { - if (!comparator) { - comparator = defaultComparator; - } - if (mapper) { - var entry = iterable.toSeq() - .map(function(v, k) {return [v, mapper(v, k, iterable)]}) - .reduce(function(a, b) {return maxCompare(comparator, a[1], b[1]) ? b : a}); - return entry && entry[0]; - } else { - return iterable.reduce(function(a, b) {return maxCompare(comparator, a, b) ? b : a}); + // ### More sequential methods + + keySeq: function() { + return this.valueSeq(); } - } - function maxCompare(comparator, a, b) { - var comp = comparator(b, a); - // b is considered the new max if the comparator declares them equal, but - // they are not equal and b is in fact a nullish value. - return (comp === 0 && b !== a && (b === undefined || b === null || b !== b)) || comp > 0; - } + }); + SetIterable.prototype.has = IterablePrototype.includes; + SetIterable.prototype.contains = SetIterable.prototype.includes; - function zipWithFactory(keyIter, zipper, iters) { - var zipSequence = makeSequence(keyIter); - zipSequence.size = new ArraySeq(iters).map(function(i ) {return i.size}).min(); - // Note: this a generic base implementation of __iterate in terms of - // __iterator which may be more generically useful in the future. - zipSequence.__iterate = function(fn, reverse) { - /* generic: - var iterator = this.__iterator(ITERATE_ENTRIES, reverse); - var step; - var iterations = 0; - while (!(step = iterator.next()).done) { - iterations++; - if (fn(step.value[1], step.value[0], this) === false) { - break; - } - } - return iterations; - */ - // indexed: - var iterator = this.__iterator(ITERATE_VALUES, reverse); - var step; - var iterations = 0; - while (!(step = iterator.next()).done) { - if (fn(step.value, iterations++, this) === false) { - break; - } - } - return iterations; - }; - zipSequence.__iteratorUncached = function(type, reverse) { - var iterators = iters.map(function(i ) - {return (i = Iterable(i), getIterator(reverse ? i.reverse() : i))} - ); - var iterations = 0; - var isDone = false; - return new Iterator(function() { - var steps; - if (!isDone) { - steps = iterators.map(function(i ) {return i.next()}); - isDone = steps.some(function(s ) {return s.done}); - } - if (isDone) { - return iteratorDone(); - } - return iteratorValue( - type, - iterations++, - zipper.apply(null, steps.map(function(s ) {return s.value})) - ); - }); - }; - return zipSequence - } + // Mixin subclasses - // #pragma Helper Functions + mixin(KeyedSeq, KeyedIterable.prototype); + mixin(IndexedSeq, IndexedIterable.prototype); + mixin(SetSeq, SetIterable.prototype); - function reify(iter, seq) { - return isSeq(iter) ? seq : iter.constructor(seq); + mixin(KeyedCollection, KeyedIterable.prototype); + mixin(IndexedCollection, IndexedIterable.prototype); + mixin(SetCollection, SetIterable.prototype); + + + // #pragma Helper functions + + function keyMapper(v, k) { + return k; } - function validateEntry(entry) { - if (entry !== Object(entry)) { - throw new TypeError('Expected [K, V] tuple: ' + entry); - } + function entryMapper(v, k) { + return [k, v]; } - function resolveSize(iter) { - assertNotInfinite(iter.size); - return ensureSize(iter); + function not(predicate) { + return function() { + return !predicate.apply(this, arguments); + } } - function iterableClass(iterable) { - return isKeyed(iterable) ? KeyedIterable : - isIndexed(iterable) ? IndexedIterable : - SetIterable; + function neg(predicate) { + return function() { + return -predicate.apply(this, arguments); + } } - function makeSequence(iterable) { - return Object.create( - ( - isKeyed(iterable) ? KeyedSeq : - isIndexed(iterable) ? IndexedSeq : - SetSeq - ).prototype - ); + function quoteString(value) { + return typeof value === 'string' ? JSON.stringify(value) : String(value); } - function cacheResultThrough() { - if (this._iter.cacheResult) { - this._iter.cacheResult(); - this.size = this._iter.size; - return this; - } else { - return Seq.prototype.cacheResult.call(this); - } + function defaultZipper() { + return arrCopy(arguments); } - function defaultComparator(a, b) { - return a > b ? 1 : a < b ? -1 : 0; + function defaultNegComparator(a, b) { + return a < b ? 1 : a > b ? -1 : 0; } - function forceIterator(keyPath) { - var iter = getIterator(keyPath); - if (!iter) { - // Array might not be iterable in this environment, so we need a fallback - // to our wrapped type. - if (!isArrayLike(keyPath)) { - throw new TypeError('Expected iterable or array-like: ' + keyPath); - } - iter = getIterator(Iterable(keyPath)); + function hashIterable(iterable) { + if (iterable.size === Infinity) { + return 0; } - return iter; + var ordered = isOrdered(iterable); + var keyed = isKeyed(iterable); + var h = ordered ? 1 : 0; + var size = iterable.__iterate( + keyed ? + ordered ? + function(v, k) { h = 31 * h + hashMerge(hash(v), hash(k)) | 0; } : + function(v, k) { h = h + hashMerge(hash(v), hash(k)) | 0; } : + ordered ? + function(v ) { h = 31 * h + hash(v) | 0; } : + function(v ) { h = h + hash(v) | 0; } + ); + return murmurHashOfSize(size, h); } - createClass(Record, KeyedCollection); + function murmurHashOfSize(size, h) { + h = imul(h, 0xCC9E2D51); + h = imul(h << 15 | h >>> -15, 0x1B873593); + h = imul(h << 13 | h >>> -13, 5); + h = (h + 0xE6546B64 | 0) ^ size; + h = imul(h ^ h >>> 16, 0x85EBCA6B); + h = imul(h ^ h >>> 13, 0xC2B2AE35); + h = smi(h ^ h >>> 16); + return h; + } - function Record(defaultValues, name) { - var hasInitialized; + function hashMerge(a, b) { + return a ^ b + 0x9E3779B9 + (a << 6) + (a >> 2) | 0; // int + } - var RecordType = function Record(values) { - if (values instanceof RecordType) { - return values; - } - if (!(this instanceof RecordType)) { - return new RecordType(values); - } - if (!hasInitialized) { - hasInitialized = true; - var keys = Object.keys(defaultValues); - setProps(RecordTypePrototype, keys); - RecordTypePrototype.size = keys.length; - RecordTypePrototype._name = name; - RecordTypePrototype._keys = keys; - RecordTypePrototype._defaultValues = defaultValues; - } - this._map = Map(values); - }; + var Immutable = { - var RecordTypePrototype = RecordType.prototype = Object.create(RecordPrototype); - RecordTypePrototype.constructor = RecordType; + Iterable: Iterable, - return RecordType; - } + Seq: Seq, + Collection: Collection, + Map: Map, + OrderedMap: OrderedMap, + List: List, + Stack: Stack, + Set: Set, + OrderedSet: OrderedSet, - Record.prototype.toString = function() { - return this.__toString(recordName(this) + ' {', '}'); - }; + Record: Record, + Range: Range, + Repeat: Repeat, - // @pragma Access + is: is, + fromJS: fromJS - Record.prototype.has = function(k) { - return this._defaultValues.hasOwnProperty(k); - }; + }; - Record.prototype.get = function(k, notSetValue) { - if (!this.has(k)) { - return notSetValue; - } - var defaultVal = this._defaultValues[k]; - return this._map ? this._map.get(k, defaultVal) : defaultVal; - }; + return Immutable; - // @pragma Modification + })); - Record.prototype.clear = function() { - if (this.__ownerID) { - this._map && this._map.clear(); - return this; - } - var RecordType = this.constructor; - return RecordType._empty || (RecordType._empty = makeRecord(this, emptyMap())); - }; +/***/ }, +/* 4 */ +/***/ function(module, exports, __webpack_require__) { - Record.prototype.set = function(k, v) { - if (!this.has(k)) { - throw new Error('Cannot set unknown key "' + k + '" on ' + recordName(this)); - } - if (this._map && !this._map.has(k)) { - var defaultVal = this._defaultValues[k]; - if (v === defaultVal) { - return this; - } - } - var newMap = this._map && this._map.set(k, v); - if (this.__ownerID || newMap === this._map) { - return this; - } - return makeRecord(this, newMap); - }; + "use strict"; - Record.prototype.remove = function(k) { - if (!this.has(k)) { - return this; - } - var newMap = this._map && this._map.remove(k); - if (this.__ownerID || newMap === this._map) { - return this; - } - return makeRecord(this, newMap); - }; + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.MonoidalReducer = exports.CloneReducer = undefined; + exports.default = reduce; - Record.prototype.wasAltered = function() { - return this._map.wasAltered(); - }; + var _cloneReducer = __webpack_require__(5); - Record.prototype.__iterator = function(type, reverse) {var this$0 = this; - return KeyedIterable(this._defaultValues).map(function(_, k) {return this$0.get(k)}).__iterator(type, reverse); - }; + Object.defineProperty(exports, "CloneReducer", { + enumerable: true, + get: function get() { + return _cloneReducer.default; + } + }); - Record.prototype.__iterate = function(fn, reverse) {var this$0 = this; - return KeyedIterable(this._defaultValues).map(function(_, k) {return this$0.get(k)}).__iterate(fn, reverse); - }; + var _monoidalReducer = __webpack_require__(7); - Record.prototype.__ensureOwner = function(ownerID) { - if (ownerID === this.__ownerID) { - return this; - } - var newMap = this._map && this._map.__ensureOwner(ownerID); - if (!ownerID) { - this.__ownerID = ownerID; - this._map = newMap; - return this; - } - return makeRecord(this, newMap, ownerID); - }; + Object.defineProperty(exports, "MonoidalReducer", { + enumerable: true, + get: function get() { + return _monoidalReducer.default; + } + }); + var _shiftSpec = __webpack_require__(6); - var RecordPrototype = Record.prototype; - RecordPrototype[DELETE] = RecordPrototype.remove; - RecordPrototype.deleteIn = - RecordPrototype.removeIn = MapPrototype.removeIn; - RecordPrototype.merge = MapPrototype.merge; - RecordPrototype.mergeWith = MapPrototype.mergeWith; - RecordPrototype.mergeIn = MapPrototype.mergeIn; - RecordPrototype.mergeDeep = MapPrototype.mergeDeep; - RecordPrototype.mergeDeepWith = MapPrototype.mergeDeepWith; - RecordPrototype.mergeDeepIn = MapPrototype.mergeDeepIn; - RecordPrototype.setIn = MapPrototype.setIn; - RecordPrototype.update = MapPrototype.update; - RecordPrototype.updateIn = MapPrototype.updateIn; - RecordPrototype.withMutations = MapPrototype.withMutations; - RecordPrototype.asMutable = MapPrototype.asMutable; - RecordPrototype.asImmutable = MapPrototype.asImmutable; + var _shiftSpec2 = _interopRequireDefault(_shiftSpec); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - function makeRecord(likeRecord, map, ownerID) { - var record = Object.create(Object.getPrototypeOf(likeRecord)); - record._map = map; - record.__ownerID = ownerID; - return record; + function transformWithSpec(transformer, node, spec) { + switch (spec.typeName) { + case "Enum": + case "String": + case "Number": + case "Boolean": + case "SourceSpan": + return node; + case "Const": + // TODO: checked version + return transformWithSpec(transformer, node, spec.argument); + case "Maybe": + return node && transformWithSpec(transformer, node, spec.argument); + case "List": + return node.map(function (e) { + return transformWithSpec(transformer, e, spec.argument); + }); + case "Union": + // TODO: checked version + return transformWithSpec(transformer, node, _shiftSpec2.default[node.type]); + default: + var state = {}; + spec.fields.forEach(function (field) { + var v = transformWithSpec(transformer, node[field.name], field.type); + state[field.name] = v == null ? null : v; + }); + if (typeof transformer["reduce" + node.type] !== "function") { + throw new Error("Encountered " + node.type + ", which the provided reducer does not handle."); + } + return transformer["reduce" + node.type](node, state); } + } /** + * Copyright 2014 Shape Security, Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License") + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ - function recordName(record) { - return record._name || record.constructor.name || 'Record'; - } + function reduce(reducer, reducible) { + return transformWithSpec(reducer, reducible, _shiftSpec2.default[reducible.type]); + } - function setProps(prototype, names) { - try { - names.forEach(setProp.bind(undefined, prototype)); - } catch (error) { - // Object.defineProperty failed. Probably IE8. - } - } +/***/ }, +/* 5 */ +/***/ function(module, exports, __webpack_require__) { - function setProp(prototype, name) { - Object.defineProperty(prototype, name, { - get: function() { - return this.get(name); - }, - set: function(value) { - invariant(this.__ownerID, 'Cannot set on an immutable record.'); - this.set(name, value); - } - }); - } + "use strict"; - createClass(Set, SetCollection); + Object.defineProperty(exports, "__esModule", { + value: true + }); - // @pragma Construction + var _shiftSpec = __webpack_require__(6); - function Set(value) { - return value === null || value === undefined ? emptySet() : - isSet(value) && !isOrdered(value) ? value : - emptySet().withMutations(function(set ) { - var iter = SetIterable(value); - assertNotInfinite(iter.size); - iter.forEach(function(v ) {return set.add(v)}); - }); - } + var _shiftSpec2 = _interopRequireDefault(_shiftSpec); - Set.of = function(/*...values*/) { - return this(arguments); - }; + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - Set.fromKeys = function(value) { - return this(KeyedIterable(value).keySeq()); - }; + function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } /** + * Copyright 2014 Shape Security, Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License") + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ - Set.prototype.toString = function() { - return this.__toString('Set {', '}'); - }; + var CloneReducer = function CloneReducer() { + _classCallCheck(this, CloneReducer); + }; - // @pragma Access + exports.default = CloneReducer; - Set.prototype.has = function(value) { - return this._map.has(value); - }; + for (var typeName in _shiftSpec2.default) { + var type = _shiftSpec2.default[typeName]; + Object.defineProperty(CloneReducer.prototype, "reduce" + typeName, { + value: function value(node, state) { + return state; + } + }); + } - // @pragma Modification +/***/ }, +/* 6 */ +/***/ function(module, exports) { - Set.prototype.add = function(value) { - return updateSet(this, this._map.set(value, true)); - }; + // Generated by src/generate-spec.js. - Set.prototype.remove = function(value) { - return updateSet(this, this._map.remove(value)); - }; + /** + * Copyright 2015 Shape Security, Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ - Set.prototype.clear = function() { - return updateSet(this, this._map.clear()); - }; + // Hack to make Babel6 import this as a module. + Object.defineProperty(exports, "__esModule", { + value: true + }); - // @pragma Composition + // Meta data generated from spec.idl. + exports.default = (function() { + var SPEC = {}; - Set.prototype.union = function() {var iters = SLICE$0.call(arguments, 0); - iters = iters.filter(function(x ) {return x.size !== 0}); - if (iters.length === 0) { - return this; - } - if (this.size === 0 && !this.__ownerID && iters.length === 1) { - return this.constructor(iters[0]); - } - return this.withMutations(function(set ) { - for (var ii = 0; ii < iters.length; ii++) { - SetIterable(iters[ii]).forEach(function(value ) {return set.add(value)}); - } - }); - }; + var BOOLEAN = { typeName: "Boolean" }; + var DOUBLE = { typeName: "Number" }; + var STRING = { typeName: "String" }; + function Maybe(arg) { return { typeName: "Maybe", argument: arg }; } + function List(arg) { return { typeName: "List", argument: arg }; } + function Const(arg) { return { typeName: "Const", argument: arg }; } + function Union() { return { typeName: "Union", arguments: [].slice.call(arguments, 0) }; } - Set.prototype.intersect = function() {var iters = SLICE$0.call(arguments, 0); - if (iters.length === 0) { - return this; - } - iters = iters.map(function(iter ) {return SetIterable(iter)}); - var originalSet = this; - return this.withMutations(function(set ) { - originalSet.forEach(function(value ) { - if (!iters.every(function(iter ) {return iter.includes(value)})) { - set.remove(value); - } - }); - }); - }; + var TYPE_INDICATOR = { + typeName: "Enum", + values: ["ArrayBinding", "ArrayExpression", "ArrowExpression", "AssignmentExpression", "BinaryExpression", "BindingIdentifier", "BindingProperty", "BindingPropertyIdentifier", "BindingPropertyProperty", "BindingWithDefault", "Block", "BlockStatement", "BreakStatement", "CallExpression", "CatchClause", "Class", "ClassDeclaration", "ClassElement", "ClassExpression", "CompoundAssignmentExpression", "ComputedMemberExpression", "ComputedPropertyName", "ConditionalExpression", "ContinueStatement", "DataProperty", "DebuggerStatement", "Directive", "DoWhileStatement", "EmptyStatement", "Export", "ExportAllFrom", "ExportDeclaration", "ExportDefault", "ExportFrom", "ExportSpecifier", "Expression", "ExpressionStatement", "ForInStatement", "ForOfStatement", "ForStatement", "FormalParameters", "Function", "FunctionBody", "FunctionDeclaration", "FunctionExpression", "Getter", "IdentifierExpression", "IfStatement", "Import", "ImportDeclaration", "ImportNamespace", "ImportSpecifier", "IterationStatement", "LabeledStatement", "LiteralBooleanExpression", "LiteralInfinityExpression", "LiteralNullExpression", "LiteralNumericExpression", "LiteralRegExpExpression", "LiteralStringExpression", "MemberExpression", "Method", "MethodDefinition", "Module", "NamedObjectProperty", "NewExpression", "NewTargetExpression", "Node", "ObjectBinding", "ObjectExpression", "ObjectProperty", "PropertyName", "ReturnStatement", "Script", "Setter", "ShorthandProperty", "SourceLocation", "SourceSpan", "SpreadElement", "Statement", "StaticMemberExpression", "StaticPropertyName", "Super", "SwitchCase", "SwitchDefault", "SwitchStatement", "SwitchStatementWithDefault", "TemplateElement", "TemplateExpression", "ThisExpression", "ThrowStatement", "TryCatchStatement", "TryFinallyStatement", "UnaryExpression", "UpdateExpression", "VariableDeclaration", "VariableDeclarationStatement", "VariableDeclarator", "WhileStatement", "WithStatement", "YieldExpression", "YieldGeneratorExpression"] + }; - Set.prototype.subtract = function() {var iters = SLICE$0.call(arguments, 0); - if (iters.length === 0) { - return this; - } - iters = iters.map(function(iter ) {return SetIterable(iter)}); - var originalSet = this; - return this.withMutations(function(set ) { - originalSet.forEach(function(value ) { - if (iters.some(function(iter ) {return iter.includes(value)})) { - set.remove(value); - } - }); - }); - }; + var VariableDeclarationKind = { + typeName: "Enum", + values: ["var", "let", "const"] + }; - Set.prototype.merge = function() { - return this.union.apply(this, arguments); - }; + var CompoundAssignmentOperator = { + typeName: "Enum", + values: ["+=", "-=", "*=", "/=", "%=", "<<=", ">>=", ">>>=", "|=", "^=", "&="] + }; - Set.prototype.mergeWith = function(merger) {var iters = SLICE$0.call(arguments, 1); - return this.union.apply(this, iters); - }; + var BinaryOperator = { + typeName: "Enum", + values: ["==", "!=", "===", "!==", "<", "<=", ">", ">=", "in", "instanceof", "<<", ">>", ">>>", "+", "-", "*", "/", "%", ",", "||", "&&", "|", "^", "&"] + }; - Set.prototype.sort = function(comparator) { - // Late binding - return OrderedSet(sortFactory(this, comparator)); - }; + var UnaryOperator = { + typeName: "Enum", + values: ["+", "-", "!", "~", "typeof", "void", "delete"] + }; - Set.prototype.sortBy = function(mapper, comparator) { - // Late binding - return OrderedSet(sortFactory(this, comparator, mapper)); - }; + var UpdateOperator = { + typeName: "Enum", + values: ["++", "--"] + }; - Set.prototype.wasAltered = function() { - return this._map.wasAltered(); - }; + var SourceLocation = SPEC.SourceLocation = {}; + var SourceSpan = SPEC.SourceSpan = {}; + var BindingWithDefault = SPEC.BindingWithDefault = {}; + var BindingIdentifier = SPEC.BindingIdentifier = {}; + var ArrayBinding = SPEC.ArrayBinding = {}; + var ObjectBinding = SPEC.ObjectBinding = {}; + var BindingPropertyIdentifier = SPEC.BindingPropertyIdentifier = {}; + var BindingPropertyProperty = SPEC.BindingPropertyProperty = {}; + var ClassExpression = SPEC.ClassExpression = {}; + var ClassDeclaration = SPEC.ClassDeclaration = {}; + var ClassElement = SPEC.ClassElement = {}; + var Module = SPEC.Module = {}; + var Import = SPEC.Import = {}; + var ImportNamespace = SPEC.ImportNamespace = {}; + var ImportSpecifier = SPEC.ImportSpecifier = {}; + var ExportAllFrom = SPEC.ExportAllFrom = {}; + var ExportFrom = SPEC.ExportFrom = {}; + var Export = SPEC.Export = {}; + var ExportDefault = SPEC.ExportDefault = {}; + var ExportSpecifier = SPEC.ExportSpecifier = {}; + var Method = SPEC.Method = {}; + var Getter = SPEC.Getter = {}; + var Setter = SPEC.Setter = {}; + var DataProperty = SPEC.DataProperty = {}; + var ShorthandProperty = SPEC.ShorthandProperty = {}; + var ComputedPropertyName = SPEC.ComputedPropertyName = {}; + var StaticPropertyName = SPEC.StaticPropertyName = {}; + var LiteralBooleanExpression = SPEC.LiteralBooleanExpression = {}; + var LiteralInfinityExpression = SPEC.LiteralInfinityExpression = {}; + var LiteralNullExpression = SPEC.LiteralNullExpression = {}; + var LiteralNumericExpression = SPEC.LiteralNumericExpression = {}; + var LiteralRegExpExpression = SPEC.LiteralRegExpExpression = {}; + var LiteralStringExpression = SPEC.LiteralStringExpression = {}; + var ArrayExpression = SPEC.ArrayExpression = {}; + var ArrowExpression = SPEC.ArrowExpression = {}; + var AssignmentExpression = SPEC.AssignmentExpression = {}; + var BinaryExpression = SPEC.BinaryExpression = {}; + var CallExpression = SPEC.CallExpression = {}; + var CompoundAssignmentExpression = SPEC.CompoundAssignmentExpression = {}; + var ComputedMemberExpression = SPEC.ComputedMemberExpression = {}; + var ConditionalExpression = SPEC.ConditionalExpression = {}; + var FunctionExpression = SPEC.FunctionExpression = {}; + var IdentifierExpression = SPEC.IdentifierExpression = {}; + var NewExpression = SPEC.NewExpression = {}; + var NewTargetExpression = SPEC.NewTargetExpression = {}; + var ObjectExpression = SPEC.ObjectExpression = {}; + var UnaryExpression = SPEC.UnaryExpression = {}; + var StaticMemberExpression = SPEC.StaticMemberExpression = {}; + var TemplateExpression = SPEC.TemplateExpression = {}; + var ThisExpression = SPEC.ThisExpression = {}; + var UpdateExpression = SPEC.UpdateExpression = {}; + var YieldExpression = SPEC.YieldExpression = {}; + var YieldGeneratorExpression = SPEC.YieldGeneratorExpression = {}; + var BlockStatement = SPEC.BlockStatement = {}; + var BreakStatement = SPEC.BreakStatement = {}; + var ContinueStatement = SPEC.ContinueStatement = {}; + var DebuggerStatement = SPEC.DebuggerStatement = {}; + var DoWhileStatement = SPEC.DoWhileStatement = {}; + var EmptyStatement = SPEC.EmptyStatement = {}; + var ExpressionStatement = SPEC.ExpressionStatement = {}; + var ForInStatement = SPEC.ForInStatement = {}; + var ForOfStatement = SPEC.ForOfStatement = {}; + var ForStatement = SPEC.ForStatement = {}; + var IfStatement = SPEC.IfStatement = {}; + var LabeledStatement = SPEC.LabeledStatement = {}; + var ReturnStatement = SPEC.ReturnStatement = {}; + var SwitchStatement = SPEC.SwitchStatement = {}; + var SwitchStatementWithDefault = SPEC.SwitchStatementWithDefault = {}; + var ThrowStatement = SPEC.ThrowStatement = {}; + var TryCatchStatement = SPEC.TryCatchStatement = {}; + var TryFinallyStatement = SPEC.TryFinallyStatement = {}; + var VariableDeclarationStatement = SPEC.VariableDeclarationStatement = {}; + var WhileStatement = SPEC.WhileStatement = {}; + var WithStatement = SPEC.WithStatement = {}; + var Block = SPEC.Block = {}; + var CatchClause = SPEC.CatchClause = {}; + var Directive = SPEC.Directive = {}; + var FormalParameters = SPEC.FormalParameters = {}; + var FunctionBody = SPEC.FunctionBody = {}; + var FunctionDeclaration = SPEC.FunctionDeclaration = {}; + var Script = SPEC.Script = {}; + var SpreadElement = SPEC.SpreadElement = {}; + var Super = SPEC.Super = {}; + var SwitchCase = SPEC.SwitchCase = {}; + var SwitchDefault = SPEC.SwitchDefault = {}; + var TemplateElement = SPEC.TemplateElement = {}; + var VariableDeclaration = SPEC.VariableDeclaration = {}; + var VariableDeclarator = SPEC.VariableDeclarator = {}; - Set.prototype.__iterate = function(fn, reverse) {var this$0 = this; - return this._map.__iterate(function(_, k) {return fn(k, k, this$0)}, reverse); - }; + var Class = Union(ClassExpression, ClassDeclaration); + var BindingProperty = Union(BindingPropertyIdentifier, BindingPropertyProperty); + var ExportDeclaration = Union(ExportAllFrom, ExportFrom, Export, ExportDefault); + var ImportDeclaration = Union(Import, ImportNamespace); + var MethodDefinition = Union(Method, Getter, Setter); + var NamedObjectProperty = Union(MethodDefinition, DataProperty); + var ObjectProperty = Union(NamedObjectProperty, ShorthandProperty); + var PropertyName = Union(ComputedPropertyName, StaticPropertyName); + var MemberExpression = Union(ComputedMemberExpression, StaticMemberExpression); + var Expression = Union(MemberExpression, ClassExpression, LiteralBooleanExpression, LiteralInfinityExpression, LiteralNullExpression, LiteralNumericExpression, LiteralRegExpExpression, LiteralStringExpression, ArrayExpression, ArrowExpression, AssignmentExpression, BinaryExpression, CallExpression, CompoundAssignmentExpression, ConditionalExpression, FunctionExpression, IdentifierExpression, NewExpression, NewTargetExpression, ObjectExpression, UnaryExpression, TemplateExpression, ThisExpression, UpdateExpression, YieldExpression, YieldGeneratorExpression); + var IterationStatement = Union(DoWhileStatement, ForInStatement, ForOfStatement, ForStatement, WhileStatement); + var Statement = Union(IterationStatement, ClassDeclaration, BlockStatement, BreakStatement, ContinueStatement, DebuggerStatement, EmptyStatement, ExpressionStatement, IfStatement, LabeledStatement, ReturnStatement, SwitchStatement, SwitchStatementWithDefault, ThrowStatement, TryCatchStatement, TryFinallyStatement, VariableDeclarationStatement, WithStatement, FunctionDeclaration); + var Node = Union(Statement, Expression, PropertyName, ObjectProperty, ImportDeclaration, ExportDeclaration, BindingWithDefault, BindingIdentifier, ArrayBinding, ObjectBinding, BindingProperty, ClassElement, Module, ImportSpecifier, ExportSpecifier, Block, CatchClause, Directive, FormalParameters, FunctionBody, Script, SpreadElement, Super, SwitchCase, SwitchDefault, TemplateElement, VariableDeclaration, VariableDeclarator); + var Function = Union(FunctionExpression, FunctionDeclaration); - Set.prototype.__iterator = function(type, reverse) { - return this._map.map(function(_, k) {return k}).__iterator(type, reverse); - }; + SourceLocation.typeName = "SourceLocation"; + SourceLocation.fields = [ + { name: "line", type: DOUBLE }, + { name: "column", type: DOUBLE }, + { name: "offset", type: DOUBLE }, + ]; - Set.prototype.__ensureOwner = function(ownerID) { - if (ownerID === this.__ownerID) { - return this; - } - var newMap = this._map.__ensureOwner(ownerID); - if (!ownerID) { - this.__ownerID = ownerID; - this._map = newMap; - return this; - } - return this.__make(newMap, ownerID); - }; + SourceSpan.typeName = "SourceSpan"; + SourceSpan.fields = [ + { name: "source", type: Maybe(STRING) }, + { name: "start", type: SourceLocation }, + { name: "end", type: SourceLocation }, + ]; + BindingWithDefault.typeName = "BindingWithDefault"; + BindingWithDefault.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "BindingWithDefault" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "binding", type: Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression) }, + { name: "init", type: Expression }, + ]; - function isSet(maybeSet) { - return !!(maybeSet && maybeSet[IS_SET_SENTINEL]); - } + BindingIdentifier.typeName = "BindingIdentifier"; + BindingIdentifier.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "BindingIdentifier" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "name", type: STRING }, + ]; - Set.isSet = isSet; + ArrayBinding.typeName = "ArrayBinding"; + ArrayBinding.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ArrayBinding" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "elements", type: List(Maybe(Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression, BindingWithDefault))) }, + { name: "restElement", type: Maybe(Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression)) }, + ]; - var IS_SET_SENTINEL = '@@__IMMUTABLE_SET__@@'; + ObjectBinding.typeName = "ObjectBinding"; + ObjectBinding.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ObjectBinding" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "properties", type: List(BindingProperty) }, + ]; - var SetPrototype = Set.prototype; - SetPrototype[IS_SET_SENTINEL] = true; - SetPrototype[DELETE] = SetPrototype.remove; - SetPrototype.mergeDeep = SetPrototype.merge; - SetPrototype.mergeDeepWith = SetPrototype.mergeWith; - SetPrototype.withMutations = MapPrototype.withMutations; - SetPrototype.asMutable = MapPrototype.asMutable; - SetPrototype.asImmutable = MapPrototype.asImmutable; + BindingPropertyIdentifier.typeName = "BindingPropertyIdentifier"; + BindingPropertyIdentifier.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "BindingPropertyIdentifier" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "binding", type: BindingIdentifier }, + { name: "init", type: Maybe(Expression) }, + ]; - SetPrototype.__empty = emptySet; - SetPrototype.__make = makeSet; + BindingPropertyProperty.typeName = "BindingPropertyProperty"; + BindingPropertyProperty.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "BindingPropertyProperty" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "name", type: PropertyName }, + { name: "binding", type: Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression, BindingWithDefault) }, + ]; - function updateSet(set, newMap) { - if (set.__ownerID) { - set.size = newMap.size; - set._map = newMap; - return set; - } - return newMap === set._map ? set : - newMap.size === 0 ? set.__empty() : - set.__make(newMap); - } + ClassExpression.typeName = "ClassExpression"; + ClassExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ClassExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "name", type: Maybe(BindingIdentifier) }, + { name: "super", type: Maybe(Expression) }, + { name: "elements", type: List(ClassElement) }, + ]; - function makeSet(map, ownerID) { - var set = Object.create(SetPrototype); - set.size = map ? map.size : 0; - set._map = map; - set.__ownerID = ownerID; - return set; - } + ClassDeclaration.typeName = "ClassDeclaration"; + ClassDeclaration.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ClassDeclaration" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "name", type: BindingIdentifier }, + { name: "super", type: Maybe(Expression) }, + { name: "elements", type: List(ClassElement) }, + ]; - var EMPTY_SET; - function emptySet() { - return EMPTY_SET || (EMPTY_SET = makeSet(emptyMap())); - } + ClassElement.typeName = "ClassElement"; + ClassElement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ClassElement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "isStatic", type: BOOLEAN }, + { name: "method", type: MethodDefinition }, + ]; - createClass(OrderedSet, Set); + Module.typeName = "Module"; + Module.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "Module" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "directives", type: List(Directive) }, + { name: "items", type: List(Union(ImportDeclaration, ExportDeclaration, Statement)) }, + ]; - // @pragma Construction + Import.typeName = "Import"; + Import.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "Import" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "moduleSpecifier", type: STRING }, + { name: "defaultBinding", type: Maybe(BindingIdentifier) }, + { name: "namedImports", type: List(ImportSpecifier) }, + ]; - function OrderedSet(value) { - return value === null || value === undefined ? emptyOrderedSet() : - isOrderedSet(value) ? value : - emptyOrderedSet().withMutations(function(set ) { - var iter = SetIterable(value); - assertNotInfinite(iter.size); - iter.forEach(function(v ) {return set.add(v)}); - }); - } + ImportNamespace.typeName = "ImportNamespace"; + ImportNamespace.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ImportNamespace" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "moduleSpecifier", type: STRING }, + { name: "defaultBinding", type: Maybe(BindingIdentifier) }, + { name: "namespaceBinding", type: BindingIdentifier }, + ]; - OrderedSet.of = function(/*...values*/) { - return this(arguments); - }; + ImportSpecifier.typeName = "ImportSpecifier"; + ImportSpecifier.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ImportSpecifier" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "name", type: Maybe(STRING) }, + { name: "binding", type: BindingIdentifier }, + ]; - OrderedSet.fromKeys = function(value) { - return this(KeyedIterable(value).keySeq()); - }; + ExportAllFrom.typeName = "ExportAllFrom"; + ExportAllFrom.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ExportAllFrom" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "moduleSpecifier", type: STRING }, + ]; - OrderedSet.prototype.toString = function() { - return this.__toString('OrderedSet {', '}'); - }; + ExportFrom.typeName = "ExportFrom"; + ExportFrom.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ExportFrom" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "namedExports", type: List(ExportSpecifier) }, + { name: "moduleSpecifier", type: Maybe(STRING) }, + ]; + Export.typeName = "Export"; + Export.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "Export" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "declaration", type: Union(FunctionDeclaration, ClassDeclaration, VariableDeclaration) }, + ]; - function isOrderedSet(maybeOrderedSet) { - return isSet(maybeOrderedSet) && isOrdered(maybeOrderedSet); - } + ExportDefault.typeName = "ExportDefault"; + ExportDefault.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ExportDefault" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "body", type: Union(FunctionDeclaration, ClassDeclaration, Expression) }, + ]; - OrderedSet.isOrderedSet = isOrderedSet; + ExportSpecifier.typeName = "ExportSpecifier"; + ExportSpecifier.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ExportSpecifier" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "name", type: Maybe(STRING) }, + { name: "exportedName", type: STRING }, + ]; - var OrderedSetPrototype = OrderedSet.prototype; - OrderedSetPrototype[IS_ORDERED_SENTINEL] = true; + Method.typeName = "Method"; + Method.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "Method" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "name", type: PropertyName }, + { name: "isGenerator", type: BOOLEAN }, + { name: "params", type: FormalParameters }, + { name: "body", type: FunctionBody }, + ]; - OrderedSetPrototype.__empty = emptyOrderedSet; - OrderedSetPrototype.__make = makeOrderedSet; + Getter.typeName = "Getter"; + Getter.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "Getter" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "name", type: PropertyName }, + { name: "body", type: FunctionBody }, + ]; - function makeOrderedSet(map, ownerID) { - var set = Object.create(OrderedSetPrototype); - set.size = map ? map.size : 0; - set._map = map; - set.__ownerID = ownerID; - return set; - } + Setter.typeName = "Setter"; + Setter.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "Setter" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "name", type: PropertyName }, + { name: "param", type: Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression, BindingWithDefault) }, + { name: "body", type: FunctionBody }, + ]; - var EMPTY_ORDERED_SET; - function emptyOrderedSet() { - return EMPTY_ORDERED_SET || (EMPTY_ORDERED_SET = makeOrderedSet(emptyOrderedMap())); - } + DataProperty.typeName = "DataProperty"; + DataProperty.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "DataProperty" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "name", type: PropertyName }, + { name: "expression", type: Expression }, + ]; - createClass(Stack, IndexedCollection); + ShorthandProperty.typeName = "ShorthandProperty"; + ShorthandProperty.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ShorthandProperty" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "name", type: STRING }, + ]; - // @pragma Construction + ComputedPropertyName.typeName = "ComputedPropertyName"; + ComputedPropertyName.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ComputedPropertyName" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "expression", type: Expression }, + ]; - function Stack(value) { - return value === null || value === undefined ? emptyStack() : - isStack(value) ? value : - emptyStack().unshiftAll(value); - } + StaticPropertyName.typeName = "StaticPropertyName"; + StaticPropertyName.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "StaticPropertyName" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "value", type: STRING }, + ]; - Stack.of = function(/*...values*/) { - return this(arguments); - }; + LiteralBooleanExpression.typeName = "LiteralBooleanExpression"; + LiteralBooleanExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "LiteralBooleanExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "value", type: BOOLEAN }, + ]; - Stack.prototype.toString = function() { - return this.__toString('Stack [', ']'); - }; + LiteralInfinityExpression.typeName = "LiteralInfinityExpression"; + LiteralInfinityExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "LiteralInfinityExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + ]; - // @pragma Access + LiteralNullExpression.typeName = "LiteralNullExpression"; + LiteralNullExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "LiteralNullExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + ]; - Stack.prototype.get = function(index, notSetValue) { - var head = this._head; - index = wrapIndex(this, index); - while (head && index--) { - head = head.next; - } - return head ? head.value : notSetValue; - }; + LiteralNumericExpression.typeName = "LiteralNumericExpression"; + LiteralNumericExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "LiteralNumericExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "value", type: DOUBLE }, + ]; - Stack.prototype.peek = function() { - return this._head && this._head.value; - }; + LiteralRegExpExpression.typeName = "LiteralRegExpExpression"; + LiteralRegExpExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "LiteralRegExpExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "pattern", type: STRING }, + { name: "flags", type: STRING }, + ]; - // @pragma Modification + LiteralStringExpression.typeName = "LiteralStringExpression"; + LiteralStringExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "LiteralStringExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "value", type: STRING }, + ]; - Stack.prototype.push = function(/*...values*/) { - if (arguments.length === 0) { - return this; - } - var newSize = this.size + arguments.length; - var head = this._head; - for (var ii = arguments.length - 1; ii >= 0; ii--) { - head = { - value: arguments[ii], - next: head - }; - } - if (this.__ownerID) { - this.size = newSize; - this._head = head; - this.__hash = undefined; - this.__altered = true; - return this; - } - return makeStack(newSize, head); - }; + ArrayExpression.typeName = "ArrayExpression"; + ArrayExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ArrayExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "elements", type: List(Maybe(Union(SpreadElement, Expression))) }, + ]; - Stack.prototype.pushAll = function(iter) { - iter = IndexedIterable(iter); - if (iter.size === 0) { - return this; - } - assertNotInfinite(iter.size); - var newSize = this.size; - var head = this._head; - iter.reverse().forEach(function(value ) { - newSize++; - head = { - value: value, - next: head - }; - }); - if (this.__ownerID) { - this.size = newSize; - this._head = head; - this.__hash = undefined; - this.__altered = true; - return this; - } - return makeStack(newSize, head); - }; + ArrowExpression.typeName = "ArrowExpression"; + ArrowExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ArrowExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "params", type: FormalParameters }, + { name: "body", type: Union(FunctionBody, Expression) }, + ]; - Stack.prototype.pop = function() { - return this.slice(1); - }; + AssignmentExpression.typeName = "AssignmentExpression"; + AssignmentExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "AssignmentExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "binding", type: Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression) }, + { name: "expression", type: Expression }, + ]; - Stack.prototype.unshift = function(/*...values*/) { - return this.push.apply(this, arguments); - }; + BinaryExpression.typeName = "BinaryExpression"; + BinaryExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "BinaryExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "operator", type: BinaryOperator }, + { name: "left", type: Expression }, + { name: "right", type: Expression }, + ]; - Stack.prototype.unshiftAll = function(iter) { - return this.pushAll(iter); - }; + CallExpression.typeName = "CallExpression"; + CallExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "CallExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "callee", type: Union(Expression, Super) }, + { name: "arguments", type: List(Union(SpreadElement, Expression)) }, + ]; - Stack.prototype.shift = function() { - return this.pop.apply(this, arguments); - }; + CompoundAssignmentExpression.typeName = "CompoundAssignmentExpression"; + CompoundAssignmentExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "CompoundAssignmentExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "operator", type: CompoundAssignmentOperator }, + { name: "binding", type: Union(BindingIdentifier, MemberExpression) }, + { name: "expression", type: Expression }, + ]; - Stack.prototype.clear = function() { - if (this.size === 0) { - return this; - } - if (this.__ownerID) { - this.size = 0; - this._head = undefined; - this.__hash = undefined; - this.__altered = true; - return this; - } - return emptyStack(); - }; + ComputedMemberExpression.typeName = "ComputedMemberExpression"; + ComputedMemberExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ComputedMemberExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "object", type: Union(Expression, Super) }, + { name: "expression", type: Expression }, + ]; - Stack.prototype.slice = function(begin, end) { - if (wholeSlice(begin, end, this.size)) { - return this; - } - var resolvedBegin = resolveBegin(begin, this.size); - var resolvedEnd = resolveEnd(end, this.size); - if (resolvedEnd !== this.size) { - // super.slice(begin, end); - return IndexedCollection.prototype.slice.call(this, begin, end); - } - var newSize = this.size - resolvedBegin; - var head = this._head; - while (resolvedBegin--) { - head = head.next; - } - if (this.__ownerID) { - this.size = newSize; - this._head = head; - this.__hash = undefined; - this.__altered = true; - return this; - } - return makeStack(newSize, head); - }; + ConditionalExpression.typeName = "ConditionalExpression"; + ConditionalExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ConditionalExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "test", type: Expression }, + { name: "consequent", type: Expression }, + { name: "alternate", type: Expression }, + ]; - // @pragma Mutability + FunctionExpression.typeName = "FunctionExpression"; + FunctionExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "FunctionExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "isGenerator", type: BOOLEAN }, + { name: "name", type: Maybe(BindingIdentifier) }, + { name: "params", type: FormalParameters }, + { name: "body", type: FunctionBody }, + ]; - Stack.prototype.__ensureOwner = function(ownerID) { - if (ownerID === this.__ownerID) { - return this; - } - if (!ownerID) { - this.__ownerID = ownerID; - this.__altered = false; - return this; - } - return makeStack(this.size, this._head, ownerID, this.__hash); - }; + IdentifierExpression.typeName = "IdentifierExpression"; + IdentifierExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "IdentifierExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "name", type: STRING }, + ]; - // @pragma Iteration + NewExpression.typeName = "NewExpression"; + NewExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "NewExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "callee", type: Expression }, + { name: "arguments", type: List(Union(SpreadElement, Expression)) }, + ]; - Stack.prototype.__iterate = function(fn, reverse) { - if (reverse) { - return this.reverse().__iterate(fn); - } - var iterations = 0; - var node = this._head; - while (node) { - if (fn(node.value, iterations++, this) === false) { - break; - } - node = node.next; - } - return iterations; - }; + NewTargetExpression.typeName = "NewTargetExpression"; + NewTargetExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "NewTargetExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + ]; - Stack.prototype.__iterator = function(type, reverse) { - if (reverse) { - return this.reverse().__iterator(type); - } - var iterations = 0; - var node = this._head; - return new Iterator(function() { - if (node) { - var value = node.value; - node = node.next; - return iteratorValue(type, iterations++, value); - } - return iteratorDone(); - }); - }; + ObjectExpression.typeName = "ObjectExpression"; + ObjectExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ObjectExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "properties", type: List(ObjectProperty) }, + ]; + UnaryExpression.typeName = "UnaryExpression"; + UnaryExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "UnaryExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "operator", type: UnaryOperator }, + { name: "operand", type: Expression }, + ]; - function isStack(maybeStack) { - return !!(maybeStack && maybeStack[IS_STACK_SENTINEL]); - } + StaticMemberExpression.typeName = "StaticMemberExpression"; + StaticMemberExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "StaticMemberExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "object", type: Union(Expression, Super) }, + { name: "property", type: STRING }, + ]; - Stack.isStack = isStack; + TemplateExpression.typeName = "TemplateExpression"; + TemplateExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "TemplateExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "tag", type: Maybe(Expression) }, + { name: "elements", type: List(Union(Expression, TemplateElement)) }, + ]; - var IS_STACK_SENTINEL = '@@__IMMUTABLE_STACK__@@'; + ThisExpression.typeName = "ThisExpression"; + ThisExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ThisExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + ]; - var StackPrototype = Stack.prototype; - StackPrototype[IS_STACK_SENTINEL] = true; - StackPrototype.withMutations = MapPrototype.withMutations; - StackPrototype.asMutable = MapPrototype.asMutable; - StackPrototype.asImmutable = MapPrototype.asImmutable; - StackPrototype.wasAltered = MapPrototype.wasAltered; + UpdateExpression.typeName = "UpdateExpression"; + UpdateExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "UpdateExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "isPrefix", type: BOOLEAN }, + { name: "operator", type: UpdateOperator }, + { name: "operand", type: Union(BindingIdentifier, MemberExpression) }, + ]; + YieldExpression.typeName = "YieldExpression"; + YieldExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "YieldExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "expression", type: Maybe(Expression) }, + ]; - function makeStack(size, head, ownerID, hash) { - var map = Object.create(StackPrototype); - map.size = size; - map._head = head; - map.__ownerID = ownerID; - map.__hash = hash; - map.__altered = false; - return map; - } + YieldGeneratorExpression.typeName = "YieldGeneratorExpression"; + YieldGeneratorExpression.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "YieldGeneratorExpression" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "expression", type: Expression }, + ]; - var EMPTY_STACK; - function emptyStack() { - return EMPTY_STACK || (EMPTY_STACK = makeStack(0)); - } + BlockStatement.typeName = "BlockStatement"; + BlockStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "BlockStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "block", type: Block }, + ]; - /** - * Contributes additional methods to a constructor - */ - function mixin(ctor, methods) { - var keyCopier = function(key ) { ctor.prototype[key] = methods[key]; }; - Object.keys(methods).forEach(keyCopier); - Object.getOwnPropertySymbols && - Object.getOwnPropertySymbols(methods).forEach(keyCopier); - return ctor; - } + BreakStatement.typeName = "BreakStatement"; + BreakStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "BreakStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "label", type: Maybe(STRING) }, + ]; - Iterable.Iterator = Iterator; + ContinueStatement.typeName = "ContinueStatement"; + ContinueStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ContinueStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "label", type: Maybe(STRING) }, + ]; - mixin(Iterable, { + DebuggerStatement.typeName = "DebuggerStatement"; + DebuggerStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "DebuggerStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + ]; - // ### Conversion to other types + DoWhileStatement.typeName = "DoWhileStatement"; + DoWhileStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "DoWhileStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "body", type: Statement }, + { name: "test", type: Expression }, + ]; - toArray: function() { - assertNotInfinite(this.size); - var array = new Array(this.size || 0); - this.valueSeq().__iterate(function(v, i) { array[i] = v; }); - return array; - }, + EmptyStatement.typeName = "EmptyStatement"; + EmptyStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "EmptyStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + ]; - toIndexedSeq: function() { - return new ToIndexedSequence(this); - }, + ExpressionStatement.typeName = "ExpressionStatement"; + ExpressionStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ExpressionStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "expression", type: Expression }, + ]; - toJS: function() { - return this.toSeq().map( - function(value ) {return value && typeof value.toJS === 'function' ? value.toJS() : value} - ).__toJS(); - }, + ForInStatement.typeName = "ForInStatement"; + ForInStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ForInStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "left", type: Union(VariableDeclaration, ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression) }, + { name: "right", type: Expression }, + { name: "body", type: Statement }, + ]; - toJSON: function() { - return this.toSeq().map( - function(value ) {return value && typeof value.toJSON === 'function' ? value.toJSON() : value} - ).__toJS(); - }, + ForOfStatement.typeName = "ForOfStatement"; + ForOfStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ForOfStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "left", type: Union(VariableDeclaration, ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression) }, + { name: "right", type: Expression }, + { name: "body", type: Statement }, + ]; - toKeyedSeq: function() { - return new ToKeyedSequence(this, true); - }, + ForStatement.typeName = "ForStatement"; + ForStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ForStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "init", type: Maybe(Union(VariableDeclaration, Expression)) }, + { name: "test", type: Maybe(Expression) }, + { name: "update", type: Maybe(Expression) }, + { name: "body", type: Statement }, + ]; - toMap: function() { - // Use Late Binding here to solve the circular dependency. - return Map(this.toKeyedSeq()); - }, + IfStatement.typeName = "IfStatement"; + IfStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "IfStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "test", type: Expression }, + { name: "consequent", type: Statement }, + { name: "alternate", type: Maybe(Statement) }, + ]; - toObject: function() { - assertNotInfinite(this.size); - var object = {}; - this.__iterate(function(v, k) { object[k] = v; }); - return object; - }, + LabeledStatement.typeName = "LabeledStatement"; + LabeledStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "LabeledStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "label", type: STRING }, + { name: "body", type: Statement }, + ]; - toOrderedMap: function() { - // Use Late Binding here to solve the circular dependency. - return OrderedMap(this.toKeyedSeq()); - }, + ReturnStatement.typeName = "ReturnStatement"; + ReturnStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ReturnStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "expression", type: Maybe(Expression) }, + ]; - toOrderedSet: function() { - // Use Late Binding here to solve the circular dependency. - return OrderedSet(isKeyed(this) ? this.valueSeq() : this); - }, + SwitchStatement.typeName = "SwitchStatement"; + SwitchStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "SwitchStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "discriminant", type: Expression }, + { name: "cases", type: List(SwitchCase) }, + ]; - toSet: function() { - // Use Late Binding here to solve the circular dependency. - return Set(isKeyed(this) ? this.valueSeq() : this); - }, + SwitchStatementWithDefault.typeName = "SwitchStatementWithDefault"; + SwitchStatementWithDefault.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "SwitchStatementWithDefault" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "discriminant", type: Expression }, + { name: "preDefaultCases", type: List(SwitchCase) }, + { name: "defaultCase", type: SwitchDefault }, + { name: "postDefaultCases", type: List(SwitchCase) }, + ]; - toSetSeq: function() { - return new ToSetSequence(this); - }, + ThrowStatement.typeName = "ThrowStatement"; + ThrowStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "ThrowStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "expression", type: Expression }, + ]; - toSeq: function() { - return isIndexed(this) ? this.toIndexedSeq() : - isKeyed(this) ? this.toKeyedSeq() : - this.toSetSeq(); - }, + TryCatchStatement.typeName = "TryCatchStatement"; + TryCatchStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "TryCatchStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "body", type: Block }, + { name: "catchClause", type: CatchClause }, + ]; - toStack: function() { - // Use Late Binding here to solve the circular dependency. - return Stack(isKeyed(this) ? this.valueSeq() : this); - }, + TryFinallyStatement.typeName = "TryFinallyStatement"; + TryFinallyStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "TryFinallyStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "body", type: Block }, + { name: "catchClause", type: Maybe(CatchClause) }, + { name: "finalizer", type: Block }, + ]; - toList: function() { - // Use Late Binding here to solve the circular dependency. - return List(isKeyed(this) ? this.valueSeq() : this); - }, + VariableDeclarationStatement.typeName = "VariableDeclarationStatement"; + VariableDeclarationStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "VariableDeclarationStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "declaration", type: VariableDeclaration }, + ]; + WhileStatement.typeName = "WhileStatement"; + WhileStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "WhileStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "test", type: Expression }, + { name: "body", type: Statement }, + ]; - // ### Common JavaScript methods and properties + WithStatement.typeName = "WithStatement"; + WithStatement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "WithStatement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "object", type: Expression }, + { name: "body", type: Statement }, + ]; - toString: function() { - return '[Iterable]'; - }, + Block.typeName = "Block"; + Block.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "Block" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "statements", type: List(Statement) }, + ]; - __toString: function(head, tail) { - if (this.size === 0) { - return head + tail; - } - return head + ' ' + this.toSeq().map(this.__toStringMapper).join(', ') + ' ' + tail; - }, + CatchClause.typeName = "CatchClause"; + CatchClause.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "CatchClause" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "binding", type: Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression) }, + { name: "body", type: Block }, + ]; + Directive.typeName = "Directive"; + Directive.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "Directive" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "rawValue", type: STRING }, + ]; - // ### ES6 Collection methods (ES6 Array and Map) + FormalParameters.typeName = "FormalParameters"; + FormalParameters.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "FormalParameters" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "items", type: List(Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression, BindingWithDefault)) }, + { name: "rest", type: Maybe(BindingIdentifier) }, + ]; - concat: function() {var values = SLICE$0.call(arguments, 0); - return reify(this, concatFactory(this, values)); - }, + FunctionBody.typeName = "FunctionBody"; + FunctionBody.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "FunctionBody" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "directives", type: List(Directive) }, + { name: "statements", type: List(Statement) }, + ]; - includes: function(searchValue) { - return this.some(function(value ) {return is(value, searchValue)}); - }, + FunctionDeclaration.typeName = "FunctionDeclaration"; + FunctionDeclaration.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "FunctionDeclaration" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "isGenerator", type: BOOLEAN }, + { name: "name", type: BindingIdentifier }, + { name: "params", type: FormalParameters }, + { name: "body", type: FunctionBody }, + ]; - entries: function() { - return this.__iterator(ITERATE_ENTRIES); - }, + Script.typeName = "Script"; + Script.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "Script" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "directives", type: List(Directive) }, + { name: "statements", type: List(Statement) }, + ]; - every: function(predicate, context) { - assertNotInfinite(this.size); - var returnValue = true; - this.__iterate(function(v, k, c) { - if (!predicate.call(context, v, k, c)) { - returnValue = false; - return false; - } - }); - return returnValue; - }, + SpreadElement.typeName = "SpreadElement"; + SpreadElement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "SpreadElement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "expression", type: Expression }, + ]; - filter: function(predicate, context) { - return reify(this, filterFactory(this, predicate, context, true)); - }, + Super.typeName = "Super"; + Super.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "Super" }, + { name: "loc", type: Maybe(SourceSpan) }, + ]; - find: function(predicate, context, notSetValue) { - var entry = this.findEntry(predicate, context); - return entry ? entry[1] : notSetValue; - }, + SwitchCase.typeName = "SwitchCase"; + SwitchCase.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "SwitchCase" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "test", type: Expression }, + { name: "consequent", type: List(Statement) }, + ]; - forEach: function(sideEffect, context) { - assertNotInfinite(this.size); - return this.__iterate(context ? sideEffect.bind(context) : sideEffect); - }, + SwitchDefault.typeName = "SwitchDefault"; + SwitchDefault.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "SwitchDefault" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "consequent", type: List(Statement) }, + ]; - join: function(separator) { - assertNotInfinite(this.size); - separator = separator !== undefined ? '' + separator : ','; - var joined = ''; - var isFirst = true; - this.__iterate(function(v ) { - isFirst ? (isFirst = false) : (joined += separator); - joined += v !== null && v !== undefined ? v.toString() : ''; - }); - return joined; - }, + TemplateElement.typeName = "TemplateElement"; + TemplateElement.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "TemplateElement" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "rawValue", type: STRING }, + ]; - keys: function() { - return this.__iterator(ITERATE_KEYS); - }, + VariableDeclaration.typeName = "VariableDeclaration"; + VariableDeclaration.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "VariableDeclaration" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "kind", type: VariableDeclarationKind }, + { name: "declarators", type: List(VariableDeclarator) }, + ]; - map: function(mapper, context) { - return reify(this, mapFactory(this, mapper, context)); - }, + VariableDeclarator.typeName = "VariableDeclarator"; + VariableDeclarator.fields = [ + { name: "type", type: Const(TYPE_INDICATOR), value: "VariableDeclarator" }, + { name: "loc", type: Maybe(SourceSpan) }, + { name: "binding", type: Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression) }, + { name: "init", type: Maybe(Expression) }, + ]; - reduce: function(reducer, initialReduction, context) { - assertNotInfinite(this.size); - var reduction; - var useFirst; - if (arguments.length < 2) { - useFirst = true; - } else { - reduction = initialReduction; - } - this.__iterate(function(v, k, c) { - if (useFirst) { - useFirst = false; - reduction = v; - } else { - reduction = reducer.call(context, reduction, v, k, c); - } - }); - return reduction; - }, + return SPEC; + }()); - reduceRight: function(reducer, initialReduction, context) { - var reversed = this.toKeyedSeq().reverse(); - return reversed.reduce.apply(reversed, arguments); - }, - reverse: function() { - return reify(this, reverseFactory(this, true)); - }, +/***/ }, +/* 7 */ +/***/ function(module, exports, __webpack_require__) { - slice: function(begin, end) { - return reify(this, sliceFactory(this, begin, end, true)); - }, + "use strict"; - some: function(predicate, context) { - return !this.every(not(predicate), context); - }, + var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); - sort: function(comparator) { - return reify(this, sortFactory(this, comparator)); - }, + var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; }; /** + * Copyright 2014 Shape Security, Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License") + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ - values: function() { - return this.__iterator(ITERATE_VALUES); - }, + Object.defineProperty(exports, "__esModule", { + value: true + }); + var _shiftSpec = __webpack_require__(6); - // ### More sequential methods + var _shiftSpec2 = _interopRequireDefault(_shiftSpec); - butLast: function() { - return this.slice(0, -1); - }, + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - isEmpty: function() { - return this.size !== undefined ? this.size === 0 : !this.some(function() {return true}); - }, + function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - count: function(predicate, context) { - return ensureSize( - predicate ? this.toSeq().filter(predicate, context) : this - ); - }, + var methods = {}; - countBy: function(grouper, context) { - return countByFactory(this, grouper, context); - }, + function id(x) { + return x; + } - equals: function(other) { - return deepEqual(this, other); - }, + function handlerForFieldOfType(type) { + switch (type.typeName) { + case "Enum": + case "String": + case "Boolean": + case "Number": + case "SourceSpan": + return null; + case "Const": + return handlerForFieldOfType(type.argument); + case "Maybe": + { + var _ret = function () { + var subHandler = handlerForFieldOfType(type.argument); + if (subHandler == null) return { + v: null + }; + return { + v: function v(t) { + return t == null ? this.identity : subHandler.call(this, t); + } + }; + }(); - entrySeq: function() { - var iterable = this; - if (iterable._cache) { - // We cache as an entries array, so we can just return the cache! - return new ArraySeq(iterable._cache); + if ((typeof _ret === "undefined" ? "undefined" : _typeof(_ret)) === "object") return _ret.v; } - var entriesSequence = iterable.toSeq().map(entryMapper).toIndexedSeq(); - entriesSequence.fromEntrySeq = function() {return iterable.toSeq()}; - return entriesSequence; - }, + case "List": + { + var _ret2 = function () { + var subHandler = handlerForFieldOfType(type.argument); + if (subHandler == null) return { + v: null + }; + return { + v: function v(t) { + var _this = this; - filterNot: function(predicate, context) { - return this.filter(not(predicate), context); - }, + return this.fold(t.map(function (x) { + return subHandler.call(_this, x); + })); + } + }; + }(); - findEntry: function(predicate, context, notSetValue) { - var found = notSetValue; - this.__iterate(function(v, k, c) { - if (predicate.call(context, v, k, c)) { - found = [k, v]; - return false; - } - }); - return found; - }, + if ((typeof _ret2 === "undefined" ? "undefined" : _typeof(_ret2)) === "object") return _ret2.v; + } + default: + return id; + } + } - findKey: function(predicate, context) { - var entry = this.findEntry(predicate, context); - return entry && entry[0]; - }, + var _loop = function _loop(typeName) { + var type = _shiftSpec2.default[typeName]; - findLast: function(predicate, context, notSetValue) { - return this.toKeyedSeq().reverse().find(predicate, context, notSetValue); - }, + var handlers = {}; + type.fields.forEach(function (field) { + var handler = handlerForFieldOfType(field.type); + if (handler != null) handlers[field.name] = handler; + }); + var fieldNames = Object.keys(handlers); - findLastEntry: function(predicate, context, notSetValue) { - return this.toKeyedSeq().reverse().findEntry(predicate, context, notSetValue); - }, + methods["reduce" + typeName] = { + value: function value(node, state) { + var _this3 = this; - findLastKey: function(predicate, context) { - return this.toKeyedSeq().reverse().findKey(predicate, context); - }, + return this.fold(fieldNames.map(function (fieldName) { + return handlers[fieldName].call(_this3, state[fieldName]); + })); + } + }; + }; - first: function() { - return this.find(returnTrue); - }, + for (var typeName in _shiftSpec2.default) { + _loop(typeName); + } - flatMap: function(mapper, context) { - return reify(this, flatMapFactory(this, mapper, context)); - }, + var MonoidalReducer = function () { + function MonoidalReducer(monoid) { + _classCallCheck(this, MonoidalReducer); - flatten: function(depth) { - return reify(this, flattenFactory(this, depth, true)); - }, + this.identity = monoid.empty(); + var concat = monoid.prototype && monoid.prototype.concat || monoid.concat; + this.append = function (a, b) { + return concat.call(a, b); + }; + } - fromEntrySeq: function() { - return new FromEntriesSequence(this); - }, + _createClass(MonoidalReducer, [{ + key: "fold", + value: function fold(list, a) { + var _this2 = this; - get: function(searchKey, notSetValue) { - return this.find(function(_, key) {return is(key, searchKey)}, undefined, notSetValue); - }, + return list.reduce(function (memo, x) { + return _this2.append(memo, x); + }, a == null ? this.identity : a); + } + }]); - getIn: function(searchKeyPath, notSetValue) { - var nested = this; - // Note: in an ES6 environment, we would prefer: - // for (var key of searchKeyPath) { - var iter = forceIterator(searchKeyPath); - var step; - while (!(step = iter.next()).done) { - var key = step.value; - nested = nested && nested.get ? nested.get(key, NOT_SET) : NOT_SET; - if (nested === NOT_SET) { - return notSetValue; - } - } - return nested; - }, + return MonoidalReducer; + }(); - groupBy: function(grouper, context) { - return groupByFactory(this, grouper, context); - }, + exports.default = MonoidalReducer; - has: function(searchKey) { - return this.get(searchKey, NOT_SET) !== NOT_SET; - }, + Object.defineProperties(MonoidalReducer.prototype, methods); - hasIn: function(searchKeyPath) { - return this.getIn(searchKeyPath, NOT_SET) !== NOT_SET; - }, +/***/ }, +/* 8 */ +/***/ function(module, exports, __webpack_require__) { - isSubset: function(iter) { - iter = typeof iter.includes === 'function' ? iter : Iterable(iter); - return this.every(function(value ) {return iter.includes(value)}); - }, - - isSuperset: function(iter) { - iter = typeof iter.isSubset === 'function' ? iter : Iterable(iter); - return iter.isSubset(this); - }, - - keyOf: function(searchValue) { - return this.findKey(function(value ) {return is(value, searchValue)}); - }, - - keySeq: function() { - return this.toSeq().map(keyMapper).toIndexedSeq(); - }, - - last: function() { - return this.toSeq().reverse().first(); - }, - - lastKeyOf: function(searchValue) { - return this.toKeyedSeq().reverse().keyOf(searchValue); - }, - - max: function(comparator) { - return maxFactory(this, comparator); - }, - - maxBy: function(mapper, comparator) { - return maxFactory(this, comparator, mapper); - }, - - min: function(comparator) { - return maxFactory(this, comparator ? neg(comparator) : defaultNegComparator); - }, - - minBy: function(mapper, comparator) { - return maxFactory(this, comparator ? neg(comparator) : defaultNegComparator, mapper); - }, - - rest: function() { - return this.slice(1); - }, - - skip: function(amount) { - return this.slice(Math.max(0, amount)); - }, - - skipLast: function(amount) { - return reify(this, this.toSeq().reverse().skip(amount).reverse()); - }, - - skipWhile: function(predicate, context) { - return reify(this, skipWhileFactory(this, predicate, context, true)); - }, - - skipUntil: function(predicate, context) { - return this.skipWhile(not(predicate), context); - }, - - sortBy: function(mapper, comparator) { - return reify(this, sortFactory(this, comparator, mapper)); - }, - - take: function(amount) { - return this.slice(0, Math.max(0, amount)); - }, - - takeLast: function(amount) { - return reify(this, this.toSeq().reverse().take(amount).reverse()); - }, - - takeWhile: function(predicate, context) { - return reify(this, takeWhileFactory(this, predicate, context)); - }, - - takeUntil: function(predicate, context) { - return this.takeWhile(not(predicate), context); - }, - - valueSeq: function() { - return this.toIndexedSeq(); - }, - - - // ### Hashable Object - - hashCode: function() { - return this.__hash || (this.__hash = hashIterable(this)); - } - - - // ### Internal - - // abstract __iterate(fn, reverse) - - // abstract __iterator(type, reverse) - }); - - // var IS_ITERABLE_SENTINEL = '@@__IMMUTABLE_ITERABLE__@@'; - // var IS_KEYED_SENTINEL = '@@__IMMUTABLE_KEYED__@@'; - // var IS_INDEXED_SENTINEL = '@@__IMMUTABLE_INDEXED__@@'; - // var IS_ORDERED_SENTINEL = '@@__IMMUTABLE_ORDERED__@@'; - - var IterablePrototype = Iterable.prototype; - IterablePrototype[IS_ITERABLE_SENTINEL] = true; - IterablePrototype[ITERATOR_SYMBOL] = IterablePrototype.values; - IterablePrototype.__toJS = IterablePrototype.toArray; - IterablePrototype.__toStringMapper = quoteString; - IterablePrototype.inspect = - IterablePrototype.toSource = function() { return this.toString(); }; - IterablePrototype.chain = IterablePrototype.flatMap; - IterablePrototype.contains = IterablePrototype.includes; - - mixin(KeyedIterable, { - - // ### More sequential methods - - flip: function() { - return reify(this, flipFactory(this)); - }, - - mapEntries: function(mapper, context) {var this$0 = this; - var iterations = 0; - return reify(this, - this.toSeq().map( - function(v, k) {return mapper.call(context, [k, v], iterations++, this$0)} - ).fromEntrySeq() - ); - }, - - mapKeys: function(mapper, context) {var this$0 = this; - return reify(this, - this.toSeq().flip().map( - function(k, v) {return mapper.call(context, k, v, this$0)} - ).flip() - ); - } - - }); - - var KeyedIterablePrototype = KeyedIterable.prototype; - KeyedIterablePrototype[IS_KEYED_SENTINEL] = true; - KeyedIterablePrototype[ITERATOR_SYMBOL] = IterablePrototype.entries; - KeyedIterablePrototype.__toJS = IterablePrototype.toObject; - KeyedIterablePrototype.__toStringMapper = function(v, k) {return JSON.stringify(k) + ': ' + quoteString(v)}; - - - - mixin(IndexedIterable, { - - // ### Conversion to other types - - toKeyedSeq: function() { - return new ToKeyedSequence(this, false); - }, - - - // ### ES6 Collection methods (ES6 Array and Map) - - filter: function(predicate, context) { - return reify(this, filterFactory(this, predicate, context, false)); - }, - - findIndex: function(predicate, context) { - var entry = this.findEntry(predicate, context); - return entry ? entry[0] : -1; - }, - - indexOf: function(searchValue) { - var key = this.keyOf(searchValue); - return key === undefined ? -1 : key; - }, - - lastIndexOf: function(searchValue) { - var key = this.lastKeyOf(searchValue); - return key === undefined ? -1 : key; - }, - - reverse: function() { - return reify(this, reverseFactory(this, false)); - }, - - slice: function(begin, end) { - return reify(this, sliceFactory(this, begin, end, false)); - }, - - splice: function(index, removeNum /*, ...values*/) { - var numArgs = arguments.length; - removeNum = Math.max(removeNum | 0, 0); - if (numArgs === 0 || (numArgs === 2 && !removeNum)) { - return this; - } - // If index is negative, it should resolve relative to the size of the - // collection. However size may be expensive to compute if not cached, so - // only call count() if the number is in fact negative. - index = resolveBegin(index, index < 0 ? this.count() : this.size); - var spliced = this.slice(0, index); - return reify( - this, - numArgs === 1 ? - spliced : - spliced.concat(arrCopy(arguments, 2), this.slice(index + removeNum)) - ); - }, - - - // ### More collection methods - - findLastIndex: function(predicate, context) { - var entry = this.findLastEntry(predicate, context); - return entry ? entry[0] : -1; - }, - - first: function() { - return this.get(0); - }, - - flatten: function(depth) { - return reify(this, flattenFactory(this, depth, false)); - }, - - get: function(index, notSetValue) { - index = wrapIndex(this, index); - return (index < 0 || (this.size === Infinity || - (this.size !== undefined && index > this.size))) ? - notSetValue : - this.find(function(_, key) {return key === index}, undefined, notSetValue); - }, - - has: function(index) { - index = wrapIndex(this, index); - return index >= 0 && (this.size !== undefined ? - this.size === Infinity || index < this.size : - this.indexOf(index) !== -1 - ); - }, - - interpose: function(separator) { - return reify(this, interposeFactory(this, separator)); - }, - - interleave: function(/*...iterables*/) { - var iterables = [this].concat(arrCopy(arguments)); - var zipped = zipWithFactory(this.toSeq(), IndexedSeq.of, iterables); - var interleaved = zipped.flatten(true); - if (zipped.size) { - interleaved.size = zipped.size * iterables.length; - } - return reify(this, interleaved); - }, - - keySeq: function() { - return Range(0, this.size); - }, - - last: function() { - return this.get(-1); - }, - - skipWhile: function(predicate, context) { - return reify(this, skipWhileFactory(this, predicate, context, false)); - }, - - zip: function(/*, ...iterables */) { - var iterables = [this].concat(arrCopy(arguments)); - return reify(this, zipWithFactory(this, defaultZipper, iterables)); - }, + "use strict"; - zipWith: function(zipper/*, ...iterables */) { - var iterables = arrCopy(arguments); - iterables[0] = this; - return reify(this, zipWithFactory(this, zipper, iterables)); - } + Object.defineProperty(exports, "__esModule", { + value: true + }); - }); + var _terms = __webpack_require__(9); - IndexedIterable.prototype[IS_INDEXED_SENTINEL] = true; - IndexedIterable.prototype[IS_ORDERED_SENTINEL] = true; + var _terms2 = _interopRequireDefault(_terms); + var _shiftReducer = __webpack_require__(4); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - mixin(SetIterable, { + class ParseReducer extends _shiftReducer.CloneReducer { + constructor(context) { + super(); + this.context = context; + } + reduceModule(node, state) { + return new _terms2.default("Module", { + directives: state.directives.toArray(), + items: state.items.toArray() + }); + } - // ### ES6 Collection methods (ES6 Array and Map) + reduceImport(node, state) { + let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null; + return new _terms2.default('Import', { + defaultBinding: state.defaultBinding, + namedImports: state.namedImports.toArray(), + moduleSpecifier: moduleSpecifier, + forSyntax: node.forSyntax + }); + } - get: function(value, notSetValue) { - return this.has(value) ? value : notSetValue; - }, + reduceImportNamespace(node, state) { + let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null; + return new _terms2.default('ImportNamespace', { + defaultBinding: state.defaultBinding, + namespaceBinding: state.namespaceBinding, + moduleSpecifier: moduleSpecifier, + forSyntax: node.forSyntax + }); + } - includes: function(value) { - return this.has(value); - }, + reduceExport(node, state) { + return new _terms2.default('Export', { + declaration: state.declaration + }); + } + reduceExportAllFrom(node, state) { + let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null; + return new _terms2.default('ExportAllFrom', { moduleSpecifier: moduleSpecifier }); + } - // ### More sequential methods + reduceExportFrom(node, state) { + let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null; + return new _terms2.default('ExportFrom', { + moduleSpecifier: moduleSpecifier, + namedExports: state.namedExports.toArray() + }); + } - keySeq: function() { - return this.valueSeq(); + reduceExportSpecifier(node, state) { + let name = state.name, + exportedName = state.exportedName; + if (name == null) { + name = exportedName.resolve(this.context.phase); + exportedName = exportedName.val(); + } else { + name = name.resolve(this.context.phase); + exportedName = exportedName.val(); } - - }); - - SetIterable.prototype.has = IterablePrototype.includes; - SetIterable.prototype.contains = SetIterable.prototype.includes; - - - // Mixin subclasses - - mixin(KeyedSeq, KeyedIterable.prototype); - mixin(IndexedSeq, IndexedIterable.prototype); - mixin(SetSeq, SetIterable.prototype); - - mixin(KeyedCollection, KeyedIterable.prototype); - mixin(IndexedCollection, IndexedIterable.prototype); - mixin(SetCollection, SetIterable.prototype); - - - // #pragma Helper functions - - function keyMapper(v, k) { - return k; + return new _terms2.default('ExportSpecifier', { + name: name, exportedName: exportedName + }); } - function entryMapper(v, k) { - return [k, v]; + reduceImportSpecifier(node, state) { + let name = state.name ? state.name.resolve(this.context.phase) : null; + return new _terms2.default('ImportSpecifier', { + name: name, + binding: state.binding + }); } - function not(predicate) { - return function() { - return !predicate.apply(this, arguments); - } + reduceIdentifierExpression(node) { + return new _terms2.default("IdentifierExpression", { + name: node.name.resolve(this.context.phase) + }); } - function neg(predicate) { - return function() { - return -predicate.apply(this, arguments); - } + reduceLiteralNumericExpression(node) { + return new _terms2.default("LiteralNumericExpression", { + value: node.value.val() + }); } - function quoteString(value) { - return typeof value === 'string' ? JSON.stringify(value) : String(value); + reduceLiteralBooleanExpression(node) { + return new _terms2.default("LiteralBooleanExpression", { + value: node.value.val() === 'true' + }); } - function defaultZipper() { - return arrCopy(arguments); + reduceLiteralStringExpression(node) { + return new _terms2.default("LiteralStringExpression", { + value: node.value.token.str + }); } - function defaultNegComparator(a, b) { - return a < b ? 1 : a > b ? -1 : 0; + reduceCallExpression(node, state) { + return new _terms2.default("CallExpression", { + callee: state.callee, + arguments: state.arguments.toArray() + }); } - function hashIterable(iterable) { - if (iterable.size === Infinity) { - return 0; - } - var ordered = isOrdered(iterable); - var keyed = isKeyed(iterable); - var h = ordered ? 1 : 0; - var size = iterable.__iterate( - keyed ? - ordered ? - function(v, k) { h = 31 * h + hashMerge(hash(v), hash(k)) | 0; } : - function(v, k) { h = h + hashMerge(hash(v), hash(k)) | 0; } : - ordered ? - function(v ) { h = 31 * h + hash(v) | 0; } : - function(v ) { h = h + hash(v) | 0; } - ); - return murmurHashOfSize(size, h); + reduceFunctionBody(node, state) { + return new _terms2.default("FunctionBody", { + directives: state.directives.toArray(), + statements: state.statements.toArray() + }); } - function murmurHashOfSize(size, h) { - h = imul(h, 0xCC9E2D51); - h = imul(h << 15 | h >>> -15, 0x1B873593); - h = imul(h << 13 | h >>> -13, 5); - h = (h + 0xE6546B64 | 0) ^ size; - h = imul(h ^ h >>> 16, 0x85EBCA6B); - h = imul(h ^ h >>> 13, 0xC2B2AE35); - h = smi(h ^ h >>> 16); - return h; + reduceFormalParameters(node, state) { + return new _terms2.default("FormalParameters", { + items: state.items.toArray(), + rest: state.rest + }); } - function hashMerge(a, b) { - return a ^ b + 0x9E3779B9 + (a << 6) + (a >> 2) | 0; // int + reduceBindingIdentifier(node) { + return new _terms2.default("BindingIdentifier", { + name: node.name.resolve(this.context.phase) + }); } - var Immutable = { - - Iterable: Iterable, + reduceBinaryExpression(node, state) { + return new _terms2.default("BinaryExpression", { + left: state.left, + operator: node.operator.val(), + right: state.right + }); + } - Seq: Seq, - Collection: Collection, - Map: Map, - OrderedMap: OrderedMap, - List: List, - Stack: Stack, - Set: Set, - OrderedSet: OrderedSet, + reduceObjectExpression(node, state) { + return new _terms2.default("ObjectExpression", { + properties: state.properties.toArray() + }); + } - Record: Record, - Range: Range, - Repeat: Repeat, + reduceVariableDeclaration(node, state) { + return new _terms2.default("VariableDeclaration", { + kind: state.kind, + declarators: state.declarators.toArray() + }); + } - is: is, - fromJS: fromJS + reduceStaticPropertyName(node) { + return new _terms2.default("StaticPropertyName", { + value: node.value.val().toString() + }); + } - }; + reduceArrayExpression(node, state) { + return new _terms2.default("ArrayExpression", { + elements: state.elements.toArray() + }); + } - return Immutable; + reduceStaticMemberExpression(node, state) { + return new _terms2.default("StaticMemberExpression", { + object: state.object, + property: state.property.val() + }); + } - })); + } + exports.default = ParseReducer; + //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/parse-reducer.js"],"names":[],"mappings":";;;;;;AAAA;;;;AACA;;;;AAEe,MAAM,YAAN,oCAAwC;AACrD,cAAY,OAAZ,EAAqB;AACnB;AACA,SAAK,OAAL,GAAe,OAAf;AACD;AACD,eAAa,IAAb,EAAmB,KAAnB,EAA0B;AACxB,WAAO,oBAAS,QAAT,EAAmB;AACxB,kBAAY,MAAM,UAAN,CAAiB,OAAjB,EADY;AAExB,aAAO,MAAM,KAAN,CAAY,OAAZ;AAFiB,KAAnB,CAAP;AAID;;AAED,eAAa,IAAb,EAAmB,KAAnB,EAA0B;AACxB,QAAI,kBAAkB,MAAM,eAAN,GAAwB,MAAM,eAAN,CAAsB,GAAtB,EAAxB,GAAsD,IAA5E;AACA,WAAO,oBAAS,QAAT,EAAmB;AACxB,sBAAgB,MAAM,cADE;AAExB,oBAAc,MAAM,YAAN,CAAmB,OAAnB,EAFU;AAGxB,sCAHwB;AAIxB,iBAAW,KAAK;AAJQ,KAAnB,CAAP;AAMD;;AAED,wBAAsB,IAAtB,EAA4B,KAA5B,EAAmC;AACjC,QAAI,kBAAkB,MAAM,eAAN,GAAwB,MAAM,eAAN,CAAsB,GAAtB,EAAxB,GAAsD,IAA5E;AACA,WAAO,oBAAS,iBAAT,EAA4B;AACjC,sBAAgB,MAAM,cADW;AAEjC,wBAAkB,MAAM,gBAFS;AAGjC,sCAHiC;AAIjC,iBAAW,KAAK;AAJiB,KAA5B,CAAP;AAMD;;AAED,eAAa,IAAb,EAAmB,KAAnB,EAA0B;AACxB,WAAO,oBAAS,QAAT,EAAmB;AACxB,mBAAa,MAAM;AADK,KAAnB,CAAP;AAGD;;AAED,sBAAoB,IAApB,EAA0B,KAA1B,EAAiC;AAC/B,QAAI,kBAAkB,MAAM,eAAN,GAAwB,MAAM,eAAN,CAAsB,GAAtB,EAAxB,GAAsD,IAA5E;AACA,WAAO,oBAAS,eAAT,EAA0B,EAAE,gCAAF,EAA1B,CAAP;AACD;;AAED,mBAAiB,IAAjB,EAAuB,KAAvB,EAA8B;AAC5B,QAAI,kBAAkB,MAAM,eAAN,GAAwB,MAAM,eAAN,CAAsB,GAAtB,EAAxB,GAAsD,IAA5E;AACA,WAAO,oBAAS,YAAT,EAAuB;AAC5B,sCAD4B;AAE5B,oBAAc,MAAM,YAAN,CAAmB,OAAnB;AAFc,KAAvB,CAAP;AAID;;AAED,wBAAsB,IAAtB,EAA4B,KAA5B,EAAmC;AACjC,QAAI,OAAO,MAAM,IAAjB;AAAA,QAAuB,eAAe,MAAM,YAA5C;AACA,QAAI,QAAQ,IAAZ,EAAkB;AAChB,aAAO,aAAa,OAAb,CAAqB,KAAK,OAAL,CAAa,KAAlC,CAAP;AACA,qBAAe,aAAa,GAAb,EAAf;AACD,KAHD,MAGO;AACL,aAAO,KAAK,OAAL,CAAa,KAAK,OAAL,CAAa,KAA1B,CAAP;AACA,qBAAe,aAAa,GAAb,EAAf;AACD;AACD,WAAO,oBAAS,iBAAT,EAA4B;AACjC,gBADiC,EAC3B;AAD2B,KAA5B,CAAP;AAGD;;AAED,wBAAsB,IAAtB,EAA4B,KAA5B,EAAmC;AACjC,QAAI,OAAO,MAAM,IAAN,GAAa,MAAM,IAAN,CAAW,OAAX,CAAmB,KAAK,OAAL,CAAa,KAAhC,CAAb,GAAsD,IAAjE;AACA,WAAO,oBAAS,iBAAT,EAA4B;AACjC,gBADiC;AAEjC,eAAS,MAAM;AAFkB,KAA5B,CAAP;AAID;;AAED,6BAA2B,IAA3B,EAAiC;AAC/B,WAAO,oBAAS,sBAAT,EAAiC;AACtC,YAAM,KAAK,IAAL,CAAU,OAAV,CAAkB,KAAK,OAAL,CAAa,KAA/B;AADgC,KAAjC,CAAP;AAGD;;AAED,iCAA+B,IAA/B,EAAqC;AACnC,WAAO,oBAAS,0BAAT,EAAqC;AAC1C,aAAO,KAAK,KAAL,CAAW,GAAX;AADmC,KAArC,CAAP;AAGD;;AAED,iCAA+B,IAA/B,EAAqC;AACnC,WAAO,oBAAS,0BAAT,EAAqC;AAC1C,aAAO,KAAK,KAAL,CAAW,GAAX,OAAqB;AADc,KAArC,CAAP;AAGD;;AAED,gCAA8B,IAA9B,EAAoC;AAClC,WAAO,oBAAS,yBAAT,EAAoC;AACzC,aAAO,KAAK,KAAL,CAAW,KAAX,CAAiB;AADiB,KAApC,CAAP;AAGD;;AAED,uBAAqB,IAArB,EAA2B,KAA3B,EAAkC;AAChC,WAAO,oBAAS,gBAAT,EAA2B;AAChC,cAAQ,MAAM,MADkB;AAEhC,iBAAW,MAAM,SAAN,CAAgB,OAAhB;AAFqB,KAA3B,CAAP;AAID;;AAED,qBAAmB,IAAnB,EAAyB,KAAzB,EAAgC;AAC9B,WAAO,oBAAS,cAAT,EAAyB;AAC9B,kBAAY,MAAM,UAAN,CAAiB,OAAjB,EADkB;AAE9B,kBAAY,MAAM,UAAN,CAAiB,OAAjB;AAFkB,KAAzB,CAAP;AAID;;AAED,yBAAuB,IAAvB,EAA6B,KAA7B,EAAoC;AAClC,WAAO,oBAAS,kBAAT,EAA6B;AAClC,aAAO,MAAM,KAAN,CAAY,OAAZ,EAD2B;AAElC,YAAM,MAAM;AAFsB,KAA7B,CAAP;AAID;;AAED,0BAAwB,IAAxB,EAA8B;AAC5B,WAAO,oBAAS,mBAAT,EAA8B;AACnC,YAAM,KAAK,IAAL,CAAU,OAAV,CAAkB,KAAK,OAAL,CAAa,KAA/B;AAD6B,KAA9B,CAAP;AAGD;;AAED,yBAAuB,IAAvB,EAA6B,KAA7B,EAAoC;AAClC,WAAO,oBAAS,kBAAT,EAA6B;AAClC,YAAM,MAAM,IADsB;AAElC,gBAAU,KAAK,QAAL,CAAc,GAAd,EAFwB;AAGlC,aAAO,MAAM;AAHqB,KAA7B,CAAP;AAKD;;AAED,yBAAuB,IAAvB,EAA6B,KAA7B,EAAoC;AAClC,WAAO,oBAAS,kBAAT,EAA6B;AAClC,kBAAY,MAAM,UAAN,CAAiB,OAAjB;AADsB,KAA7B,CAAP;AAGD;;AAED,4BAA0B,IAA1B,EAAgC,KAAhC,EAAuC;AACrC,WAAO,oBAAS,qBAAT,EAAgC;AACrC,YAAM,MAAM,IADyB;AAErC,mBAAa,MAAM,WAAN,CAAkB,OAAlB;AAFwB,KAAhC,CAAP;AAID;;AAED,2BAAyB,IAAzB,EAA+B;AAC7B,WAAO,oBAAS,oBAAT,EAA+B;AACpC,aAAO,KAAK,KAAL,CAAW,GAAX,GAAiB,QAAjB;AAD6B,KAA/B,CAAP;AAGD;;AAED,wBAAsB,IAAtB,EAA4B,KAA5B,EAAmC;AACjC,WAAO,oBAAS,iBAAT,EAA4B;AACjC,gBAAU,MAAM,QAAN,CAAe,OAAf;AADuB,KAA5B,CAAP;AAGD;;AAED,+BAA6B,IAA7B,EAAmC,KAAnC,EAA0C;AACxC,WAAO,oBAAS,wBAAT,EAAmC;AACxC,cAAQ,MAAM,MAD0B;AAExC,gBAAU,MAAM,QAAN,CAAe,GAAf;AAF8B,KAAnC,CAAP;AAID;;AAlKoD;kBAAlC,Y","file":"parse-reducer.js","sourcesContent":["import Term from \"./terms\";\nimport { CloneReducer } from \"shift-reducer\";\n\nexport default class ParseReducer extends CloneReducer {\n  constructor(context) {\n    super();\n    this.context = context;\n  }\n  reduceModule(node, state) {\n    return new Term(\"Module\", {\n      directives: state.directives.toArray(),\n      items: state.items.toArray()\n    });\n  }\n\n  reduceImport(node, state) {\n    let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null;\n    return new Term('Import', {\n      defaultBinding: state.defaultBinding,\n      namedImports: state.namedImports.toArray(),\n      moduleSpecifier,\n      forSyntax: node.forSyntax\n    });\n  }\n\n  reduceImportNamespace(node, state) {\n    let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null;\n    return new Term('ImportNamespace', {\n      defaultBinding: state.defaultBinding,\n      namespaceBinding: state.namespaceBinding,\n      moduleSpecifier,\n      forSyntax: node.forSyntax\n    });\n  }\n\n  reduceExport(node, state) {\n    return new Term('Export', {\n      declaration: state.declaration\n    });\n  }\n\n  reduceExportAllFrom(node, state) {\n    let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null;\n    return new Term('ExportAllFrom', { moduleSpecifier });\n  }\n\n  reduceExportFrom(node, state) {\n    let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null;\n    return new Term('ExportFrom', {\n      moduleSpecifier,\n      namedExports: state.namedExports.toArray()\n    });\n  }\n\n  reduceExportSpecifier(node, state) {\n    let name = state.name, exportedName = state.exportedName;\n    if (name == null) {\n      name = exportedName.resolve(this.context.phase);\n      exportedName = exportedName.val();\n    } else {\n      name = name.resolve(this.context.phase);\n      exportedName = exportedName.val();\n    }\n    return new Term('ExportSpecifier', {\n      name, exportedName\n    });\n  }\n\n  reduceImportSpecifier(node, state) {\n    let name = state.name ? state.name.resolve(this.context.phase) : null;\n    return new Term('ImportSpecifier', {\n      name,\n      binding: state.binding\n    });\n  }\n\n  reduceIdentifierExpression(node) {\n    return new Term(\"IdentifierExpression\", {\n      name: node.name.resolve(this.context.phase)\n    });\n  }\n\n  reduceLiteralNumericExpression(node) {\n    return new Term(\"LiteralNumericExpression\", {\n      value: node.value.val()\n    });\n  }\n\n  reduceLiteralBooleanExpression(node) {\n    return new Term(\"LiteralBooleanExpression\", {\n      value: node.value.val() === 'true'\n    });\n  }\n\n  reduceLiteralStringExpression(node) {\n    return new Term(\"LiteralStringExpression\", {\n      value: node.value.token.str\n    });\n  }\n\n  reduceCallExpression(node, state) {\n    return new Term(\"CallExpression\", {\n      callee: state.callee,\n      arguments: state.arguments.toArray()\n    });\n  }\n\n  reduceFunctionBody(node, state) {\n    return new Term(\"FunctionBody\", {\n      directives: state.directives.toArray(),\n      statements: state.statements.toArray()\n    });\n  }\n\n  reduceFormalParameters(node, state) {\n    return new Term(\"FormalParameters\", {\n      items: state.items.toArray(),\n      rest: state.rest\n    });\n  }\n\n  reduceBindingIdentifier(node) {\n    return new Term(\"BindingIdentifier\", {\n      name: node.name.resolve(this.context.phase)\n    });\n  }\n\n  reduceBinaryExpression(node, state) {\n    return new Term(\"BinaryExpression\", {\n      left: state.left,\n      operator: node.operator.val(),\n      right: state.right\n    });\n  }\n\n  reduceObjectExpression(node, state) {\n    return new Term(\"ObjectExpression\", {\n      properties: state.properties.toArray()\n    });\n  }\n\n  reduceVariableDeclaration(node, state) {\n    return new Term(\"VariableDeclaration\", {\n      kind: state.kind,\n      declarators: state.declarators.toArray()\n    });\n  }\n\n  reduceStaticPropertyName(node) {\n    return new Term(\"StaticPropertyName\", {\n      value: node.value.val().toString()\n    });\n  }\n\n  reduceArrayExpression(node, state) {\n    return new Term(\"ArrayExpression\", {\n      elements: state.elements.toArray()\n    });\n  }\n\n  reduceStaticMemberExpression(node, state) {\n    return new Term(\"StaticMemberExpression\", {\n      object: state.object,\n      property: state.property.val()\n    });\n  }\n\n}\n"]} /***/ }, -/* 12 */ +/* 9 */ /***/ function(module, exports, __webpack_require__) { "use strict"; @@ -7684,609 +6586,264 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack Object.defineProperty(exports, "__esModule", { value: true }); - exports.ALL_PHASES = exports.Types = undefined; - - var _immutable = __webpack_require__(11); - - var _errors = __webpack_require__(13); - - var _bindingMap = __webpack_require__(14); - - var _bindingMap2 = _interopRequireDefault(_bindingMap); + exports.isImportDeclaration = exports.isCompiletimeStatement = exports.isCompiletimeDeclaration = exports.isSyntaxDeclarationStatement = exports.isExportSyntax = exports.isParenthesizedExpression = exports.isFunctionWithName = exports.isFunctionTerm = exports.isSyntaxrecDeclaration = exports.isSyntaxDeclaration = exports.isEOF = exports.isVariableDeclarator = exports.isVariableDeclaration = exports.isSyntaxTemplate = exports.isTemplateElement = exports.isSwitchDefault = exports.isSwitchCase = exports.isSuper = exports.isSpreadElement = exports.isScript = exports.isFunctionDeclaration = exports.isFunctionBody = exports.isFormalParameters = exports.isDirective = exports.isCatchClause = exports.isBlock = exports.isPragma = exports.isWithStatement = exports.isWhileStatement = exports.isVariableDeclarationStatement = exports.isTryFinallyStatement = exports.isTryCatchStatement = exports.isThrowStatement = exports.isSwitchStatementWithDefault = exports.isSwitchStatement = exports.isReturnStatement = exports.isLabeledStatement = exports.isIfStatement = exports.isForStatement = exports.isForOfStatement = exports.isForInStatement = exports.isExpressionStatement = exports.isEmptyStatement = exports.isDoWhileStatement = exports.isDebuggerStatement = exports.isCompoundAssignmentExpression = exports.isContinueStatement = exports.isBreakStatement = exports.isBlockStatement = exports.isYieldGeneratorExpression = exports.isYieldExpression = exports.isUpdateExpression = exports.isThisExpression = exports.isTemplateExpression = exports.isStaticMemberExpression = exports.isUnaryExpression = exports.isObjectExpression = exports.isNewTargetExpression = exports.isNewExpression = exports.isIdentifierExpression = exports.isFunctionExpression = exports.isConditionalExpression = exports.isComputedMemberExpression = exports.isComputedAssignmentExpression = exports.isCallExpression = exports.isBinaryExpression = exports.isAssignmentExpression = exports.isArrowExpression = exports.isArrayExpression = exports.isLiteralStringExpression = exports.isLiteralRegExpExpression = exports.isLiteralNumericExpression = exports.isLiteralNullExpression = exports.isLiteralInfinityExpression = exports.isLiteralBooleanExpression = exports.isStaticPropertyName = exports.isComputedPropertyName = exports.isShorthandProperty = exports.isDataProperty = exports.isSetter = exports.isGetter = exports.isMethod = exports.isExportSpecifier = exports.isExportDefault = exports.isExport = exports.isExportFrom = exports.isExportAllFrom = exports.isImportSpecifier = exports.isImportNamespace = exports.isImport = exports.isModule = exports.isClassElement = exports.isClassDeclaration = exports.isClassExpression = exports.isBindingPropertyProperty = exports.isBindingPropertyIdentifier = exports.isObjectBinding = exports.isArrayBinding = exports.isBindingIdentifier = exports.isBindingWithDefault = undefined; - var _ramdaFantasy = __webpack_require__(15); + var _immutable = __webpack_require__(3); - var _tokenizer = __webpack_require__(4); + var _ramda = __webpack_require__(10); - var _ramda = __webpack_require__(27); + var R = _interopRequireWildcard(_ramda); - var _ = _interopRequireWildcard(_ramda); + var _sweetSpec = __webpack_require__(11); - function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + var _sweetSpec2 = _interopRequireDefault(_sweetSpec); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - const Just_825 = _ramdaFantasy.Maybe.Just; - const Nothing_826 = _ramdaFantasy.Maybe.Nothing; - function getFirstSlice_827(stx_831) { - if (!stx_831 || typeof stx_831.isDelimiter !== "function") return null; - if (!stx_831.isDelimiter()) { - return stx_831.token.slice; - } - return stx_831.token.get(0).token.slice; - } - function sizeDecending_828(a_832, b_833) { - if (a_832.scopes.size > b_833.scopes.size) { - return -1; - } else if (b_833.scopes.size > a_832.scopes.size) { - return 1; - } else { - return 0; - } - } - let Types_829 = { null: { match: token_834 => !Types_829.delimiter.match(token_834) && token_834.type === _tokenizer.TokenType.NULL, create: (value_835, stx_836) => new Syntax({ type: _tokenizer.TokenType.NULL, value: null }, stx_836) }, number: { match: token_837 => !Types_829.delimiter.match(token_837) && token_837.type.klass === _tokenizer.TokenClass.NumericLiteral, create: (value_838, stx_839) => new Syntax({ type: _tokenizer.TokenType.NUMBER, value: value_838 }, stx_839) }, string: { match: token_840 => !Types_829.delimiter.match(token_840) && token_840.type.klass === _tokenizer.TokenClass.StringLiteral, create: (value_841, stx_842) => new Syntax({ type: _tokenizer.TokenType.STRING, str: value_841 }, stx_842) }, punctuator: { match: token_843 => !Types_829.delimiter.match(token_843) && token_843.type.klass === _tokenizer.TokenClass.Punctuator, create: (value_844, stx_845) => new Syntax({ type: { klass: _tokenizer.TokenClass.Punctuator, name: value_844 }, value: value_844 }, stx_845) }, keyword: { match: token_846 => !Types_829.delimiter.match(token_846) && token_846.type.klass === _tokenizer.TokenClass.Keyword, create: (value_847, stx_848) => new Syntax({ type: { klass: _tokenizer.TokenClass.Keyword, name: value_847 }, value: value_847 }, stx_848) }, identifier: { match: token_849 => !Types_829.delimiter.match(token_849) && token_849.type.klass === _tokenizer.TokenClass.Ident, create: (value_850, stx_851) => new Syntax({ type: _tokenizer.TokenType.IDENTIFIER, value: value_850 }, stx_851) }, regularExpression: { match: token_852 => !Types_829.delimiter.match(token_852) && token_852.type.klass === _tokenizer.TokenClass.RegularExpression, create: (value_853, stx_854) => new Syntax({ type: _tokenizer.TokenType.REGEXP, value: value_853 }, stx_854) }, braces: { match: token_855 => Types_829.delimiter.match(token_855) && token_855.get(0).token.type === _tokenizer.TokenType.LBRACE, create: (inner_856, stx_857) => { - let left_858 = new Syntax({ type: _tokenizer.TokenType.LBRACE, value: "{", slice: getFirstSlice_827(stx_857) }); - let right_859 = new Syntax({ type: _tokenizer.TokenType.RBRACE, value: "}", slice: getFirstSlice_827(stx_857) }); - return new Syntax(_immutable.List.of(left_858).concat(inner_856).push(right_859), stx_857); - } }, brackets: { match: token_860 => Types_829.delimiter.match(token_860) && token_860.get(0).token.type === _tokenizer.TokenType.LBRACK, create: (inner_861, stx_862) => { - let left_863 = new Syntax({ type: _tokenizer.TokenType.LBRACK, value: "[", slice: getFirstSlice_827(stx_862) }); - let right_864 = new Syntax({ type: _tokenizer.TokenType.RBRACK, value: "]", slice: getFirstSlice_827(stx_862) }); - return new Syntax(_immutable.List.of(left_863).concat(inner_861).push(right_864), stx_862); - } }, parens: { match: token_865 => Types_829.delimiter.match(token_865) && token_865.get(0).token.type === _tokenizer.TokenType.LPAREN, create: (inner_866, stx_867) => { - let left_868 = new Syntax({ type: _tokenizer.TokenType.LPAREN, value: "(", slice: getFirstSlice_827(stx_867) }); - let right_869 = new Syntax({ type: _tokenizer.TokenType.RPAREN, value: ")", slice: getFirstSlice_827(stx_867) }); - return new Syntax(_immutable.List.of(left_868).concat(inner_866).push(right_869), stx_867); - } }, assign: { match: token_870 => { - if (Types_829.punctuator.match(token_870)) { - switch (token_870.value) { - case "=": - case "|=": - case "^=": - case "&=": - case "<<=": - case ">>=": - case ">>>=": - case "+=": - case "-=": - case "*=": - case "/=": - case "%=": - return true; - default: - return false; - } - } - return false; - } }, boolean: { match: token_871 => !Types_829.delimiter.match(token_871) && token_871.type === _tokenizer.TokenType.TRUE || token_871.type === _tokenizer.TokenType.FALSE }, template: { match: token_872 => !Types_829.delimiter.match(token_872) && token_872.type === _tokenizer.TokenType.TEMPLATE }, delimiter: { match: token_873 => _immutable.List.isList(token_873) }, syntaxTemplate: { match: token_874 => Types_829.delimiter.match(token_874) && token_874.get(0).val() === "#`" }, eof: { match: token_875 => !Types_829.delimiter.match(token_875) && token_875.type === _tokenizer.TokenType.EOS } }; - ; - const ALL_PHASES_830 = {}; - ; - class Syntax { - constructor(token_876) { - let oldstx_877 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } - this.token = token_876; - this.bindings = oldstx_877.bindings != null ? oldstx_877.bindings : new _bindingMap2.default(); - this.scopesets = oldstx_877.scopesets != null ? oldstx_877.scopesets : { all: (0, _immutable.List)(), phase: (0, _immutable.Map)() }; - Object.freeze(this); - } - static of(token_878) { - let stx_879 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + const attrName = a => a.attrName; - return new Syntax(token_878, stx_879); - } - static from(type_880, value_881) { - let stx_882 = arguments.length <= 2 || arguments[2] === undefined ? {} : arguments[2]; + class Term { - if (!Types_829[type_880]) { - throw new Error(type_880 + " is not a valid type"); - } else if (!Types_829[type_880].create) { - throw new Error("Cannot create a syntax from type " + type_880); + constructor(type, props) { + let spec = _sweetSpec2.default.getDescendant(type); + if (spec == null) { + throw new Error(`Unknown term: ${ type }`); } - let newstx_883 = Types_829[type_880].create(value_881, stx_882); - let slice_884 = getFirstSlice_827(stx_882); - if (slice_884 != null) { - newstx_883.token.slice = slice_884; + this.type = type; + this.loc = null; + this.spec = spec; + let propKeys = Object.keys(props); + let fieldNames = spec.getAttributes().map(attrName); + let diff = R.symmetricDifference(propKeys, fieldNames); + if (diff.length !== 0) { + throw new Error(`Unexpected properties for term ${ type }: ${ diff }`); } - return newstx_883; - } - from(type_885, value_886) { - return Syntax.from(type_885, value_886, this); - } - fromNull() { - return this.from("null", null); + Object.assign(this, props); } - fromNumber(value_887) { - return this.from("number", value_887); - } - fromString(value_888) { - return this.from("string", value_888); - } - fromPunctuator(value_889) { - return this.from("punctuator", value_889); - } - fromKeyword(value_890) { - return this.from("keyword"); - } - fromIdentifier(value_891) { - return this.from("identifier", value_891); - } - fromRegularExpression(value_892) { - return this.from("regularExpression", value_892); - } - fromBraces(inner_893) { - return this.from("braces", inner_893); - } - fromBrackets(inner_894) { - return this.from("brackets", inner_894); - } - fromParens(inner_895) { - return this.from("parens", inner_895); - } - static fromNull() { - let stx_896 = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; - return Syntax.from("null", null, stx_896); - } - static fromNumber(value_897) { - let stx_898 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + extend(props) { + let specAttrNames = this.spec.getAttributes().map(attrName); + let newProps = R.pick(specAttrNames, this); - return Syntax.from("number", value_897, stx_898); - } - static fromString(value_899) { - let stx_900 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + let invalidAttrs = R.difference(Object.keys(props), specAttrNames); + if (invalidAttrs.length > 0) { + throw new Error(`Unexpected properties for term ${ this.type }: ${ invalidAttrs }`); + } - return Syntax.from("string", value_899, stx_900); + return new Term(this.type, Object.assign(newProps, props)); } - static fromPunctuator(value_901) { - let stx_902 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("punctuator", value_901, stx_902); + // TODO: remove + gen() { + let includeImports = arguments.length <= 0 || arguments[0] === undefined ? true : arguments[0]; + + let next = {}; + for (let field of this.spec.getAttributes()) { + if (this[field.attrName] == null) { + next[field.attrName] = null; + } else if (this[field.attrName] instanceof Term) { + next[field.attrName] = this[field.attrName].gen(includeImports); + } else if (_immutable.List.isList(this[field.attrName])) { + let pred = includeImports ? R.complement(isCompiletimeStatement) : R.both(R.complement(isImportDeclaration), R.complement(isCompiletimeStatement)); + next[field.attrName] = this[field.attrName].filter(pred).map(term => term instanceof Term ? term.gen(includeImports) : term); + } else { + next[field.attrName] = this[field.attrName]; + } + } + return new Term(this.type, next); } - static fromKeyword(value_903) { - let stx_904 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("keyword", value_903, stx_904); + // TODO: remove + visit(f) { + let next = {}; + for (let field of _sweetSpec2.default.getDescendant(this.type).getAttributes()) { + if (this[field.attrName] == null) { + next[field.attrName] = null; + } else if (_immutable.List.isList(this[field.attrName])) { + next[field.attrName] = this[field.attrName].map(field => field != null ? f(field) : null); + } else { + next[field.attrName] = f(this[field.attrName]); + } + } + return this.extend(next); } - static fromIdentifier(value_905) { - let stx_906 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("identifier", value_905, stx_906); + // TODO: remove + addScope(scope, bindings, phase, options) { + return this.visit(term => { + if (typeof term.addScope === 'function') { + return term.addScope(scope, bindings, phase, options); + } + return term; + }); } - static fromRegularExpression(value_907) { - let stx_908 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("regularExpression", value_907, stx_908); + // TODO: remove + removeScope(scope, phase) { + return this.visit(term => { + if (typeof term.removeScope === 'function') { + return term.removeScope(scope, phase); + } + return term; + }); } - static fromBraces(inner_909) { - let stx_910 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("braces", inner_909, stx_910); + // TODO: this is very wrong + lineNumber() { + for (let field of _sweetSpec2.default.getDescendant(this.type).getAttributes()) { + if (typeof this[field.attrName] && this[field.attrName].lineNumber === 'function') { + return this[field.attrName].lineNumber(); + } + } } - static fromBrackets(inner_911) { - let stx_912 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("brackets", inner_911, stx_912); + setLineNumber(line) { + let next = {}; + for (let field of _sweetSpec2.default.getDescendant(this.type).getAttributes()) { + if (this[field.attrName] == null) { + next[field.attrName] = null; + } else if (typeof this[field.attrName].setLineNumber === 'function') { + next[field.attrName] = this[field.attrName].setLineNumber(line); + } else if (_immutable.List.isList(this[field.attrName])) { + next[field.attrName] = this[field.attrName].map(f => f.setLineNumber(line)); + } else { + next[field.attrName] = this[field.attrName]; + } + } + return new Term(this.type, next); } - static fromParens(inner_913) { - let stx_914 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + } - return Syntax.from("parens", inner_913, stx_914); - } - resolve(phase_915) { - (0, _errors.assert)(phase_915 != null, "must provide a phase to resolve"); - let allScopes_916 = this.scopesets.all; - let stxScopes_917 = this.scopesets.phase.has(phase_915) ? this.scopesets.phase.get(phase_915) : (0, _immutable.List)(); - stxScopes_917 = allScopes_916.concat(stxScopes_917); - if (stxScopes_917.size === 0 || !(this.match("identifier") || this.match("keyword"))) { - return this.token.value; - } - let scope_918 = stxScopes_917.last(); - let bindings_919 = this.bindings; - if (scope_918) { - let scopesetBindingList = bindings_919.get(this); - if (scopesetBindingList) { - let biggestBindingPair = scopesetBindingList.filter(_ref => { - let scopes = _ref.scopes; - let binding = _ref.binding; + exports.default = Term; // bindings + + const isBindingWithDefault = exports.isBindingWithDefault = R.whereEq({ type: "BindingWithDefault" }); + const isBindingIdentifier = exports.isBindingIdentifier = R.whereEq({ type: "BindingIdentifier" }); + const isArrayBinding = exports.isArrayBinding = R.whereEq({ type: "ArrayBinding" }); + const isObjectBinding = exports.isObjectBinding = R.whereEq({ type: "ObjectBinding" }); + const isBindingPropertyIdentifier = exports.isBindingPropertyIdentifier = R.whereEq({ type: "BindingPropertyIdentifier" }); + const isBindingPropertyProperty = exports.isBindingPropertyProperty = R.whereEq({ type: "BindingPropertyIdentifier" }); + + // class + const isClassExpression = exports.isClassExpression = R.whereEq({ type: "ClassExpression" }); + const isClassDeclaration = exports.isClassDeclaration = R.whereEq({ type: "ClassDeclaration" }); + const isClassElement = exports.isClassElement = R.whereEq({ type: "ClassElement" }); + + // modules + const isModule = exports.isModule = R.whereEq({ type: "Module" }); + const isImport = exports.isImport = R.whereEq({ type: "Import" }); + const isImportNamespace = exports.isImportNamespace = R.whereEq({ type: "ImportNamespace" }); + const isImportSpecifier = exports.isImportSpecifier = R.whereEq({ type: "ImportSpecifier" }); + const isExportAllFrom = exports.isExportAllFrom = R.whereEq({ type: "ExportAllFrom" }); + const isExportFrom = exports.isExportFrom = R.whereEq({ type: "ExportFrom" }); + const isExport = exports.isExport = R.whereEq({ type: "Export" }); + const isExportDefault = exports.isExportDefault = R.whereEq({ type: "ExportDefault" }); + const isExportSpecifier = exports.isExportSpecifier = R.whereEq({ type: "ExportSpecifier" }); + + // property definition + const isMethod = exports.isMethod = R.whereEq({ type: "Method" }); + const isGetter = exports.isGetter = R.whereEq({ type: "Getter" }); + const isSetter = exports.isSetter = R.whereEq({ type: "Setter" }); + const isDataProperty = exports.isDataProperty = R.whereEq({ type: "DataProperty" }); + const isShorthandProperty = exports.isShorthandProperty = R.whereEq({ type: "ShorthandProperty" }); + const isComputedPropertyName = exports.isComputedPropertyName = R.whereEq({ type: "ComputedPropertyName" }); + const isStaticPropertyName = exports.isStaticPropertyName = R.whereEq({ type: "StaticPropertyName" }); + + // literals + const isLiteralBooleanExpression = exports.isLiteralBooleanExpression = R.whereEq({ type: "LiteralBooleanExpression" }); + const isLiteralInfinityExpression = exports.isLiteralInfinityExpression = R.whereEq({ type: "LiteralInfinityExpression" }); + const isLiteralNullExpression = exports.isLiteralNullExpression = R.whereEq({ type: "LiteralNullExpression" }); + const isLiteralNumericExpression = exports.isLiteralNumericExpression = R.whereEq({ type: "LiteralNumericExpression" }); + const isLiteralRegExpExpression = exports.isLiteralRegExpExpression = R.whereEq({ type: "LiteralRegExpExpression" }); + const isLiteralStringExpression = exports.isLiteralStringExpression = R.whereEq({ type: "LiteralStringExpression" }); + + // expressions + const isArrayExpression = exports.isArrayExpression = R.whereEq({ type: "ArrayExpression" }); + const isArrowExpression = exports.isArrowExpression = R.whereEq({ type: "ArrowExpression" }); + const isAssignmentExpression = exports.isAssignmentExpression = R.whereEq({ type: "AssignmentExpression" }); + const isBinaryExpression = exports.isBinaryExpression = R.whereEq({ type: "BinaryExpression" }); + const isCallExpression = exports.isCallExpression = R.whereEq({ type: "CallExpression" }); + const isComputedAssignmentExpression = exports.isComputedAssignmentExpression = R.whereEq({ type: "ComputedAssignmentExpression" }); + const isComputedMemberExpression = exports.isComputedMemberExpression = R.whereEq({ type: "ComputedMemberExpression" }); + const isConditionalExpression = exports.isConditionalExpression = R.whereEq({ type: "ConditionalExpression" }); + const isFunctionExpression = exports.isFunctionExpression = R.whereEq({ type: "FunctionExpression" }); + const isIdentifierExpression = exports.isIdentifierExpression = R.whereEq({ type: "IdentifierExpression" }); + const isNewExpression = exports.isNewExpression = R.whereEq({ type: "NewExpression" }); + const isNewTargetExpression = exports.isNewTargetExpression = R.whereEq({ type: "NewTargetExpression" }); + const isObjectExpression = exports.isObjectExpression = R.whereEq({ type: "ObjectExpression" }); + const isUnaryExpression = exports.isUnaryExpression = R.whereEq({ type: "UnaryExpression" }); + const isStaticMemberExpression = exports.isStaticMemberExpression = R.whereEq({ type: "StaticMemberExpression" }); + const isTemplateExpression = exports.isTemplateExpression = R.whereEq({ type: "TemplateExpression" }); + const isThisExpression = exports.isThisExpression = R.whereEq({ type: "ThisExpression" }); + const isUpdateExpression = exports.isUpdateExpression = R.whereEq({ type: "UpdateExpression" }); + const isYieldExpression = exports.isYieldExpression = R.whereEq({ type: "YieldExpression" }); + const isYieldGeneratorExpression = exports.isYieldGeneratorExpression = R.whereEq({ type: "YieldGeneratorExpression" }); + + // statements + const isBlockStatement = exports.isBlockStatement = R.whereEq({ type: "BlockStatement" }); + const isBreakStatement = exports.isBreakStatement = R.whereEq({ type: "BreakStatement" }); + const isContinueStatement = exports.isContinueStatement = R.whereEq({ type: "ContinueStatement" }); + const isCompoundAssignmentExpression = exports.isCompoundAssignmentExpression = R.whereEq({ type: "CompoundAssignmentExpression" }); + const isDebuggerStatement = exports.isDebuggerStatement = R.whereEq({ type: "DebuggerStatement" }); + const isDoWhileStatement = exports.isDoWhileStatement = R.whereEq({ type: "DoWhileStatement" }); + const isEmptyStatement = exports.isEmptyStatement = R.whereEq({ type: "EmptyStatement" }); + const isExpressionStatement = exports.isExpressionStatement = R.whereEq({ type: "ExpressionStatement" }); + const isForInStatement = exports.isForInStatement = R.whereEq({ type: "ForInStatement" }); + const isForOfStatement = exports.isForOfStatement = R.whereEq({ type: "ForOfStatement" }); + const isForStatement = exports.isForStatement = R.whereEq({ type: "ForStatement" }); + const isIfStatement = exports.isIfStatement = R.whereEq({ type: "IfStatement" }); + const isLabeledStatement = exports.isLabeledStatement = R.whereEq({ type: "LabeledStatement" }); + const isReturnStatement = exports.isReturnStatement = R.whereEq({ type: "ReturnStatement" }); + const isSwitchStatement = exports.isSwitchStatement = R.whereEq({ type: "SwitchStatement" }); + const isSwitchStatementWithDefault = exports.isSwitchStatementWithDefault = R.whereEq({ type: "SwitchStatementWithDefault" }); + const isThrowStatement = exports.isThrowStatement = R.whereEq({ type: "ThrowStatement" }); + const isTryCatchStatement = exports.isTryCatchStatement = R.whereEq({ type: "TryCatchStatement" }); + const isTryFinallyStatement = exports.isTryFinallyStatement = R.whereEq({ type: "TryFinallyStatement" }); + const isVariableDeclarationStatement = exports.isVariableDeclarationStatement = R.whereEq({ type: "VariableDeclarationStatement" }); + const isWhileStatement = exports.isWhileStatement = R.whereEq({ type: "WhileStatement" }); + const isWithStatement = exports.isWithStatement = R.whereEq({ type: "WithStatement" }); + + // other + const isPragma = exports.isPragma = R.whereEq({ type: 'Pragma' }); + const isBlock = exports.isBlock = R.whereEq({ type: "Block" }); + const isCatchClause = exports.isCatchClause = R.whereEq({ type: "CatchClause" }); + const isDirective = exports.isDirective = R.whereEq({ type: "Directive" }); + const isFormalParameters = exports.isFormalParameters = R.whereEq({ type: "FormalParameters" }); + const isFunctionBody = exports.isFunctionBody = R.whereEq({ type: "FunctionBody" }); + const isFunctionDeclaration = exports.isFunctionDeclaration = R.whereEq({ type: "FunctionDeclaration" }); + const isScript = exports.isScript = R.whereEq({ type: "Script" }); + const isSpreadElement = exports.isSpreadElement = R.whereEq({ type: "SpreadElement" }); + const isSuper = exports.isSuper = R.whereEq({ type: "Super" }); + const isSwitchCase = exports.isSwitchCase = R.whereEq({ type: "SwitchCase" }); + const isSwitchDefault = exports.isSwitchDefault = R.whereEq({ type: "SwitchDefault" }); + const isTemplateElement = exports.isTemplateElement = R.whereEq({ type: "TemplateElement" }); + const isSyntaxTemplate = exports.isSyntaxTemplate = R.whereEq({ type: "SyntaxTemplate" }); + const isVariableDeclaration = exports.isVariableDeclaration = R.whereEq({ type: "VariableDeclaration" }); + const isVariableDeclarator = exports.isVariableDeclarator = R.whereEq({ type: "VariableDeclarator" }); + const isEOF = exports.isEOF = R.whereEq({ type: 'EOF' }); + const isSyntaxDeclaration = exports.isSyntaxDeclaration = R.both(isVariableDeclaration, R.whereEq({ kind: 'syntax' })); + const isSyntaxrecDeclaration = exports.isSyntaxrecDeclaration = R.both(isVariableDeclaration, R.whereEq({ kind: 'syntaxrec' })); + const isFunctionTerm = exports.isFunctionTerm = R.either(isFunctionDeclaration, isFunctionExpression); + const isFunctionWithName = exports.isFunctionWithName = R.and(isFunctionTerm, R.complement(R.where({ name: R.isNil }))); + const isParenthesizedExpression = exports.isParenthesizedExpression = R.whereEq({ type: 'ParenthesizedExpression' }); + const isExportSyntax = exports.isExportSyntax = R.both(isExport, exp => R.or(isSyntaxDeclaration(exp.declaration), isSyntaxrecDeclaration(exp.declaration))); + const isSyntaxDeclarationStatement = exports.isSyntaxDeclarationStatement = R.both(isVariableDeclarationStatement, decl => isCompiletimeDeclaration(decl.declaration)); + + const isCompiletimeDeclaration = exports.isCompiletimeDeclaration = R.either(isSyntaxDeclaration, isSyntaxrecDeclaration); + const isCompiletimeStatement = exports.isCompiletimeStatement = term => { + return term instanceof Term && isVariableDeclarationStatement(term) && isCompiletimeDeclaration(term.declaration); + }; + const isImportDeclaration = exports.isImportDeclaration = R.either(isImport, isImportNamespace); + //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/terms.js"],"names":[],"mappings":";;;;;;;AAAA;;AACA;;IAAY,C;;AACZ;;;;;;;;AAEA,MAAM,WAAW,KAAK,EAAE,QAAxB;;AAEe,MAAM,IAAN,CAAW;;AAKxB,cAAY,IAAZ,EAA0B,KAA1B,EAAqC;AACnC,QAAI,OAAO,oBAAS,aAAT,CAAuB,IAAvB,CAAX;AACA,QAAI,QAAQ,IAAZ,EAAkB;AAChB,YAAM,IAAI,KAAJ,CAAW,kBAAgB,IAAK,GAAhC,CAAN;AACD;AACD,SAAK,IAAL,GAAY,IAAZ;AACA,SAAK,GAAL,GAAW,IAAX;AACA,SAAK,IAAL,GAAY,IAAZ;AACA,QAAI,WAAW,OAAO,IAAP,CAAY,KAAZ,CAAf;AACA,QAAI,aAAa,KAAK,aAAL,GAAqB,GAArB,CAAyB,QAAzB,CAAjB;AACA,QAAI,OAAO,EAAE,mBAAF,CAAsB,QAAtB,EAAgC,UAAhC,CAAX;AACA,QAAI,KAAK,MAAL,KAAgB,CAApB,EAAuB;AACrB,YAAM,IAAI,KAAJ,CAAW,mCAAiC,IAAK,OAAI,IAAK,GAA1D,CAAN;AACD;AACD,WAAO,MAAP,CAAc,IAAd,EAAoB,KAApB;AACD;;AAED,SAAO,KAAP,EAAkB;AAChB,QAAI,gBAAgB,KAAK,IAAL,CAAU,aAAV,GAA0B,GAA1B,CAA8B,QAA9B,CAApB;AACA,QAAI,WAAW,EAAE,IAAF,CAAO,aAAP,EAAsB,IAAtB,CAAf;;AAEA,QAAI,eAAe,EAAE,UAAF,CAAa,OAAO,IAAP,CAAY,KAAZ,CAAb,EAAiC,aAAjC,CAAnB;AACA,QAAI,aAAa,MAAb,GAAsB,CAA1B,EAA6B;AAC3B,YAAM,IAAI,KAAJ,CAAW,mCAAiC,KAAK,IAAK,OAAI,YAAa,GAAvE,CAAN;AACD;;AAED,WAAO,IAAI,IAAJ,CAAS,KAAK,IAAd,EAAoB,OAAO,MAAP,CAAc,QAAd,EAAwB,KAAxB,CAApB,CAAP;AACD;;AAED;AACA,QAAoC;AAAA,QAAhC,cAAgC,yDAAN,IAAM;;AAClC,QAAI,OAAO,EAAX;AACA,SAAK,IAAI,KAAT,IAAkB,KAAK,IAAL,CAAU,aAAV,EAAlB,EAA6C;AAC3C,UAAI,KAAK,MAAM,QAAX,KAAwB,IAA5B,EAAkC;AAChC,aAAK,MAAM,QAAX,IAAuB,IAAvB;AACD,OAFD,MAEO,IAAI,KAAK,MAAM,QAAX,aAAgC,IAApC,EAA0C;AAC/C,aAAK,MAAM,QAAX,IAAuB,KAAK,MAAM,QAAX,EAAqB,GAArB,CAAyB,cAAzB,CAAvB;AACD,OAFM,MAEA,IAAI,gBAAK,MAAL,CAAY,KAAK,MAAM,QAAX,CAAZ,CAAJ,EAAuC;AAC5C,YAAI,OAAO,iBAAiB,EAAE,UAAF,CAAa,sBAAb,CAAjB,GAAwD,EAAE,IAAF,CAAO,EAAE,UAAF,CAAa,mBAAb,CAAP,EAA0C,EAAE,UAAF,CAAa,sBAAb,CAA1C,CAAnE;AACA,aAAK,MAAM,QAAX,IAAuB,KAAK,MAAM,QAAX,EAAqB,MAArB,CAA4B,IAA5B,EACG,GADH,CACO,QAAQ,gBAAgB,IAAhB,GAAuB,KAAK,GAAL,CAAS,cAAT,CAAvB,GAAkD,IADjE,CAAvB;AAED,OAJM,MAIA;AACL,aAAK,MAAM,QAAX,IAAuB,KAAK,MAAM,QAAX,CAAvB;AACD;AACF;AACD,WAAO,IAAI,IAAJ,CAAS,KAAK,IAAd,EAAoB,IAApB,CAAP;AACD;;AAED;AACA,QAAM,CAAN,EAAS;AACP,QAAI,OAAO,EAAX;AACA,SAAK,IAAI,KAAT,IAAkB,oBAAS,aAAT,CAAuB,KAAK,IAA5B,EAAkC,aAAlC,EAAlB,EAAqE;AACnE,UAAI,KAAK,MAAM,QAAX,KAAwB,IAA5B,EAAkC;AAChC,aAAK,MAAM,QAAX,IAAuB,IAAvB;AACD,OAFD,MAEO,IAAI,gBAAK,MAAL,CAAY,KAAK,MAAM,QAAX,CAAZ,CAAJ,EAAuC;AAC5C,aAAK,MAAM,QAAX,IAAuB,KAAK,MAAM,QAAX,EAAqB,GAArB,CAAyB,SAAS,SAAS,IAAT,GAAgB,EAAE,KAAF,CAAhB,GAA2B,IAA7D,CAAvB;AACD,OAFM,MAEA;AACL,aAAK,MAAM,QAAX,IAAuB,EAAE,KAAK,MAAM,QAAX,CAAF,CAAvB;AACD;AACF;AACD,WAAO,KAAK,MAAL,CAAY,IAAZ,CAAP;AACD;;AAED;AACA,WAAS,KAAT,EAAgB,QAAhB,EAA0B,KAA1B,EAAiC,OAAjC,EAA0C;AACxC,WAAO,KAAK,KAAL,CAAW,QAAQ;AACxB,UAAI,OAAO,KAAK,QAAZ,KAAyB,UAA7B,EAAyC;AACvC,eAAO,KAAK,QAAL,CAAc,KAAd,EAAqB,QAArB,EAA+B,KAA/B,EAAsC,OAAtC,CAAP;AACD;AACD,aAAO,IAAP;AACD,KALM,CAAP;AAMD;;AAED;AACA,cAAY,KAAZ,EAAmB,KAAnB,EAA0B;AACxB,WAAO,KAAK,KAAL,CAAW,QAAQ;AACxB,UAAI,OAAO,KAAK,WAAZ,KAA4B,UAAhC,EAA4C;AAC1C,eAAO,KAAK,WAAL,CAAiB,KAAjB,EAAwB,KAAxB,CAAP;AACD;AACD,aAAO,IAAP;AACD,KALM,CAAP;AAMD;;AAED;AACA,eAAa;AACX,SAAK,IAAI,KAAT,IAAkB,oBAAS,aAAT,CAAuB,KAAK,IAA5B,EAAkC,aAAlC,EAAlB,EAAqE;AACnE,UAAI,OAAO,KAAK,MAAM,QAAX,CAAP,IAA+B,KAAK,MAAM,QAAX,EAAqB,UAArB,KAAoC,UAAvE,EAAmF;AACjF,eAAO,KAAK,MAAM,QAAX,EAAqB,UAArB,EAAP;AACD;AACF;AACF;;AAED,gBAAc,IAAd,EAAoB;AAClB,QAAI,OAAO,EAAX;AACA,SAAK,IAAI,KAAT,IAAkB,oBAAS,aAAT,CAAuB,KAAK,IAA5B,EAAkC,aAAlC,EAAlB,EAAqE;AACnE,UAAI,KAAK,MAAM,QAAX,KAAwB,IAA5B,EAAkC;AAChC,aAAK,MAAM,QAAX,IAAuB,IAAvB;AACD,OAFD,MAEO,IAAI,OAAO,KAAK,MAAM,QAAX,EAAqB,aAA5B,KAA8C,UAAlD,EAA8D;AACnE,aAAK,MAAM,QAAX,IAAuB,KAAK,MAAM,QAAX,EAAqB,aAArB,CAAmC,IAAnC,CAAvB;AACD,OAFM,MAEA,IAAI,gBAAK,MAAL,CAAY,KAAK,MAAM,QAAX,CAAZ,CAAJ,EAAuC;AAC5C,aAAK,MAAM,QAAX,IAAuB,KAAK,MAAM,QAAX,EAAqB,GAArB,CAAyB,KAAK,EAAE,aAAF,CAAgB,IAAhB,CAA9B,CAAvB;AACD,OAFM,MAEA;AACL,aAAK,MAAM,QAAX,IAAuB,KAAK,MAAM,QAAX,CAAvB;AACD;AACF;AACD,WAAO,IAAI,IAAJ,CAAS,KAAK,IAAd,EAAoB,IAApB,CAAP;AACD;AA/GuB;;kBAAL,I,CAmHrB;;AACO,MAAM,sDAAuB,EAAE,OAAF,CAAU,EAAE,MAAM,oBAAR,EAAV,CAA7B;AACA,MAAM,oDAAsB,EAAE,OAAF,CAAU,EAAE,MAAM,mBAAR,EAAV,CAA5B;AACA,MAAM,0CAAiB,EAAE,OAAF,CAAU,EAAE,MAAM,cAAR,EAAV,CAAvB;AACA,MAAM,4CAAkB,EAAE,OAAF,CAAU,EAAE,MAAM,eAAR,EAAV,CAAxB;AACA,MAAM,oEAA8B,EAAE,OAAF,CAAU,EAAE,MAAM,2BAAR,EAAV,CAApC;AACA,MAAM,gEAA4B,EAAE,OAAF,CAAU,EAAE,MAAM,2BAAR,EAAV,CAAlC;;AAEP;AACO,MAAM,gDAAoB,EAAE,OAAF,CAAU,EAAE,MAAM,iBAAR,EAAV,CAA1B;AACA,MAAM,kDAAqB,EAAE,OAAF,CAAU,EAAE,MAAM,kBAAR,EAAV,CAA3B;AACA,MAAM,0CAAiB,EAAE,OAAF,CAAU,EAAE,MAAM,cAAR,EAAV,CAAvB;;AAEP;AACO,MAAM,8BAAW,EAAE,OAAF,CAAU,EAAE,MAAM,QAAR,EAAV,CAAjB;AACA,MAAM,8BAAW,EAAE,OAAF,CAAU,EAAE,MAAM,QAAR,EAAV,CAAjB;AACA,MAAM,gDAAoB,EAAE,OAAF,CAAU,EAAE,MAAM,iBAAR,EAAV,CAA1B;AACA,MAAM,gDAAoB,EAAE,OAAF,CAAU,EAAE,MAAM,iBAAR,EAAV,CAA1B;AACA,MAAM,4CAAkB,EAAE,OAAF,CAAU,EAAE,MAAM,eAAR,EAAV,CAAxB;AACA,MAAM,sCAAe,EAAE,OAAF,CAAU,EAAE,MAAM,YAAR,EAAV,CAArB;AACA,MAAM,8BAAW,EAAE,OAAF,CAAU,EAAE,MAAM,QAAR,EAAV,CAAjB;AACA,MAAM,4CAAkB,EAAE,OAAF,CAAU,EAAE,MAAM,eAAR,EAAV,CAAxB;AACA,MAAM,gDAAoB,EAAE,OAAF,CAAU,EAAE,MAAM,iBAAR,EAAV,CAA1B;;AAEP;AACO,MAAM,8BAAW,EAAE,OAAF,CAAU,EAAE,MAAM,QAAR,EAAV,CAAjB;AACA,MAAM,8BAAW,EAAE,OAAF,CAAU,EAAE,MAAM,QAAR,EAAV,CAAjB;AACA,MAAM,8BAAW,EAAE,OAAF,CAAU,EAAE,MAAM,QAAR,EAAV,CAAjB;AACA,MAAM,0CAAiB,EAAE,OAAF,CAAU,EAAE,MAAM,cAAR,EAAV,CAAvB;AACA,MAAM,oDAAsB,EAAE,OAAF,CAAU,EAAE,MAAM,mBAAR,EAAV,CAA5B;AACA,MAAM,0DAAyB,EAAE,OAAF,CAAU,EAAE,MAAM,sBAAR,EAAV,CAA/B;AACA,MAAM,sDAAuB,EAAE,OAAF,CAAU,EAAE,MAAM,oBAAR,EAAV,CAA7B;;AAEP;AACO,MAAM,kEAA6B,EAAE,OAAF,CAAU,EAAE,MAAM,0BAAR,EAAV,CAAnC;AACA,MAAM,oEAA8B,EAAE,OAAF,CAAU,EAAE,MAAM,2BAAR,EAAV,CAApC;AACA,MAAM,4DAA0B,EAAE,OAAF,CAAU,EAAE,MAAM,uBAAR,EAAV,CAAhC;AACA,MAAM,kEAA6B,EAAE,OAAF,CAAU,EAAE,MAAM,0BAAR,EAAV,CAAnC;AACA,MAAM,gEAA4B,EAAE,OAAF,CAAU,EAAE,MAAM,yBAAR,EAAV,CAAlC;AACA,MAAM,gEAA4B,EAAE,OAAF,CAAU,EAAE,MAAM,yBAAR,EAAV,CAAlC;;AAEP;AACO,MAAM,gDAAoB,EAAE,OAAF,CAAU,EAAE,MAAM,iBAAR,EAAV,CAA1B;AACA,MAAM,gDAAoB,EAAE,OAAF,CAAU,EAAE,MAAM,iBAAR,EAAV,CAA1B;AACA,MAAM,0DAAyB,EAAE,OAAF,CAAU,EAAE,MAAM,sBAAR,EAAV,CAA/B;AACA,MAAM,kDAAqB,EAAE,OAAF,CAAU,EAAE,MAAM,kBAAR,EAAV,CAA3B;AACA,MAAM,8CAAmB,EAAE,OAAF,CAAU,EAAE,MAAM,gBAAR,EAAV,CAAzB;AACA,MAAM,0EAAiC,EAAE,OAAF,CAAU,EAAE,MAAM,8BAAR,EAAV,CAAvC;AACA,MAAM,kEAA6B,EAAE,OAAF,CAAU,EAAE,MAAM,0BAAR,EAAV,CAAnC;AACA,MAAM,4DAA0B,EAAE,OAAF,CAAU,EAAE,MAAM,uBAAR,EAAV,CAAhC;AACA,MAAM,sDAAuB,EAAE,OAAF,CAAU,EAAE,MAAM,oBAAR,EAAV,CAA7B;AACA,MAAM,0DAAyB,EAAE,OAAF,CAAU,EAAE,MAAM,sBAAR,EAAV,CAA/B;AACA,MAAM,4CAAkB,EAAE,OAAF,CAAU,EAAE,MAAM,eAAR,EAAV,CAAxB;AACA,MAAM,wDAAwB,EAAE,OAAF,CAAU,EAAE,MAAM,qBAAR,EAAV,CAA9B;AACA,MAAM,kDAAqB,EAAE,OAAF,CAAU,EAAE,MAAM,kBAAR,EAAV,CAA3B;AACA,MAAM,gDAAoB,EAAE,OAAF,CAAU,EAAE,MAAM,iBAAR,EAAV,CAA1B;AACA,MAAM,8DAA2B,EAAE,OAAF,CAAU,EAAE,MAAM,wBAAR,EAAV,CAAjC;AACA,MAAM,sDAAuB,EAAE,OAAF,CAAU,EAAE,MAAM,oBAAR,EAAV,CAA7B;AACA,MAAM,8CAAmB,EAAE,OAAF,CAAU,EAAE,MAAM,gBAAR,EAAV,CAAzB;AACA,MAAM,kDAAqB,EAAE,OAAF,CAAU,EAAE,MAAM,kBAAR,EAAV,CAA3B;AACA,MAAM,gDAAoB,EAAE,OAAF,CAAU,EAAE,MAAM,iBAAR,EAAV,CAA1B;AACA,MAAM,kEAA6B,EAAE,OAAF,CAAU,EAAE,MAAM,0BAAR,EAAV,CAAnC;;AAEP;AACO,MAAM,8CAAmB,EAAE,OAAF,CAAU,EAAE,MAAM,gBAAR,EAAV,CAAzB;AACA,MAAM,8CAAmB,EAAE,OAAF,CAAU,EAAE,MAAM,gBAAR,EAAV,CAAzB;AACA,MAAM,oDAAsB,EAAE,OAAF,CAAU,EAAE,MAAM,mBAAR,EAAV,CAA5B;AACA,MAAM,0EAAiC,EAAE,OAAF,CAAU,EAAE,MAAM,8BAAR,EAAV,CAAvC;AACA,MAAM,oDAAsB,EAAE,OAAF,CAAU,EAAE,MAAM,mBAAR,EAAV,CAA5B;AACA,MAAM,kDAAqB,EAAE,OAAF,CAAU,EAAE,MAAM,kBAAR,EAAV,CAA3B;AACA,MAAM,8CAAmB,EAAE,OAAF,CAAU,EAAE,MAAM,gBAAR,EAAV,CAAzB;AACA,MAAM,wDAAwB,EAAE,OAAF,CAAU,EAAE,MAAM,qBAAR,EAAV,CAA9B;AACA,MAAM,8CAAmB,EAAE,OAAF,CAAU,EAAE,MAAM,gBAAR,EAAV,CAAzB;AACA,MAAM,8CAAmB,EAAE,OAAF,CAAU,EAAE,MAAM,gBAAR,EAAV,CAAzB;AACA,MAAM,0CAAiB,EAAE,OAAF,CAAU,EAAE,MAAM,cAAR,EAAV,CAAvB;AACA,MAAM,wCAAgB,EAAE,OAAF,CAAU,EAAE,MAAM,aAAR,EAAV,CAAtB;AACA,MAAM,kDAAqB,EAAE,OAAF,CAAU,EAAE,MAAM,kBAAR,EAAV,CAA3B;AACA,MAAM,gDAAoB,EAAE,OAAF,CAAU,EAAE,MAAM,iBAAR,EAAV,CAA1B;AACA,MAAM,gDAAoB,EAAE,OAAF,CAAU,EAAE,MAAM,iBAAR,EAAV,CAA1B;AACA,MAAM,sEAA+B,EAAE,OAAF,CAAU,EAAE,MAAM,4BAAR,EAAV,CAArC;AACA,MAAM,8CAAmB,EAAE,OAAF,CAAU,EAAE,MAAM,gBAAR,EAAV,CAAzB;AACA,MAAM,oDAAsB,EAAE,OAAF,CAAU,EAAE,MAAM,mBAAR,EAAV,CAA5B;AACA,MAAM,wDAAwB,EAAE,OAAF,CAAU,EAAE,MAAM,qBAAR,EAAV,CAA9B;AACA,MAAM,0EAAiC,EAAE,OAAF,CAAU,EAAE,MAAM,8BAAR,EAAV,CAAvC;AACA,MAAM,8CAAmB,EAAE,OAAF,CAAU,EAAE,MAAM,gBAAR,EAAV,CAAzB;AACA,MAAM,4CAAkB,EAAE,OAAF,CAAU,EAAE,MAAM,eAAR,EAAV,CAAxB;;AAEP;AACO,MAAM,8BAAW,EAAE,OAAF,CAAU,EAAE,MAAM,QAAR,EAAV,CAAjB;AACA,MAAM,4BAAU,EAAE,OAAF,CAAU,EAAE,MAAM,OAAR,EAAV,CAAhB;AACA,MAAM,wCAAgB,EAAE,OAAF,CAAU,EAAE,MAAM,aAAR,EAAV,CAAtB;AACA,MAAM,oCAAc,EAAE,OAAF,CAAU,EAAE,MAAM,WAAR,EAAV,CAApB;AACA,MAAM,kDAAqB,EAAE,OAAF,CAAU,EAAE,MAAM,kBAAR,EAAV,CAA3B;AACA,MAAM,0CAAiB,EAAE,OAAF,CAAU,EAAE,MAAM,cAAR,EAAV,CAAvB;AACA,MAAM,wDAAwB,EAAE,OAAF,CAAU,EAAE,MAAM,qBAAR,EAAV,CAA9B;AACA,MAAM,8BAAW,EAAE,OAAF,CAAU,EAAE,MAAM,QAAR,EAAV,CAAjB;AACA,MAAM,4CAAkB,EAAE,OAAF,CAAU,EAAE,MAAM,eAAR,EAAV,CAAxB;AACA,MAAM,4BAAU,EAAE,OAAF,CAAU,EAAE,MAAM,OAAR,EAAV,CAAhB;AACA,MAAM,sCAAe,EAAE,OAAF,CAAU,EAAE,MAAM,YAAR,EAAV,CAArB;AACA,MAAM,4CAAkB,EAAE,OAAF,CAAU,EAAE,MAAM,eAAR,EAAV,CAAxB;AACA,MAAM,gDAAoB,EAAE,OAAF,CAAU,EAAE,MAAM,iBAAR,EAAV,CAA1B;AACA,MAAM,8CAAmB,EAAE,OAAF,CAAU,EAAE,MAAM,gBAAR,EAAV,CAAzB;AACA,MAAM,wDAAwB,EAAE,OAAF,CAAU,EAAE,MAAM,qBAAR,EAAV,CAA9B;AACA,MAAM,sDAAuB,EAAE,OAAF,CAAU,EAAE,MAAM,oBAAR,EAAV,CAA7B;AACA,MAAM,wBAAQ,EAAE,OAAF,CAAU,EAAE,MAAM,KAAR,EAAV,CAAd;AACA,MAAM,oDAAsB,EAAE,IAAF,CAAO,qBAAP,EAA8B,EAAE,OAAF,CAAU,EAAE,MAAM,QAAR,EAAV,CAA9B,CAA5B;AACA,MAAM,0DAAyB,EAAE,IAAF,CAAO,qBAAP,EAA8B,EAAE,OAAF,CAAU,EAAE,MAAM,WAAR,EAAV,CAA9B,CAA/B;AACA,MAAM,0CAAiB,EAAE,MAAF,CAAS,qBAAT,EAAgC,oBAAhC,CAAvB;AACA,MAAM,kDAAqB,EAAE,GAAF,CAAM,cAAN,EAAsB,EAAE,UAAF,CAAa,EAAE,KAAF,CAAQ,EAAE,MAAM,EAAE,KAAV,EAAR,CAAb,CAAtB,CAA3B;AACA,MAAM,gEAA4B,EAAE,OAAF,CAAU,EAAE,MAAM,yBAAR,EAAV,CAAlC;AACA,MAAM,0CAAiB,EAAE,IAAF,CAAO,QAAP,EAAiB,OAAO,EAAE,EAAF,CAAK,oBAAoB,IAAI,WAAxB,CAAL,EAA2C,uBAAuB,IAAI,WAA3B,CAA3C,CAAxB,CAAvB;AACA,MAAM,sEAA+B,EAAE,IAAF,CAAO,8BAAP,EAAuC,QAAQ,yBAAyB,KAAK,WAA9B,CAA/C,CAArC;;AAGA,MAAM,8DAA2B,EAAE,MAAF,CAAS,mBAAT,EAA8B,sBAA9B,CAAjC;AACA,MAAM,0DAAyB,QAAQ;AAC5C,SAAQ,gBAAgB,IAAjB,IAA0B,+BAA+B,IAA/B,CAA1B,IAAkE,yBAAyB,KAAK,WAA9B,CAAzE;AACD,CAFM;AAGA,MAAM,oDAAsB,EAAE,MAAF,CAAS,QAAT,EAAmB,iBAAnB,CAA5B","file":"terms.js","sourcesContent":["import { List } from \"immutable\";\nimport * as R from \"ramda\";\nimport TermSpec from 'sweet-spec';\n\nconst attrName = a => a.attrName;\n\nexport default class Term {\n  type: string;\n  loc: null;\n  spec: typeof TermSpec;\n\n  constructor(type: string, props: {}) {\n    let spec = TermSpec.getDescendant(type);\n    if (spec == null) {\n      throw new Error(`Unknown term: ${type}`);\n    }\n    this.type = type;\n    this.loc = null;\n    this.spec = spec;\n    let propKeys = Object.keys(props);\n    let fieldNames = spec.getAttributes().map(attrName);\n    let diff = R.symmetricDifference(propKeys, fieldNames);\n    if (diff.length !== 0) {\n      throw new Error(`Unexpected properties for term ${type}: ${diff}`);\n    }\n    Object.assign(this, props);\n  }\n\n  extend(props: {}) {\n    let specAttrNames = this.spec.getAttributes().map(attrName);\n    let newProps = R.pick(specAttrNames, this);\n\n    let invalidAttrs = R.difference(Object.keys(props), specAttrNames);\n    if (invalidAttrs.length > 0) {\n      throw new Error(`Unexpected properties for term ${this.type}: ${invalidAttrs}`);\n    }\n\n    return new Term(this.type, Object.assign(newProps, props));\n  }\n\n  // TODO: remove\n  gen(includeImports: boolean = true) {\n    let next = {};\n    for (let field of this.spec.getAttributes()) {\n      if (this[field.attrName] == null) {\n        next[field.attrName] = null;\n      } else if (this[field.attrName] instanceof Term) {\n        next[field.attrName] = this[field.attrName].gen(includeImports);\n      } else if (List.isList(this[field.attrName])) {\n        let pred = includeImports ? R.complement(isCompiletimeStatement) : R.both(R.complement(isImportDeclaration), R.complement(isCompiletimeStatement));\n        next[field.attrName] = this[field.attrName].filter(pred)\n                                 .map(term => term instanceof Term ? term.gen(includeImports) : term);\n      } else {\n        next[field.attrName] = this[field.attrName];\n      }\n    }\n    return new Term(this.type, next);\n  }\n\n  // TODO: remove\n  visit(f) {\n    let next = {};\n    for (let field of TermSpec.getDescendant(this.type).getAttributes()) {\n      if (this[field.attrName] == null) {\n        next[field.attrName] = null;\n      } else if (List.isList(this[field.attrName])) {\n        next[field.attrName] = this[field.attrName].map(field => field != null ? f(field) : null);\n      } else {\n        next[field.attrName] = f(this[field.attrName]);\n      }\n    }\n    return this.extend(next);\n  }\n\n  // TODO: remove\n  addScope(scope, bindings, phase, options) {\n    return this.visit(term => {\n      if (typeof term.addScope === 'function') {\n        return term.addScope(scope, bindings, phase, options);\n      }\n      return term;\n    });\n  }\n\n  // TODO: remove\n  removeScope(scope, phase) {\n    return this.visit(term => {\n      if (typeof term.removeScope === 'function') {\n        return term.removeScope(scope, phase);\n      }\n      return term;\n    });\n  }\n\n  // TODO: this is very wrong\n  lineNumber() {\n    for (let field of TermSpec.getDescendant(this.type).getAttributes()) {\n      if (typeof this[field.attrName] && this[field.attrName].lineNumber === 'function') {\n        return this[field.attrName].lineNumber();\n      }\n    }\n  }\n\n  setLineNumber(line) {\n    let next = {};\n    for (let field of TermSpec.getDescendant(this.type).getAttributes()) {\n      if (this[field.attrName] == null) {\n        next[field.attrName] = null;\n      } else if (typeof this[field.attrName].setLineNumber === 'function') {\n        next[field.attrName] = this[field.attrName].setLineNumber(line);\n      } else if (List.isList(this[field.attrName])) {\n        next[field.attrName] = this[field.attrName].map(f => f.setLineNumber(line));\n      } else {\n        next[field.attrName] = this[field.attrName];\n      }\n    }\n    return new Term(this.type, next);\n  }\n}\n\n\n// bindings\nexport const isBindingWithDefault = R.whereEq({ type: \"BindingWithDefault\" });\nexport const isBindingIdentifier = R.whereEq({ type: \"BindingIdentifier\" });\nexport const isArrayBinding = R.whereEq({ type: \"ArrayBinding\" });\nexport const isObjectBinding = R.whereEq({ type: \"ObjectBinding\" });\nexport const isBindingPropertyIdentifier = R.whereEq({ type: \"BindingPropertyIdentifier\" });\nexport const isBindingPropertyProperty = R.whereEq({ type: \"BindingPropertyIdentifier\" });\n\n// class\nexport const isClassExpression = R.whereEq({ type: \"ClassExpression\" });\nexport const isClassDeclaration = R.whereEq({ type: \"ClassDeclaration\" });\nexport const isClassElement = R.whereEq({ type: \"ClassElement\" });\n\n// modules\nexport const isModule = R.whereEq({ type: \"Module\" });\nexport const isImport = R.whereEq({ type: \"Import\" });\nexport const isImportNamespace = R.whereEq({ type: \"ImportNamespace\" });\nexport const isImportSpecifier = R.whereEq({ type: \"ImportSpecifier\" });\nexport const isExportAllFrom = R.whereEq({ type: \"ExportAllFrom\" });\nexport const isExportFrom = R.whereEq({ type: \"ExportFrom\" });\nexport const isExport = R.whereEq({ type: \"Export\" });\nexport const isExportDefault = R.whereEq({ type: \"ExportDefault\" });\nexport const isExportSpecifier = R.whereEq({ type: \"ExportSpecifier\" });\n\n// property definition\nexport const isMethod = R.whereEq({ type: \"Method\" });\nexport const isGetter = R.whereEq({ type: \"Getter\" });\nexport const isSetter = R.whereEq({ type: \"Setter\" });\nexport const isDataProperty = R.whereEq({ type: \"DataProperty\" });\nexport const isShorthandProperty = R.whereEq({ type: \"ShorthandProperty\" });\nexport const isComputedPropertyName = R.whereEq({ type: \"ComputedPropertyName\" });\nexport const isStaticPropertyName = R.whereEq({ type: \"StaticPropertyName\" });\n\n// literals\nexport const isLiteralBooleanExpression = R.whereEq({ type: \"LiteralBooleanExpression\" });\nexport const isLiteralInfinityExpression = R.whereEq({ type: \"LiteralInfinityExpression\" });\nexport const isLiteralNullExpression = R.whereEq({ type: \"LiteralNullExpression\" });\nexport const isLiteralNumericExpression = R.whereEq({ type: \"LiteralNumericExpression\" });\nexport const isLiteralRegExpExpression = R.whereEq({ type: \"LiteralRegExpExpression\" });\nexport const isLiteralStringExpression = R.whereEq({ type: \"LiteralStringExpression\" });\n\n// expressions\nexport const isArrayExpression = R.whereEq({ type: \"ArrayExpression\" });\nexport const isArrowExpression = R.whereEq({ type: \"ArrowExpression\" });\nexport const isAssignmentExpression = R.whereEq({ type: \"AssignmentExpression\" });\nexport const isBinaryExpression = R.whereEq({ type: \"BinaryExpression\" });\nexport const isCallExpression = R.whereEq({ type: \"CallExpression\" });\nexport const isComputedAssignmentExpression = R.whereEq({ type: \"ComputedAssignmentExpression\" });\nexport const isComputedMemberExpression = R.whereEq({ type: \"ComputedMemberExpression\" });\nexport const isConditionalExpression = R.whereEq({ type: \"ConditionalExpression\" });\nexport const isFunctionExpression = R.whereEq({ type: \"FunctionExpression\" });\nexport const isIdentifierExpression = R.whereEq({ type: \"IdentifierExpression\" });\nexport const isNewExpression = R.whereEq({ type: \"NewExpression\" });\nexport const isNewTargetExpression = R.whereEq({ type: \"NewTargetExpression\" });\nexport const isObjectExpression = R.whereEq({ type: \"ObjectExpression\" });\nexport const isUnaryExpression = R.whereEq({ type: \"UnaryExpression\" });\nexport const isStaticMemberExpression = R.whereEq({ type: \"StaticMemberExpression\" });\nexport const isTemplateExpression = R.whereEq({ type: \"TemplateExpression\" });\nexport const isThisExpression = R.whereEq({ type: \"ThisExpression\" });\nexport const isUpdateExpression = R.whereEq({ type: \"UpdateExpression\" });\nexport const isYieldExpression = R.whereEq({ type: \"YieldExpression\" });\nexport const isYieldGeneratorExpression = R.whereEq({ type: \"YieldGeneratorExpression\" });\n\n// statements\nexport const isBlockStatement = R.whereEq({ type: \"BlockStatement\" });\nexport const isBreakStatement = R.whereEq({ type: \"BreakStatement\" });\nexport const isContinueStatement = R.whereEq({ type: \"ContinueStatement\" });\nexport const isCompoundAssignmentExpression = R.whereEq({ type: \"CompoundAssignmentExpression\" });\nexport const isDebuggerStatement = R.whereEq({ type: \"DebuggerStatement\" });\nexport const isDoWhileStatement = R.whereEq({ type: \"DoWhileStatement\" });\nexport const isEmptyStatement = R.whereEq({ type: \"EmptyStatement\" });\nexport const isExpressionStatement = R.whereEq({ type: \"ExpressionStatement\" });\nexport const isForInStatement = R.whereEq({ type: \"ForInStatement\" });\nexport const isForOfStatement = R.whereEq({ type: \"ForOfStatement\" });\nexport const isForStatement = R.whereEq({ type: \"ForStatement\" });\nexport const isIfStatement = R.whereEq({ type: \"IfStatement\" });\nexport const isLabeledStatement = R.whereEq({ type: \"LabeledStatement\" });\nexport const isReturnStatement = R.whereEq({ type: \"ReturnStatement\" });\nexport const isSwitchStatement = R.whereEq({ type: \"SwitchStatement\" });\nexport const isSwitchStatementWithDefault = R.whereEq({ type: \"SwitchStatementWithDefault\" });\nexport const isThrowStatement = R.whereEq({ type: \"ThrowStatement\" });\nexport const isTryCatchStatement = R.whereEq({ type: \"TryCatchStatement\" });\nexport const isTryFinallyStatement = R.whereEq({ type: \"TryFinallyStatement\" });\nexport const isVariableDeclarationStatement = R.whereEq({ type: \"VariableDeclarationStatement\" });\nexport const isWhileStatement = R.whereEq({ type: \"WhileStatement\" });\nexport const isWithStatement = R.whereEq({ type: \"WithStatement\" });\n\n// other\nexport const isPragma = R.whereEq({ type: 'Pragma' });\nexport const isBlock = R.whereEq({ type: \"Block\" });\nexport const isCatchClause = R.whereEq({ type: \"CatchClause\" });\nexport const isDirective = R.whereEq({ type: \"Directive\" });\nexport const isFormalParameters = R.whereEq({ type: \"FormalParameters\" });\nexport const isFunctionBody = R.whereEq({ type: \"FunctionBody\" });\nexport const isFunctionDeclaration = R.whereEq({ type: \"FunctionDeclaration\" });\nexport const isScript = R.whereEq({ type: \"Script\" });\nexport const isSpreadElement = R.whereEq({ type: \"SpreadElement\" });\nexport const isSuper = R.whereEq({ type: \"Super\" });\nexport const isSwitchCase = R.whereEq({ type: \"SwitchCase\" });\nexport const isSwitchDefault = R.whereEq({ type: \"SwitchDefault\" });\nexport const isTemplateElement = R.whereEq({ type: \"TemplateElement\" });\nexport const isSyntaxTemplate = R.whereEq({ type: \"SyntaxTemplate\" });\nexport const isVariableDeclaration = R.whereEq({ type: \"VariableDeclaration\" });\nexport const isVariableDeclarator = R.whereEq({ type: \"VariableDeclarator\" });\nexport const isEOF = R.whereEq({ type: 'EOF' });\nexport const isSyntaxDeclaration = R.both(isVariableDeclaration, R.whereEq({ kind: 'syntax' }));\nexport const isSyntaxrecDeclaration = R.both(isVariableDeclaration, R.whereEq({ kind: 'syntaxrec' }));\nexport const isFunctionTerm = R.either(isFunctionDeclaration, isFunctionExpression);\nexport const isFunctionWithName = R.and(isFunctionTerm, R.complement(R.where({ name: R.isNil })));\nexport const isParenthesizedExpression = R.whereEq({ type: 'ParenthesizedExpression'});\nexport const isExportSyntax = R.both(isExport, exp => R.or(isSyntaxDeclaration(exp.declaration), isSyntaxrecDeclaration(exp.declaration)));\nexport const isSyntaxDeclarationStatement = R.both(isVariableDeclarationStatement, decl => isCompiletimeDeclaration(decl.declaration));\n\n\nexport const isCompiletimeDeclaration = R.either(isSyntaxDeclaration, isSyntaxrecDeclaration);\nexport const isCompiletimeStatement = term => {\n  return (term instanceof Term) && isVariableDeclarationStatement(term) && isCompiletimeDeclaration(term.declaration);\n};\nexport const isImportDeclaration = R.either(isImport, isImportNamespace);\n"]} - return scopes.isSubset(stxScopes_917); - }).sort(sizeDecending_828); - if (biggestBindingPair.size >= 2 && biggestBindingPair.get(0).scopes.size === biggestBindingPair.get(1).scopes.size) { - let debugBase = "{" + stxScopes_917.map(s_920 => s_920.toString()).join(", ") + "}"; - let debugAmbigousScopesets = biggestBindingPair.map(_ref2 => { - let scopes = _ref2.scopes; +/***/ }, +/* 10 */ +/***/ function(module, exports, __webpack_require__) { - return "{" + scopes.map(s_921 => s_921.toString()).join(", ") + "}"; - }).join(", "); - throw new Error("Scopeset " + debugBase + " has ambiguous subsets " + debugAmbigousScopesets); - } else if (biggestBindingPair.size !== 0) { - let bindingStr = biggestBindingPair.get(0).binding.toString(); - if (_ramdaFantasy.Maybe.isJust(biggestBindingPair.get(0).alias)) { - return biggestBindingPair.get(0).alias.getOrElse(null).resolve(phase_915); - } - return bindingStr; - } - } - } - return this.token.value; - } - val() { - (0, _errors.assert)(!this.match("delimiter"), "cannot get the val of a delimiter"); - if (this.match("string")) { - return this.token.str; - } - if (this.match("template")) { - return this.token.items.map(el_922 => { - if (typeof el_922.match === "function" && el_922.match("delimiter")) { - return "${...}"; - } - return el_922.slice.text; - }).join(""); - } - return this.token.value; - } - lineNumber() { - if (!this.match("delimiter")) { - return this.token.slice.startLocation.line; - } else { - return this.token.get(0).lineNumber(); - } - } - setLineNumber(line_923) { - let newTok_924 = {}; - if (this.isDelimiter()) { - newTok_924 = this.token.map(s_925 => s_925.setLineNumber(line_923)); - } else { - for (let key of Object.keys(this.token)) { - newTok_924[key] = this.token[key]; - } - (0, _errors.assert)(newTok_924.slice && newTok_924.slice.startLocation, "all tokens must have line info"); - newTok_924.slice.startLocation.line = line_923; - } - return new Syntax(newTok_924, this); - } - inner() { - (0, _errors.assert)(this.match("delimiter"), "can only get the inner of a delimiter"); - return this.token.slice(1, this.token.size - 1); - } - addScope(scope_926, bindings_927, phase_928) { - let options_929 = arguments.length <= 3 || arguments[3] === undefined ? { flip: false } : arguments[3]; - - let token_930 = this.match("delimiter") ? this.token.map(s_934 => s_934.addScope(scope_926, bindings_927, phase_928, options_929)) : this.token; - if (this.match("template")) { - token_930 = _.merge(token_930, { items: token_930.items.map(it_935 => { - if (it_935 instanceof Syntax && it_935.match("delimiter")) { - return it_935.addScope(scope_926, bindings_927, phase_928, options_929); - } - return it_935; - }) }); - } - let oldScopeset_931; - if (phase_928 === ALL_PHASES_830) { - oldScopeset_931 = this.scopesets.all; - } else { - oldScopeset_931 = this.scopesets.phase.has(phase_928) ? this.scopesets.phase.get(phase_928) : (0, _immutable.List)(); - } - let newScopeset_932; - if (options_929.flip) { - let index = oldScopeset_931.indexOf(scope_926); - if (index !== -1) { - newScopeset_932 = oldScopeset_931.remove(index); - } else { - newScopeset_932 = oldScopeset_931.push(scope_926); - } - } else { - newScopeset_932 = oldScopeset_931.push(scope_926); - } - let newstx_933 = { bindings: bindings_927, scopesets: { all: this.scopesets.all, phase: this.scopesets.phase } }; - if (phase_928 === ALL_PHASES_830) { - newstx_933.scopesets.all = newScopeset_932; - } else { - newstx_933.scopesets.phase = newstx_933.scopesets.phase.set(phase_928, newScopeset_932); - } - return new Syntax(token_930, newstx_933); - } - removeScope(scope_936, phase_937) { - let token_938 = this.match("delimiter") ? this.token.map(s_944 => s_944.removeScope(scope_936, phase_937)) : this.token; - let phaseScopeset_939 = this.scopesets.phase.has(phase_937) ? this.scopesets.phase.get(phase_937) : (0, _immutable.List)(); - let allScopeset_940 = this.scopesets.all; - let newstx_941 = { bindings: this.bindings, scopesets: { all: this.scopesets.all, phase: this.scopesets.phase } }; - let phaseIndex_942 = phaseScopeset_939.indexOf(scope_936); - let allIndex_943 = allScopeset_940.indexOf(scope_936); - if (phaseIndex_942 !== -1) { - newstx_941.scopesets.phase = this.scopesets.phase.set(phase_937, phaseScopeset_939.remove(phaseIndex_942)); - } else if (allIndex_943 !== -1) { - newstx_941.scopesets.all = allScopeset_940.remove(allIndex_943); - } - return new Syntax(token_938, newstx_941); - } - match(type_945, value_946) { - if (!Types_829[type_945]) { - throw new Error(type_945 + " is an invalid type"); - } - return Types_829[type_945].match(this.token) && (value_946 == null || (value_946 instanceof RegExp ? value_946.test(this.val()) : this.val() == value_946)); - } - isIdentifier(value_947) { - return this.match("identifier", value_947); - } - isAssign(value_948) { - return this.match("assign", value_948); - } - isBooleanLiteral(value_949) { - return this.match("boolean", value_949); - } - isKeyword(value_950) { - return this.match("keyword", value_950); - } - isNullLiteral(value_951) { - return this.match("null", value_951); - } - isNumericLiteral(value_952) { - return this.match("number", value_952); - } - isPunctuator(value_953) { - return this.match("punctuator", value_953); - } - isStringLiteral(value_954) { - return this.match("string", value_954); - } - isRegularExpression(value_955) { - return this.match("regularExpression", value_955); - } - isTemplate(value_956) { - return this.match("template", value_956); - } - isDelimiter(value_957) { - return this.match("delimiter", value_957); - } - isParens(value_958) { - return this.match("parens", value_958); - } - isBraces(value_959) { - return this.match("braces", value_959); - } - isBrackets(value_960) { - return this.match("brackets", value_960); - } - isSyntaxTemplate(value_961) { - return this.match("syntaxTemplate", value_961); - } - isEOF(value_962) { - return this.match("eof", value_962); - } - toString() { - if (this.match("delimiter")) { - return this.token.map(s_963 => s_963.toString()).join(" "); - } - if (this.match("string")) { - return "'" + this.token.str; - } - if (this.match("template")) { - return this.val(); - } - return this.token.value; - } - } - exports.default = Syntax; - exports.Types = Types_829; - exports.ALL_PHASES = ALL_PHASES_830; - //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/syntax.js"],"names":[],"mappings":"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","file":"syntax.js","sourcesContent":["import {List, Map} from \"immutable\";\nimport {assert} from \"./errors\";\nimport BindingMap from \"./binding-map\";\nimport {Maybe} from \"ramda-fantasy\";\nimport {TokenType, TokenClass} from \"shift-parser/dist/tokenizer\";\nimport  * as _ from \"ramda\";\nconst Just_825 = Maybe.Just;\nconst Nothing_826 = Maybe.Nothing;\nfunction getFirstSlice_827(stx_831) {\n  if (!stx_831 || typeof stx_831.isDelimiter !== \"function\") return null;\n  if (!stx_831.isDelimiter()) {\n    return stx_831.token.slice;\n  }\n  return stx_831.token.get(0).token.slice;\n}\nfunction sizeDecending_828(a_832, b_833) {\n  if (a_832.scopes.size > b_833.scopes.size) {\n    return -1;\n  } else if (b_833.scopes.size > a_832.scopes.size) {\n    return 1;\n  } else {\n    return 0;\n  }\n}\nlet Types_829 = {null: {match: token_834 => !Types_829.delimiter.match(token_834) && token_834.type === TokenType.NULL, create: (value_835, stx_836) => new Syntax({type: TokenType.NULL, value: null}, stx_836)}, number: {match: token_837 => !Types_829.delimiter.match(token_837) && token_837.type.klass === TokenClass.NumericLiteral, create: (value_838, stx_839) => new Syntax({type: TokenType.NUMBER, value: value_838}, stx_839)}, string: {match: token_840 => !Types_829.delimiter.match(token_840) && token_840.type.klass === TokenClass.StringLiteral, create: (value_841, stx_842) => new Syntax({type: TokenType.STRING, str: value_841}, stx_842)}, punctuator: {match: token_843 => !Types_829.delimiter.match(token_843) && token_843.type.klass === TokenClass.Punctuator, create: (value_844, stx_845) => new Syntax({type: {klass: TokenClass.Punctuator, name: value_844}, value: value_844}, stx_845)}, keyword: {match: token_846 => !Types_829.delimiter.match(token_846) && token_846.type.klass === TokenClass.Keyword, create: (value_847, stx_848) => new Syntax({type: {klass: TokenClass.Keyword, name: value_847}, value: value_847}, stx_848)}, identifier: {match: token_849 => !Types_829.delimiter.match(token_849) && token_849.type.klass === TokenClass.Ident, create: (value_850, stx_851) => new Syntax({type: TokenType.IDENTIFIER, value: value_850}, stx_851)}, regularExpression: {match: token_852 => !Types_829.delimiter.match(token_852) && token_852.type.klass === TokenClass.RegularExpression, create: (value_853, stx_854) => new Syntax({type: TokenType.REGEXP, value: value_853}, stx_854)}, braces: {match: token_855 => Types_829.delimiter.match(token_855) && token_855.get(0).token.type === TokenType.LBRACE, create: (inner_856, stx_857) => {\n  let left_858 = new Syntax({type: TokenType.LBRACE, value: \"{\", slice: getFirstSlice_827(stx_857)});\n  let right_859 = new Syntax({type: TokenType.RBRACE, value: \"}\", slice: getFirstSlice_827(stx_857)});\n  return new Syntax(List.of(left_858).concat(inner_856).push(right_859), stx_857);\n}}, brackets: {match: token_860 => Types_829.delimiter.match(token_860) && token_860.get(0).token.type === TokenType.LBRACK, create: (inner_861, stx_862) => {\n  let left_863 = new Syntax({type: TokenType.LBRACK, value: \"[\", slice: getFirstSlice_827(stx_862)});\n  let right_864 = new Syntax({type: TokenType.RBRACK, value: \"]\", slice: getFirstSlice_827(stx_862)});\n  return new Syntax(List.of(left_863).concat(inner_861).push(right_864), stx_862);\n}}, parens: {match: token_865 => Types_829.delimiter.match(token_865) && token_865.get(0).token.type === TokenType.LPAREN, create: (inner_866, stx_867) => {\n  let left_868 = new Syntax({type: TokenType.LPAREN, value: \"(\", slice: getFirstSlice_827(stx_867)});\n  let right_869 = new Syntax({type: TokenType.RPAREN, value: \")\", slice: getFirstSlice_827(stx_867)});\n  return new Syntax(List.of(left_868).concat(inner_866).push(right_869), stx_867);\n}}, assign: {match: token_870 => {\n  if (Types_829.punctuator.match(token_870)) {\n    switch (token_870.value) {\n      case \"=\":\n      case \"|=\":\n      case \"^=\":\n      case \"&=\":\n      case \"<<=\":\n      case \">>=\":\n      case \">>>=\":\n      case \"+=\":\n      case \"-=\":\n      case \"*=\":\n      case \"/=\":\n      case \"%=\":\n        return true;\n      default:\n        return false;\n    }\n  }\n  return false;\n}}, boolean: {match: token_871 => !Types_829.delimiter.match(token_871) && token_871.type === TokenType.TRUE || token_871.type === TokenType.FALSE}, template: {match: token_872 => !Types_829.delimiter.match(token_872) && token_872.type === TokenType.TEMPLATE}, delimiter: {match: token_873 => List.isList(token_873)}, syntaxTemplate: {match: token_874 => Types_829.delimiter.match(token_874) && token_874.get(0).val() === \"#`\"}, eof: {match: token_875 => !Types_829.delimiter.match(token_875) && token_875.type === TokenType.EOS}};\n;\nconst ALL_PHASES_830 = {};\n;\nexport default class Syntax {\n  constructor(token_876, oldstx_877 = {}) {\n    this.token = token_876;\n    this.bindings = oldstx_877.bindings != null ? oldstx_877.bindings : new BindingMap;\n    this.scopesets = oldstx_877.scopesets != null ? oldstx_877.scopesets : {all: List(), phase: Map()};\n    Object.freeze(this);\n  }\n  static of(token_878, stx_879 = {}) {\n    return new Syntax(token_878, stx_879);\n  }\n  static from(type_880, value_881, stx_882 = {}) {\n    if (!Types_829[type_880]) {\n      throw new Error(type_880 + \" is not a valid type\");\n    } else if (!Types_829[type_880].create) {\n      throw new Error(\"Cannot create a syntax from type \" + type_880);\n    }\n    let newstx_883 = Types_829[type_880].create(value_881, stx_882);\n    let slice_884 = getFirstSlice_827(stx_882);\n    if (slice_884 != null) {\n      newstx_883.token.slice = slice_884;\n    }\n    return newstx_883;\n  }\n  from(type_885, value_886) {\n    return Syntax.from(type_885, value_886, this);\n  }\n  fromNull() {\n    return this.from(\"null\", null);\n  }\n  fromNumber(value_887) {\n    return this.from(\"number\", value_887);\n  }\n  fromString(value_888) {\n    return this.from(\"string\", value_888);\n  }\n  fromPunctuator(value_889) {\n    return this.from(\"punctuator\", value_889);\n  }\n  fromKeyword(value_890) {\n    return this.from(\"keyword\");\n  }\n  fromIdentifier(value_891) {\n    return this.from(\"identifier\", value_891);\n  }\n  fromRegularExpression(value_892) {\n    return this.from(\"regularExpression\", value_892);\n  }\n  fromBraces(inner_893) {\n    return this.from(\"braces\", inner_893);\n  }\n  fromBrackets(inner_894) {\n    return this.from(\"brackets\", inner_894);\n  }\n  fromParens(inner_895) {\n    return this.from(\"parens\", inner_895);\n  }\n  static fromNull(stx_896 = {}) {\n    return Syntax.from(\"null\", null, stx_896);\n  }\n  static fromNumber(value_897, stx_898 = {}) {\n    return Syntax.from(\"number\", value_897, stx_898);\n  }\n  static fromString(value_899, stx_900 = {}) {\n    return Syntax.from(\"string\", value_899, stx_900);\n  }\n  static fromPunctuator(value_901, stx_902 = {}) {\n    return Syntax.from(\"punctuator\", value_901, stx_902);\n  }\n  static fromKeyword(value_903, stx_904 = {}) {\n    return Syntax.from(\"keyword\", value_903, stx_904);\n  }\n  static fromIdentifier(value_905, stx_906 = {}) {\n    return Syntax.from(\"identifier\", value_905, stx_906);\n  }\n  static fromRegularExpression(value_907, stx_908 = {}) {\n    return Syntax.from(\"regularExpression\", value_907, stx_908);\n  }\n  static fromBraces(inner_909, stx_910 = {}) {\n    return Syntax.from(\"braces\", inner_909, stx_910);\n  }\n  static fromBrackets(inner_911, stx_912 = {}) {\n    return Syntax.from(\"brackets\", inner_911, stx_912);\n  }\n  static fromParens(inner_913, stx_914 = {}) {\n    return Syntax.from(\"parens\", inner_913, stx_914);\n  }\n  resolve(phase_915) {\n    assert(phase_915 != null, \"must provide a phase to resolve\");\n    let allScopes_916 = this.scopesets.all;\n    let stxScopes_917 = this.scopesets.phase.has(phase_915) ? this.scopesets.phase.get(phase_915) : List();\n    stxScopes_917 = allScopes_916.concat(stxScopes_917);\n    if (stxScopes_917.size === 0 || !(this.match(\"identifier\") || this.match(\"keyword\"))) {\n      return this.token.value;\n    }\n    let scope_918 = stxScopes_917.last();\n    let bindings_919 = this.bindings;\n    if (scope_918) {\n      let scopesetBindingList = bindings_919.get(this);\n      if (scopesetBindingList) {\n        let biggestBindingPair = scopesetBindingList.filter(({scopes, binding}) => {\n          return scopes.isSubset(stxScopes_917);\n        }).sort(sizeDecending_828);\n        if (biggestBindingPair.size >= 2 && biggestBindingPair.get(0).scopes.size === biggestBindingPair.get(1).scopes.size) {\n          let debugBase = \"{\" + stxScopes_917.map(s_920 => s_920.toString()).join(\", \") + \"}\";\n          let debugAmbigousScopesets = biggestBindingPair.map(({scopes}) => {\n            return \"{\" + scopes.map(s_921 => s_921.toString()).join(\", \") + \"}\";\n          }).join(\", \");\n          throw new Error(\"Scopeset \" + debugBase + \" has ambiguous subsets \" + debugAmbigousScopesets);\n        } else if (biggestBindingPair.size !== 0) {\n          let bindingStr = biggestBindingPair.get(0).binding.toString();\n          if (Maybe.isJust(biggestBindingPair.get(0).alias)) {\n            return biggestBindingPair.get(0).alias.getOrElse(null).resolve(phase_915);\n          }\n          return bindingStr;\n        }\n      }\n    }\n    return this.token.value;\n  }\n  val() {\n    assert(!this.match(\"delimiter\"), \"cannot get the val of a delimiter\");\n    if (this.match(\"string\")) {\n      return this.token.str;\n    }\n    if (this.match(\"template\")) {\n      return this.token.items.map(el_922 => {\n        if (typeof el_922.match === \"function\" && el_922.match(\"delimiter\")) {\n          return \"${...}\";\n        }\n        return el_922.slice.text;\n      }).join(\"\");\n    }\n    return this.token.value;\n  }\n  lineNumber() {\n    if (!this.match(\"delimiter\")) {\n      return this.token.slice.startLocation.line;\n    } else {\n      return this.token.get(0).lineNumber();\n    }\n  }\n  setLineNumber(line_923) {\n    let newTok_924 = {};\n    if (this.isDelimiter()) {\n      newTok_924 = this.token.map(s_925 => s_925.setLineNumber(line_923));\n    } else {\n      for (let key of Object.keys(this.token)) {\n        newTok_924[key] = this.token[key];\n      }\n      assert(newTok_924.slice && newTok_924.slice.startLocation, \"all tokens must have line info\");\n      newTok_924.slice.startLocation.line = line_923;\n    }\n    return new Syntax(newTok_924, this);\n  }\n  inner() {\n    assert(this.match(\"delimiter\"), \"can only get the inner of a delimiter\");\n    return this.token.slice(1, this.token.size - 1);\n  }\n  addScope(scope_926, bindings_927, phase_928, options_929 = {flip: false}) {\n    let token_930 = this.match(\"delimiter\") ? this.token.map(s_934 => s_934.addScope(scope_926, bindings_927, phase_928, options_929)) : this.token;\n    if (this.match(\"template\")) {\n      token_930 = _.merge(token_930, {items: token_930.items.map(it_935 => {\n        if (it_935 instanceof Syntax && it_935.match(\"delimiter\")) {\n          return it_935.addScope(scope_926, bindings_927, phase_928, options_929);\n        }\n        return it_935;\n      })});\n    }\n    let oldScopeset_931;\n    if (phase_928 === ALL_PHASES_830) {\n      oldScopeset_931 = this.scopesets.all;\n    } else {\n      oldScopeset_931 = this.scopesets.phase.has(phase_928) ? this.scopesets.phase.get(phase_928) : List();\n    }\n    let newScopeset_932;\n    if (options_929.flip) {\n      let index = oldScopeset_931.indexOf(scope_926);\n      if (index !== -1) {\n        newScopeset_932 = oldScopeset_931.remove(index);\n      } else {\n        newScopeset_932 = oldScopeset_931.push(scope_926);\n      }\n    } else {\n      newScopeset_932 = oldScopeset_931.push(scope_926);\n    }\n    let newstx_933 = {bindings: bindings_927, scopesets: {all: this.scopesets.all, phase: this.scopesets.phase}};\n    if (phase_928 === ALL_PHASES_830) {\n      newstx_933.scopesets.all = newScopeset_932;\n    } else {\n      newstx_933.scopesets.phase = newstx_933.scopesets.phase.set(phase_928, newScopeset_932);\n    }\n    return new Syntax(token_930, newstx_933);\n  }\n  removeScope(scope_936, phase_937) {\n    let token_938 = this.match(\"delimiter\") ? this.token.map(s_944 => s_944.removeScope(scope_936, phase_937)) : this.token;\n    let phaseScopeset_939 = this.scopesets.phase.has(phase_937) ? this.scopesets.phase.get(phase_937) : List();\n    let allScopeset_940 = this.scopesets.all;\n    let newstx_941 = {bindings: this.bindings, scopesets: {all: this.scopesets.all, phase: this.scopesets.phase}};\n    let phaseIndex_942 = phaseScopeset_939.indexOf(scope_936);\n    let allIndex_943 = allScopeset_940.indexOf(scope_936);\n    if (phaseIndex_942 !== -1) {\n      newstx_941.scopesets.phase = this.scopesets.phase.set(phase_937, phaseScopeset_939.remove(phaseIndex_942));\n    } else if (allIndex_943 !== -1) {\n      newstx_941.scopesets.all = allScopeset_940.remove(allIndex_943);\n    }\n    return new Syntax(token_938, newstx_941);\n  }\n  match(type_945, value_946) {\n    if (!Types_829[type_945]) {\n      throw new Error(type_945 + \" is an invalid type\");\n    }\n    return Types_829[type_945].match(this.token) && (value_946 == null || (value_946 instanceof RegExp ? value_946.test(this.val()) : this.val() == value_946));\n  }\n  isIdentifier(value_947) {\n    return this.match(\"identifier\", value_947);\n  }\n  isAssign(value_948) {\n    return this.match(\"assign\", value_948);\n  }\n  isBooleanLiteral(value_949) {\n    return this.match(\"boolean\", value_949);\n  }\n  isKeyword(value_950) {\n    return this.match(\"keyword\", value_950);\n  }\n  isNullLiteral(value_951) {\n    return this.match(\"null\", value_951);\n  }\n  isNumericLiteral(value_952) {\n    return this.match(\"number\", value_952);\n  }\n  isPunctuator(value_953) {\n    return this.match(\"punctuator\", value_953);\n  }\n  isStringLiteral(value_954) {\n    return this.match(\"string\", value_954);\n  }\n  isRegularExpression(value_955) {\n    return this.match(\"regularExpression\", value_955);\n  }\n  isTemplate(value_956) {\n    return this.match(\"template\", value_956);\n  }\n  isDelimiter(value_957) {\n    return this.match(\"delimiter\", value_957);\n  }\n  isParens(value_958) {\n    return this.match(\"parens\", value_958);\n  }\n  isBraces(value_959) {\n    return this.match(\"braces\", value_959);\n  }\n  isBrackets(value_960) {\n    return this.match(\"brackets\", value_960);\n  }\n  isSyntaxTemplate(value_961) {\n    return this.match(\"syntaxTemplate\", value_961);\n  }\n  isEOF(value_962) {\n    return this.match(\"eof\", value_962);\n  }\n  toString() {\n    if (this.match(\"delimiter\")) {\n      return this.token.map(s_963 => s_963.toString()).join(\" \");\n    }\n    if (this.match(\"string\")) {\n      return \"'\" + this.token.str;\n    }\n    if (this.match(\"template\")) {\n      return this.val();\n    }\n    return this.token.value;\n  }\n}\nexport {Types_829 as Types};\nexport {ALL_PHASES_830 as ALL_PHASES}"]} - -/***/ }, -/* 13 */ -/***/ function(module, exports) { - - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - function expect_336(cond_338, message_339, offendingSyntax_340, rest_341) { - if (!cond_338) { - let ctx = ""; - if (rest_341) { - let ctx = rest_341.slice(0, 20).map(s_342 => { - let val_343 = s_342.isDelimiter() ? "( ... )" : s_342.val(); - if (s_342 === offendingSyntax_340) { - return "__" + val_343 + "__"; - } - return val_343; - }).join(" "); - } - throw new Error("[error]: " + message_339 + "\n" + ctx); - } - } - function assert_337(cond_344, message_345) { - if (!cond_344) { - throw new Error("[assertion error]: " + message_345); - } - } - exports.expect = expect_336; - exports.assert = assert_337; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2Vycm9ycy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLFNBQVMsVUFBVCxDQUFvQixRQUFwQixFQUE4QixXQUE5QixFQUEyQyxtQkFBM0MsRUFBZ0UsUUFBaEUsRUFBMEU7QUFDeEUsTUFBSSxDQUFDLFFBQUwsRUFBZTtBQUNiLFFBQUksTUFBTSxFQUFWO0FBQ0EsUUFBSSxRQUFKLEVBQWM7QUFDWixVQUFJLE1BQU0sU0FBUyxLQUFULENBQWUsQ0FBZixFQUFrQixFQUFsQixFQUFzQixHQUF0QixDQUEwQixTQUFTO0FBQzNDLFlBQUksVUFBVSxNQUFNLFdBQU4sS0FBc0IsU0FBdEIsR0FBa0MsTUFBTSxHQUFOLEVBQWhEO0FBQ0EsWUFBSSxVQUFVLG1CQUFkLEVBQW1DO0FBQ2pDLGlCQUFPLE9BQU8sT0FBUCxHQUFpQixJQUF4QjtBQUNEO0FBQ0QsZUFBTyxPQUFQO0FBQ0QsT0FOUyxFQU1QLElBTk8sQ0FNRixHQU5FLENBQVY7QUFPRDtBQUNELFVBQU0sSUFBSSxLQUFKLENBQVUsY0FBYyxXQUFkLEdBQTRCLElBQTVCLEdBQW1DLEdBQTdDLENBQU47QUFDRDtBQUNGO0FBQ0QsU0FBUyxVQUFULENBQW9CLFFBQXBCLEVBQThCLFdBQTlCLEVBQTJDO0FBQ3pDLE1BQUksQ0FBQyxRQUFMLEVBQWU7QUFDYixVQUFNLElBQUksS0FBSixDQUFVLHdCQUF3QixXQUFsQyxDQUFOO0FBQ0Q7QUFDRjtRQUNxQixNLEdBQWQsVTtRQUNjLE0sR0FBZCxVIiwiZmlsZSI6ImVycm9ycy5qcyIsInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIGV4cGVjdF8zMzYoY29uZF8zMzgsIG1lc3NhZ2VfMzM5LCBvZmZlbmRpbmdTeW50YXhfMzQwLCByZXN0XzM0MSkge1xuICBpZiAoIWNvbmRfMzM4KSB7XG4gICAgbGV0IGN0eCA9IFwiXCI7XG4gICAgaWYgKHJlc3RfMzQxKSB7XG4gICAgICBsZXQgY3R4ID0gcmVzdF8zNDEuc2xpY2UoMCwgMjApLm1hcChzXzM0MiA9PiB7XG4gICAgICAgIGxldCB2YWxfMzQzID0gc18zNDIuaXNEZWxpbWl0ZXIoKSA/IFwiKCAuLi4gKVwiIDogc18zNDIudmFsKCk7XG4gICAgICAgIGlmIChzXzM0MiA9PT0gb2ZmZW5kaW5nU3ludGF4XzM0MCkge1xuICAgICAgICAgIHJldHVybiBcIl9fXCIgKyB2YWxfMzQzICsgXCJfX1wiO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB2YWxfMzQzO1xuICAgICAgfSkuam9pbihcIiBcIik7XG4gICAgfVxuICAgIHRocm93IG5ldyBFcnJvcihcIltlcnJvcl06IFwiICsgbWVzc2FnZV8zMzkgKyBcIlxcblwiICsgY3R4KTtcbiAgfVxufVxuZnVuY3Rpb24gYXNzZXJ0XzMzNyhjb25kXzM0NCwgbWVzc2FnZV8zNDUpIHtcbiAgaWYgKCFjb25kXzM0NCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIlthc3NlcnRpb24gZXJyb3JdOiBcIiArIG1lc3NhZ2VfMzQ1KTtcbiAgfVxufVxuZXhwb3J0IHtleHBlY3RfMzM2IGFzIGV4cGVjdH07XG5leHBvcnQge2Fzc2VydF8zMzcgYXMgYXNzZXJ0fSJdfQ== - -/***/ }, -/* 14 */ -/***/ function(module, exports, __webpack_require__) { - - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - - var _immutable = __webpack_require__(11); - - var _errors = __webpack_require__(13); - - var _ramdaFantasy = __webpack_require__(15); - - var _syntax = __webpack_require__(12); - - class BindingMap { - constructor() { - this._map = new Map(); - } - add(stx_20, _ref) { - let binding = _ref.binding; - let phase = _ref.phase; - var _ref$skipDup = _ref.skipDup; - let skipDup = _ref$skipDup === undefined ? false : _ref$skipDup; - - let stxName_21 = stx_20.val(); - let allScopeset_22 = stx_20.scopesets.all; - let scopeset_23 = stx_20.scopesets.phase.has(phase) ? stx_20.scopesets.phase.get(phase) : (0, _immutable.List)(); - scopeset_23 = allScopeset_22.concat(scopeset_23); - (0, _errors.assert)(phase != null, "must provide a phase for binding add"); - if (this._map.has(stxName_21)) { - let scopesetBindingList = this._map.get(stxName_21); - if (skipDup && scopesetBindingList.some(s_24 => s_24.scopes.equals(scopeset_23))) { - return; - } - this._map.set(stxName_21, scopesetBindingList.push({ scopes: scopeset_23, binding: binding, alias: _ramdaFantasy.Maybe.Nothing() })); - } else { - this._map.set(stxName_21, _immutable.List.of({ scopes: scopeset_23, binding: binding, alias: _ramdaFantasy.Maybe.Nothing() })); - } - } - addForward(stx_25, forwardStx_26, binding_27, phase_28) { - let stxName_29 = stx_25.token.value; - let allScopeset_30 = stx_25.scopesets.all; - let scopeset_31 = stx_25.scopesets.phase.has(phase_28) ? stx_25.scopesets.phase.get(phase_28) : (0, _immutable.List)(); - scopeset_31 = allScopeset_30.concat(scopeset_31); - (0, _errors.assert)(phase_28 != null, "must provide a phase for binding add"); - if (this._map.has(stxName_29)) { - let scopesetBindingList = this._map.get(stxName_29); - this._map.set(stxName_29, scopesetBindingList.push({ scopes: scopeset_31, binding: binding_27, alias: _ramdaFantasy.Maybe.of(forwardStx_26) })); - } else { - this._map.set(stxName_29, _immutable.List.of({ scopes: scopeset_31, binding: binding_27, alias: _ramdaFantasy.Maybe.of(forwardStx_26) })); - } - } - get(stx_32) { - return this._map.get(stx_32.token.value); - } - } - exports.default = BindingMap; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2JpbmRpbmctbWFwLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNlLE1BQU0sVUFBTixDQUFpQjtBQUM5QixnQkFBYztBQUNaLFNBQUssSUFBTCxHQUFZLElBQUksR0FBSixFQUFaO0FBQ0Q7QUFDRCxNQUFJLE1BQUosUUFBK0M7QUFBQSxRQUFsQyxPQUFrQyxRQUFsQyxPQUFrQztBQUFBLFFBQXpCLEtBQXlCLFFBQXpCLEtBQXlCO0FBQUEsNEJBQWxCLE9BQWtCO0FBQUEsUUFBbEIsT0FBa0IsZ0NBQVIsS0FBUTs7QUFDN0MsUUFBSSxhQUFhLE9BQU8sR0FBUCxFQUFqQjtBQUNBLFFBQUksaUJBQWlCLE9BQU8sU0FBUCxDQUFpQixHQUF0QztBQUNBLFFBQUksY0FBYyxPQUFPLFNBQVAsQ0FBaUIsS0FBakIsQ0FBdUIsR0FBdkIsQ0FBMkIsS0FBM0IsSUFBb0MsT0FBTyxTQUFQLENBQWlCLEtBQWpCLENBQXVCLEdBQXZCLENBQTJCLEtBQTNCLENBQXBDLEdBQXdFLHNCQUExRjtBQUNBLGtCQUFjLGVBQWUsTUFBZixDQUFzQixXQUF0QixDQUFkO0FBQ0Esd0JBQU8sU0FBUyxJQUFoQixFQUFzQixzQ0FBdEI7QUFDQSxRQUFJLEtBQUssSUFBTCxDQUFVLEdBQVYsQ0FBYyxVQUFkLENBQUosRUFBK0I7QUFDN0IsVUFBSSxzQkFBc0IsS0FBSyxJQUFMLENBQVUsR0FBVixDQUFjLFVBQWQsQ0FBMUI7QUFDQSxVQUFJLFdBQVcsb0JBQW9CLElBQXBCLENBQXlCLFFBQVEsS0FBSyxNQUFMLENBQVksTUFBWixDQUFtQixXQUFuQixDQUFqQyxDQUFmLEVBQWtGO0FBQ2hGO0FBQ0Q7QUFDRCxXQUFLLElBQUwsQ0FBVSxHQUFWLENBQWMsVUFBZCxFQUEwQixvQkFBb0IsSUFBcEIsQ0FBeUIsRUFBQyxRQUFRLFdBQVQsRUFBc0IsU0FBUyxPQUEvQixFQUF3QyxPQUFPLG9CQUFNLE9BQU4sRUFBL0MsRUFBekIsQ0FBMUI7QUFDRCxLQU5ELE1BTU87QUFDTCxXQUFLLElBQUwsQ0FBVSxHQUFWLENBQWMsVUFBZCxFQUEwQixnQkFBSyxFQUFMLENBQVEsRUFBQyxRQUFRLFdBQVQsRUFBc0IsU0FBUyxPQUEvQixFQUF3QyxPQUFPLG9CQUFNLE9BQU4sRUFBL0MsRUFBUixDQUExQjtBQUNEO0FBQ0Y7QUFDRCxhQUFXLE1BQVgsRUFBbUIsYUFBbkIsRUFBa0MsVUFBbEMsRUFBOEMsUUFBOUMsRUFBd0Q7QUFDdEQsUUFBSSxhQUFhLE9BQU8sS0FBUCxDQUFhLEtBQTlCO0FBQ0EsUUFBSSxpQkFBaUIsT0FBTyxTQUFQLENBQWlCLEdBQXRDO0FBQ0EsUUFBSSxjQUFjLE9BQU8sU0FBUCxDQUFpQixLQUFqQixDQUF1QixHQUF2QixDQUEyQixRQUEzQixJQUF1QyxPQUFPLFNBQVAsQ0FBaUIsS0FBakIsQ0FBdUIsR0FBdkIsQ0FBMkIsUUFBM0IsQ0FBdkMsR0FBOEUsc0JBQWhHO0FBQ0Esa0JBQWMsZUFBZSxNQUFmLENBQXNCLFdBQXRCLENBQWQ7QUFDQSx3QkFBTyxZQUFZLElBQW5CLEVBQXlCLHNDQUF6QjtBQUNBLFFBQUksS0FBSyxJQUFMLENBQVUsR0FBVixDQUFjLFVBQWQsQ0FBSixFQUErQjtBQUM3QixVQUFJLHNCQUFzQixLQUFLLElBQUwsQ0FBVSxHQUFWLENBQWMsVUFBZCxDQUExQjtBQUNBLFdBQUssSUFBTCxDQUFVLEdBQVYsQ0FBYyxVQUFkLEVBQTBCLG9CQUFvQixJQUFwQixDQUF5QixFQUFDLFFBQVEsV0FBVCxFQUFzQixTQUFTLFVBQS9CLEVBQTJDLE9BQU8sb0JBQU0sRUFBTixDQUFTLGFBQVQsQ0FBbEQsRUFBekIsQ0FBMUI7QUFDRCxLQUhELE1BR087QUFDTCxXQUFLLElBQUwsQ0FBVSxHQUFWLENBQWMsVUFBZCxFQUEwQixnQkFBSyxFQUFMLENBQVEsRUFBQyxRQUFRLFdBQVQsRUFBc0IsU0FBUyxVQUEvQixFQUEyQyxPQUFPLG9CQUFNLEVBQU4sQ0FBUyxhQUFULENBQWxELEVBQVIsQ0FBMUI7QUFDRDtBQUNGO0FBQ0QsTUFBSSxNQUFKLEVBQVk7QUFDVixXQUFPLEtBQUssSUFBTCxDQUFVLEdBQVYsQ0FBYyxPQUFPLEtBQVAsQ0FBYSxLQUEzQixDQUFQO0FBQ0Q7QUFuQzZCO2tCQUFYLFUiLCJmaWxlIjoiYmluZGluZy1tYXAuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0xpc3R9IGZyb20gXCJpbW11dGFibGVcIjtcbmltcG9ydCB7ZXhwZWN0LCBhc3NlcnR9IGZyb20gXCIuL2Vycm9yc1wiO1xuaW1wb3J0IHtNYXliZX0gZnJvbSBcInJhbWRhLWZhbnRhc3lcIjtcbmltcG9ydCB7QUxMX1BIQVNFU30gZnJvbSBcIi4vc3ludGF4XCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBCaW5kaW5nTWFwIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5fbWFwID0gbmV3IE1hcDtcbiAgfVxuICBhZGQoc3R4XzIwLCB7YmluZGluZywgcGhhc2UsIHNraXBEdXAgPSBmYWxzZX0pIHtcbiAgICBsZXQgc3R4TmFtZV8yMSA9IHN0eF8yMC52YWwoKTtcbiAgICBsZXQgYWxsU2NvcGVzZXRfMjIgPSBzdHhfMjAuc2NvcGVzZXRzLmFsbDtcbiAgICBsZXQgc2NvcGVzZXRfMjMgPSBzdHhfMjAuc2NvcGVzZXRzLnBoYXNlLmhhcyhwaGFzZSkgPyBzdHhfMjAuc2NvcGVzZXRzLnBoYXNlLmdldChwaGFzZSkgOiBMaXN0KCk7XG4gICAgc2NvcGVzZXRfMjMgPSBhbGxTY29wZXNldF8yMi5jb25jYXQoc2NvcGVzZXRfMjMpO1xuICAgIGFzc2VydChwaGFzZSAhPSBudWxsLCBcIm11c3QgcHJvdmlkZSBhIHBoYXNlIGZvciBiaW5kaW5nIGFkZFwiKTtcbiAgICBpZiAodGhpcy5fbWFwLmhhcyhzdHhOYW1lXzIxKSkge1xuICAgICAgbGV0IHNjb3Blc2V0QmluZGluZ0xpc3QgPSB0aGlzLl9tYXAuZ2V0KHN0eE5hbWVfMjEpO1xuICAgICAgaWYgKHNraXBEdXAgJiYgc2NvcGVzZXRCaW5kaW5nTGlzdC5zb21lKHNfMjQgPT4gc18yNC5zY29wZXMuZXF1YWxzKHNjb3Blc2V0XzIzKSkpIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuICAgICAgdGhpcy5fbWFwLnNldChzdHhOYW1lXzIxLCBzY29wZXNldEJpbmRpbmdMaXN0LnB1c2goe3Njb3Blczogc2NvcGVzZXRfMjMsIGJpbmRpbmc6IGJpbmRpbmcsIGFsaWFzOiBNYXliZS5Ob3RoaW5nKCl9KSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX21hcC5zZXQoc3R4TmFtZV8yMSwgTGlzdC5vZih7c2NvcGVzOiBzY29wZXNldF8yMywgYmluZGluZzogYmluZGluZywgYWxpYXM6IE1heWJlLk5vdGhpbmcoKX0pKTtcbiAgICB9XG4gIH1cbiAgYWRkRm9yd2FyZChzdHhfMjUsIGZvcndhcmRTdHhfMjYsIGJpbmRpbmdfMjcsIHBoYXNlXzI4KSB7XG4gICAgbGV0IHN0eE5hbWVfMjkgPSBzdHhfMjUudG9rZW4udmFsdWU7XG4gICAgbGV0IGFsbFNjb3Blc2V0XzMwID0gc3R4XzI1LnNjb3Blc2V0cy5hbGw7XG4gICAgbGV0IHNjb3Blc2V0XzMxID0gc3R4XzI1LnNjb3Blc2V0cy5waGFzZS5oYXMocGhhc2VfMjgpID8gc3R4XzI1LnNjb3Blc2V0cy5waGFzZS5nZXQocGhhc2VfMjgpIDogTGlzdCgpO1xuICAgIHNjb3Blc2V0XzMxID0gYWxsU2NvcGVzZXRfMzAuY29uY2F0KHNjb3Blc2V0XzMxKTtcbiAgICBhc3NlcnQocGhhc2VfMjggIT0gbnVsbCwgXCJtdXN0IHByb3ZpZGUgYSBwaGFzZSBmb3IgYmluZGluZyBhZGRcIik7XG4gICAgaWYgKHRoaXMuX21hcC5oYXMoc3R4TmFtZV8yOSkpIHtcbiAgICAgIGxldCBzY29wZXNldEJpbmRpbmdMaXN0ID0gdGhpcy5fbWFwLmdldChzdHhOYW1lXzI5KTtcbiAgICAgIHRoaXMuX21hcC5zZXQoc3R4TmFtZV8yOSwgc2NvcGVzZXRCaW5kaW5nTGlzdC5wdXNoKHtzY29wZXM6IHNjb3Blc2V0XzMxLCBiaW5kaW5nOiBiaW5kaW5nXzI3LCBhbGlhczogTWF5YmUub2YoZm9yd2FyZFN0eF8yNil9KSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX21hcC5zZXQoc3R4TmFtZV8yOSwgTGlzdC5vZih7c2NvcGVzOiBzY29wZXNldF8zMSwgYmluZGluZzogYmluZGluZ18yNywgYWxpYXM6IE1heWJlLm9mKGZvcndhcmRTdHhfMjYpfSkpO1xuICAgIH1cbiAgfVxuICBnZXQoc3R4XzMyKSB7XG4gICAgcmV0dXJuIHRoaXMuX21hcC5nZXQoc3R4XzMyLnRva2VuLnZhbHVlKTtcbiAgfVxufVxuIl19 - -/***/ }, -/* 15 */ -/***/ function(module, exports, __webpack_require__) { - - module.exports = { - Either: __webpack_require__(16), - Future: __webpack_require__(19), - Identity: __webpack_require__(20), - IO: __webpack_require__(21), - lift2: __webpack_require__(22), - lift3: __webpack_require__(23), - Maybe: __webpack_require__(24), - Tuple: __webpack_require__(25), - Reader: __webpack_require__(26) - }; - - -/***/ }, -/* 16 */ -/***/ function(module, exports, __webpack_require__) { - - var R = __webpack_require__(17); - - var util = __webpack_require__(18); - - - function Either(left, right) { - switch (arguments.length) { - case 0: - throw new TypeError('no arguments to Either'); - case 1: - return function(right) { - return right == null ? Either.Left(left) : Either.Right(right); - }; - default: - return right == null ? Either.Left(left) : Either.Right(right); - } - } - - Either.prototype.map = util.returnThis; - - Either.of = Either.prototype.of = function(value) { - return Either.Right(value); - }; - - Either.prototype.chain = util.returnThis; // throw? - - Either.equals = Either.prototype.equals = util.getEquals(Either); - - - // Right - function _Right(x) { - this.value = x; - } - util.extend(_Right, Either); - - _Right.prototype.map = function(fn) { - return new _Right(fn(this.value)); - }; - - _Right.prototype.ap = function(that) { - return that.map(this.value); - }; - - _Right.prototype.chain = function(f) { - return f(this.value); - }; - - _Right.prototype.bimap = function(_, f) { - return new _Right(f(this.value)); - }; - - _Right.prototype.extend = function(f) { - return new _Right(f(this)); - }; - - _Right.prototype.toString = function() { - return 'Either.Right(' + R.toString(this.value) + ')'; - }; - - Either.Right = function(value) { - return new _Right(value); - }; - - - // Left - function _Left(x) { - this.value = x; - } - util.extend(_Left, Either); - - _Left.prototype.ap = function(that) { return that; }; - - _Left.prototype.bimap = function(f) { - return new _Left(f(this.value)); - }; - - _Left.prototype.extend = util.returnThis; - - _Left.prototype.toString = function() { - return 'Either.Left(' + R.toString(this.value) + ')'; - }; - - Either.Left = function(value) { - return new _Left(value); - }; - - - module.exports = Either; - - -/***/ }, -/* 17 */ -/***/ function(module, exports, __webpack_require__) { - - // Ramda v0.17.1 + // Ramda v0.19.1 // https://github.com/ramda/ramda - // (c) 2013-2015 Scott Sauyet, Michael Hurley, and David Chambers + // (c) 2013-2016 Scott Sauyet, Michael Hurley, and David Chambers // Ramda may be freely distributed under the MIT license. ;(function() { @@ -8295,10 +6852,11 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /** * A special placeholder value used to specify "gaps" within curried functions, - * allowing partial application of any combination of arguments, - * regardless of their positions. + * allowing partial application of any combination of arguments, regardless of + * their positions. * - * If `g` is a curried ternary function and `_` is `R.__`, the following are equivalent: + * If `g` is a curried ternary function and `_` is `R.__`, the following are + * equivalent: * * - `g(1, 2, 3)` * - `g(_, 2, 3)(1)` @@ -8311,6 +6869,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @constant * @memberOf R + * @since v0.6.0 * @category Function * @example * @@ -8319,9 +6878,9 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack */ var __ = { '@@functional/placeholder': true }; - // jshint unused:vars + /* eslint-disable no-unused-vars */ var _arity = function _arity(n, fn) { - // jshint unused:vars + /* eslint-disable no-unused-vars */ switch (n) { case 0: return function () { @@ -8372,6 +6931,15 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack } }; + var _arrayFromIterator = function _arrayFromIterator(iter) { + var list = []; + var next; + while (!(next = iter.next()).done) { + list.push(next.value); + } + return list; + }; + var _cloneRegExp = function _cloneRegExp(pattern) { return new RegExp(pattern.source, (pattern.global ? 'g' : '') + (pattern.ignoreCase ? 'i' : '') + (pattern.multiline ? 'm' : '') + (pattern.sticky ? 'y' : '') + (pattern.unicode ? 'u' : '')); }; @@ -8414,7 +6982,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }; var _containsWith = function _containsWith(pred, x, list) { - var idx = 0, len = list.length; + var idx = 0; + var len = list.length; while (idx < len) { if (pred(x, list[idx])) { return true; @@ -8424,161 +6993,10 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return false; }; - /** - * Optimized internal two-arity curry function. - * - * @private - * @category Function - * @param {Function} fn The function to curry. - * @return {Function} The curried function. - */ - var _curry1 = function _curry1(fn) { - return function f1(a) { - if (arguments.length === 0) { - return f1; - } else if (a != null && a['@@functional/placeholder'] === true) { - return f1; - } else { - return fn.apply(this, arguments); - } - }; - }; - - /** - * Optimized internal two-arity curry function. - * - * @private - * @category Function - * @param {Function} fn The function to curry. - * @return {Function} The curried function. - */ - var _curry2 = function _curry2(fn) { - return function f2(a, b) { - var n = arguments.length; - if (n === 0) { - return f2; - } else if (n === 1 && a != null && a['@@functional/placeholder'] === true) { - return f2; - } else if (n === 1) { - return _curry1(function (b) { - return fn(a, b); - }); - } else if (n === 2 && a != null && a['@@functional/placeholder'] === true && b != null && b['@@functional/placeholder'] === true) { - return f2; - } else if (n === 2 && a != null && a['@@functional/placeholder'] === true) { - return _curry1(function (a) { - return fn(a, b); - }); - } else if (n === 2 && b != null && b['@@functional/placeholder'] === true) { - return _curry1(function (b) { - return fn(a, b); - }); - } else { - return fn(a, b); - } - }; - }; - - /** - * Optimized internal three-arity curry function. - * - * @private - * @category Function - * @param {Function} fn The function to curry. - * @return {Function} The curried function. - */ - var _curry3 = function _curry3(fn) { - return function f3(a, b, c) { - var n = arguments.length; - if (n === 0) { - return f3; - } else if (n === 1 && a != null && a['@@functional/placeholder'] === true) { - return f3; - } else if (n === 1) { - return _curry2(function (b, c) { - return fn(a, b, c); - }); - } else if (n === 2 && a != null && a['@@functional/placeholder'] === true && b != null && b['@@functional/placeholder'] === true) { - return f3; - } else if (n === 2 && a != null && a['@@functional/placeholder'] === true) { - return _curry2(function (a, c) { - return fn(a, b, c); - }); - } else if (n === 2 && b != null && b['@@functional/placeholder'] === true) { - return _curry2(function (b, c) { - return fn(a, b, c); - }); - } else if (n === 2) { - return _curry1(function (c) { - return fn(a, b, c); - }); - } else if (n === 3 && a != null && a['@@functional/placeholder'] === true && b != null && b['@@functional/placeholder'] === true && c != null && c['@@functional/placeholder'] === true) { - return f3; - } else if (n === 3 && a != null && a['@@functional/placeholder'] === true && b != null && b['@@functional/placeholder'] === true) { - return _curry2(function (a, b) { - return fn(a, b, c); - }); - } else if (n === 3 && a != null && a['@@functional/placeholder'] === true && c != null && c['@@functional/placeholder'] === true) { - return _curry2(function (a, c) { - return fn(a, b, c); - }); - } else if (n === 3 && b != null && b['@@functional/placeholder'] === true && c != null && c['@@functional/placeholder'] === true) { - return _curry2(function (b, c) { - return fn(a, b, c); - }); - } else if (n === 3 && a != null && a['@@functional/placeholder'] === true) { - return _curry1(function (a) { - return fn(a, b, c); - }); - } else if (n === 3 && b != null && b['@@functional/placeholder'] === true) { - return _curry1(function (b) { - return fn(a, b, c); - }); - } else if (n === 3 && c != null && c['@@functional/placeholder'] === true) { - return _curry1(function (c) { - return fn(a, b, c); - }); - } else { - return fn(a, b, c); - } - }; - }; - - /** - * Internal curryN function. - * - * @private - * @category Function - * @param {Number} length The arity of the curried function. - * @return {array} An array of arguments received thus far. - * @param {Function} fn The function to curry. - */ - var _curryN = function _curryN(length, received, fn) { - return function () { - var combined = []; - var argsIdx = 0; - var left = length; - var combinedIdx = 0; - while (combinedIdx < received.length || argsIdx < arguments.length) { - var result; - if (combinedIdx < received.length && (received[combinedIdx] == null || received[combinedIdx]['@@functional/placeholder'] !== true || argsIdx >= arguments.length)) { - result = received[combinedIdx]; - } else { - result = arguments[argsIdx]; - argsIdx += 1; - } - combined[combinedIdx] = result; - if (result == null || result['@@functional/placeholder'] !== true) { - left -= 1; - } - combinedIdx += 1; - } - return left <= 0 ? fn.apply(this, combined) : _arity(left, _curryN(length, combined, fn)); - }; - }; - var _filter = function _filter(fn, list) { - var idx = 0, len = list.length, result = []; + var idx = 0; + var len = list.length; + var result = []; while (idx < len) { if (fn(list[idx])) { result[result.length] = list[idx]; @@ -8595,19 +7013,6 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }; }; - /** - * @private - * @param {Function} fn The strategy for extracting function names from an object - * @return {Function} A function that takes an object and returns an array of function names. - */ - var _functionsWith = function _functionsWith(fn) { - return function (obj) { - return _filter(function (key) { - return typeof obj[key] === 'function'; - }, fn(obj)); - }; - }; - var _has = function _has(prop, obj) { return Object.prototype.hasOwnProperty.call(obj, prop); }; @@ -8616,6 +7021,15 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return x; }; + var _isArguments = function () { + var toString = Object.prototype.toString; + return toString.call(arguments) === '[object Arguments]' ? function _isArguments(x) { + return toString.call(x) === '[object Arguments]'; + } : function _isArguments(x) { + return _has('callee', x); + }; + }(); + /** * Tests whether or not an object is an array. * @@ -8648,6 +7062,18 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return Object.prototype.toString.call(x) === '[object Number]'; }; + var _isObject = function _isObject(x) { + return Object.prototype.toString.call(x) === '[object Object]'; + }; + + var _isPlaceholder = function _isPlaceholder(a) { + return a != null && typeof a === 'object' && a['@@functional/placeholder'] === true; + }; + + var _isRegExp = function _isRegExp(x) { + return Object.prototype.toString.call(x) === '[object RegExp]'; + }; + var _isString = function _isString(x) { return Object.prototype.toString.call(x) === '[object String]'; }; @@ -8656,15 +7082,21 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return typeof obj['@@transducer/step'] === 'function'; }; - var _map = function _map(fn, list) { - var idx = 0, len = list.length, result = Array(len); + var _map = function _map(fn, functor) { + var idx = 0; + var len = functor.length; + var result = Array(len); while (idx < len) { - result[idx] = fn(list[idx]); + result[idx] = fn(functor[idx]); idx += 1; } return result; }; + var _of = function _of(x) { + return [x]; + }; + var _pipe = function _pipe(f, g) { return function () { return g.call(this, f.apply(this, arguments)); @@ -8680,8 +7112,11 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }; }; + // \b matches word boundary; [\b] matches backspace var _quote = function _quote(s) { - return '"' + s.replace(/"/g, '\\"') + '"'; + var escaped = s.replace(/\\/g, '\\\\').replace(/[\b]/g, '\\b') // \b matches word boundary; [\b] matches backspace + .replace(/\f/g, '\\f').replace(/\n/g, '\\n').replace(/\r/g, '\\r').replace(/\t/g, '\\t').replace(/\v/g, '\\v').replace(/\0/g, '\\0'); + return '"' + escaped.replace(/"/g, '\\"') + '"'; }; var _reduced = function _reduced(x) { @@ -8740,34 +7175,6 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }; }(); - var _xdropRepeatsWith = function () { - function XDropRepeatsWith(pred, xf) { - this.xf = xf; - this.pred = pred; - this.lastValue = undefined; - this.seenFirstValue = false; - } - XDropRepeatsWith.prototype['@@transducer/init'] = function () { - return this.xf['@@transducer/init'](); - }; - XDropRepeatsWith.prototype['@@transducer/result'] = function (result) { - return this.xf['@@transducer/result'](result); - }; - XDropRepeatsWith.prototype['@@transducer/step'] = function (result, input) { - var sameAsLast = false; - if (!this.seenFirstValue) { - this.seenFirstValue = true; - } else if (this.pred(this.lastValue, input)) { - sameAsLast = true; - } - this.lastValue = input; - return sameAsLast ? result : this.xf['@@transducer/step'](result, input); - }; - return _curry2(function _xdropRepeatsWith(pred, xf) { - return new XDropRepeatsWith(pred, xf); - }); - }(); - var _xfBase = { init: function () { return this.xf['@@transducer/init'](); @@ -8777,15 +7184,412 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack } }; - var _xfilter = function () { - function XFilter(f, xf) { - this.xf = xf; - this.f = f; + var _xwrap = function () { + function XWrap(fn) { + this.f = fn; } - XFilter.prototype['@@transducer/init'] = _xfBase.init; - XFilter.prototype['@@transducer/result'] = _xfBase.result; - XFilter.prototype['@@transducer/step'] = function (result, input) { - return this.f(input) ? this.xf['@@transducer/step'](result, input) : result; + XWrap.prototype['@@transducer/init'] = function () { + throw new Error('init not implemented on XWrap'); + }; + XWrap.prototype['@@transducer/result'] = function (acc) { + return acc; + }; + XWrap.prototype['@@transducer/step'] = function (acc, x) { + return this.f(acc, x); + }; + return function _xwrap(fn) { + return new XWrap(fn); + }; + }(); + + var _aperture = function _aperture(n, list) { + var idx = 0; + var limit = list.length - (n - 1); + var acc = new Array(limit >= 0 ? limit : 0); + while (idx < limit) { + acc[idx] = _slice(list, idx, idx + n); + idx += 1; + } + return acc; + }; + + /** + * Similar to hasMethod, this checks whether a function has a [methodname] + * function. If it isn't an array it will execute that function otherwise it + * will default to the ramda implementation. + * + * @private + * @param {Function} fn ramda implemtation + * @param {String} methodname property to check for a custom implementation + * @return {Object} Whatever the return value of the method is. + */ + var _checkForMethod = function _checkForMethod(methodname, fn) { + return function () { + var length = arguments.length; + if (length === 0) { + return fn(); + } + var obj = arguments[length - 1]; + return _isArray(obj) || typeof obj[methodname] !== 'function' ? fn.apply(this, arguments) : obj[methodname].apply(obj, _slice(arguments, 0, length - 1)); + }; + }; + + /** + * Optimized internal one-arity curry function. + * + * @private + * @category Function + * @param {Function} fn The function to curry. + * @return {Function} The curried function. + */ + var _curry1 = function _curry1(fn) { + return function f1(a) { + if (arguments.length === 0 || _isPlaceholder(a)) { + return f1; + } else { + return fn.apply(this, arguments); + } + }; + }; + + /** + * Optimized internal two-arity curry function. + * + * @private + * @category Function + * @param {Function} fn The function to curry. + * @return {Function} The curried function. + */ + var _curry2 = function _curry2(fn) { + return function f2(a, b) { + switch (arguments.length) { + case 0: + return f2; + case 1: + return _isPlaceholder(a) ? f2 : _curry1(function (_b) { + return fn(a, _b); + }); + default: + return _isPlaceholder(a) && _isPlaceholder(b) ? f2 : _isPlaceholder(a) ? _curry1(function (_a) { + return fn(_a, b); + }) : _isPlaceholder(b) ? _curry1(function (_b) { + return fn(a, _b); + }) : fn(a, b); + } + }; + }; + + /** + * Optimized internal three-arity curry function. + * + * @private + * @category Function + * @param {Function} fn The function to curry. + * @return {Function} The curried function. + */ + var _curry3 = function _curry3(fn) { + return function f3(a, b, c) { + switch (arguments.length) { + case 0: + return f3; + case 1: + return _isPlaceholder(a) ? f3 : _curry2(function (_b, _c) { + return fn(a, _b, _c); + }); + case 2: + return _isPlaceholder(a) && _isPlaceholder(b) ? f3 : _isPlaceholder(a) ? _curry2(function (_a, _c) { + return fn(_a, b, _c); + }) : _isPlaceholder(b) ? _curry2(function (_b, _c) { + return fn(a, _b, _c); + }) : _curry1(function (_c) { + return fn(a, b, _c); + }); + default: + return _isPlaceholder(a) && _isPlaceholder(b) && _isPlaceholder(c) ? f3 : _isPlaceholder(a) && _isPlaceholder(b) ? _curry2(function (_a, _b) { + return fn(_a, _b, c); + }) : _isPlaceholder(a) && _isPlaceholder(c) ? _curry2(function (_a, _c) { + return fn(_a, b, _c); + }) : _isPlaceholder(b) && _isPlaceholder(c) ? _curry2(function (_b, _c) { + return fn(a, _b, _c); + }) : _isPlaceholder(a) ? _curry1(function (_a) { + return fn(_a, b, c); + }) : _isPlaceholder(b) ? _curry1(function (_b) { + return fn(a, _b, c); + }) : _isPlaceholder(c) ? _curry1(function (_c) { + return fn(a, b, _c); + }) : fn(a, b, c); + } + }; + }; + + /** + * Internal curryN function. + * + * @private + * @category Function + * @param {Number} length The arity of the curried function. + * @param {Array} received An array of arguments received thus far. + * @param {Function} fn The function to curry. + * @return {Function} The curried function. + */ + var _curryN = function _curryN(length, received, fn) { + return function () { + var combined = []; + var argsIdx = 0; + var left = length; + var combinedIdx = 0; + while (combinedIdx < received.length || argsIdx < arguments.length) { + var result; + if (combinedIdx < received.length && (!_isPlaceholder(received[combinedIdx]) || argsIdx >= arguments.length)) { + result = received[combinedIdx]; + } else { + result = arguments[argsIdx]; + argsIdx += 1; + } + combined[combinedIdx] = result; + if (!_isPlaceholder(result)) { + left -= 1; + } + combinedIdx += 1; + } + return left <= 0 ? fn.apply(this, combined) : _arity(left, _curryN(length, combined, fn)); + }; + }; + + /** + * Returns a function that dispatches with different strategies based on the + * object in list position (last argument). If it is an array, executes [fn]. + * Otherwise, if it has a function with [methodname], it will execute that + * function (functor case). Otherwise, if it is a transformer, uses transducer + * [xf] to return a new transformer (transducer case). Otherwise, it will + * default to executing [fn]. + * + * @private + * @param {String} methodname property to check for a custom implementation + * @param {Function} xf transducer to initialize if object is transformer + * @param {Function} fn default ramda implementation + * @return {Function} A function that dispatches on object in list position + */ + var _dispatchable = function _dispatchable(methodname, xf, fn) { + return function () { + var length = arguments.length; + if (length === 0) { + return fn(); + } + var obj = arguments[length - 1]; + if (!_isArray(obj)) { + var args = _slice(arguments, 0, length - 1); + if (typeof obj[methodname] === 'function') { + return obj[methodname].apply(obj, args); + } + if (_isTransformer(obj)) { + var transducer = xf.apply(null, args); + return transducer(obj); + } + } + return fn.apply(this, arguments); + }; + }; + + var _dropLastWhile = function dropLastWhile(pred, list) { + var idx = list.length - 1; + while (idx >= 0 && pred(list[idx])) { + idx -= 1; + } + return _slice(list, 0, idx + 1); + }; + + var _xall = function () { + function XAll(f, xf) { + this.xf = xf; + this.f = f; + this.all = true; + } + XAll.prototype['@@transducer/init'] = _xfBase.init; + XAll.prototype['@@transducer/result'] = function (result) { + if (this.all) { + result = this.xf['@@transducer/step'](result, true); + } + return this.xf['@@transducer/result'](result); + }; + XAll.prototype['@@transducer/step'] = function (result, input) { + if (!this.f(input)) { + this.all = false; + result = _reduced(this.xf['@@transducer/step'](result, false)); + } + return result; + }; + return _curry2(function _xall(f, xf) { + return new XAll(f, xf); + }); + }(); + + var _xany = function () { + function XAny(f, xf) { + this.xf = xf; + this.f = f; + this.any = false; + } + XAny.prototype['@@transducer/init'] = _xfBase.init; + XAny.prototype['@@transducer/result'] = function (result) { + if (!this.any) { + result = this.xf['@@transducer/step'](result, false); + } + return this.xf['@@transducer/result'](result); + }; + XAny.prototype['@@transducer/step'] = function (result, input) { + if (this.f(input)) { + this.any = true; + result = _reduced(this.xf['@@transducer/step'](result, true)); + } + return result; + }; + return _curry2(function _xany(f, xf) { + return new XAny(f, xf); + }); + }(); + + var _xaperture = function () { + function XAperture(n, xf) { + this.xf = xf; + this.pos = 0; + this.full = false; + this.acc = new Array(n); + } + XAperture.prototype['@@transducer/init'] = _xfBase.init; + XAperture.prototype['@@transducer/result'] = function (result) { + this.acc = null; + return this.xf['@@transducer/result'](result); + }; + XAperture.prototype['@@transducer/step'] = function (result, input) { + this.store(input); + return this.full ? this.xf['@@transducer/step'](result, this.getCopy()) : result; + }; + XAperture.prototype.store = function (input) { + this.acc[this.pos] = input; + this.pos += 1; + if (this.pos === this.acc.length) { + this.pos = 0; + this.full = true; + } + }; + XAperture.prototype.getCopy = function () { + return _concat(_slice(this.acc, this.pos), _slice(this.acc, 0, this.pos)); + }; + return _curry2(function _xaperture(n, xf) { + return new XAperture(n, xf); + }); + }(); + + var _xdrop = function () { + function XDrop(n, xf) { + this.xf = xf; + this.n = n; + } + XDrop.prototype['@@transducer/init'] = _xfBase.init; + XDrop.prototype['@@transducer/result'] = _xfBase.result; + XDrop.prototype['@@transducer/step'] = function (result, input) { + if (this.n > 0) { + this.n -= 1; + return result; + } + return this.xf['@@transducer/step'](result, input); + }; + return _curry2(function _xdrop(n, xf) { + return new XDrop(n, xf); + }); + }(); + + var _xdropLast = function () { + function XDropLast(n, xf) { + this.xf = xf; + this.pos = 0; + this.full = false; + this.acc = new Array(n); + } + XDropLast.prototype['@@transducer/init'] = _xfBase.init; + XDropLast.prototype['@@transducer/result'] = function (result) { + this.acc = null; + return this.xf['@@transducer/result'](result); + }; + XDropLast.prototype['@@transducer/step'] = function (result, input) { + if (this.full) { + result = this.xf['@@transducer/step'](result, this.acc[this.pos]); + } + this.store(input); + return result; + }; + XDropLast.prototype.store = function (input) { + this.acc[this.pos] = input; + this.pos += 1; + if (this.pos === this.acc.length) { + this.pos = 0; + this.full = true; + } + }; + return _curry2(function _xdropLast(n, xf) { + return new XDropLast(n, xf); + }); + }(); + + var _xdropRepeatsWith = function () { + function XDropRepeatsWith(pred, xf) { + this.xf = xf; + this.pred = pred; + this.lastValue = undefined; + this.seenFirstValue = false; + } + XDropRepeatsWith.prototype['@@transducer/init'] = function () { + return this.xf['@@transducer/init'](); + }; + XDropRepeatsWith.prototype['@@transducer/result'] = function (result) { + return this.xf['@@transducer/result'](result); + }; + XDropRepeatsWith.prototype['@@transducer/step'] = function (result, input) { + var sameAsLast = false; + if (!this.seenFirstValue) { + this.seenFirstValue = true; + } else if (this.pred(this.lastValue, input)) { + sameAsLast = true; + } + this.lastValue = input; + return sameAsLast ? result : this.xf['@@transducer/step'](result, input); + }; + return _curry2(function _xdropRepeatsWith(pred, xf) { + return new XDropRepeatsWith(pred, xf); + }); + }(); + + var _xdropWhile = function () { + function XDropWhile(f, xf) { + this.xf = xf; + this.f = f; + } + XDropWhile.prototype['@@transducer/init'] = _xfBase.init; + XDropWhile.prototype['@@transducer/result'] = _xfBase.result; + XDropWhile.prototype['@@transducer/step'] = function (result, input) { + if (this.f) { + if (this.f(input)) { + return result; + } + this.f = null; + } + return this.xf['@@transducer/step'](result, input); + }; + return _curry2(function _xdropWhile(f, xf) { + return new XDropWhile(f, xf); + }); + }(); + + var _xfilter = function () { + function XFilter(f, xf) { + this.xf = xf; + this.f = f; + } + XFilter.prototype['@@transducer/init'] = _xfBase.init; + XFilter.prototype['@@transducer/result'] = _xfBase.result; + XFilter.prototype['@@transducer/step'] = function (result, input) { + return this.f(input) ? this.xf['@@transducer/step'](result, input) : result; }; return _curry2(function _xfilter(f, xf) { return new XFilter(f, xf); @@ -8937,29 +7741,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); }(); - var _xwrap = function () { - function XWrap(fn) { - this.f = fn; - } - XWrap.prototype['@@transducer/init'] = function () { - throw new Error('init not implemented on XWrap'); - }; - XWrap.prototype['@@transducer/result'] = function (acc) { - return acc; - }; - XWrap.prototype['@@transducer/step'] = function (acc, x) { - return this.f(acc, x); - }; - return function _xwrap(fn) { - return new XWrap(fn); - }; - }(); - /** * Adds two numbers. Equivalent to `a + b` but curried. * * @func * @memberOf R + * @since v0.1.0 * @category Math * @sig Number -> Number -> Number * @param {Number} a @@ -8976,13 +7763,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Applies a function to the value at the given index of an array, - * returning a new copy of the array with the element at the given - * index replaced with the result of the function application. - * @see R.update + * Applies a function to the value at the given index of an array, returning a + * new copy of the array with the element at the given index replaced with the + * result of the function application. * * @func * @memberOf R + * @since v0.14.0 * @category List * @sig (a -> a) -> Number -> [a] -> [a] * @param {Function} fn The function to apply. @@ -8992,6 +7779,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @return {Array} A copy of the supplied array-like object with * the element at index `idx` replaced with the value * returned by applying `fn` to the existing element. + * @see R.update * @example * * R.adjust(R.add(10), 1, [0, 1, 2]); //=> [0, 11, 2] @@ -9008,15 +7796,52 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return _list; }); + /** + * Returns `true` if all elements of the list match the predicate, `false` if + * there are any that don't. + * + * Dispatches to the `all` method of the second argument, if present. + * + * Acts as a transducer if a transformer is given in list position. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category List + * @sig (a -> Boolean) -> [a] -> Boolean + * @param {Function} fn The predicate function. + * @param {Array} list The array to consider. + * @return {Boolean} `true` if the predicate is satisfied by every element, `false` + * otherwise. + * @see R.any, R.none, R.transduce + * @example + * + * var lessThan2 = R.flip(R.lt)(2); + * var lessThan3 = R.flip(R.lt)(3); + * R.all(lessThan2)([1, 2]); //=> false + * R.all(lessThan3)([1, 2]); //=> true + */ + var all = _curry2(_dispatchable('all', _xall, function all(fn, list) { + var idx = 0; + while (idx < list.length) { + if (!fn(list[idx])) { + return false; + } + idx += 1; + } + return true; + })); + /** * Returns a function that always returns the given value. Note that for * non-primitives the value returned is a reference to the original value. * - * This function is known as `const`, `constant`, or `K` (for K combinator) - * in other languages and libraries. + * This function is known as `const`, `constant`, or `K` (for K combinator) in + * other languages and libraries. * * @func * @memberOf R + * @since v0.1.0 * @category Function * @sig a -> (* -> a) * @param {*} val The value to wrap in a function @@ -9033,39 +7858,96 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a new list, composed of n-tuples of consecutive elements - * If `n` is greater than the length of the list, an empty list is returned. + * Returns `true` if both arguments are `true`; `false` otherwise. * * @func * @memberOf R - * @category List - * @sig Number -> [a] -> [[a]] - * @param {Number} n The size of the tuples to create - * @param {Array} list The list to split into `n`-tuples - * @return {Array} The new list. + * @since v0.1.0 + * @category Logic + * @sig * -> * -> * + * @param {Boolean} a A boolean value + * @param {Boolean} b A boolean value + * @return {Boolean} `true` if both arguments are `true`, `false` otherwise + * @see R.both * @example * - * R.aperture(2, [1, 2, 3, 4, 5]); //=> [[1, 2], [2, 3], [3, 4], [4, 5]] - * R.aperture(3, [1, 2, 3, 4, 5]); //=> [[1, 2, 3], [2, 3, 4], [3, 4, 5]] - * R.aperture(7, [1, 2, 3, 4, 5]); //=> [] + * R.and(true, true); //=> true + * R.and(true, false); //=> false + * R.and(false, true); //=> false + * R.and(false, false); //=> false */ - var aperture = _curry2(function aperture(n, list) { - var idx = 0; - var limit = list.length - (n - 1); - var acc = new Array(limit >= 0 ? limit : 0); - while (idx < limit) { - acc[idx] = _slice(list, idx, idx + n); - idx += 1; - } - return acc; + var and = _curry2(function and(a, b) { + return a && b; }); /** - * Returns a new list containing the contents of the given list, followed by the given - * element. + * Returns `true` if at least one of elements of the list match the predicate, + * `false` otherwise. + * + * Dispatches to the `any` method of the second argument, if present. + * + * Acts as a transducer if a transformer is given in list position. * * @func * @memberOf R + * @since v0.1.0 + * @category List + * @sig (a -> Boolean) -> [a] -> Boolean + * @param {Function} fn The predicate function. + * @param {Array} list The array to consider. + * @return {Boolean} `true` if the predicate is satisfied by at least one element, `false` + * otherwise. + * @see R.all, R.none, R.transduce + * @example + * + * var lessThan0 = R.flip(R.lt)(0); + * var lessThan2 = R.flip(R.lt)(2); + * R.any(lessThan0)([1, 2]); //=> false + * R.any(lessThan2)([1, 2]); //=> true + */ + var any = _curry2(_dispatchable('any', _xany, function any(fn, list) { + var idx = 0; + while (idx < list.length) { + if (fn(list[idx])) { + return true; + } + idx += 1; + } + return false; + })); + + /** + * Returns a new list, composed of n-tuples of consecutive elements If `n` is + * greater than the length of the list, an empty list is returned. + * + * Dispatches to the `aperture` method of the second argument, if present. + * + * Acts as a transducer if a transformer is given in list position. + * + * @func + * @memberOf R + * @since v0.12.0 + * @category List + * @sig Number -> [a] -> [[a]] + * @param {Number} n The size of the tuples to create + * @param {Array} list The list to split into `n`-tuples + * @return {Array} The new list. + * @see R.transduce + * @example + * + * R.aperture(2, [1, 2, 3, 4, 5]); //=> [[1, 2], [2, 3], [3, 4], [4, 5]] + * R.aperture(3, [1, 2, 3, 4, 5]); //=> [[1, 2, 3], [2, 3, 4], [3, 4, 5]] + * R.aperture(7, [1, 2, 3, 4, 5]); //=> [] + */ + var aperture = _curry2(_dispatchable('aperture', _xaperture, _aperture)); + + /** + * Returns a new list containing the contents of the given list, followed by + * the given element. + * + * @func + * @memberOf R + * @since v0.1.0 * @category List * @sig a -> [a] -> [a] * @param {*} el The element to add to the end of the new list. @@ -9085,11 +7967,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /** * Applies function `fn` to the argument list `args`. This is useful for - * creating a fixed-arity function from a variadic function. `fn` should - * be a bound function if context is significant. + * creating a fixed-arity function from a variadic function. `fn` should be a + * bound function if context is significant. * * @func * @memberOf R + * @since v0.7.0 * @category Function * @sig (*... -> a) -> [*] -> a * @param {Function} fn @@ -9107,12 +7990,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /** * Makes a shallow clone of an object, setting or overriding the specified - * property with the given value. Note that this copies and flattens - * prototype properties onto the new object as well. All non-primitive - * properties are copied by reference. + * property with the given value. Note that this copies and flattens prototype + * properties onto the new object as well. All non-primitive properties are + * copied by reference. * * @func * @memberOf R + * @since v0.8.0 * @category Object * @sig String -> a -> {k: v} -> {k: v} * @param {String} prop the property name to set @@ -9134,14 +8018,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Makes a shallow clone of an object, setting or overriding the nodes - * required to create the given path, and placing the specific value at the - * tail end of that path. Note that this copies and flattens prototype - * properties onto the new object as well. All non-primitive properties - * are copied by reference. + * Makes a shallow clone of an object, setting or overriding the nodes required + * to create the given path, and placing the specific value at the tail end of + * that path. Note that this copies and flattens prototype properties onto the + * new object as well. All non-primitive properties are copied by reference. * * @func * @memberOf R + * @since v0.8.0 * @category Object * @sig [String] -> a -> {k: v} -> {k: v} * @param {Array} path the path to set @@ -9156,7 +8040,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var assocPath = _curry3(function assocPath(path, val, obj) { switch (path.length) { case 0: - return obj; + return val; case 1: return assoc(path[0], val, obj); default: @@ -9171,13 +8055,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.6.0 * @category Function * @category Object - * @see R.partial * @sig (* -> *) -> {*} -> (* -> *) * @param {Function} fn The function to bind to context * @param {Object} thisObj The context to bind `fn` to * @return {Function} A function that will execute in the context of `thisObj`. + * @see R.partial */ var bind = _curry2(function bind(fn, thisObj) { return _arity(fn.length, function () { @@ -9186,13 +8071,15 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * A function wrapping calls to the two functions in an `&&` operation, returning the result of the first - * function if it is false-y and the result of the second function otherwise. Note that this is - * short-circuited, meaning that the second function will not be invoked if the first returns a false-y - * value. + * A function wrapping calls to the two functions in an `&&` operation, + * returning the result of the first function if it is false-y and the result + * of the second function otherwise. Note that this is short-circuited, + * meaning that the second function will not be invoked if the first returns a + * false-y value. * * @func * @memberOf R + * @since v0.12.0 * @category Logic * @sig (*... -> Boolean) -> (*... -> Boolean) -> (*... -> Boolean) * @param {Function} f a predicate @@ -9201,8 +8088,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @see R.and * @example * - * var gt10 = function(x) { return x > 10; }; - * var even = function(x) { return x % 2 === 0 }; + * var gt10 = x => x > 10; + * var even = x => x % 2 === 0; * var f = R.both(gt10, even); * f(100); //=> true * f(101); //=> false @@ -9214,19 +8101,19 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Makes a comparator function out of a function that reports whether the first element is less than the second. + * Makes a comparator function out of a function that reports whether the first + * element is less than the second. * * @func * @memberOf R + * @since v0.1.0 * @category Function * @sig (a, b -> Boolean) -> (a, b -> Number) * @param {Function} pred A predicate function of arity two. * @return {Function} A Function :: a -> b -> Int that returns `-1` if a < b, `1` if b < a, otherwise `0`. * @example * - * var cmp = R.comparator(function(a, b) { - * return a.age < b.age; - * }); + * var cmp = R.comparator((a, b) => a.age < b.age); * var people = [ * // ... * ]; @@ -9238,41 +8125,17 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }; }); - /** - * Takes a function `f` and returns a function `g` such that: - * - * - applying `g` to zero or more arguments will give __true__ if applying - * the same arguments to `f` gives a logical __false__ value; and - * - * - applying `g` to zero or more arguments will give __false__ if applying - * the same arguments to `f` gives a logical __true__ value. - * - * @func - * @memberOf R - * @category Logic - * @sig (*... -> *) -> (*... -> Boolean) - * @param {Function} f - * @return {Function} - * @see R.not - * @example - * - * var isEven = function(n) { return n % 2 === 0; }; - * var isOdd = R.complement(isEven); - * isOdd(21); //=> true - * isOdd(42); //=> false - */ - var complement = _curry1(_complement); - /** * Returns a function, `fn`, which encapsulates if/else-if/else logic. - * `R.cond` takes a list of [predicate, transform] pairs. All of the - * arguments to `fn` are applied to each of the predicates in turn - * until one returns a "truthy" value, at which point `fn` returns the - * result of applying its arguments to the corresponding transformer. - * If none of the predicates matches, `fn` returns undefined. + * `R.cond` takes a list of [predicate, transform] pairs. All of the arguments + * to `fn` are applied to each of the predicates in turn until one returns a + * "truthy" value, at which point `fn` returns the result of applying its + * arguments to the corresponding transformer. If none of the predicates + * matches, `fn` returns undefined. * * @func * @memberOf R + * @since v0.6.0 * @category Logic * @sig [[(*... -> Boolean),(*... -> *)]] -> (*... -> *) * @param {Array} pairs @@ -9282,7 +8145,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * var fn = R.cond([ * [R.equals(0), R.always('water freezes at 0°C')], * [R.equals(100), R.always('water boils at 100°C')], - * [R.T, function(temp) { return 'nothing special happens at ' + temp + '°C'; }] + * [R.T, temp => 'nothing special happens at ' + temp + '°C'] * ]); * fn(0); //=> 'water freezes at 0°C' * fn(50); //=> 'nothing special happens at 50°C' @@ -9301,34 +8164,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns `true` if the `x` is found in the `list`, using `pred` as an - * equality predicate for `x`. - * - * @func - * @memberOf R - * @category List - * @sig (a, a -> Boolean) -> a -> [a] -> Boolean - * @param {Function} pred A predicate used to test whether two items are equal. - * @param {*} x The item to find - * @param {Array} list The list to iterate over - * @return {Boolean} `true` if `x` is in `list`, else `false`. - * @example - * - * var xs = [{x: 12}, {x: 11}, {x: 10}]; - * R.containsWith(function(a, b) { return a.x === b.x; }, {x: 10}, xs); //=> true - * R.containsWith(function(a, b) { return a.x === b.x; }, {x: 1}, xs); //=> false - */ - var containsWith = _curry3(_containsWith); - - /** - * Counts the elements of a list according to how many match each value - * of a key generated by the supplied function. Returns an object - * mapping the keys produced by `fn` to the number of occurrences in - * the list. Note that all keys are coerced to strings because of how - * JavaScript objects work. + * Counts the elements of a list according to how many match each value of a + * key generated by the supplied function. Returns an object mapping the keys + * produced by `fn` to the number of occurrences in the list. Note that all + * keys are coerced to strings because of how JavaScript objects work. * * @func * @memberOf R + * @since v0.1.0 * @category Relation * @sig (a -> String) -> [a] -> {*} * @param {Function} fn The function used to map values to keys. @@ -9354,34 +8197,10 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Creates an object containing a single key:value pair. - * - * @func - * @memberOf R - * @category Object - * @sig String -> a -> {String:a} - * @param {String} key - * @param {*} val - * @return {Object} - * @example - * - * var matchPhrases = R.compose( - * R.createMapEntry('must'), - * R.map(R.createMapEntry('match_phrase')) - * ); - * matchPhrases(['foo', 'bar', 'baz']); //=> {must: [{match_phrase: 'foo'}, {match_phrase: 'bar'}, {match_phrase: 'baz'}]} - */ - var createMapEntry = _curry2(function createMapEntry(key, val) { - var obj = {}; - obj[key] = val; - return obj; - }); - - /** - * Returns a curried equivalent of the provided function, with the - * specified arity. The curried function has two unusual capabilities. - * First, its arguments needn't be provided one at a time. If `g` is - * `R.curryN(3, f)`, the following are equivalent: + * Returns a curried equivalent of the provided function, with the specified + * arity. The curried function has two unusual capabilities. First, its + * arguments needn't be provided one at a time. If `g` is `R.curryN(3, f)`, the + * following are equivalent: * * - `g(1)(2)(3)` * - `g(1)(2, 3)` @@ -9390,8 +8209,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * Secondly, the special placeholder value `R.__` may be used to specify * "gaps", allowing partial application of any combination of arguments, - * regardless of their positions. If `g` is as above and `_` is `R.__`, - * the following are equivalent: + * regardless of their positions. If `g` is as above and `_` is `R.__`, the + * following are equivalent: * * - `g(1, 2, 3)` * - `g(_, 2, 3)(1)` @@ -9403,6 +8222,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.5.0 * @category Function * @sig Number -> (* -> a) -> (* -> a) * @param {Number} length The arity for the returned function. @@ -9411,11 +8231,9 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @see R.curry * @example * - * var addFourNumbers = function() { - * return R.sum([].slice.call(arguments, 0, 4)); - * }; + * var sumArgs = (...args) => R.sum(args); * - * var curriedAddFourNumbers = R.curryN(4, addFourNumbers); + * var curriedAddFourNumbers = R.curryN(4, sumArgs); * var f = curriedAddFourNumbers(1, 2); * var g = f(3); * g(4); //=> 10 @@ -9432,6 +8250,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.9.0 * @category Math * @sig Number -> Number * @param {Number} n @@ -9444,11 +8263,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var dec = add(-1); /** - * Returns the second argument if it is not null or undefined. If it is null - * or undefined, the first (default) argument is returned. + * Returns the second argument if it is not `null`, `undefined` or `NaN` + * otherwise the first argument is returned. * * @func * @memberOf R + * @since v0.10.0 * @category Logic * @sig a -> b -> a | b * @param {a} val The default value. @@ -9456,33 +8276,35 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @return {*} The the second value or the default value * @example * - * var defaultTo42 = defaultTo(42); + * var defaultTo42 = R.defaultTo(42); * * defaultTo42(null); //=> 42 * defaultTo42(undefined); //=> 42 * defaultTo42('Ramda'); //=> 'Ramda' + * defaultTo42(parseInt('string')); //=> 42 */ var defaultTo = _curry2(function defaultTo(d, v) { - return v == null ? d : v; + return v == null || v !== v ? d : v; }); /** - * Finds the set (i.e. no duplicates) of all elements in the first list not contained in the second list. - * Duplication is determined according to the value returned by applying the supplied predicate to two list - * elements. + * Finds the set (i.e. no duplicates) of all elements in the first list not + * contained in the second list. Duplication is determined according to the + * value returned by applying the supplied predicate to two list elements. * * @func * @memberOf R + * @since v0.1.0 * @category Relation - * @sig (a,a -> Boolean) -> [a] -> [a] -> [a] + * @sig (a -> a -> Boolean) -> [*] -> [*] -> [*] * @param {Function} pred A predicate used to test whether two items are equal. * @param {Array} list1 The first list. * @param {Array} list2 The second list. - * @see R.difference * @return {Array} The elements in `list1` that are not in `list2`. + * @see R.difference * @example * - * function cmp(x, y) { return x.a === y.a; } + * function cmp(x, y) => x.a === y.a; * var l1 = [{a: 1}, {a: 2}, {a: 3}]; * var l2 = [{a: 3}, {a: 4}]; * R.differenceWith(cmp, l1, l2); //=> [{a: 1}, {a: 2}] @@ -9491,10 +8313,9 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var out = []; var idx = 0; var firstLen = first.length; - var containsPred = containsWith(pred); while (idx < firstLen) { - if (!containsPred(first[idx], second) && !containsPred(first[idx], out)) { - out[out.length] = first[idx]; + if (!_containsWith(pred, first[idx], second) && !_containsWith(pred, first[idx], out)) { + out.push(first[idx]); } idx += 1; } @@ -9506,6 +8327,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.10.0 * @category Object * @sig String -> {k: v} -> {k: v} * @param {String} prop the name of the property to dissociate @@ -9527,13 +8349,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Makes a shallow clone of an object, omitting the property at the - * given path. Note that this copies and flattens prototype properties - * onto the new object as well. All non-primitive properties are copied - * by reference. + * Makes a shallow clone of an object, omitting the property at the given path. + * Note that this copies and flattens prototype properties onto the new object + * as well. All non-primitive properties are copied by reference. * * @func * @memberOf R + * @since v0.11.0 * @category Object * @sig [String] -> {k: v} -> {k: v} * @param {Array} path the path to set @@ -9562,6 +8384,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category Math * @sig Number -> Number -> Number * @param {Number} a The first value. @@ -9583,43 +8406,49 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a new list containing all but last the`n` elements of a given list, - * passing each value from the right to the supplied predicate function, skipping - * elements while the predicate function returns `true`. The predicate function - * is passed one argument: (value)*. + * Returns a new list containing the last `n` elements of a given list, passing + * each value to the supplied predicate function, skipping elements while the + * predicate function returns `true`. The predicate function is passed one + * argument: *(value)*. + * + * Dispatches to the `dropWhile` method of the second argument, if present. + * + * Acts as a transducer if a transformer is given in list position. * * @func * @memberOf R + * @since v0.9.0 * @category List * @sig (a -> Boolean) -> [a] -> [a] * @param {Function} fn The function called per iteration. * @param {Array} list The collection to iterate over. * @return {Array} A new array. - * @see R.takeLastWhile + * @see R.takeWhile, R.transduce, R.addIndex * @example * - * var lteThree = function(x) { - * return x <= 3; - * }; + * var lteTwo = x => x <= 2; * - * R.dropLastWhile(lteThree, [1, 2, 3, 4, 3, 2, 1]); //=> [1, 2] + * R.dropWhile(lteTwo, [1, 2, 3, 4, 3, 2, 1]); //=> [3, 4, 3, 2, 1] */ - var dropLastWhile = _curry2(function dropLastWhile(pred, list) { - var idx = list.length - 1; - while (idx >= 0 && pred(list[idx])) { - idx -= 1; + var dropWhile = _curry2(_dispatchable('dropWhile', _xdropWhile, function dropWhile(pred, list) { + var idx = 0; + var len = list.length; + while (idx < len && pred(list[idx])) { + idx += 1; } - return _slice(list, 0, idx + 1); - }); + return _slice(list, idx); + })); /** - * A function wrapping calls to the two functions in an `||` operation, returning the result of the first - * function if it is truth-y and the result of the second function otherwise. Note that this is - * short-circuited, meaning that the second function will not be invoked if the first returns a truth-y - * value. + * A function wrapping calls to the two functions in an `||` operation, + * returning the result of the first function if it is truth-y and the result + * of the second function otherwise. Note that this is short-circuited, + * meaning that the second function will not be invoked if the first returns a + * truth-y value. * * @func * @memberOf R + * @since v0.12.0 * @category Logic * @sig (*... -> Boolean) -> (*... -> Boolean) -> (*... -> Boolean) * @param {Function} f a predicate @@ -9628,8 +8457,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @see R.or * @example * - * var gt10 = function(x) { return x > 10; }; - * var even = function(x) { return x % 2 === 0 }; + * var gt10 = x => x > 10; + * var even = x => x % 2 === 0; * var f = R.either(gt10, even); * f(101); //=> true * f(8); //=> true @@ -9642,11 +8471,15 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /** * Returns the empty value of its argument's type. Ramda defines the empty - * value of Array (`[]`), Object (`{}`), and String (`''`). Other types are - * supported if they define `.empty` and/or `.prototype.empty`. + * value of Array (`[]`), Object (`{}`), String (`''`), and Arguments. Other + * types are supported if they define `.empty` and/or + * `.prototype.empty`. + * + * Dispatches to the `empty` method of the first argument, if present. * * @func * @memberOf R + * @since v0.3.0 * @category Function * @sig a -> a * @param {*} x @@ -9658,32 +8491,25 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * R.empty('unicorns'); //=> '' * R.empty({x: 1, y: 2}); //=> {} */ + // else var empty = _curry1(function empty(x) { - if (x != null && typeof x.empty === 'function') { - return x.empty(); - } else if (x != null && typeof x.constructor != null && typeof x.constructor.empty === 'function') { - return x.constructor.empty(); - } else { - switch (Object.prototype.toString.call(x)) { - case '[object Array]': - return []; - case '[object Object]': - return {}; - case '[object String]': - return ''; - } - } + return x != null && typeof x.empty === 'function' ? x.empty() : x != null && x.constructor != null && typeof x.constructor.empty === 'function' ? x.constructor.empty() : _isArray(x) ? [] : _isString(x) ? '' : _isObject(x) ? {} : _isArguments(x) ? function () { + return arguments; + }() : // else + void 0; }); /** - * Creates a new object by recursively evolving a shallow copy of `object`, according to the - * `transformation` functions. All non-primitive properties are copied by reference. + * Creates a new object by recursively evolving a shallow copy of `object`, + * according to the `transformation` functions. All non-primitive properties + * are copied by reference. * - * A `tranformation` function will not be invoked if its corresponding key does not exist in - * the evolved object. + * A `transformation` function will not be invoked if its corresponding key + * does not exist in the evolved object. * * @func * @memberOf R + * @since v0.9.0 * @category Object * @sig {k: (v -> v)} -> {k: v} -> {k: v} * @param {Object} transformations The object specifying transformation functions to apply @@ -9701,7 +8527,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * R.evolve(transformations, tomato); //=> {firstName: 'Tomato', data: {elapsed: 101, remaining: 1399}, id:123} */ var evolve = _curry2(function evolve(transformations, object) { - var transformation, key, type, result = {}; + var result = {}; + var transformation, key, type; for (key in object) { transformation = transformations[key]; type = typeof transformation; @@ -9710,22 +8537,208 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return result; }); + /** + * Returns the first element of the list which matches the predicate, or + * `undefined` if no element matches. + * + * Dispatches to the `find` method of the second argument, if present. + * + * Acts as a transducer if a transformer is given in list position. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category List + * @sig (a -> Boolean) -> [a] -> a | undefined + * @param {Function} fn The predicate function used to determine if the element is the + * desired one. + * @param {Array} list The array to consider. + * @return {Object} The element found, or `undefined`. + * @see R.transduce + * @example + * + * var xs = [{a: 1}, {a: 2}, {a: 3}]; + * R.find(R.propEq('a', 2))(xs); //=> {a: 2} + * R.find(R.propEq('a', 4))(xs); //=> undefined + */ + var find = _curry2(_dispatchable('find', _xfind, function find(fn, list) { + var idx = 0; + var len = list.length; + while (idx < len) { + if (fn(list[idx])) { + return list[idx]; + } + idx += 1; + } + })); + + /** + * Returns the index of the first element of the list which matches the + * predicate, or `-1` if no element matches. + * + * Dispatches to the `findIndex` method of the second argument, if present. + * + * Acts as a transducer if a transformer is given in list position. + * + * @func + * @memberOf R + * @since v0.1.1 + * @category List + * @sig (a -> Boolean) -> [a] -> Number + * @param {Function} fn The predicate function used to determine if the element is the + * desired one. + * @param {Array} list The array to consider. + * @return {Number} The index of the element found, or `-1`. + * @see R.transduce + * @example + * + * var xs = [{a: 1}, {a: 2}, {a: 3}]; + * R.findIndex(R.propEq('a', 2))(xs); //=> 1 + * R.findIndex(R.propEq('a', 4))(xs); //=> -1 + */ + var findIndex = _curry2(_dispatchable('findIndex', _xfindIndex, function findIndex(fn, list) { + var idx = 0; + var len = list.length; + while (idx < len) { + if (fn(list[idx])) { + return idx; + } + idx += 1; + } + return -1; + })); + + /** + * Returns the last element of the list which matches the predicate, or + * `undefined` if no element matches. + * + * Dispatches to the `findLast` method of the second argument, if present. + * + * Acts as a transducer if a transformer is given in list position. + * + * @func + * @memberOf R + * @since v0.1.1 + * @category List + * @sig (a -> Boolean) -> [a] -> a | undefined + * @param {Function} fn The predicate function used to determine if the element is the + * desired one. + * @param {Array} list The array to consider. + * @return {Object} The element found, or `undefined`. + * @see R.transduce + * @example + * + * var xs = [{a: 1, b: 0}, {a:1, b: 1}]; + * R.findLast(R.propEq('a', 1))(xs); //=> {a: 1, b: 1} + * R.findLast(R.propEq('a', 4))(xs); //=> undefined + */ + var findLast = _curry2(_dispatchable('findLast', _xfindLast, function findLast(fn, list) { + var idx = list.length - 1; + while (idx >= 0) { + if (fn(list[idx])) { + return list[idx]; + } + idx -= 1; + } + })); + + /** + * Returns the index of the last element of the list which matches the + * predicate, or `-1` if no element matches. + * + * Dispatches to the `findLastIndex` method of the second argument, if present. + * + * Acts as a transducer if a transformer is given in list position. + * + * @func + * @memberOf R + * @since v0.1.1 + * @category List + * @sig (a -> Boolean) -> [a] -> Number + * @param {Function} fn The predicate function used to determine if the element is the + * desired one. + * @param {Array} list The array to consider. + * @return {Number} The index of the element found, or `-1`. + * @see R.transduce + * @example + * + * var xs = [{a: 1, b: 0}, {a:1, b: 1}]; + * R.findLastIndex(R.propEq('a', 1))(xs); //=> 1 + * R.findLastIndex(R.propEq('a', 4))(xs); //=> -1 + */ + var findLastIndex = _curry2(_dispatchable('findLastIndex', _xfindLastIndex, function findLastIndex(fn, list) { + var idx = list.length - 1; + while (idx >= 0) { + if (fn(list[idx])) { + return idx; + } + idx -= 1; + } + return -1; + })); + + /** + * Iterate over an input `list`, calling a provided function `fn` for each + * element in the list. + * + * `fn` receives one argument: *(value)*. + * + * Note: `R.forEach` does not skip deleted or unassigned indices (sparse + * arrays), unlike the native `Array.prototype.forEach` method. For more + * details on this behavior, see: + * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach#Description + * + * Also note that, unlike `Array.prototype.forEach`, Ramda's `forEach` returns + * the original array. In some libraries this function is named `each`. + * + * Dispatches to the `forEach` method of the second argument, if present. + * + * @func + * @memberOf R + * @since v0.1.1 + * @category List + * @sig (a -> *) -> [a] -> [a] + * @param {Function} fn The function to invoke. Receives one argument, `value`. + * @param {Array} list The list to iterate over. + * @return {Array} The original list. + * @see R.addIndex + * @example + * + * var printXPlusFive = x => console.log(x + 5); + * R.forEach(printXPlusFive, [1, 2, 3]); //=> [1, 2, 3] + * //-> 6 + * //-> 7 + * //-> 8 + */ + var forEach = _curry2(_checkForMethod('forEach', function forEach(fn, list) { + var len = list.length; + var idx = 0; + while (idx < len) { + fn(list[idx]); + idx += 1; + } + return list; + })); + /** * Creates a new object out of a list key-value pairs. * * @func * @memberOf R + * @since v0.3.0 * @category List * @sig [[k,v]] -> {k: v} * @param {Array} pairs An array of two-element arrays that will be the keys and values of the output object. * @return {Object} The object made by pairing up `keys` and `values`. - * @see R.toPairs + * @see R.toPairs, R.pair * @example * * R.fromPairs([['a', 1], ['b', 2], ['c', 3]]); //=> {a: 1, b: 2, c: 3} */ var fromPairs = _curry1(function fromPairs(pairs) { - var idx = 0, len = pairs.length, out = {}; + var idx = 0; + var len = pairs.length; + var out = {}; while (idx < len) { if (_isArray(pairs[idx]) && pairs[idx].length) { out[pairs[idx][0]] = pairs[idx][1]; @@ -9736,11 +8749,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns `true` if the first argument is greater than the second; - * `false` otherwise. + * Returns `true` if the first argument is greater than the second; `false` + * otherwise. * * @func * @memberOf R + * @since v0.1.0 * @category Relation * @sig Ord a => a -> a -> Boolean * @param {*} a @@ -9765,6 +8779,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category Relation * @sig Ord a => a -> a -> Boolean * @param {Number} a @@ -9784,11 +8799,11 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns whether or not an object has an own property with - * the specified name + * Returns whether or not an object has an own property with the specified name * * @func * @memberOf R + * @since v0.7.0 * @category Object * @sig s -> {s: x} -> Boolean * @param {String} prop The name of the property to check for. @@ -9810,11 +8825,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var has = _curry2(_has); /** - * Returns whether or not an object or its prototype chain has - * a property with the specified name + * Returns whether or not an object or its prototype chain has a property with + * the specified name * * @func * @memberOf R + * @since v0.7.0 * @category Object * @sig s -> {s: x} -> Boolean * @param {String} prop The name of the property to check for. @@ -9845,6 +8861,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.15.0 * @category Relation * @sig a -> a -> Boolean * @param {*} a @@ -9877,11 +8894,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * A function that does nothing but return the parameter supplied to it. Good as a default - * or placeholder function. + * A function that does nothing but return the parameter supplied to it. Good + * as a default or placeholder function. * * @func * @memberOf R + * @since v0.1.0 * @category Function * @sig a -> a * @param {*} x The value to return. @@ -9896,11 +8914,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var identity = _curry1(_identity); /** - * Creates a function that will process either the `onTrue` or the `onFalse` function depending - * upon the result of the `condition` predicate. + * Creates a function that will process either the `onTrue` or the `onFalse` + * function depending upon the result of the `condition` predicate. * * @func * @memberOf R + * @since v0.8.0 * @category Logic * @sig (*... -> Boolean) -> (*... -> *) -> (*... -> *) -> (*... -> *) * @param {Function} condition A predicate function @@ -9908,13 +8927,16 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @param {Function} onFalse A function to invoke when the `condition` evaluates to a falsy value. * @return {Function} A new unary function that will process either the `onTrue` or the `onFalse` * function depending upon the result of the `condition` predicate. + * @see R.unless, R.when * @example * - * // Flatten all arrays in the list but leave other values alone. - * var flattenArrays = R.map(R.ifElse(Array.isArray, R.flatten, R.identity)); - * - * flattenArrays([[0], [[10], [8]], 1234, {}]); //=> [[0], [10, 8], 1234, {}] - * flattenArrays([[[10], 123], [8, [10]], "hello"]); //=> [[10, 123], [8, 10], "hello"] + * var incCount = R.ifElse( + * R.has('count'), + * R.over(R.lensProp('count'), R.inc), + * R.assoc('count', 1) + * ); + * incCount({}); //=> { count: 1 } + * incCount({ count: 1 }); //=> { count: 2 } */ var ifElse = _curry3(function ifElse(condition, onTrue, onFalse) { return curryN(Math.max(condition.length, onTrue.length, onFalse.length), function _ifElse() { @@ -9927,6 +8949,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.9.0 * @category Math * @sig Number -> Number * @param {Number} n @@ -9939,12 +8962,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var inc = add(1); /** - * Inserts the supplied element into the list, at index `index`. _Note - * that this is not destructive_: it returns a copy of the list with the changes. + * Inserts the supplied element into the list, at index `index`. _Note that + * this is not destructive_: it returns a copy of the list with the changes. * No lists have been harmed in the application of this function. * * @func * @memberOf R + * @since v0.2.2 * @category List * @sig Number -> a -> [a] -> [a] * @param {Number} index The position to insert the element @@ -9963,12 +8987,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Inserts the sub-list into the list, at index `index`. _Note that this - * is not destructive_: it returns a copy of the list with the changes. + * Inserts the sub-list into the list, at index `index`. _Note that this is not + * destructive_: it returns a copy of the list with the changes. * No lists have been harmed in the application of this function. * * @func * @memberOf R + * @since v0.9.0 * @category List * @sig Number -> [a] -> [a] -> [a] * @param {Number} index The position to insert the sub-list @@ -9985,11 +9010,44 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * See if an object (`val`) is an instance of the supplied constructor. - * This function will check up the inheritance chain, if any. + * Creates a new list with the separator interposed between elements. + * + * Dispatches to the `intersperse` method of the second argument, if present. + * + * @func + * @memberOf R + * @since v0.14.0 + * @category List + * @sig a -> [a] -> [a] + * @param {*} separator The element to add to the list. + * @param {Array} list The list to be interposed. + * @return {Array} The new list. + * @example + * + * R.intersperse('n', ['ba', 'a', 'a']); //=> ['ba', 'n', 'a', 'n', 'a'] + */ + var intersperse = _curry2(_checkForMethod('intersperse', function intersperse(separator, list) { + var out = []; + var idx = 0; + var length = list.length; + while (idx < length) { + if (idx === length - 1) { + out.push(list[idx]); + } else { + out.push(list[idx], separator); + } + idx += 1; + } + return out; + })); + + /** + * See if an object (`val`) is an instance of the supplied constructor. This + * function will check up the inheritance chain, if any. * * @func * @memberOf R + * @since v0.3.0 * @category Type * @sig (* -> {*}) -> a -> Boolean * @param {Object} ctor A constructor @@ -10015,6 +9073,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.5.0 * @category Type * @category List * @sig * -> Boolean @@ -10053,34 +9112,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return false; }); - /** - * Reports whether the list has zero elements. - * - * @func - * @memberOf R - * @category Logic - * @sig [a] -> Boolean - * @param {Array} list - * @return {Boolean} - * @example - * - * R.isEmpty([1, 2, 3]); //=> false - * R.isEmpty([]); //=> true - * R.isEmpty(''); //=> true - * R.isEmpty(null); //=> false - * R.isEmpty(R.keys({})); //=> true - * R.isEmpty({}); //=> false ({} does not have a length property) - * R.isEmpty({length: 0}); //=> true - */ - var isEmpty = _curry1(function isEmpty(list) { - return Object(list).length === 0; - }); - /** * Checks if the input value is `null` or `undefined`. * * @func * @memberOf R + * @since v0.9.0 * @category Type * @sig * -> Boolean * @param {*} x The value to test. @@ -10097,13 +9134,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a list containing the names of all the enumerable own - * properties of the supplied object. - * Note that the order of the output array is not guaranteed to be - * consistent across different JS platforms. + * Returns a list containing the names of all the enumerable own properties of + * the supplied object. + * Note that the order of the output array is not guaranteed to be consistent + * across different JS platforms. * * @func * @memberOf R + * @since v0.1.0 * @category Object * @sig {k: v} -> [k] * @param {Object} obj The object to extract properties from @@ -10113,6 +9151,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * R.keys({a: 1, b: 2, c: 3}); //=> ['a', 'b', 'c'] */ // cover IE < 9 keys issues + // Safari bug var keys = function () { // cover IE < 9 keys issues var hasEnumBug = !{ toString: null }.propertyIsEnumerable('toString'); @@ -10125,6 +9164,11 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack 'hasOwnProperty', 'toLocaleString' ]; + // Safari bug + var hasArgsEnumBug = function () { + 'use strict'; + return arguments.propertyIsEnumerable('length'); + }(); var contains = function contains(list, item) { var idx = 0; while (idx < list.length) { @@ -10135,15 +9179,17 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack } return false; }; - return typeof Object.keys === 'function' ? _curry1(function keys(obj) { + return typeof Object.keys === 'function' && !hasArgsEnumBug ? _curry1(function keys(obj) { return Object(obj) !== obj ? [] : Object.keys(obj); }) : _curry1(function keys(obj) { if (Object(obj) !== obj) { return []; } - var prop, ks = [], nIdx; + var prop, nIdx; + var ks = []; + var checkArgsLength = hasArgsEnumBug && _isArguments(obj); for (prop in obj) { - if (_has(prop, obj)) { + if (_has(prop, obj) && (!checkArgsLength || prop !== 'length')) { ks[ks.length] = prop; } } @@ -10162,13 +9208,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }(); /** - * Returns a list containing the names of all the - * properties of the supplied object, including prototype properties. - * Note that the order of the output array is not guaranteed to be - * consistent across different JS platforms. + * Returns a list containing the names of all the properties of the supplied + * object, including prototype properties. + * Note that the order of the output array is not guaranteed to be consistent + * across different JS platforms. * * @func * @memberOf R + * @since v0.2.0 * @category Object * @sig {k: v} -> [k] * @param {Object} obj The object to extract properties from @@ -10181,7 +9228,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * R.keysIn(f); //=> ['x', 'y'] */ var keysIn = _curry1(function keysIn(obj) { - var prop, ks = []; + var prop; + var ks = []; for (prop in obj) { ks[ks.length] = prop; } @@ -10193,6 +9241,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.3.0 * @category List * @sig [a] -> Number * @param {Array} list The array to inspect. @@ -10207,11 +9256,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns `true` if the first argument is less than the second; - * `false` otherwise. + * Returns `true` if the first argument is less than the second; `false` + * otherwise. * * @func * @memberOf R + * @since v0.1.0 * @category Relation * @sig Ord a => a -> a -> Boolean * @param {*} a @@ -10236,6 +9286,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category Relation * @sig Ord a => a -> a -> Boolean * @param {Number} a @@ -10255,32 +9306,36 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * The mapAccum function behaves like a combination of map and reduce; it applies a - * function to each element of a list, passing an accumulating parameter from left to - * right, and returning a final value of this accumulator together with the new list. + * The mapAccum function behaves like a combination of map and reduce; it + * applies a function to each element of a list, passing an accumulating + * parameter from left to right, and returning a final value of this + * accumulator together with the new list. * - * The iterator function receives two arguments, *acc* and *value*, and should return - * a tuple *[acc, value]*. + * The iterator function receives two arguments, *acc* and *value*, and should + * return a tuple *[acc, value]*. * * @func * @memberOf R + * @since v0.10.0 * @category List * @sig (acc -> x -> (acc, y)) -> acc -> [x] -> (acc, [y]) * @param {Function} fn The function to be called on every element of the input `list`. * @param {*} acc The accumulator value. * @param {Array} list The list to iterate over. * @return {*} The final, accumulated value. + * @see R.addIndex * @example * * var digits = ['1', '2', '3', '4']; - * var append = function(a, b) { - * return [a + b, a + b]; - * } + * var append = (a, b) => [a + b, a + b]; * * R.mapAccum(append, 0, digits); //=> ['01234', ['01', '012', '0123', '01234']] */ var mapAccum = _curry3(function mapAccum(fn, acc, list) { - var idx = 0, len = list.length, result = [], tuple = [acc]; + var idx = 0; + var len = list.length; + var result = []; + var tuple = [acc]; while (idx < len) { tuple = fn(tuple[0], list[idx]); result[idx] = tuple[1]; @@ -10293,35 +9348,38 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * The mapAccumRight function behaves like a combination of map and reduce; it applies a - * function to each element of a list, passing an accumulating parameter from right - * to left, and returning a final value of this accumulator together with the new list. + * The mapAccumRight function behaves like a combination of map and reduce; it + * applies a function to each element of a list, passing an accumulating + * parameter from right to left, and returning a final value of this + * accumulator together with the new list. * - * Similar to `mapAccum`, except moves through the input list from the right to the - * left. + * Similar to `mapAccum`, except moves through the input list from the right to + * the left. * - * The iterator function receives two arguments, *acc* and *value*, and should return - * a tuple *[acc, value]*. + * The iterator function receives two arguments, *acc* and *value*, and should + * return a tuple *[acc, value]*. * * @func * @memberOf R + * @since v0.10.0 * @category List * @sig (acc -> x -> (acc, y)) -> acc -> [x] -> (acc, [y]) * @param {Function} fn The function to be called on every element of the input `list`. * @param {*} acc The accumulator value. * @param {Array} list The list to iterate over. * @return {*} The final, accumulated value. + * @see R.addIndex * @example * * var digits = ['1', '2', '3', '4']; - * var append = function(a, b) { - * return [a + b, a + b]; - * } + * var append = (a, b) => [a + b, a + b]; * * R.mapAccumRight(append, 0, digits); //=> ['04321', ['04321', '0432', '043', '04']] */ var mapAccumRight = _curry3(function mapAccumRight(fn, acc, list) { - var idx = list.length - 1, result = [], tuple = [acc]; + var idx = list.length - 1; + var result = []; + var tuple = [acc]; while (idx >= 0) { tuple = fn(tuple[0], list[idx]); result[idx] = tuple[1]; @@ -10334,19 +9392,20 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Tests a regular expression against a String. Note that this function - * will return an empty array when there are no matches. This differs - * from [`String.prototype.match`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/match) + * Tests a regular expression against a String. Note that this function will + * return an empty array when there are no matches. This differs from + * [`String.prototype.match`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/match) * which returns `null` when there are no matches. * * @func * @memberOf R - * @see R.test + * @since v0.1.0 * @category String * @sig RegExp -> String -> [String | Undefined] * @param {RegExp} rx A regular expression. * @param {String} str The string to match against * @return {Array} The list of matches or empty array. + * @see R.test * @example * * R.match(/([a-z]a)/g, 'bananas'); //=> ['ba', 'na', 'na'] @@ -10358,13 +9417,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * mathMod behaves like the modulo operator should mathematically, unlike the `%` - * operator (and by extension, R.modulo). So while "-17 % 5" is -2, + * mathMod behaves like the modulo operator should mathematically, unlike the + * `%` operator (and by extension, R.modulo). So while "-17 % 5" is -2, * mathMod(-17, 5) is 3. mathMod requires Integer arguments, and returns NaN * when the modulus is zero or negative. * * @func * @memberOf R + * @since v0.3.0 * @category Math * @sig Number -> Number -> Number * @param {Number} m The dividend. @@ -10403,6 +9463,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category Relation * @sig Ord a => a -> a -> a * @param {*} a @@ -10419,11 +9480,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Takes a function and two values, and returns whichever value produces - * the larger result when passed to the provided function. + * Takes a function and two values, and returns whichever value produces the + * larger result when passed to the provided function. * * @func * @memberOf R + * @since v0.8.0 * @category Relation * @sig Ord b => (a -> b) -> a -> a -> a * @param {Function} f @@ -10433,44 +9495,57 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @see R.max, R.minBy * @example * - * R.maxBy(function(n) { return n * n; }, -3, 2); //=> -3 + * // square :: Number -> Number + * var square = n => n * n; + * + * R.maxBy(square, -3, 2); //=> -3 + * + * R.reduce(R.maxBy(square), 0, [3, -5, 4, 1, -2]); //=> -5 + * R.reduce(R.maxBy(square), 0, []); //=> 0 */ var maxBy = _curry3(function maxBy(f, a, b) { return f(b) > f(a) ? b : a; }); /** - * Create a new object with the own properties of `a` - * merged with the own properties of object `b`. - * - * @func - * @memberOf R + * Creates a new object with the own properties of the two provided objects. If + * a key exists in both objects, the provided function is applied to the key + * and the values associated with the key in each object, with the result being + * used as the value associated with the key in the returned object. The key + * will be excluded from the returned object if the resulting value is + * `undefined`. + * + * @func + * @memberOf R + * @since 0.19.1 + * @since 0.19.0 * @category Object - * @sig {k: v} -> {k: v} -> {k: v} - * @param {Object} a - * @param {Object} b + * @sig (String -> a -> a -> a) -> {a} -> {a} -> {a} + * @param {Function} fn + * @param {Object} l + * @param {Object} r * @return {Object} + * @see R.merge, R.mergeWith * @example * - * R.merge({ 'name': 'fred', 'age': 10 }, { 'age': 40 }); - * //=> { 'name': 'fred', 'age': 40 } - * - * var resetToDefault = R.merge(R.__, {x: 0}); - * resetToDefault({x: 5, y: 2}); //=> {x: 0, y: 2} + * let concatValues = (k, l, r) => k == 'values' ? R.concat(l, r) : r + * R.mergeWithKey(concatValues, + * { a: true, thing: 'foo', values: [10, 20] }, + * { b: true, thing: 'bar', values: [15, 35] }); + * //=> { a: true, b: true, thing: 'bar', values: [10, 20, 15, 35] } */ - var merge = _curry2(function merge(a, b) { + var mergeWithKey = _curry3(function mergeWithKey(fn, l, r) { var result = {}; - var ks = keys(a); - var idx = 0; - while (idx < ks.length) { - result[ks[idx]] = a[ks[idx]]; - idx += 1; + var k; + for (k in l) { + if (_has(k, l)) { + result[k] = _has(k, r) ? fn(k, l[k], r[k]) : l[k]; + } } - ks = keys(b); - idx = 0; - while (idx < ks.length) { - result[ks[idx]] = b[ks[idx]]; - idx += 1; + for (k in r) { + if (_has(k, r) && !_has(k, result)) { + result[k] = r[k]; + } } return result; }); @@ -10480,6 +9555,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category Relation * @sig Ord a => a -> a -> a * @param {*} a @@ -10496,11 +9572,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Takes a function and two values, and returns whichever value produces - * the smaller result when passed to the provided function. + * Takes a function and two values, and returns whichever value produces the + * smaller result when passed to the provided function. * * @func * @memberOf R + * @since v0.8.0 * @category Relation * @sig Ord b => (a -> b) -> a -> a -> a * @param {Function} f @@ -10510,19 +9587,26 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @see R.min, R.maxBy * @example * - * R.minBy(function(n) { return n * n; }, -3, 2); //=> 2 + * // square :: Number -> Number + * var square = n => n * n; + * + * R.minBy(square, -3, 2); //=> 2 + * + * R.reduce(R.minBy(square), Infinity, [3, -5, 4, 1, -2]); //=> 1 + * R.reduce(R.minBy(square), Infinity, []); //=> Infinity */ var minBy = _curry3(function minBy(f, a, b) { return f(b) < f(a) ? b : a; }); /** - * Divides the second parameter by the first and returns the remainder. - * Note that this functions preserves the JavaScript-style behavior for - * modulo. For mathematical modulo see `mathMod` + * Divides the second parameter by the first and returns the remainder. Note + * that this function preserves the JavaScript-style behavior for modulo. For + * mathematical modulo see `mathMod`. * * @func * @memberOf R + * @since v0.1.1 * @category Math * @sig Number -> Number -> Number * @param {Number} a The value to the divide. @@ -10549,6 +9633,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category Math * @sig Number -> Number -> Number * @param {Number} a The first value. @@ -10568,11 +9653,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Wraps a function of any arity (including nullary) in a function that accepts exactly `n` - * parameters. Any extraneous parameters will not be passed to the supplied function. + * Wraps a function of any arity (including nullary) in a function that accepts + * exactly `n` parameters. Any extraneous parameters will not be passed to the + * supplied function. * * @func * @memberOf R + * @since v0.1.0 * @category Function * @sig Number -> (* -> a) -> (* -> a) * @param {Number} n The desired arity of the new function. @@ -10581,9 +9668,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * arity `n`. * @example * - * var takesTwoArgs = function(a, b) { - * return [a, b]; - * }; + * var takesTwoArgs = (a, b) => [a, b]; + * * takesTwoArgs.length; //=> 2 * takesTwoArgs(1, 2); //=> [1, 2] * @@ -10648,6 +9734,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.9.0 * @category Math * @sig Number -> Number * @param {Number} n @@ -10660,12 +9747,37 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return -n; }); + /** + * Returns `true` if no elements of the list match the predicate, `false` + * otherwise. + * + * Dispatches to the `any` method of the second argument, if present. + * + * @func + * @memberOf R + * @since v0.12.0 + * @category List + * @sig (a -> Boolean) -> [a] -> Boolean + * @param {Function} fn The predicate function. + * @param {Array} list The array to consider. + * @return {Boolean} `true` if the predicate is not satisfied by every element, `false` otherwise. + * @see R.all, R.any + * @example + * + * var isEven = n => n % 2 === 0; + * + * R.none(isEven, [1, 3, 5, 7, 9, 11]); //=> true + * R.none(isEven, [1, 3, 5, 7, 8, 11]); //=> false + */ + var none = _curry2(_complement(_dispatchable('any', _xany, any))); + /** * A function that returns the `!` of its argument. It will return `true` when * passed false-y value, and `false` when passed a truth-y one. * * @func * @memberOf R + * @since v0.1.0 * @category Logic * @sig * -> Boolean * @param {*} a any value @@ -10683,11 +9795,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns the nth element of the given list or string. - * If n is negative the element at index length + n is returned. + * Returns the nth element of the given list or string. If n is negative the + * element at index length + n is returned. * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig Number -> [a] -> a | Undefined * @sig Number -> String -> String @@ -10714,6 +9827,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.9.0 * @category Function * @sig Number -> *... -> * * @param {Number} n @@ -10730,43 +9844,29 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns the nth character of the given string. - * - * @func - * @memberOf R - * @category String - * @sig Number -> String -> String - * @param {Number} n - * @param {String} str - * @return {String} - * @deprecated since v0.16.0 - * @example - * - * R.nthChar(2, 'Ramda'); //=> 'm' - * R.nthChar(-2, 'Ramda'); //=> 'd' - */ - var nthChar = _curry2(function nthChar(n, str) { - return str.charAt(n < 0 ? str.length + n : n); - }); - - /** - * Returns the character code of the nth character of the given string. + * Creates an object containing a single key:value pair. * * @func * @memberOf R - * @category String - * @sig Number -> String -> Number - * @param {Number} n - * @param {String} str - * @return {Number} - * @deprecated since v0.16.0 + * @since v0.18.0 + * @category Object + * @sig String -> a -> {String:a} + * @param {String} key + * @param {*} val + * @return {Object} + * @see R.pair * @example * - * R.nthCharCode(2, 'Ramda'); //=> 'm'.charCodeAt(0) - * R.nthCharCode(-2, 'Ramda'); //=> 'd'.charCodeAt(0) + * var matchPhrases = R.compose( + * R.objOf('must'), + * R.map(R.objOf('match_phrase')) + * ); + * matchPhrases(['foo', 'bar', 'baz']); //=> {must: [{match_phrase: 'foo'}, {match_phrase: 'bar'}, {match_phrase: 'baz'}]} */ - var nthCharCode = _curry2(function nthCharCode(n, str) { - return str.charCodeAt(n < 0 ? str.length + n : n); + var objOf = _curry2(function objOf(key, val) { + var obj = {}; + obj[key] = val; + return obj; }); /** @@ -10777,6 +9877,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.3.0 * @category Function * @sig a -> [a] * @param {*} x any value @@ -10786,47 +9887,74 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * R.of(null); //=> [null] * R.of([42]); //=> [[42]] */ - var of = _curry1(function of(x) { - return [x]; - }); + var of = _curry1(_of); /** - * Accepts a function `fn` and returns a function that guards invocation of `fn` such that - * `fn` can only ever be called once, no matter how many times the returned function is - * invoked. + * Accepts a function `fn` and returns a function that guards invocation of + * `fn` such that `fn` can only ever be called once, no matter how many times + * the returned function is invoked. The first value calculated is returned in + * subsequent invocations. * * @func * @memberOf R + * @since v0.1.0 * @category Function * @sig (a... -> b) -> (a... -> b) * @param {Function} fn The function to wrap in a call-only-once wrapper. * @return {Function} The wrapped function. * @example * - * var addOneOnce = R.once(function(x){ return x + 1; }); + * var addOneOnce = R.once(x => x + 1); * addOneOnce(10); //=> 11 * addOneOnce(addOneOnce(50)); //=> 11 */ var once = _curry1(function once(fn) { - var called = false, result; - return function () { + var called = false; + var result; + return _arity(fn.length, function () { if (called) { return result; } called = true; result = fn.apply(this, arguments); return result; - }; + }); + }); + + /** + * Returns `true` if one or both of its arguments are `true`. Returns `false` + * if both arguments are `false`. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category Logic + * @sig * -> * -> * + * @param {Boolean} a A boolean value + * @param {Boolean} b A boolean value + * @return {Boolean} `true` if one or both arguments are `true`, `false` otherwise + * @see R.either + * @example + * + * R.or(true, true); //=> true + * R.or(true, false); //=> true + * R.or(false, true); //=> true + * R.or(false, false); //=> false + */ + var or = _curry2(function or(a, b) { + return a || b; }); /** * Returns the result of "setting" the portion of the given data structure - * focused by the given lens to the given value. + * focused by the given lens to the result of applying the given function to + * the focused value. * * @func * @memberOf R + * @since v0.16.0 * @category Object - * @typedef Lens s a = Functor f => (a -> f a) -> s -> f s + * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s * @sig Lens s a -> (a -> a) -> s -> s * @param {Lens} lens * @param {*} v @@ -10855,14 +9983,39 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); }(); + /** + * Takes two arguments, `fst` and `snd`, and returns `[fst, snd]`. + * + * @func + * @memberOf R + * @since v0.18.0 + * @category List + * @sig a -> b -> (a,b) + * @param {*} fst + * @param {*} snd + * @return {Array} + * @see R.createMapEntry, R.of + * @example + * + * R.pair('foo', 'bar'); //=> ['foo', 'bar'] + */ + var pair = _curry2(function pair(fst, snd) { + return [ + fst, + snd + ]; + }); + /** * Retrieve the value at a given path. * * @func * @memberOf R + * @since v0.2.0 * @category Object * @sig [String] -> {k: v} -> v | Undefined * @param {Array} path The path to use. + * @param {Object} obj The object to retrieve the nested property from. * @return {*} The data at `path`. * @example * @@ -10870,29 +10023,76 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * R.path(['a', 'b'], {c: {b: 2}}); //=> undefined */ var path = _curry2(function path(paths, obj) { - if (obj == null) { - return; - } else { - var val = obj; - for (var idx = 0, len = paths.length; idx < len && val != null; idx += 1) { - val = val[paths[idx]]; + var val = obj; + var idx = 0; + while (idx < paths.length) { + if (val == null) { + return; } - return val; + val = val[paths[idx]]; + idx += 1; } + return val; }); /** - * Returns a partial copy of an object containing only the keys specified. If the key does not exist, the - * property is ignored. + * If the given, non-null object has a value at the given path, returns the + * value at that path. Otherwise returns the provided default value. + * + * @func + * @memberOf R + * @since v0.18.0 + * @category Object + * @sig a -> [String] -> Object -> a + * @param {*} d The default value. + * @param {Array} p The path to use. + * @param {Object} obj The object to retrieve the nested property from. + * @return {*} The data at `path` of the supplied object or the default value. + * @example + * + * R.pathOr('N/A', ['a', 'b'], {a: {b: 2}}); //=> 2 + * R.pathOr('N/A', ['a', 'b'], {c: {b: 2}}); //=> "N/A" + */ + var pathOr = _curry3(function pathOr(d, p, obj) { + return defaultTo(d, path(p, obj)); + }); + + /** + * Returns `true` if the specified object property at given path satisfies the + * given predicate; `false` otherwise. + * + * @func + * @memberOf R + * @since 0.19.1 + * @since 0.19.0 + * @category Logic + * @sig (a -> Boolean) -> [String] -> Object -> Boolean + * @param {Function} pred + * @param {Array} propPath + * @param {*} obj + * @return {Boolean} + * @see R.propSatisfies, R.path + * @example + * + * R.pathSatisfies(y => y > 0, ['x', 'y'], {x: {y: 2}}); //=> true + */ + var pathSatisfies = _curry3(function pathSatisfies(pred, propPath, obj) { + return propPath.length > 0 && pred(path(propPath, obj)); + }); + + /** + * Returns a partial copy of an object containing only the keys specified. If + * the key does not exist, the property is ignored. * * @func * @memberOf R + * @since v0.1.0 * @category Object * @sig [k] -> {k: v} -> {k: v} * @param {Array} names an array of String property names to copy onto a new object * @param {Object} obj The object to copy from * @return {Object} A new object with only properties from `names` on it. - * @see R.omit + * @see R.omit, R.props * @example * * R.pick(['a', 'd'], {a: 1, b: 2, c: 3, d: 4}); //=> {a: 1, d: 4} @@ -10911,10 +10111,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Similar to `pick` except that this one includes a `key: undefined` pair for properties that don't exist. + * Similar to `pick` except that this one includes a `key: undefined` pair for + * properties that don't exist. * * @func * @memberOf R + * @since v0.1.0 * @category Object * @sig [k] -> {k: v} -> {k: v} * @param {Array} names an array of String property names to copy onto a new object @@ -10939,11 +10141,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a partial copy of an object containing only the keys that - * satisfy the supplied predicate. + * Returns a partial copy of an object containing only the keys that satisfy + * the supplied predicate. * * @func * @memberOf R + * @since v0.8.0 * @category Object * @sig (v, k -> Boolean) -> {k: v} -> {k: v} * @param {Function} pred A predicate to determine whether or not a key @@ -10951,10 +10154,10 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @param {Object} obj The object to copy from * @return {Object} A new object with only properties that satisfy `pred` * on it. - * @see R.pick + * @see R.pick, R.filter * @example * - * var isUpperCase = function(val, key) { return key.toUpperCase() === key; } + * var isUpperCase = (val, key) => key.toUpperCase() === key; * R.pickBy(isUpperCase, {a: 1, b: 2, A: 3, B: 4}); //=> {A: 3, B: 4} */ var pickBy = _curry2(function pickBy(test, obj) { @@ -10968,11 +10171,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a new list with the given element at the front, followed by the contents of the - * list. + * Returns a new list with the given element at the front, followed by the + * contents of the list. * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig a -> [a] -> [a] * @param {*} el The item to add to the head of the output list. @@ -10988,10 +10192,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a function that when supplied an object returns the indicated property of that object, if it exists. + * Returns a function that when supplied an object returns the indicated + * property of that object, if it exists. * * @func * @memberOf R + * @since v0.1.0 * @category Object * @sig s -> {s: a} -> a | Undefined * @param {String} p The property name @@ -11008,11 +10214,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /** * If the given, non-null object has an own property with the specified name, - * returns the value of that property. - * Otherwise returns the provided default value. + * returns the value of that property. Otherwise returns the provided default + * value. * * @func * @memberOf R + * @since v0.6.0 * @category Object * @sig a -> String -> Object -> a * @param {*} val The default value. @@ -11041,14 +10248,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.16.0 * @category Logic * @sig (a -> Boolean) -> String -> {String: a} -> Boolean * @param {Function} pred * @param {String} name * @param {*} obj * @return {Boolean} - * @see R.propEq - * @see R.propIs + * @see R.propEq, R.propIs * @example * * R.propSatisfies(x => x > 0, 'x', {x: 1, y: 2}); //=> true @@ -11058,10 +10265,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Acts as multiple `prop`: array of keys in, array of values out. Preserves order. + * Acts as multiple `prop`: array of keys in, array of values out. Preserves + * order. * * @func * @memberOf R + * @since v0.1.0 * @category Object * @sig [k] -> {k: v} -> [v] * @param {Array} ps The property names to fetch @@ -11087,11 +10296,11 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a list of numbers from `from` (inclusive) to `to` - * (exclusive). + * Returns a list of numbers from `from` (inclusive) to `to` (exclusive). * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig Number -> Number -> [Number] * @param {Number} from The first number in the list. @@ -11116,20 +10325,23 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a single item by iterating through the list, successively calling the iterator - * function and passing it an accumulator value and the current value from the array, and - * then passing the result to the next call. + * Returns a single item by iterating through the list, successively calling + * the iterator function and passing it an accumulator value and the current + * value from the array, and then passing the result to the next call. * - * Similar to `reduce`, except moves through the input list from the right to the left. + * Similar to `reduce`, except moves through the input list from the right to + * the left. * * The iterator function receives two values: *(acc, value)* * - * Note: `R.reduceRight` does not skip deleted or unassigned indices (sparse arrays), unlike - * the native `Array.prototype.reduce` method. For more details on this behavior, see: + * Note: `R.reduceRight` does not skip deleted or unassigned indices (sparse + * arrays), unlike the native `Array.prototype.reduce` method. For more details + * on this behavior, see: * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduceRight#Description * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig (a,b -> a) -> a -> [b] -> a * @param {Function} fn The iterator function. Receives two values, the accumulator and the @@ -11137,12 +10349,11 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @param {*} acc The accumulator value. * @param {Array} list The list to iterate over. * @return {*} The final, accumulated value. + * @see R.addIndex * @example * * var pairs = [ ['a', 1], ['b', 2], ['c', 3] ]; - * var flattenPairs = function(acc, pair) { - * return acc.concat(pair); - * }; + * var flattenPairs = (acc, pair) => acc.concat(pair); * * R.reduceRight(flattenPairs, [], pairs); //=> [ 'c', 3, 'b', 2, 'a', 1 ] */ @@ -11156,26 +10367,25 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a value wrapped to indicate that it is the final value of the - * reduce and transduce functions. The returned value - * should be considered a black box: the internal structure is not - * guaranteed to be stable. + * Returns a value wrapped to indicate that it is the final value of the reduce + * and transduce functions. The returned value should be considered a black + * box: the internal structure is not guaranteed to be stable. * * Note: this optimization is unavailable to functions not explicitly listed - * above. For instance, it is not currently supported by reduceIndexed, - * reduceRight, or reduceRightIndexed. + * above. For instance, it is not currently supported by reduceRight. * * @func * @memberOf R + * @since v0.15.0 * @category List - * @see R.reduce, R.transduce * @sig a -> * * @param {*} x The final value of the reduce. * @return {*} The wrapped value. + * @see R.reduce, R.transduce * @example * * R.reduce( - * R.pipe(R.add, R.ifElse(R.lte(10), R.reduced, R.identity)), + * R.pipe(R.add, R.when(R.gte(R.__, 10), R.reduced)), * 0, * [1, 2, 3, 4, 5]) // 10 */ @@ -11183,12 +10393,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /** * Removes the sub-list of `list` starting at index `start` and containing - * `count` elements. _Note that this is not destructive_: it returns a - * copy of the list with the changes. + * `count` elements. _Note that this is not destructive_: it returns a copy of + * the list with the changes. * No lists have been harmed in the application of this function. * * @func * @memberOf R + * @since v0.2.2 * @category List * @sig Number -> Number -> [a] -> [a] * @param {Number} start The position to start removing elements @@ -11208,6 +10419,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.7.0 * @category String * @sig RegExp|String -> String -> String -> String * @param {RegExp|String} pattern A regular expression or a substring to match. @@ -11227,31 +10439,40 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a new list with the same elements as the original list, just - * in the reverse order. + * Returns a new list or string with the elements or characters in reverse + * order. * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig [a] -> [a] - * @param {Array} list The list to reverse. - * @return {Array} A copy of the list in reverse order. + * @sig String -> String + * @param {Array|String} list + * @return {Array|String} * @example * * R.reverse([1, 2, 3]); //=> [3, 2, 1] * R.reverse([1, 2]); //=> [2, 1] * R.reverse([1]); //=> [1] * R.reverse([]); //=> [] + * + * R.reverse('abc'); //=> 'cba' + * R.reverse('ab'); //=> 'ba' + * R.reverse('a'); //=> 'a' + * R.reverse(''); //=> '' */ var reverse = _curry1(function reverse(list) { - return _slice(list).reverse(); + return _isString(list) ? list.split('').reverse().join('') : _slice(list).reverse(); }); /** - * Scan is similar to reduce, but returns a list of successively reduced values from the left + * Scan is similar to reduce, but returns a list of successively reduced values + * from the left * * @func * @memberOf R + * @since v0.10.0 * @category List * @sig (a,b -> a) -> a -> [b] -> [a] * @param {Function} fn The iterator function. Receives two values, the accumulator and the @@ -11265,7 +10486,9 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * var factorials = R.scan(R.multiply, 1, numbers); //=> [1, 1, 2, 6, 24] */ var scan = _curry3(function scan(fn, acc, list) { - var idx = 0, len = list.length, result = [acc]; + var idx = 0; + var len = list.length; + var result = [acc]; while (idx < len) { acc = fn(acc, list[idx]); result[idx + 1] = acc; @@ -11280,8 +10503,9 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.16.0 * @category Object - * @typedef Lens s a = Functor f => (a -> f a) -> s -> f s + * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s * @sig Lens s a -> a -> s -> s * @param {Lens} lens * @param {*} v @@ -11300,12 +10524,43 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a copy of the list, sorted according to the comparator function, which should accept two values at a - * time and return a negative number if the first value is smaller, a positive number if it's larger, and zero - * if they are equal. Please note that this is a **copy** of the list. It does not modify the original. + * Returns the elements of the given list or string (or object with a `slice` + * method) from `fromIndex` (inclusive) to `toIndex` (exclusive). + * + * Dispatches to the `slice` method of the third argument, if present. + * + * @func + * @memberOf R + * @since v0.1.4 + * @category List + * @sig Number -> Number -> [a] -> [a] + * @sig Number -> Number -> String -> String + * @param {Number} fromIndex The start index (inclusive). + * @param {Number} toIndex The end index (exclusive). + * @param {*} list + * @return {*} + * @example + * + * R.slice(1, 3, ['a', 'b', 'c', 'd']); //=> ['b', 'c'] + * R.slice(1, Infinity, ['a', 'b', 'c', 'd']); //=> ['b', 'c', 'd'] + * R.slice(0, -1, ['a', 'b', 'c', 'd']); //=> ['a', 'b', 'c'] + * R.slice(-3, -1, ['a', 'b', 'c', 'd']); //=> ['b', 'c'] + * R.slice(0, 3, 'ramda'); //=> 'ram' + */ + var slice = _curry3(_checkForMethod('slice', function slice(fromIndex, toIndex, list) { + return Array.prototype.slice.call(list, fromIndex, toIndex); + })); + + /** + * Returns a copy of the list, sorted according to the comparator function, + * which should accept two values at a time and return a negative number if the + * first value is smaller, a positive number if it's larger, and zero if they + * are equal. Please note that this is a **copy** of the list. It does not + * modify the original. * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig (a,a -> Number) -> [a] -> [a] * @param {Function} comparator A sorting function :: a -> b -> Int @@ -11325,6 +10580,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category Relation * @sig Ord b => (a -> b) -> [a] -> [a] * @param {Function} fn @@ -11332,7 +10588,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @return {Array} A new list sorted by the keys generated by `fn`. * @example * - * var sortByFirstItem = R.sortBy(prop(0)); + * var sortByFirstItem = R.sortBy(R.prop(0)); * var sortByNameCaseInsensitive = R.sortBy(R.compose(R.toLower, R.prop('name'))); * var pairs = [[-1, 1], [-2, 2], [-3, 3]]; * sortByFirstItem(pairs); //=> [[-3, 3], [-2, 2], [-1, 1]] @@ -11359,11 +10615,101 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); }); + /** + * Splits a given list or string at a given index. + * + * @func + * @memberOf R + * @since 0.19.1 + * @since 0.19.0 + * @category List + * @sig Number -> [a] -> [[a], [a]] + * @sig Number -> String -> [String, String] + * @param {Number} index The index where the array/string is split. + * @param {Array|String} array The array/string to be split. + * @return {Array} + * @example + * + * R.splitAt(1, [1, 2, 3]); //=> [[1], [2, 3]] + * R.splitAt(5, 'hello world'); //=> ['hello', ' world'] + * R.splitAt(-1, 'foobar'); //=> ['fooba', 'r'] + */ + var splitAt = _curry2(function splitAt(index, array) { + return [ + slice(0, index, array), + slice(index, length(array), array) + ]; + }); + + /** + * Splits a collection into slices of the specified length. + * + * @func + * @memberOf R + * @since v0.16.0 + * @category List + * @sig Number -> [a] -> [[a]] + * @sig Number -> String -> [String] + * @param {Number} n + * @param {Array} list + * @return {Array} + * @example + * + * R.splitEvery(3, [1, 2, 3, 4, 5, 6, 7]); //=> [[1, 2, 3], [4, 5, 6], [7]] + * R.splitEvery(3, 'foobarbaz'); //=> ['foo', 'bar', 'baz'] + */ + var splitEvery = _curry2(function splitEvery(n, list) { + if (n <= 0) { + throw new Error('First argument to splitEvery must be a positive integer'); + } + var result = []; + var idx = 0; + while (idx < list.length) { + result.push(slice(idx, idx += n, list)); + } + return result; + }); + + /** + * Takes a list and a predicate and returns a pair of lists with the following properties: + * + * - the result of concatenating the two output lists is equivalent to the input list; + * - none of the elements of the first output list satisfies the predicate; and + * - if the second output list is non-empty, its first element satisfies the predicate. + * + * @func + * @memberOf R + * @since 0.19.1 + * @since 0.19.0 + * @category List + * @sig (a -> Boolean) -> [a] -> [[a], [a]] + * @param {Function} pred The predicate that determines where the array is split. + * @param {Array} list The array to be split. + * @return {Array} + * @example + * + * R.splitWhen(R.equals(2), [1, 2, 3, 1, 2, 3]); //=> [[1], [2, 3, 1, 2, 3]] + */ + var splitWhen = _curry2(function splitWhen(pred, list) { + var idx = 0; + var len = list.length; + var prefix = []; + while (idx < len && !pred(list[idx])) { + prefix.push(list[idx]); + idx += 1; + } + return [ + prefix, + _slice(list, idx) + ]; + }); + /** * Subtracts two numbers. Equivalent to `a - b` but curried. * * @func * @memberOf R + * @since v0.1.0 * @category Math * @sig Number -> Number -> Number * @param {Number} a The first value. @@ -11386,24 +10732,96 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a new list containing the last `n` elements of a given list, passing each value - * to the supplied predicate function, and terminating when the predicate function returns - * `false`. Excludes the element that caused the predicate function to fail. The predicate - * function is passed one argument: *(value)*. + * Returns all but the first element of the given list or string (or object + * with a `tail` method). + * + * Dispatches to the `slice` method of the first argument, if present. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category List + * @sig [a] -> [a] + * @sig String -> String + * @param {*} list + * @return {*} + * @see R.head, R.init, R.last + * @example + * + * R.tail([1, 2, 3]); //=> [2, 3] + * R.tail([1, 2]); //=> [2] + * R.tail([1]); //=> [] + * R.tail([]); //=> [] + * + * R.tail('abc'); //=> 'bc' + * R.tail('ab'); //=> 'b' + * R.tail('a'); //=> '' + * R.tail(''); //=> '' + */ + var tail = _checkForMethod('tail', slice(1, Infinity)); + + /** + * Returns the first `n` elements of the given list, string, or + * transducer/transformer (or object with a `take` method). + * + * Dispatches to the `take` method of the second argument, if present. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category List + * @sig Number -> [a] -> [a] + * @sig Number -> String -> String + * @param {Number} n + * @param {*} list + * @return {*} + * @see R.drop + * @example + * + * R.take(1, ['foo', 'bar', 'baz']); //=> ['foo'] + * R.take(2, ['foo', 'bar', 'baz']); //=> ['foo', 'bar'] + * R.take(3, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] + * R.take(4, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] + * R.take(3, 'ramda'); //=> 'ram' + * + * var personnel = [ + * 'Dave Brubeck', + * 'Paul Desmond', + * 'Eugene Wright', + * 'Joe Morello', + * 'Gerry Mulligan', + * 'Bob Bates', + * 'Joe Dodge', + * 'Ron Crotty' + * ]; + * + * var takeFive = R.take(5); + * takeFive(personnel); + * //=> ['Dave Brubeck', 'Paul Desmond', 'Eugene Wright', 'Joe Morello', 'Gerry Mulligan'] + */ + var take = _curry2(_dispatchable('take', _xtake, function take(n, xs) { + return slice(0, n < 0 ? Infinity : n, xs); + })); + + /** + * Returns a new list containing the last `n` elements of a given list, passing + * each value to the supplied predicate function, and terminating when the + * predicate function returns `false`. Excludes the element that caused the + * predicate function to fail. The predicate function is passed one argument: + * *(value)*. * * @func * @memberOf R + * @since v0.16.0 * @category List * @sig (a -> Boolean) -> [a] -> [a] * @param {Function} fn The function called per iteration. * @param {Array} list The collection to iterate over. * @return {Array} A new array. - * @see R.dropLastWhile + * @see R.dropLastWhile, R.addIndex * @example * - * var isNotOne = function(x) { - * return !(x === 1); - * }; + * var isNotOne = x => x !== 1; * * R.takeLastWhile(isNotOne, [1, 2, 3, 4]); //=> [2, 3, 4] */ @@ -11415,11 +10833,47 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return _slice(list, idx + 1, Infinity); }); + /** + * Returns a new list containing the first `n` elements of a given list, + * passing each value to the supplied predicate function, and terminating when + * the predicate function returns `false`. Excludes the element that caused the + * predicate function to fail. The predicate function is passed one argument: + * *(value)*. + * + * Dispatches to the `takeWhile` method of the second argument, if present. + * + * Acts as a transducer if a transformer is given in list position. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category List + * @sig (a -> Boolean) -> [a] -> [a] + * @param {Function} fn The function called per iteration. + * @param {Array} list The collection to iterate over. + * @return {Array} A new array. + * @see R.dropWhile, R.transduce, R.addIndex + * @example + * + * var isNotFour = x => x !== 4; + * + * R.takeWhile(isNotFour, [1, 2, 3, 4, 3, 2, 1]); //=> [1, 2, 3] + */ + var takeWhile = _curry2(_dispatchable('takeWhile', _xtakeWhile, function takeWhile(fn, list) { + var idx = 0; + var len = list.length; + while (idx < len && fn(list[idx])) { + idx += 1; + } + return _slice(list, 0, idx); + })); + /** * Runs the given function with the supplied object, then returns the object. * * @func * @memberOf R + * @since v0.1.0 * @category Function * @sig (a -> *) -> a -> a * @param {Function} fn The function to call with `x`. The return value of `fn` will be thrown away. @@ -11427,7 +10881,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @return {*} `x`. * @example * - * var sayX = function(x) { console.log('x is ' + x); }; + * var sayX = x => console.log('x is ' + x); * R.tap(sayX, 100); //=> 100 * //-> 'x is 100' */ @@ -11437,36 +10891,17 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Determines whether a given string matches a given regular expression. - * - * @func - * @memberOf R - * @see R.match - * @category String - * @sig RegExp -> String -> Boolean - * @param {RegExp} pattern - * @param {String} str - * @return {Boolean} - * @example - * - * R.test(/^x/, 'xyz'); //=> true - * R.test(/^y/, 'xyz'); //=> false - */ - var test = _curry2(function test(pattern, str) { - return _cloneRegExp(pattern).test(str); - }); - - /** - * Calls an input function `n` times, returning an array containing the results of those - * function calls. + * Calls an input function `n` times, returning an array containing the results + * of those function calls. * - * `fn` is passed one argument: The current value of `n`, which begins at `0` and is - * gradually incremented to `n - 1`. + * `fn` is passed one argument: The current value of `n`, which begins at `0` + * and is gradually incremented to `n - 1`. * * @func * @memberOf R + * @since v0.2.3 * @category List - * @sig (i -> a) -> i -> [a] + * @sig (Number -> a) -> Number -> [a] * @param {Function} fn The function to invoke. Passed one argument, the current value of `n`. * @param {Number} n A value between `0` and `n - 1`. Increments after each function call. * @return {Array} An array containing the return values of all calls to `fn`. @@ -11476,8 +10911,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack */ var times = _curry2(function times(fn, n) { var len = Number(n); - var list = new Array(len); var idx = 0; + var list; + if (len < 0 || isNaN(len)) { + throw new RangeError('n must be a non-negative number'); + } + list = new Array(len); while (idx < len) { list[idx] = fn(idx); idx += 1; @@ -11486,13 +10925,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Converts an object into an array of key, value arrays. - * Only the object's own properties are used. - * Note that the order of the output array is not guaranteed to be - * consistent across different JS platforms. + * Converts an object into an array of key, value arrays. Only the object's + * own properties are used. + * Note that the order of the output array is not guaranteed to be consistent + * across different JS platforms. * * @func * @memberOf R + * @since v0.4.0 * @category Object * @sig {String: *} -> [[String,*]] * @param {Object} obj The object to extract from @@ -11516,13 +10956,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Converts an object into an array of key, value arrays. - * The object's own properties and prototype properties are used. - * Note that the order of the output array is not guaranteed to be - * consistent across different JS platforms. + * Converts an object into an array of key, value arrays. The object's own + * properties and prototype properties are used. Note that the order of the + * output array is not guaranteed to be consistent across different JS + * platforms. * * @func * @memberOf R + * @since v0.4.0 * @category Object * @sig {String: *} -> [[String,*]] * @param {Object} obj The object to extract from @@ -11546,11 +10987,53 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return pairs; }); + /** + * Transposes the rows and columns of a 2D list. + * When passed a list of `n` lists of length `x`, + * returns a list of `x` lists of length `n`. + * + * + * @func + * @memberOf R + * @since 0.19.1 + * @since 0.19.0 + * @category List + * @sig [[a]] -> [[a]] + * @param {Array} list A 2D list + * @return {Array} A 2D list + * @example + * + * R.transpose([[1, 'a'], [2, 'b'], [3, 'c']]) //=> [[1, 2, 3], ['a', 'b', 'c']] + * R.transpose([[1, 2, 3], ['a', 'b', 'c']]) //=> [[1, 'a'], [2, 'b'], [3, 'c']] + * + * If some of the rows are shorter than the following rows, their elements are skipped: + * + * R.transpose([[10, 11], [20], [], [30, 31, 32]]) //=> [[10, 20, 30], [11, 31], [32]] + */ + var transpose = _curry1(function transpose(outerlist) { + var i = 0; + var result = []; + while (i < outerlist.length) { + var innerlist = outerlist[i]; + var j = 0; + while (j < innerlist.length) { + if (typeof result[j] === 'undefined') { + result[j] = []; + } + result[j].push(innerlist[j]); + j += 1; + } + i += 1; + } + return result; + }); + /** * Removes (strips) whitespace from both ends of the string. * * @func * @memberOf R + * @since v0.6.0 * @category String * @sig String -> String * @param {String} str The string to trim. @@ -11578,12 +11061,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }(); /** - * Gives a single-word string description of the (native) type of a value, returning such - * answers as 'Object', 'Number', 'Array', or 'Null'. Does not attempt to distinguish user - * Object types any further, reporting them all as 'Object'. + * Gives a single-word string description of the (native) type of a value, + * returning such answers as 'Object', 'Number', 'Array', or 'Null'. Does not + * attempt to distinguish user Object types any further, reporting them all as + * 'Object'. * * @func * @memberOf R + * @since v0.8.0 * @category Type * @sig (* -> {*}) -> String * @param {*} val The value to test @@ -11603,18 +11088,19 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Takes a function `fn`, which takes a single array argument, and returns - * a function which: + * Takes a function `fn`, which takes a single array argument, and returns a + * function which: * * - takes any number of positional arguments; * - passes these arguments to `fn` as an array; and * - returns the result. * - * In other words, R.unapply derives a variadic function from a function - * which takes an array. R.unapply is the inverse of R.apply. + * In other words, R.unapply derives a variadic function from a function which + * takes an array. R.unapply is the inverse of R.apply. * * @func * @memberOf R + * @since v0.8.0 * @category Function * @sig ([*...] -> a) -> (*... -> a) * @param {Function} fn @@ -11631,11 +11117,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Wraps a function of any arity (including nullary) in a function that accepts exactly 1 - * parameter. Any extraneous parameters will not be passed to the supplied function. + * Wraps a function of any arity (including nullary) in a function that accepts + * exactly 1 parameter. Any extraneous parameters will not be passed to the + * supplied function. * * @func * @memberOf R + * @since v0.2.0 * @category Function * @sig (* -> b) -> (a -> b) * @param {Function} fn The function to wrap. @@ -11663,6 +11151,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.14.0 * @category Function * @sig Number -> (a -> b) -> (a -> c) * @param {Number} length The arity for the returned function. @@ -11671,18 +11160,10 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @see R.curry * @example * - * var addFour = function(a) { - * return function(b) { - * return function(c) { - * return function(d) { - * return a + b + c + d; - * }; - * }; - * }; - * }; + * var addFour = a => b => c => d => a + b + c + d; * * var uncurriedAddFour = R.uncurryN(4, addFour); - * curriedAddFour(1, 2, 3, 4); //=> 10 + * uncurriedAddFour(1, 2, 3, 4); //=> 10 */ var uncurryN = _curry2(function uncurryN(depth, fn) { return curryN(depth, function () { @@ -11701,14 +11182,16 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Builds a list from a seed value. Accepts an iterator function, which returns either false - * to stop iteration or an array of length 2 containing the value to add to the resulting - * list and the seed to be used in the next call to the iterator function. + * Builds a list from a seed value. Accepts an iterator function, which returns + * either false to stop iteration or an array of length 2 containing the value + * to add to the resulting list and the seed to be used in the next call to the + * iterator function. * * The iterator function receives one argument: *(seed)*. * * @func * @memberOf R + * @since v0.10.0 * @category List * @sig (a -> [b]) -> * -> [b] * @param {Function} fn The iterator function. receives one argument, `seed`, and returns @@ -11719,7 +11202,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @return {Array} The final list. * @example * - * var f = function(n) { return n > 50 ? false : [-n, n + 10] }; + * var f = n => n > 50 ? false : [-n, n + 10]; * R.unfold(f, 10); //=> [-10, -20, -30, -40, -50] */ var unfold = _curry2(function unfold(fn, seed) { @@ -11733,12 +11216,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a new list containing only one copy of each element in the original list, based - * upon the value returned by applying the supplied predicate to two list elements. Prefers - * the first item if two items compare equal based on the predicate. + * Returns a new list containing only one copy of each element in the original + * list, based upon the value returned by applying the supplied predicate to + * two list elements. Prefers the first item if two items compare equal based + * on the predicate. * * @func * @memberOf R + * @since v0.2.0 * @category List * @sig (a, a -> Boolean) -> [a] -> [a] * @param {Function} pred A predicate used to test whether two items are equal. @@ -11746,15 +11231,17 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @return {Array} The list of unique items. * @example * - * var strEq = function(a, b) { return String(a) === String(b); }; + * var strEq = R.eqBy(String); * R.uniqWith(strEq)([1, '1', 2, 1]); //=> [1, 2] * R.uniqWith(strEq)([{}, {}]); //=> [{}] * R.uniqWith(strEq)([1, '1', 1]); //=> [1] * R.uniqWith(strEq)(['1', 1, 1]); //=> ['1'] */ var uniqWith = _curry2(function uniqWith(pred, list) { - var idx = 0, len = list.length; - var result = [], item; + var idx = 0; + var len = list.length; + var result = []; + var item; while (idx < len) { item = list[idx]; if (!_containsWith(pred, item, result)) { @@ -11766,18 +11253,48 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a new copy of the array with the element at the - * provided index replaced with the given value. - * @see R.adjust + * Tests the final argument by passing it to the given predicate function. If + * the predicate is not satisfied, the function will return the result of + * calling the `whenFalseFn` function with the same argument. If the predicate + * is satisfied, the argument is returned as is. + * + * @func + * @memberOf R + * @since v0.18.0 + * @category Logic + * @sig (a -> Boolean) -> (a -> a) -> a -> a + * @param {Function} pred A predicate function + * @param {Function} whenFalseFn A function to invoke when the `pred` evaluates + * to a falsy value. + * @param {*} x An object to test with the `pred` function and + * pass to `whenFalseFn` if necessary. + * @return {*} Either `x` or the result of applying `x` to `whenFalseFn`. + * @see R.ifElse, R.when + * @example + * + * // coerceArray :: (a|[a]) -> [a] + * var coerceArray = R.unless(R.isArrayLike, R.of); + * coerceArray([1, 2, 3]); //=> [1, 2, 3] + * coerceArray(1); //=> [1] + */ + var unless = _curry3(function unless(pred, whenFalseFn, x) { + return pred(x) ? x : whenFalseFn(x); + }); + + /** + * Returns a new copy of the array with the element at the provided index + * replaced with the given value. * * @func * @memberOf R + * @since v0.14.0 * @category List * @sig Number -> a -> [a] -> [a] * @param {Number} idx The index to update. * @param {*} x The value to exist at the given index of the returned array. * @param {Array|Arguments} list The source array-like object to be updated. * @return {Array} A copy of `list` with the value at index `idx` replaced with `x`. + * @see R.adjust * @example * * R.update(1, 11, [0, 1, 2]); //=> [0, 11, 2] @@ -11787,13 +11304,53 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return adjust(always(x), idx, list); }); + /** + * Accepts a function `fn` and a list of transformer functions and returns a + * new curried function. When the new function is invoked, it calls the + * function `fn` with parameters consisting of the result of calling each + * supplied handler on successive arguments to the new function. + * + * If more arguments are passed to the returned function than transformer + * functions, those arguments are passed directly to `fn` as additional + * parameters. If you expect additional arguments that don't need to be + * transformed, although you can ignore them, it's best to pass an identity + * function so that the new function reports the correct arity. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category Function + * @sig (x1 -> x2 -> ... -> z) -> [(a -> x1), (b -> x2), ...] -> (a -> b -> ... -> z) + * @param {Function} fn The function to wrap. + * @param {Array} transformers A list of transformer functions + * @return {Function} The wrapped function. + * @example + * + * R.useWith(Math.pow, [R.identity, R.identity])(3, 4); //=> 81 + * R.useWith(Math.pow, [R.identity, R.identity])(3)(4); //=> 81 + * R.useWith(Math.pow, [R.dec, R.inc])(3, 4); //=> 32 + * R.useWith(Math.pow, [R.dec, R.inc])(3)(4); //=> 32 + */ + var useWith = _curry2(function useWith(fn, transformers) { + return curryN(transformers.length, function () { + var args = []; + var idx = 0; + while (idx < transformers.length) { + args.push(transformers[idx].call(this, arguments[idx])); + idx += 1; + } + return fn.apply(this, args.concat(_slice(arguments, transformers.length))); + }); + }); + /** * Returns a list of all the enumerable own properties of the supplied object. - * Note that the order of the output array is not guaranteed across - * different JS platforms. + * Note that the order of the output array is not guaranteed across different + * JS platforms. * * @func * @memberOf R + * @since v0.1.0 * @category Object * @sig {k: v} -> [v] * @param {Object} obj The object to extract values from @@ -11815,13 +11372,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a list of all the properties, including prototype properties, - * of the supplied object. - * Note that the order of the output array is not guaranteed to be - * consistent across different JS platforms. + * Returns a list of all the properties, including prototype properties, of the + * supplied object. + * Note that the order of the output array is not guaranteed to be consistent + * across different JS platforms. * * @func * @memberOf R + * @since v0.2.0 * @category Object * @sig {k: v} -> [v] * @param {Object} obj The object to extract values from @@ -11834,7 +11392,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * R.valuesIn(f); //=> ['X', 'Y'] */ var valuesIn = _curry1(function valuesIn(obj) { - var prop, vs = []; + var prop; + var vs = []; for (prop in obj) { vs[vs.length] = obj[prop]; } @@ -11847,8 +11406,9 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.16.0 * @category Object - * @typedef Lens s a = Functor f => (a -> f a) -> s -> f s + * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s * @sig Lens s a -> s -> a * @param {Lens} lens * @param {*} x @@ -11875,18 +11435,51 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); }(); + /** + * Tests the final argument by passing it to the given predicate function. If + * the predicate is satisfied, the function will return the result of calling + * the `whenTrueFn` function with the same argument. If the predicate is not + * satisfied, the argument is returned as is. + * + * @func + * @memberOf R + * @since v0.18.0 + * @category Logic + * @sig (a -> Boolean) -> (a -> a) -> a -> a + * @param {Function} pred A predicate function + * @param {Function} whenTrueFn A function to invoke when the `condition` + * evaluates to a truthy value. + * @param {*} x An object to test with the `pred` function and + * pass to `whenTrueFn` if necessary. + * @return {*} Either `x` or the result of applying `x` to `whenTrueFn`. + * @see R.ifElse, R.unless + * @example + * + * // truncate :: String -> String + * var truncate = R.when( + * R.propSatisfies(R.gt(R.__, 10), 'length'), + * R.pipe(R.take(10), R.append('…'), R.join('')) + * ); + * truncate('12345'); //=> '12345' + * truncate('0123456789ABC'); //=> '0123456789…' + */ + var when = _curry3(function when(pred, whenTrueFn, x) { + return pred(x) ? whenTrueFn(x) : x; + }); + /** * Takes a spec object and a test object; returns true if the test satisfies * the spec. Each of the spec's own properties must be a predicate function. - * Each predicate is applied to the value of the corresponding property of - * the test object. `where` returns true if all the predicates return true, - * false otherwise. + * Each predicate is applied to the value of the corresponding property of the + * test object. `where` returns true if all the predicates return true, false + * otherwise. * * `where` is well suited to declaratively expressing constraints for other * functions such as `filter` and `find`. * * @func * @memberOf R + * @since v0.1.1 * @category Object * @sig {String: (* -> Boolean)} -> {String: *} -> Boolean * @param {Object} spec @@ -11918,11 +11511,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Wrap a function inside another to allow you to make adjustments to the parameters, or do - * other processing either before the internal function is called or with its results. - * + * Wrap a function inside another to allow you to make adjustments to the + * parameters, or do other processing either before the internal function is + * called or with its results. + * * @func * @memberOf R + * @since v0.1.0 * @category Function * @sig (a... -> b) -> ((a... -> b) -> a... -> c) -> (a... -> c) * @param {Function} fn The function to wrap. @@ -11930,11 +11525,10 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @return {Function} The wrapped function. * @example * - * var greet = function(name) {return 'Hello ' + name;}; + * var greet = name => 'Hello ' + name; + * + * var shoutedGreet = R.wrap(greet, (gr, name) => gr(name).toUpperCase()); * - * var shoutedGreet = R.wrap(greet, function(gr, name) { - * return gr(name).toUpperCase(); - * }); * shoutedGreet("Kathy"); //=> "HELLO KATHY" * * var shortenedGreet = R.wrap(greet, function(gr, name) { @@ -11949,11 +11543,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Creates a new list out of the two supplied by creating each possible - * pair from the lists. + * Creates a new list out of the two supplied by creating each possible pair + * from the lists. * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig [a] -> [b] -> [[a,b]] * @param {Array} as The first list. @@ -11987,13 +11582,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Creates a new list out of the two supplied by pairing up - * equally-positioned items from both lists. The returned list is - * truncated to the length of the shorter of the two input lists. + * Creates a new list out of the two supplied by pairing up equally-positioned + * items from both lists. The returned list is truncated to the length of the + * shorter of the two input lists. * Note: `zip` is equivalent to `zipWith(function(a, b) { return [a, b] })`. * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig [a] -> [b] -> [[a,b]] * @param {Array} list1 The first array to consider. @@ -12022,6 +11618,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.3.0 * @category List * @sig [String] -> [*] -> {String: *} * @param {Array} keys The array that will be properties on the output object. @@ -12032,7 +11629,9 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * R.zipObj(['a', 'b', 'c'], [1, 2, 3]); //=> {a: 1, b: 2, c: 3} */ var zipObj = _curry2(function zipObj(keys, values) { - var idx = 0, len = keys.length, out = {}; + var idx = 0; + var len = keys.length; + var out = {}; while (idx < len) { out[keys[idx]] = values[idx]; idx += 1; @@ -12041,12 +11640,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Creates a new list out of the two supplied by applying the function to - * each equally-positioned pair in the lists. The returned list is - * truncated to the length of the shorter of the two input lists. + * Creates a new list out of the two supplied by applying the function to each + * equally-positioned pair in the lists. The returned list is truncated to the + * length of the shorter of the two input lists. * * @function * @memberOf R + * @since v0.1.0 * @category List * @sig (a,b -> c) -> [a] -> [b] -> [c] * @param {Function} fn The function used to combine the two elements into one value. @@ -12056,14 +11656,16 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * using `fn`. * @example * - * var f = function(x, y) { + * var f = (x, y) => { * // ... * }; * R.zipWith(f, [1, 2, 3], ['a', 'b', 'c']); * //=> [f(1, 'a'), f(2, 'b'), f(3, 'c')] */ var zipWith = _curry3(function zipWith(fn, a, b) { - var rv = [], idx = 0, len = Math.min(a.length, b.length); + var rv = []; + var idx = 0; + var len = Math.min(a.length, b.length); while (idx < len) { rv[idx] = fn(a[idx], b[idx]); idx += 1; @@ -12076,9 +11678,11 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.9.0 * @category Function - * @sig * -> false - * @return {Boolean} false + * @sig * -> Boolean + * @param {*} + * @return {Boolean} * @see R.always, R.T * @example * @@ -12091,9 +11695,11 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.9.0 * @category Function - * @sig * -> true - * @return {Boolean} `true`. + * @sig * -> Boolean + * @param {*} + * @return {Boolean} * @see R.always, R.F * @example * @@ -12101,27 +11707,6 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack */ var T = always(true); - /** - * Similar to hasMethod, this checks whether a function has a [methodname] - * function. If it isn't an array it will execute that function otherwise it will - * default to the ramda implementation. - * - * @private - * @param {Function} fn ramda implemtation - * @param {String} methodname property to check for a custom implementation - * @return {Object} Whatever the return value of the method is. - */ - var _checkForMethod = function _checkForMethod(methodname, fn) { - return function () { - var length = arguments.length; - if (length === 0) { - return fn(); - } - var obj = arguments[length - 1]; - return _isArray(obj) || typeof obj[methodname] !== 'function' ? fn.apply(this, arguments) : obj[methodname].apply(obj, _slice(arguments, 0, length - 1)); - }; - }; - /** * Copies an object. * @@ -12154,7 +11739,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack case 'Array': return copy([]); case 'Date': - return new Date(value); + return new Date(value.valueOf()); case 'RegExp': return _cloneRegExp(value); default: @@ -12163,129 +11748,115 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }; var _createPartialApplicator = function _createPartialApplicator(concat) { - return function (fn) { - var args = _slice(arguments, 1); + return _curry2(function (fn, args) { return _arity(Math.max(0, fn.length - args.length), function () { return fn.apply(this, concat(args, arguments)); }); - }; + }); }; - /** - * Returns a function that dispatches with different strategies based on the - * object in list position (last argument). If it is an array, executes [fn]. - * Otherwise, if it has a function with [methodname], it will execute that - * function (functor case). Otherwise, if it is a transformer, uses transducer - * [xf] to return a new transformer (transducer case). Otherwise, it will - * default to executing [fn]. - * - * @private - * @param {String} methodname property to check for a custom implementation - * @param {Function} xf transducer to initialize if object is transformer - * @param {Function} fn default ramda implementation - * @return {Function} A function that dispatches on object in list position - */ - var _dispatchable = function _dispatchable(methodname, xf, fn) { - return function () { - var length = arguments.length; - if (length === 0) { - return fn(); - } - var obj = arguments[length - 1]; - if (!_isArray(obj)) { - var args = _slice(arguments, 0, length - 1); - if (typeof obj[methodname] === 'function') { - return obj[methodname].apply(obj, args); - } - if (_isTransformer(obj)) { - var transducer = xf.apply(null, args); - return transducer(obj); - } - } - return fn.apply(this, arguments); - }; + var _dropLast = function dropLast(n, xs) { + return take(n < xs.length ? xs.length - n : 0, xs); }; - // The algorithm used to handle cyclic structures is - // inspired by underscore's isEqual - // RegExp equality algorithm: http://stackoverflow.com/a/10776635 + // Values of other types are only equal if identical. var _equals = function _equals(a, b, stackA, stackB) { - var typeA = type(a); - if (typeA !== type(b)) { - return false; - } - if (typeA === 'Boolean' || typeA === 'Number' || typeA === 'String') { - return typeof a === 'object' ? typeof b === 'object' && identical(a.valueOf(), b.valueOf()) : identical(a, b); - } if (identical(a, b)) { return true; } - if (typeA === 'RegExp') { - // RegExp equality algorithm: http://stackoverflow.com/a/10776635 - return a.source === b.source && a.global === b.global && a.ignoreCase === b.ignoreCase && a.multiline === b.multiline && a.sticky === b.sticky && a.unicode === b.unicode; + if (type(a) !== type(b)) { + return false; } - if (Object(a) === a) { - if (typeA === 'Date' && a.getTime() !== b.getTime()) { + if (a == null || b == null) { + return false; + } + if (typeof a.equals === 'function' || typeof b.equals === 'function') { + return typeof a.equals === 'function' && a.equals(b) && typeof b.equals === 'function' && b.equals(a); + } + switch (type(a)) { + case 'Arguments': + case 'Array': + case 'Object': + break; + case 'Boolean': + case 'Number': + case 'String': + if (!(typeof a === typeof b && identical(a.valueOf(), b.valueOf()))) { return false; } - var keysA = keys(a); - if (keysA.length !== keys(b).length) { + break; + case 'Date': + if (!identical(a.valueOf(), b.valueOf())) { return false; } - var idx = stackA.length - 1; - while (idx >= 0) { - if (stackA[idx] === a) { - return stackB[idx] === b; - } - idx -= 1; + break; + case 'Error': + return a.name === b.name && a.message === b.message; + case 'RegExp': + if (!(a.source === b.source && a.global === b.global && a.ignoreCase === b.ignoreCase && a.multiline === b.multiline && a.sticky === b.sticky && a.unicode === b.unicode)) { + return false; } - stackA[stackA.length] = a; - stackB[stackB.length] = b; - idx = keysA.length - 1; - while (idx >= 0) { - var key = keysA[idx]; - if (!_has(key, b) || !_equals(b[key], a[key], stackA, stackB)) { - return false; - } - idx -= 1; + break; + case 'Map': + case 'Set': + if (!_equals(_arrayFromIterator(a.entries()), _arrayFromIterator(b.entries()), stackA, stackB)) { + return false; } - stackA.pop(); - stackB.pop(); - return true; + break; + case 'Int8Array': + case 'Uint8Array': + case 'Uint8ClampedArray': + case 'Int16Array': + case 'Uint16Array': + case 'Int32Array': + case 'Uint32Array': + case 'Float32Array': + case 'Float64Array': + break; + case 'ArrayBuffer': + break; + default: + // Values of other types are only equal if identical. + return false; } - return false; - }; - - /** - * Private function that determines whether or not a provided object has a given method. - * Does not ignore methods stored on the object's prototype chain. Used for dynamically - * dispatching Ramda methods to non-Array objects. - * - * @private - * @param {String} methodName The name of the method to check for. - * @param {Object} obj The object to test. - * @return {Boolean} `true` has a given method, `false` otherwise. - * @example - * - * var person = { name: 'John' }; - * person.shout = function() { alert(this.name); }; - * - * _hasMethod('shout', person); //=> true - * _hasMethod('foo', person); //=> false - */ - var _hasMethod = function _hasMethod(methodName, obj) { - return obj != null && !_isArray(obj) && typeof obj[methodName] === 'function'; + var keysA = keys(a); + if (keysA.length !== keys(b).length) { + return false; + } + var idx = stackA.length - 1; + while (idx >= 0) { + if (stackA[idx] === a) { + return stackB[idx] === b; + } + idx -= 1; + } + stackA.push(a); + stackB.push(b); + idx = keysA.length - 1; + while (idx >= 0) { + var key = keysA[idx]; + if (!(_has(key, b) && _equals(b[key], a[key], stackA, stackB))) { + return false; + } + idx -= 1; + } + stackA.pop(); + stackB.pop(); + return true; }; /** - * `_makeFlat` is a helper function that returns a one-level or fully recursive function - * based on the flag passed in. + * `_makeFlat` is a helper function that returns a one-level or fully recursive + * function based on the flag passed in. * * @private */ var _makeFlat = function _makeFlat(recursive) { return function flatt(list) { - var value, result = [], idx = 0, j, ilen = list.length, jlen; + var value, jlen, j; + var result = []; + var idx = 0; + var ilen = list.length; while (idx < ilen) { if (isArrayLike(list[idx])) { value = recursive ? flatt(list[idx]) : list[idx]; @@ -12306,7 +11877,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var _reduce = function () { function _arrayReduce(xf, acc, list) { - var idx = 0, len = list.length; + var idx = 0; + var len = list.length; while (idx < len) { acc = xf['@@transducer/step'](acc, list[idx]); if (acc && acc['@@transducer/reduced']) { @@ -12353,132 +11925,31 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }; }(); - var _stepCat = function () { - var _stepCatArray = { - '@@transducer/init': Array, - '@@transducer/step': function (xs, x) { - return _concat(xs, [x]); - }, - '@@transducer/result': _identity - }; - var _stepCatString = { - '@@transducer/init': String, - '@@transducer/step': function (a, b) { - return a + b; - }, - '@@transducer/result': _identity - }; - var _stepCatObject = { - '@@transducer/init': Object, - '@@transducer/step': function (result, input) { - return merge(result, isArrayLike(input) ? createMapEntry(input[0], input[1]) : input); - }, - '@@transducer/result': _identity - }; - return function _stepCat(obj) { - if (_isTransformer(obj)) { - return obj; - } - if (isArrayLike(obj)) { - return _stepCatArray; - } - if (typeof obj === 'string') { - return _stepCatString; - } - if (typeof obj === 'object') { - return _stepCatObject; - } - throw new Error('Cannot create transformer for ' + obj); - }; - }(); - - var _xall = function () { - function XAll(f, xf) { - this.xf = xf; - this.f = f; - this.all = true; - } - XAll.prototype['@@transducer/init'] = _xfBase.init; - XAll.prototype['@@transducer/result'] = function (result) { - if (this.all) { - result = this.xf['@@transducer/step'](result, true); - } - return this.xf['@@transducer/result'](result); - }; - XAll.prototype['@@transducer/step'] = function (result, input) { - if (!this.f(input)) { - this.all = false; - result = _reduced(this.xf['@@transducer/step'](result, false)); - } - return result; - }; - return _curry2(function _xall(f, xf) { - return new XAll(f, xf); - }); - }(); - - var _xany = function () { - function XAny(f, xf) { + var _xdropLastWhile = function () { + function XDropLastWhile(fn, xf) { + this.f = fn; + this.retained = []; this.xf = xf; - this.f = f; - this.any = false; } - XAny.prototype['@@transducer/init'] = _xfBase.init; - XAny.prototype['@@transducer/result'] = function (result) { - if (!this.any) { - result = this.xf['@@transducer/step'](result, false); - } + XDropLastWhile.prototype['@@transducer/init'] = _xfBase.init; + XDropLastWhile.prototype['@@transducer/result'] = function (result) { + this.retained = null; return this.xf['@@transducer/result'](result); }; - XAny.prototype['@@transducer/step'] = function (result, input) { - if (this.f(input)) { - this.any = true; - result = _reduced(this.xf['@@transducer/step'](result, true)); - } - return result; + XDropLastWhile.prototype['@@transducer/step'] = function (result, input) { + return this.f(input) ? this.retain(result, input) : this.flush(result, input); }; - return _curry2(function _xany(f, xf) { - return new XAny(f, xf); - }); - }(); - - var _xdrop = function () { - function XDrop(n, xf) { - this.xf = xf; - this.n = n; - } - XDrop.prototype['@@transducer/init'] = _xfBase.init; - XDrop.prototype['@@transducer/result'] = _xfBase.result; - XDrop.prototype['@@transducer/step'] = function (result, input) { - if (this.n > 0) { - this.n -= 1; - return result; - } + XDropLastWhile.prototype.flush = function (result, input) { + result = _reduce(this.xf['@@transducer/step'], result, this.retained); + this.retained = []; return this.xf['@@transducer/step'](result, input); }; - return _curry2(function _xdrop(n, xf) { - return new XDrop(n, xf); - }); - }(); - - var _xdropWhile = function () { - function XDropWhile(f, xf) { - this.xf = xf; - this.f = f; - } - XDropWhile.prototype['@@transducer/init'] = _xfBase.init; - XDropWhile.prototype['@@transducer/result'] = _xfBase.result; - XDropWhile.prototype['@@transducer/step'] = function (result, input) { - if (this.f) { - if (this.f(input)) { - return result; - } - this.f = null; - } - return this.xf['@@transducer/step'](result, input); + XDropLastWhile.prototype.retain = function (result, input) { + this.retained.push(input); + return result; }; - return _curry2(function _xdropWhile(f, xf) { - return new XDropWhile(f, xf); + return _curry2(function _xdropLastWhile(fn, xf) { + return new XDropLastWhile(fn, xf); }); }(); @@ -12500,6 +11971,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack } } } + this.inputs = null; return this.xf['@@transducer/result'](result); }; XGroupBy.prototype['@@transducer/step'] = function (result, input) { @@ -12517,16 +11989,18 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }(); /** - * Creates a new list iteration function from an existing one by adding two new parameters - * to its callback function: the current index, and the entire list. + * Creates a new list iteration function from an existing one by adding two new + * parameters to its callback function: the current index, and the entire list. * - * This would turn, for instance, Ramda's simple `map` function into one that more closely - * resembles `Array.prototype.map`. Note that this will only work for functions in which - * the iteration callback function is the first parameter, and where the list is the last - * parameter. (This latter might be unimportant if the list parameter is not used.) + * This would turn, for instance, Ramda's simple `map` function into one that + * more closely resembles `Array.prototype.map`. Note that this will only work + * for functions in which the iteration callback function is the first + * parameter, and where the list is the last parameter. (This latter might be + * unimportant if the list parameter is not used.) * * @func * @memberOf R + * @since v0.15.0 * @category Function * @category List * @sig ((a ... -> b) ... -> [a] -> *) -> (a ..., Int, [a] -> b) ... -> [a] -> *) @@ -12535,7 +12009,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @example * * var mapIndexed = R.addIndex(R.map); - * mapIndexed(function(val, idx) {return idx + '-' + val;}, ['f', 'o', 'o', 'b', 'a', 'r']); + * mapIndexed((val, idx) => idx + '-' + val, ['f', 'o', 'o', 'b', 'a', 'r']); * //=> ['0-f', '1-o', '2-o', '3-b', '4-a', '5-r'] */ var addIndex = _curry1(function addIndex(fn) { @@ -12557,104 +12031,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns `true` if all elements of the list match the predicate, `false` if there are any - * that don't. - * - * Acts as a transducer if a transformer is given in list position. - * @see R.transduce - * - * @func - * @memberOf R - * @category List - * @sig (a -> Boolean) -> [a] -> Boolean - * @param {Function} fn The predicate function. - * @param {Array} list The array to consider. - * @return {Boolean} `true` if the predicate is satisfied by every element, `false` - * otherwise. - * @see R.any, R.none - * @example - * - * var lessThan2 = R.flip(R.lt)(2); - * var lessThan3 = R.flip(R.lt)(3); - * R.all(lessThan2)([1, 2]); //=> false - * R.all(lessThan3)([1, 2]); //=> true - */ - var all = _curry2(_dispatchable('all', _xall, function all(fn, list) { - var idx = 0; - while (idx < list.length) { - if (!fn(list[idx])) { - return false; - } - idx += 1; - } - return true; - })); - - /** - * A function that returns the first argument if it's falsy otherwise the second - * argument. Note that this is NOT short-circuited, meaning that if expressions - * are passed they are both evaluated. - * - * Dispatches to the `and` method of the first argument if applicable. - * - * @func - * @memberOf R - * @category Logic - * @sig * -> * -> * - * @param {*} a any value - * @param {*} b any other value - * @return {*} the first argument if falsy otherwise the second argument. - * @see R.both - * @example - * - * R.and(false, true); //=> false - * R.and(0, []); //=> 0 - * R.and(null, ''); => null - */ - var and = _curry2(function and(a, b) { - return _hasMethod('and', a) ? a.and(b) : a && b; - }); - - /** - * Returns `true` if at least one of elements of the list match the predicate, `false` - * otherwise. - * - * Acts as a transducer if a transformer is given in list position. - * @see R.transduce - * - * @func - * @memberOf R - * @category List - * @sig (a -> Boolean) -> [a] -> Boolean - * @param {Function} fn The predicate function. - * @param {Array} list The array to consider. - * @return {Boolean} `true` if the predicate is satisfied by at least one element, `false` - * otherwise. - * @see R.all, R.none - * @example - * - * var lessThan0 = R.flip(R.lt)(0); - * var lessThan2 = R.flip(R.lt)(2); - * R.any(lessThan0)([1, 2]); //=> false - * R.any(lessThan2)([1, 2]); //=> true - */ - var any = _curry2(_dispatchable('any', _xany, function any(fn, list) { - var idx = 0; - while (idx < list.length) { - if (fn(list[idx])) { - return true; - } - idx += 1; - } - return false; - })); - - /** - * Wraps a function of any arity (including nullary) in a function that accepts exactly 2 - * parameters. Any extraneous parameters will not be passed to the supplied function. + * Wraps a function of any arity (including nullary) in a function that accepts + * exactly 2 parameters. Any extraneous parameters will not be passed to the + * supplied function. * * @func * @memberOf R + * @since v0.2.0 * @category Function * @sig (* -> c) -> (a, b -> c) * @param {Function} fn The function to wrap. @@ -12679,11 +12062,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /** * Creates a deep copy of the value which may contain (nested) `Array`s and - * `Object`s, `Number`s, `String`s, `Boolean`s and `Date`s. `Function`s are - * not copied, but assigned by their reference. - * + * `Object`s, `Number`s, `String`s, `Boolean`s and `Date`s. `Function`s are not + * copied, but assigned by their reference. + * + * Dispatches to a `clone` method if present. + * * @func * @memberOf R + * @since v0.1.0 * @category Object * @sig {*} -> {*} * @param {*} value The object or array to clone @@ -12695,45 +12081,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * objects[0] === objectsClone[0]; //=> false */ var clone = _curry1(function clone(value) { - return _clone(value, [], []); - }); - - /** - * Returns a new list consisting of the elements of the first list followed by the elements - * of the second. - * - * @func - * @memberOf R - * @category List - * @sig [a] -> [a] -> [a] - * @param {Array} list1 The first list to merge. - * @param {Array} list2 The second set to merge. - * @return {Array} A new array consisting of the contents of `list1` followed by the - * contents of `list2`. If, instead of an Array for `list1`, you pass an - * object with a `concat` method on it, `concat` will call `list1.concat` - * and pass it the value of `list2`. - * - * @example - * - * R.concat([], []); //=> [] - * R.concat([4, 5, 6], [1, 2, 3]); //=> [4, 5, 6, 1, 2, 3] - * R.concat('ABC', 'DEF'); // 'ABCDEF' - */ - var concat = _curry2(function concat(set1, set2) { - if (_isArray(set2)) { - return _concat(set1, set2); - } else if (_hasMethod('concat', set1)) { - return set1.concat(set2); - } else { - throw new TypeError('can\'t concat ' + typeof set1); - } + return value != null && typeof value.clone === 'function' ? value.clone() : _clone(value, [], []); }); /** - * Returns a curried equivalent of the provided function. The curried - * function has two unusual capabilities. First, its arguments needn't - * be provided one at a time. If `f` is a ternary function and `g` is - * `R.curry(f)`, the following are equivalent: + * Returns a curried equivalent of the provided function. The curried function + * has two unusual capabilities. First, its arguments needn't be provided one + * at a time. If `f` is a ternary function and `g` is `R.curry(f)`, the + * following are equivalent: * * - `g(1)(2)(3)` * - `g(1)(2, 3)` @@ -12742,8 +12097,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * Secondly, the special placeholder value `R.__` may be used to specify * "gaps", allowing partial application of any combination of arguments, - * regardless of their positions. If `g` is as above and `_` is `R.__`, - * the following are equivalent: + * regardless of their positions. If `g` is as above and `_` is `R.__`, the + * following are equivalent: * * - `g(1, 2, 3)` * - `g(_, 2, 3)(1)` @@ -12755,6 +12110,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category Function * @sig (* -> a) -> (* -> a) * @param {Function} fn The function to curry. @@ -12762,9 +12118,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @see R.curryN * @example * - * var addFourNumbers = function(a, b, c, d) { - * return a + b + c + d; - * }; + * var addFourNumbers = (a, b, c, d) => a + b + c + d; * * var curriedAddFourNumbers = R.curry(addFourNumbers); * var f = curriedAddFourNumbers(1, 2); @@ -12776,225 +12130,152 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a new list containing the last `n` elements of a given list, passing each value - * to the supplied predicate function, skipping elements while the predicate function returns - * `true`. The predicate function is passed one argument: *(value)*. + * Returns all but the first `n` elements of the given list, string, or + * transducer/transformer (or object with a `drop` method). * - * Acts as a transducer if a transformer is given in list position. - * @see R.transduce + * Dispatches to the `drop` method of the second argument, if present. * * @func * @memberOf R + * @since v0.1.0 * @category List - * @sig (a -> Boolean) -> [a] -> [a] - * @param {Function} fn The function called per iteration. - * @param {Array} list The collection to iterate over. - * @return {Array} A new array. - * @see R.takeWhile + * @sig Number -> [a] -> [a] + * @sig Number -> String -> String + * @param {Number} n + * @param {*} list + * @return {*} + * @see R.take, R.transduce * @example * - * var lteTwo = function(x) { - * return x <= 2; - * }; - * - * R.dropWhile(lteTwo, [1, 2, 3, 4, 3, 2, 1]); //=> [3, 4, 3, 2, 1] + * R.drop(1, ['foo', 'bar', 'baz']); //=> ['bar', 'baz'] + * R.drop(2, ['foo', 'bar', 'baz']); //=> ['baz'] + * R.drop(3, ['foo', 'bar', 'baz']); //=> [] + * R.drop(4, ['foo', 'bar', 'baz']); //=> [] + * R.drop(3, 'ramda'); //=> 'da' */ - var dropWhile = _curry2(_dispatchable('dropWhile', _xdropWhile, function dropWhile(pred, list) { - var idx = 0, len = list.length; - while (idx < len && pred(list[idx])) { - idx += 1; - } - return _slice(list, idx); + var drop = _curry2(_dispatchable('drop', _xdrop, function drop(n, xs) { + return slice(Math.max(0, n), Infinity, xs); })); /** - * Returns `true` if its arguments are equivalent, `false` otherwise. - * Dispatches to an `equals` method if present. Handles cyclical data - * structures. + * Returns a list containing all but the last `n` elements of the given `list`. * * @func * @memberOf R - * @category Relation - * @sig a -> b -> Boolean - * @param {*} a - * @param {*} b - * @return {Boolean} + * @since v0.16.0 + * @category List + * @sig Number -> [a] -> [a] + * @sig Number -> String -> String + * @param {Number} n The number of elements of `xs` to skip. + * @param {Array} xs The collection to consider. + * @return {Array} + * @see R.takeLast * @example * - * R.equals(1, 1); //=> true - * R.equals(1, '1'); //=> false - * R.equals([1, 2, 3], [1, 2, 3]); //=> true - * - * var a = {}; a.v = a; - * var b = {}; b.v = b; - * R.equals(a, b); //=> true + * R.dropLast(1, ['foo', 'bar', 'baz']); //=> ['foo', 'bar'] + * R.dropLast(2, ['foo', 'bar', 'baz']); //=> ['foo'] + * R.dropLast(3, ['foo', 'bar', 'baz']); //=> [] + * R.dropLast(4, ['foo', 'bar', 'baz']); //=> [] + * R.dropLast(3, 'ramda'); //=> 'ra' */ - var equals = _curry2(function equals(a, b) { - return _hasMethod('equals', a) ? a.equals(b) : _hasMethod('equals', b) ? b.equals(a) : _equals(a, b, [], []); - }); + var dropLast = _curry2(_dispatchable('dropLast', _xdropLast, _dropLast)); /** - * Returns a new list containing only those items that match a given predicate function. - * The predicate function is passed one argument: *(value)*. - * - * Note that `R.filter` does not skip deleted or unassigned indices, unlike the native - * `Array.prototype.filter` method. For more details on this behavior, see: - * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter#Description - * - * Acts as a transducer if a transformer is given in list position. - * @see R.transduce + * Returns a new list containing all but last the`n` elements of a given list, + * passing each value from the right to the supplied predicate function, + * skipping elements while the predicate function returns `true`. The predicate + * function is passed one argument: (value)*. * * @func * @memberOf R + * @since v0.16.0 * @category List * @sig (a -> Boolean) -> [a] -> [a] * @param {Function} fn The function called per iteration. * @param {Array} list The collection to iterate over. - * @return {Array} The new filtered array. - * @see R.reject + * @return {Array} A new array. + * @see R.takeLastWhile, R.addIndex * @example * - * var isEven = function(n) { - * return n % 2 === 0; - * }; - * R.filter(isEven, [1, 2, 3, 4]); //=> [2, 4] - */ - var filter = _curry2(_dispatchable('filter', _xfilter, _filter)); - - /** - * Returns the first element of the list which matches the predicate, or `undefined` if no - * element matches. - * - * Acts as a transducer if a transformer is given in list position. - * @see R.transduce - * - * @func - * @memberOf R - * @category List - * @sig (a -> Boolean) -> [a] -> a | undefined - * @param {Function} fn The predicate function used to determine if the element is the - * desired one. - * @param {Array} list The array to consider. - * @return {Object} The element found, or `undefined`. - * @example + * var lteThree = x => x <= 3; * - * var xs = [{a: 1}, {a: 2}, {a: 3}]; - * R.find(R.propEq('a', 2))(xs); //=> {a: 2} - * R.find(R.propEq('a', 4))(xs); //=> undefined + * R.dropLastWhile(lteThree, [1, 2, 3, 4, 3, 2, 1]); //=> [1, 2, 3, 4] */ - var find = _curry2(_dispatchable('find', _xfind, function find(fn, list) { - var idx = 0; - var len = list.length; - while (idx < len) { - if (fn(list[idx])) { - return list[idx]; - } - idx += 1; - } - })); + var dropLastWhile = _curry2(_dispatchable('dropLastWhile', _xdropLastWhile, _dropLastWhile)); /** - * Returns the index of the first element of the list which matches the predicate, or `-1` - * if no element matches. + * Returns `true` if its arguments are equivalent, `false` otherwise. Handles + * cyclical data structures. * - * Acts as a transducer if a transformer is given in list position. - * @see R.transduce + * Dispatches symmetrically to the `equals` methods of both arguments, if + * present. * * @func * @memberOf R - * @category List - * @sig (a -> Boolean) -> [a] -> Number - * @param {Function} fn The predicate function used to determine if the element is the - * desired one. - * @param {Array} list The array to consider. - * @return {Number} The index of the element found, or `-1`. + * @since v0.15.0 + * @category Relation + * @sig a -> b -> Boolean + * @param {*} a + * @param {*} b + * @return {Boolean} * @example * - * var xs = [{a: 1}, {a: 2}, {a: 3}]; - * R.findIndex(R.propEq('a', 2))(xs); //=> 1 - * R.findIndex(R.propEq('a', 4))(xs); //=> -1 + * R.equals(1, 1); //=> true + * R.equals(1, '1'); //=> false + * R.equals([1, 2, 3], [1, 2, 3]); //=> true + * + * var a = {}; a.v = a; + * var b = {}; b.v = b; + * R.equals(a, b); //=> true */ - var findIndex = _curry2(_dispatchable('findIndex', _xfindIndex, function findIndex(fn, list) { - var idx = 0; - var len = list.length; - while (idx < len) { - if (fn(list[idx])) { - return idx; - } - idx += 1; - } - return -1; - })); + var equals = _curry2(function equals(a, b) { + return _equals(a, b, [], []); + }); /** - * Returns the last element of the list which matches the predicate, or `undefined` if no - * element matches. + * Takes a predicate and a "filterable", and returns a new filterable of the + * same type containing the members of the given filterable which satisfy the + * given predicate. + * + * Dispatches to the `filter` method of the second argument, if present. * * Acts as a transducer if a transformer is given in list position. - * @see R.transduce * * @func * @memberOf R + * @since v0.1.0 * @category List - * @sig (a -> Boolean) -> [a] -> a | undefined - * @param {Function} fn The predicate function used to determine if the element is the - * desired one. - * @param {Array} list The array to consider. - * @return {Object} The element found, or `undefined`. + * @sig Filterable f => (a -> Boolean) -> f a -> f a + * @param {Function} pred + * @param {Array} filterable + * @return {Array} + * @see R.reject, R.transduce, R.addIndex * @example * - * var xs = [{a: 1, b: 0}, {a:1, b: 1}]; - * R.findLast(R.propEq('a', 1))(xs); //=> {a: 1, b: 1} - * R.findLast(R.propEq('a', 4))(xs); //=> undefined - */ - var findLast = _curry2(_dispatchable('findLast', _xfindLast, function findLast(fn, list) { - var idx = list.length - 1; - while (idx >= 0) { - if (fn(list[idx])) { - return list[idx]; - } - idx -= 1; - } - })); - - /** - * Returns the index of the last element of the list which matches the predicate, or - * `-1` if no element matches. - * - * Acts as a transducer if a transformer is given in list position. - * @see R.transduce + * var isEven = n => n % 2 === 0; * - * @func - * @memberOf R - * @category List - * @sig (a -> Boolean) -> [a] -> Number - * @param {Function} fn The predicate function used to determine if the element is the - * desired one. - * @param {Array} list The array to consider. - * @return {Number} The index of the element found, or `-1`. - * @example + * R.filter(isEven, [1, 2, 3, 4]); //=> [2, 4] * - * var xs = [{a: 1, b: 0}, {a:1, b: 1}]; - * R.findLastIndex(R.propEq('a', 1))(xs); //=> 1 - * R.findLastIndex(R.propEq('a', 4))(xs); //=> -1 + * R.filter(isEven, {a: 1, b: 2, c: 3, d: 4}); //=> {b: 2, d: 4} */ - var findLastIndex = _curry2(_dispatchable('findLastIndex', _xfindLastIndex, function findLastIndex(fn, list) { - var idx = list.length - 1; - while (idx >= 0) { - if (fn(list[idx])) { - return idx; + // else + var filter = _curry2(_dispatchable('filter', _xfilter, function (pred, filterable) { + return _isObject(filterable) ? _reduce(function (acc, key) { + if (pred(filterable[key])) { + acc[key] = filterable[key]; } - idx -= 1; - } - return -1; + return acc; + }, {}, keys(filterable)) : // else + _filter(pred, filterable); })); /** - * Returns a new list by pulling every item out of it (and all its sub-arrays) and putting - * them in a new array, depth-first. + * Returns a new list by pulling every item out of it (and all its sub-arrays) + * and putting them in a new array, depth-first. * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig [a] -> [b] * @param {Array} list The array to consider. @@ -13008,20 +12289,19 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var flatten = _curry1(_makeFlat(true)); /** - * Returns a new function much like the supplied one, except that the first two arguments' - * order is reversed. + * Returns a new function much like the supplied one, except that the first two + * arguments' order is reversed. * * @func * @memberOf R + * @since v0.1.0 * @category Function * @sig (a -> b -> c -> ... -> z) -> (b -> a -> c -> ... -> z) * @param {Function} fn The function to invoke with its first two parameters reversed. * @return {*} The result of invoking `fn` with its first two parameters' order reversed. * @example * - * var mergeThree = function(a, b, c) { - * return ([]).concat(a, b, c); - * }; + * var mergeThree = (a, b, c) => [].concat(a, b, c); * * mergeThree(1, 2, 3); //=> [1, 2, 3] * @@ -13037,99 +12317,24 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Iterate over an input `list`, calling a provided function `fn` for each element in the - * list. - * - * `fn` receives one argument: *(value)*. - * - * Note: `R.forEach` does not skip deleted or unassigned indices (sparse arrays), unlike - * the native `Array.prototype.forEach` method. For more details on this behavior, see: - * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach#Description - * - * Also note that, unlike `Array.prototype.forEach`, Ramda's `forEach` returns the original - * array. In some libraries this function is named `each`. - * - * @func - * @memberOf R - * @category List - * @sig (a -> *) -> [a] -> [a] - * @param {Function} fn The function to invoke. Receives one argument, `value`. - * @param {Array} list The list to iterate over. - * @return {Array} The original list. - * @example - * - * var printXPlusFive = function(x) { console.log(x + 5); }; - * R.forEach(printXPlusFive, [1, 2, 3]); //=> [1, 2, 3] - * //-> 6 - * //-> 7 - * //-> 8 - */ - var forEach = _curry2(_checkForMethod('forEach', function forEach(fn, list) { - var len = list.length; - var idx = 0; - while (idx < len) { - fn(list[idx]); - idx += 1; - } - return list; - })); - - /** - * Returns a list of function names of object's own functions - * - * @func - * @memberOf R - * @category Object - * @sig {*} -> [String] - * @param {Object} obj The objects with functions in it - * @return {Array} A list of the object's own properties that map to functions. - * @example - * - * R.functions(R); // returns list of ramda's own function names - * - * var F = function() { this.x = function(){}; this.y = 1; } - * F.prototype.z = function() {}; - * F.prototype.a = 100; - * R.functions(new F()); //=> ["x"] - */ - var functions = _curry1(_functionsWith(keys)); - - /** - * Returns a list of function names of object's own and prototype functions - * - * @func - * @memberOf R - * @category Object - * @sig {*} -> [String] - * @param {Object} obj The objects with functions in it - * @return {Array} A list of the object's own properties and prototype - * properties that map to functions. - * @example - * - * R.functionsIn(R); // returns list of ramda's own and prototype function names + * Splits a list into sub-lists stored in an object, based on the result of + * calling a String-returning function on each element, and grouping the + * results according to values returned. * - * var F = function() { this.x = function(){}; this.y = 1; } - * F.prototype.z = function() {}; - * F.prototype.a = 100; - * R.functionsIn(new F()); //=> ["x", "z"] - */ - var functionsIn = _curry1(_functionsWith(keysIn)); - - /** - * Splits a list into sub-lists stored in an object, based on the result of calling a String-returning function - * on each element, and grouping the results according to values returned. + * Dispatches to the `groupBy` method of the second argument, if present. * * Acts as a transducer if a transformer is given in list position. - * @see R.transduce * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig (a -> String) -> [a] -> {String: [a]} * @param {Function} fn Function :: a -> String * @param {Array} list The array to group * @return {Object} An object with the output of `fn` for keys, mapped to arrays of elements * that produced that key when passed to `fn`. + * @see R.transduce * @example * * var byGrade = R.groupBy(function(student) { @@ -13165,12 +12370,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category List - * @see R.tail, R.init, R.last * @sig [a] -> a | Undefined * @sig String -> String - * @param {*} list + * @param {Array|String} list * @return {*} + * @see R.tail, R.init, R.last * @example * * R.head(['fi', 'fo', 'fum']); //=> 'fi' @@ -13181,22 +12387,77 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack */ var head = nth(0); + /** + * Given a function that generates a key, turns a list of objects into an + * object indexing the objects by the given key. Note that if multiple + * objects generate the same value for the indexing key only the last value + * will be included in the generated object. + * + * @func + * @memberOf R + * @since 0.19.1 + * @since 0.19.0 + * @category List + * @sig (a -> String) -> [{k: v}] -> {k: {k: v}} + * @param {Function} fn Function :: a -> String + * @param {Array} array The array of objects to index + * @return {Object} An object indexing each array element by the given property. + * @example + * + * var list = [{id: 'xyz', title: 'A'}, {id: 'abc', title: 'B'}]; + * R.indexBy(R.prop('id'), list); + * //=> {abc: {id: 'abc', title: 'B'}, xyz: {id: 'xyz', title: 'A'}} + */ + var indexBy = _curry2(function indexBy(fn, list) { + return _reduce(function (acc, elem) { + var key = fn(elem); + acc[key] = elem; + return acc; + }, {}, list); + }); + + /** + * Returns all but the last element of the given list or string. + * + * @func + * @memberOf R + * @since v0.9.0 + * @category List + * @sig [a] -> [a] + * @sig String -> String + * @param {*} list + * @return {*} + * @see R.last, R.head, R.tail + * @example + * + * R.init([1, 2, 3]); //=> [1, 2] + * R.init([1, 2]); //=> [1] + * R.init([1]); //=> [] + * R.init([]); //=> [] + * + * R.init('abc'); //=> 'ab' + * R.init('ab'); //=> 'a' + * R.init('a'); //=> '' + * R.init(''); //=> '' + */ + var init = slice(0, -1); + /** * Combines two lists into a set (i.e. no duplicates) composed of those - * elements common to both lists. Duplication is determined according - * to the value returned by applying the supplied predicate to two list - * elements. + * elements common to both lists. Duplication is determined according to the + * value returned by applying the supplied predicate to two list elements. * * @func * @memberOf R + * @since v0.1.0 * @category Relation - * @sig (a,a -> Boolean) -> [a] -> [a] -> [a] + * @sig (a -> a -> Boolean) -> [*] -> [*] -> [*] * @param {Function} pred A predicate function that determines whether * the two supplied elements are equal. * @param {Array} list1 One list of items to compare * @param {Array} list2 A second list of items to compare - * @see R.intersection * @return {Array} A new list containing those elements common to both lists. + * @see R.intersection * @example * * var buffaloSpringfield = [ @@ -13213,13 +12474,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * {id: 177, name: 'Neil Young'} * ]; * - * var sameId = function(o1, o2) {return o1.id === o2.id;}; - * - * R.intersectionWith(sameId, buffaloSpringfield, csny); + * R.intersectionWith(R.eqBy(R.prop('id')), buffaloSpringfield, csny); * //=> [{id: 456, name: 'Stephen Stills'}, {id: 177, name: 'Neil Young'}] */ var intersectionWith = _curry3(function intersectionWith(pred, list1, list2) { - var results = [], idx = 0; + var results = []; + var idx = 0; while (idx < list1.length) { if (_containsWith(pred, list1[idx], list2)) { results[results.length] = list1[idx]; @@ -13230,97 +12490,30 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Creates a new list with the separator interposed between elements. + * Same as R.invertObj, however this accounts for objects with duplicate values + * by putting the values into an array. * * @func * @memberOf R - * @category List - * @sig a -> [a] -> [a] - * @param {*} separator The element to add to the list. - * @param {Array} list The list to be interposed. - * @return {Array} The new list. + * @since v0.9.0 + * @category Object + * @sig {s: x} -> {x: [ s, ... ]} + * @param {Object} obj The object or array to invert + * @return {Object} out A new object with keys + * in an array. * @example * - * R.intersperse('n', ['ba', 'a', 'a']); //=> ['ba', 'n', 'a', 'n', 'a'] + * var raceResultsByFirstName = { + * first: 'alice', + * second: 'jake', + * third: 'alice', + * }; + * R.invert(raceResultsByFirstName); + * //=> { 'alice': ['first', 'third'], 'jake':['second'] } */ - var intersperse = _curry2(_checkForMethod('intersperse', function intersperse(separator, list) { - var out = []; - var idx = 0; - var length = list.length; - while (idx < length) { - if (idx === length - 1) { - out.push(list[idx]); - } else { - out.push(list[idx], separator); - } - idx += 1; - } - return out; - })); - - /** - * Transforms the items of the list with the transducer and appends the transformed items to - * the accumulator using an appropriate iterator function based on the accumulator type. - * - * The accumulator can be an array, string, object or a transformer. Iterated items will - * be appended to arrays and concatenated to strings. Objects will be merged directly or 2-item - * arrays will be merged as key, value pairs. - * - * The accumulator can also be a transformer object that provides a 2-arity reducing iterator - * function, step, 0-arity initial value function, init, and 1-arity result extraction function - * result. The step function is used as the iterator function in reduce. The result function is - * used to convert the final accumulator into the return type and in most cases is R.identity. - * The init function is used to provide the initial accumulator. - * - * The iteration is performed with R.reduce after initializing the transducer. - * - * @func - * @memberOf R - * @category List - * @sig a -> (b -> b) -> [c] -> a - * @param {*} acc The initial accumulator value. - * @param {Function} xf The transducer function. Receives a transformer and returns a transformer. - * @param {Array} list The list to iterate over. - * @return {*} The final, accumulated value. - * @example - * - * var numbers = [1, 2, 3, 4]; - * var transducer = R.compose(R.map(R.add(1)), R.take(2)); - * - * R.into([], transducer, numbers); //=> [2, 3] - * - * var intoArray = R.into([]); - * intoArray(transducer, numbers); //=> [2, 3] - */ - var into = _curry3(function into(acc, xf, list) { - return _isTransformer(acc) ? _reduce(xf(acc), acc['@@transducer/init'](), list) : _reduce(xf(_stepCat(acc)), acc, list); - }); - - /** - * Same as R.invertObj, however this accounts for objects - * with duplicate values by putting the values into an - * array. - * - * @func - * @memberOf R - * @category Object - * @sig {s: x} -> {x: [ s, ... ]} - * @param {Object} obj The object or array to invert - * @return {Object} out A new object with keys - * in an array. - * @example - * - * var raceResultsByFirstName = { - * first: 'alice', - * second: 'jake', - * third: 'alice', - * }; - * R.invert(raceResultsByFirstName); - * //=> { 'alice': ['first', 'third'], 'jake':['second'] } - */ - var invert = _curry1(function invert(obj) { - var props = keys(obj); - var len = props.length; + var invert = _curry1(function invert(obj) { + var props = keys(obj); + var len = props.length; var idx = 0; var out = {}; while (idx < len) { @@ -13334,11 +12527,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a new object with the keys of the given object - * as values, and the values of the given object as keys. + * Returns a new object with the keys of the given object as values, and the + * values of the given object, which are coerced to strings, as keys. Note + * that the last key found is preferred when handling the same value. * * @func * @memberOf R + * @since v0.9.0 * @category Object * @sig {s: x} -> {x: s} * @param {Object} obj The object or array to invert @@ -13370,17 +12565,43 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return out; }); + /** + * Returns `true` if the given value is its type's empty value; `false` + * otherwise. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category Logic + * @sig a -> Boolean + * @param {*} x + * @return {Boolean} + * @see R.empty + * @example + * + * R.isEmpty([1, 2, 3]); //=> false + * R.isEmpty([]); //=> true + * R.isEmpty(''); //=> true + * R.isEmpty(null); //=> false + * R.isEmpty({}); //=> true + * R.isEmpty({length: 0}); //=> false + */ + var isEmpty = _curry1(function isEmpty(x) { + return x != null && equals(x, empty(x)); + }); + /** * Returns the last element of the given list or string. * * @func * @memberOf R + * @since v0.1.4 * @category List - * @see R.init, R.head, R.tail * @sig [a] -> a | Undefined * @sig String -> String * @param {*} list * @return {*} + * @see R.init, R.head, R.tail * @example * * R.last(['fi', 'fo', 'fum']); //=> 'fum' @@ -13392,12 +12613,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var last = nth(-1); /** - * Returns the position of the last occurrence of an item in - * an array, or -1 if the item is not included in the array. - * `R.equals` is used to determine equality. + * Returns the position of the last occurrence of an item in an array, or -1 if + * the item is not included in the array. `R.equals` is used to determine + * equality. * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig a -> [a] -> Number * @param {*} target The item to find. @@ -13410,7 +12632,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * R.lastIndexOf(10, [1,2,3,4]); //=> -1 */ var lastIndexOf = _curry2(function lastIndexOf(target, xs) { - if (_hasMethod('lastIndexOf', xs)) { + if (typeof xs.lastIndexOf === 'function' && !_isArray(xs)) { return xs.lastIndexOf(target); } else { var idx = xs.length - 1; @@ -13425,82 +12647,71 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a new list, constructed by applying the supplied function to every element of the - * supplied list. + * Takes a function and + * a [functor](https://github.com/fantasyland/fantasy-land#functor), + * applies the function to each of the functor's values, and returns + * a functor of the same shape. * - * Note: `R.map` does not skip deleted or unassigned indices (sparse arrays), unlike the - * native `Array.prototype.map` method. For more details on this behavior, see: - * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map#Description + * Ramda provides suitable `map` implementations for `Array` and `Object`, + * so this function may be applied to `[1, 2, 3]` or `{x: 1, y: 2, z: 3}`. + * + * Dispatches to the `map` method of the second argument, if present. * * Acts as a transducer if a transformer is given in list position. - * @see R.transduce + * + * Also treats functions as functors and will compose them together. * * @func * @memberOf R + * @since v0.1.0 * @category List - * @sig (a -> b) -> [a] -> [b] + * @sig Functor f => (a -> b) -> f a -> f b * @param {Function} fn The function to be called on every element of the input `list`. * @param {Array} list The list to be iterated over. * @return {Array} The new list. + * @see R.transduce, R.addIndex * @example * - * var double = function(x) { - * return x * 2; - * }; + * var double = x => x * 2; * * R.map(double, [1, 2, 3]); //=> [2, 4, 6] - */ - var map = _curry2(_dispatchable('map', _xmap, _map)); - - /** - * Map, but for objects. Creates an object with the same keys as `obj` and values - * generated by running each property of `obj` through `fn`. `fn` is passed one argument: - * *(value)*. - * - * @func - * @memberOf R - * @category Object - * @sig (v -> v) -> {k: v} -> {k: v} - * @param {Function} fn A function called for each property in `obj`. Its return value will - * become a new property on the return object. - * @param {Object} obj The object to iterate over. - * @return {Object} A new object with the same keys as `obj` and values that are the result - * of running each property through `fn`. - * @example * - * var values = { x: 1, y: 2, z: 3 }; - * var double = function(num) { - * return num * 2; - * }; - * - * R.mapObj(double, values); //=> { x: 2, y: 4, z: 6 } + * R.map(double, {x: 1, y: 2, z: 3}); //=> {x: 2, y: 4, z: 6} */ - var mapObj = _curry2(function mapObj(fn, obj) { - return _reduce(function (acc, key) { - acc[key] = fn(obj[key]); - return acc; - }, {}, keys(obj)); - }); + var map = _curry2(_dispatchable('map', _xmap, function map(fn, functor) { + switch (Object.prototype.toString.call(functor)) { + case '[object Function]': + return curryN(functor.length, function () { + return fn.call(this, functor.apply(this, arguments)); + }); + case '[object Object]': + return _reduce(function (acc, key) { + acc[key] = fn(functor[key]); + return acc; + }, {}, keys(functor)); + default: + return _map(fn, functor); + } + })); /** - * Like `mapObj`, but but passes additional arguments to the predicate function. The - * predicate function is passed three arguments: *(value, key, obj)*. + * An Object-specific version of `map`. The function is applied to three + * arguments: *(value, key, obj)*. If only the value is significant, use + * `map` instead. * * @func * @memberOf R + * @since v0.9.0 * @category Object - * @sig (v, k, {k: v} -> v) -> {k: v} -> {k: v} - * @param {Function} fn A function called for each property in `obj`. Its return value will - * become a new property on the return object. - * @param {Object} obj The object to iterate over. - * @return {Object} A new object with the same keys as `obj` and values that are the result - * of running each property through `fn`. + * @sig ((*, String, Object) -> *) -> Object -> Object + * @param {Function} fn + * @param {Object} obj + * @return {Object} + * @see R.map * @example * * var values = { x: 1, y: 2, z: 3 }; - * var prependKeyAndDouble = function(num, key, obj) { - * return key + (num * 2); - * }; + * var prependKeyAndDouble = (num, key, obj) => key + (num * 2); * * R.mapObjIndexed(prependKeyAndDouble, values); //=> { x: 'x2', y: 'y4', z: 'z6' } */ @@ -13512,116 +12723,104 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns `true` if no elements of the list match the predicate, - * `false` otherwise. - * - * @func - * @memberOf R - * @category List - * @sig (a -> Boolean) -> [a] -> Boolean - * @param {Function} fn The predicate function. - * @param {Array} list The array to consider. - * @return {Boolean} `true` if the predicate is not satisfied by every element, `false` otherwise. - * @see R.all, R.any - * @example - * - * R.none(R.isNaN, [1, 2, 3]); //=> true - * R.none(R.isNaN, [1, 2, 3, NaN]); //=> false - */ - var none = _curry2(_complement(_dispatchable('any', _xany, any))); - - /** - * A function that returns the first truthy of two arguments otherwise the - * last argument. Note that this is NOT short-circuited, meaning that if - * expressions are passed they are both evaluated. - * - * Dispatches to the `or` method of the first argument if applicable. + * Creates a new object with the own properties of the two provided objects. If + * a key exists in both objects, the provided function is applied to the values + * associated with the key in each object, with the result being used as the + * value associated with the key in the returned object. The key will be + * excluded from the returned object if the resulting value is `undefined`. * * @func * @memberOf R - * @category Logic - * @sig * -> * -> * - * @param {*} a any value - * @param {*} b any other value - * @return {*} the first truthy argument, otherwise the last argument. - * @see R.either + * @since 0.19.1 + * @since 0.19.0 + * @category Object + * @sig (a -> a -> a) -> {a} -> {a} -> {a} + * @param {Function} fn + * @param {Object} l + * @param {Object} r + * @return {Object} + * @see R.merge, R.mergeWithKey * @example * - * R.or(false, true); //=> true - * R.or(0, []); //=> [] - * R.or(null, ''); => '' + * R.mergeWith(R.concat, + * { a: true, values: [10, 20] }, + * { b: true, values: [15, 35] }); + * //=> { a: true, b: true, values: [10, 20, 15, 35] } */ - var or = _curry2(function or(a, b) { - return _hasMethod('or', a) ? a.or(b) : a || b; + var mergeWith = _curry3(function mergeWith(fn, l, r) { + return mergeWithKey(function (_, _l, _r) { + return fn(_l, _r); + }, l, r); }); /** - * Accepts as its arguments a function and any number of values and returns a function that, - * when invoked, calls the original function with all of the values prepended to the - * original function's arguments list. In some libraries this function is named `applyLeft`. + * Takes a function `f` and a list of arguments, and returns a function `g`. + * When applied, `g` returns the result of applying `f` to the arguments + * provided initially followed by the arguments provided to `g`. * * @func * @memberOf R + * @since v0.10.0 * @category Function - * @sig (a -> b -> ... -> i -> j -> ... -> m -> n) -> a -> b-> ... -> i -> (j -> ... -> m -> n) - * @param {Function} fn The function to invoke. - * @param {...*} [args] Arguments to prepend to `fn` when the returned function is invoked. - * @return {Function} A new function wrapping `fn`. When invoked, it will call `fn` - * with `args` prepended to `fn`'s arguments list. + * @sig ((a, b, c, ..., n) -> x) -> [a, b, c, ...] -> ((d, e, f, ..., n) -> x) + * @param {Function} f + * @param {Array} args + * @return {Function} + * @see R.partialRight * @example * - * var multiply = function(a, b) { return a * b; }; - * var double = R.partial(multiply, 2); + * var multiply = (a, b) => a * b; + * var double = R.partial(multiply, [2]); * double(2); //=> 4 * - * var greet = function(salutation, title, firstName, lastName) { - * return salutation + ', ' + title + ' ' + firstName + ' ' + lastName + '!'; - * }; - * var sayHello = R.partial(greet, 'Hello'); - * var sayHelloToMs = R.partial(sayHello, 'Ms.'); + * var greet = (salutation, title, firstName, lastName) => + * salutation + ', ' + title + ' ' + firstName + ' ' + lastName + '!'; + * + * var sayHello = R.partial(greet, ['Hello']); + * var sayHelloToMs = R.partial(sayHello, ['Ms.']); * sayHelloToMs('Jane', 'Jones'); //=> 'Hello, Ms. Jane Jones!' */ - var partial = curry(_createPartialApplicator(_concat)); + var partial = _createPartialApplicator(_concat); /** - * Accepts as its arguments a function and any number of values and returns a function that, - * when invoked, calls the original function with all of the values appended to the original - * function's arguments list. - * - * Note that `partialRight` is the opposite of `partial`: `partialRight` fills `fn`'s arguments - * from the right to the left. In some libraries this function is named `applyRight`. + * Takes a function `f` and a list of arguments, and returns a function `g`. + * When applied, `g` returns the result of applying `f` to the arguments + * provided to `g` followed by the arguments provided initially. * * @func * @memberOf R + * @since v0.10.0 * @category Function - * @sig (a -> b-> ... -> i -> j -> ... -> m -> n) -> j -> ... -> m -> n -> (a -> b-> ... -> i) - * @param {Function} fn The function to invoke. - * @param {...*} [args] Arguments to append to `fn` when the returned function is invoked. - * @return {Function} A new function wrapping `fn`. When invoked, it will call `fn` with - * `args` appended to `fn`'s arguments list. + * @sig ((a, b, c, ..., n) -> x) -> [d, e, f, ..., n] -> ((a, b, c, ...) -> x) + * @param {Function} f + * @param {Array} args + * @return {Function} + * @see R.partial * @example * - * var greet = function(salutation, title, firstName, lastName) { - * return salutation + ', ' + title + ' ' + firstName + ' ' + lastName + '!'; - * }; - * var greetMsJaneJones = R.partialRight(greet, 'Ms.', 'Jane', 'Jones'); + * var greet = (salutation, title, firstName, lastName) => + * salutation + ', ' + title + ' ' + firstName + ' ' + lastName + '!'; + * + * var greetMsJaneJones = R.partialRight(greet, ['Ms.', 'Jane', 'Jones']); * * greetMsJaneJones('Hello'); //=> 'Hello, Ms. Jane Jones!' */ - var partialRight = curry(_createPartialApplicator(flip(_concat))); + var partialRight = _createPartialApplicator(flip(_concat)); /** - * Takes a predicate and a list and returns the pair of lists of - * elements which do and do not satisfy the predicate, respectively. + * Takes a predicate and a list and returns the pair of lists of elements which + * do and do not satisfy the predicate, respectively. * * @func * @memberOf R + * @since v0.1.4 * @category List * @sig (a -> Boolean) -> [a] -> [[a],[a]] * @param {Function} pred A predicate to determine which array the element belongs to. * @param {Array} list The array to partition. * @return {Array} A nested array, containing first an array of elements that satisfied the predicate, * and second an array of elements that did not satisfy. + * @see R.filter, R.reject * @example * * R.partition(R.contains('s'), ['sss', 'ttt', 'foo', 'bars']); @@ -13639,11 +12838,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Determines whether a nested path on an object has a specific value, - * in `R.equals` terms. Most likely used to filter a list. + * Determines whether a nested path on an object has a specific value, in + * `R.equals` terms. Most likely used to filter a list. * * @func * @memberOf R + * @since v0.7.0 * @category Relation * @sig [String] -> * -> {String: *} -> Boolean * @param {Array} path The path of the nested property to use @@ -13665,15 +12865,18 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a new list by plucking the same named property off all objects in the list supplied. + * Returns a new list by plucking the same named property off all objects in + * the list supplied. * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig k -> [{k: v}] -> [v] * @param {Number|String} key The key name to pluck off of each object. * @param {Array} list The array to consider. * @return {Array} The list of values for the given key. + * @see R.props * @example * * R.pluck('a')([{a: 1}, {a: 2}]); //=> [1, 2] @@ -13683,12 +12886,38 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return map(prop(p), list); }); + /** + * Reasonable analog to SQL `select` statement. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category Object + * @category Relation + * @sig [k] -> [{k: v}] -> [{k: v}] + * @param {Array} props The property names to project + * @param {Array} objs The objects to query + * @return {Array} An array of objects with just the `props` properties. + * @example + * + * var abby = {name: 'Abby', age: 7, hair: 'blond', grade: 2}; + * var fred = {name: 'Fred', age: 12, hair: 'brown', grade: 7}; + * var kids = [abby, fred]; + * R.project(['name', 'grade'], kids); //=> [{name: 'Abby', grade: 2}, {name: 'Fred', grade: 7}] + */ + // passing `identity` gives correct arity + var project = useWith(_map, [ + pickAll, + identity + ]); + /** * Returns `true` if the specified object property is equal, in `R.equals` * terms, to the given value; `false` otherwise. * * @func * @memberOf R + * @since v0.1.0 * @category Relation * @sig String -> a -> Object -> Boolean * @param {String} name @@ -13716,14 +12945,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.16.0 * @category Type * @sig Type -> String -> Object -> Boolean * @param {Function} type * @param {String} name * @param {*} obj * @return {Boolean} - * @see R.is - * @see R.propSatisfies + * @see R.is, R.propSatisfies * @example * * R.propIs(Number, 'x', {x: 1, y: 2}); //=> true @@ -13735,62 +12964,64 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a single item by iterating through the list, successively calling the iterator - * function and passing it an accumulator value and the current value from the array, and - * then passing the result to the next call. + * Returns a single item by iterating through the list, successively calling + * the iterator function and passing it an accumulator value and the current + * value from the array, and then passing the result to the next call. * - * The iterator function receives two values: *(acc, value)*. It may use `R.reduced` to - * shortcut the iteration. + * The iterator function receives two values: *(acc, value)*. It may use + * `R.reduced` to shortcut the iteration. * - * Note: `R.reduce` does not skip deleted or unassigned indices (sparse arrays), unlike - * the native `Array.prototype.reduce` method. For more details on this behavior, see: + * Note: `R.reduce` does not skip deleted or unassigned indices (sparse + * arrays), unlike the native `Array.prototype.reduce` method. For more details + * on this behavior, see: * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce#Description - * @see R.reduced + * + * Dispatches to the `reduce` method of the third argument, if present. * * @func * @memberOf R + * @since v0.1.0 * @category List - * @sig (a,b -> a) -> a -> [b] -> a + * @sig ((a, b) -> a) -> a -> [b] -> a * @param {Function} fn The iterator function. Receives two values, the accumulator and the * current element from the array. * @param {*} acc The accumulator value. * @param {Array} list The list to iterate over. * @return {*} The final, accumulated value. + * @see R.reduced, R.addIndex * @example * * var numbers = [1, 2, 3]; - * var add = function(a, b) { - * return a + b; - * }; + * var add = (a, b) => a + b; * * R.reduce(add, 10, numbers); //=> 16 */ var reduce = _curry3(_reduce); /** - * Similar to `filter`, except that it keeps only values for which the given predicate - * function returns falsy. The predicate function is passed one argument: *(value)*. + * The complement of `filter`. * * Acts as a transducer if a transformer is given in list position. - * @see R.transduce * * @func * @memberOf R + * @since v0.1.0 * @category List - * @sig (a -> Boolean) -> [a] -> [a] - * @param {Function} fn The function called per iteration. - * @param {Array} list The collection to iterate over. - * @return {Array} The new filtered array. - * @see R.filter + * @sig Filterable f => (a -> Boolean) -> f a -> f a + * @param {Function} pred + * @param {Array} filterable + * @return {Array} + * @see R.filter, R.transduce, R.addIndex * @example * - * var isOdd = function(n) { - * return n % 2 === 1; - * }; + * var isOdd = (n) => n % 2 === 1; + * * R.reject(isOdd, [1, 2, 3, 4]); //=> [2, 4] + * + * R.reject(isOdd, {a: 1, b: 2, c: 3, d: 4}); //=> {b: 2, d: 4} */ - var reject = _curry2(function reject(fn, list) { - return filter(_complement(fn), list); + var reject = _curry2(function reject(pred, filterable) { + return filter(_complement(pred), filterable); }); /** @@ -13798,6 +13029,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.1 * @category List * @sig a -> n -> [a] * @param {*} value The value to repeat. @@ -13815,64 +13047,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return times(always(value), n); }); - /** - * Returns the elements of the given list or string (or object with a `slice` - * method) from `fromIndex` (inclusive) to `toIndex` (exclusive). - * - * @func - * @memberOf R - * @category List - * @sig Number -> Number -> [a] -> [a] - * @sig Number -> Number -> String -> String - * @param {Number} fromIndex The start index (inclusive). - * @param {Number} toIndex The end index (exclusive). - * @param {*} list - * @return {*} - * @example - * - * R.slice(1, 3, ['a', 'b', 'c', 'd']); //=> ['b', 'c'] - * R.slice(1, Infinity, ['a', 'b', 'c', 'd']); //=> ['b', 'c', 'd'] - * R.slice(0, -1, ['a', 'b', 'c', 'd']); //=> ['a', 'b', 'c'] - * R.slice(-3, -1, ['a', 'b', 'c', 'd']); //=> ['b', 'c'] - * R.slice(0, 3, 'ramda'); //=> 'ram' - */ - var slice = _curry3(_checkForMethod('slice', function slice(fromIndex, toIndex, list) { - return Array.prototype.slice.call(list, fromIndex, toIndex); - })); - - /** - * Splits a collection into slices of the specified length. - * - * @func - * @memberOf R - * @category List - * @sig Number -> [a] -> [[a]] - * @sig Number -> String -> [String] - * @param {Number} n - * @param {Array} list - * @return {Array} - * @example - * - * R.splitEvery(3, [1, 2, 3, 4, 5, 6, 7]); //=> [[1, 2, 3], [4, 5, 6], [7]] - * R.splitEvery(3, 'foobarbaz'); //=> ['foo', 'bar', 'baz'] - */ - var splitEvery = _curry2(function splitEvery(n, list) { - if (n <= 0) { - throw new Error('First argument to splitEvery must be a positive integer'); - } - var result = []; - var idx = 0; - while (idx < list.length) { - result.push(slice(idx, idx += n, list)); - } - return result; - }); - /** * Adds together all the elements of a list. * * @func * @memberOf R + * @since v0.1.0 * @category Math * @sig [Number] -> Number * @param {Array} list An array of numbers @@ -13885,130 +13065,59 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var sum = reduce(add, 0); /** - * Returns all but the first element of the given list or string (or object - * with a `tail` method). + * Returns a new list containing the last `n` elements of the given list. + * If `n > list.length`, returns a list of `list.length` elements. * * @func * @memberOf R + * @since v0.16.0 * @category List - * @see R.head, R.init, R.last - * @sig [a] -> [a] - * @sig String -> String - * @param {*} list - * @return {*} + * @sig Number -> [a] -> [a] + * @sig Number -> String -> String + * @param {Number} n The number of elements to return. + * @param {Array} xs The collection to consider. + * @return {Array} + * @see R.dropLast * @example * - * R.tail([1, 2, 3]); //=> [2, 3] - * R.tail([1, 2]); //=> [2] - * R.tail([1]); //=> [] - * R.tail([]); //=> [] - * - * R.tail('abc'); //=> 'bc' - * R.tail('ab'); //=> 'b' - * R.tail('a'); //=> '' - * R.tail(''); //=> '' + * R.takeLast(1, ['foo', 'bar', 'baz']); //=> ['baz'] + * R.takeLast(2, ['foo', 'bar', 'baz']); //=> ['bar', 'baz'] + * R.takeLast(3, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] + * R.takeLast(4, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] + * R.takeLast(3, 'ramda'); //=> 'mda' */ - var tail = _checkForMethod('tail', slice(1, Infinity)); + var takeLast = _curry2(function takeLast(n, xs) { + return drop(n >= 0 ? xs.length - n : 0, xs); + }); /** - * Returns the first `n` elements of the given list, string, or - * transducer/transformer (or object with a `take` method). - * - * @func - * @memberOf R - * @category List - * @sig Number -> [a] -> [a] - * @sig Number -> String -> String - * @param {Number} n - * @param {*} list - * @return {*} - * @see R.drop - * @example - * - * R.take(1, ['foo', 'bar', 'baz']); //=> ['foo'] - * R.take(2, ['foo', 'bar', 'baz']); //=> ['foo', 'bar'] - * R.take(3, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] - * R.take(4, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] - * R.take(3, 'ramda'); //=> 'ram' - * - * var personnel = [ - * 'Dave Brubeck', - * 'Paul Desmond', - * 'Eugene Wright', - * 'Joe Morello', - * 'Gerry Mulligan', - * 'Bob Bates', - * 'Joe Dodge', - * 'Ron Crotty' - * ]; - * - * var takeFive = R.take(5); - * takeFive(personnel); - * //=> ['Dave Brubeck', 'Paul Desmond', 'Eugene Wright', 'Joe Morello', 'Gerry Mulligan'] - */ - var take = _curry2(_dispatchable('take', _xtake, function take(n, xs) { - return slice(0, n < 0 ? Infinity : n, xs); - })); - - /** - * Returns a new list containing the first `n` elements of a given list, passing each value - * to the supplied predicate function, and terminating when the predicate function returns - * `false`. Excludes the element that caused the predicate function to fail. The predicate - * function is passed one argument: *(value)*. - * - * Acts as a transducer if a transformer is given in list position. - * @see R.transduce - * - * @func - * @memberOf R - * @category List - * @sig (a -> Boolean) -> [a] -> [a] - * @param {Function} fn The function called per iteration. - * @param {Array} list The collection to iterate over. - * @return {Array} A new array. - * @see R.dropWhile - * @example - * - * var isNotFour = function(x) { - * return !(x === 4); - * }; - * - * R.takeWhile(isNotFour, [1, 2, 3, 4]); //=> [1, 2, 3] - */ - var takeWhile = _curry2(_dispatchable('takeWhile', _xtakeWhile, function takeWhile(fn, list) { - var idx = 0, len = list.length; - while (idx < len && fn(list[idx])) { - idx += 1; - } - return _slice(list, 0, idx); - })); - - /** - * Initializes a transducer using supplied iterator function. Returns a single item by - * iterating through the list, successively calling the transformed iterator function and - * passing it an accumulator value and the current value from the array, and then passing - * the result to the next call. + * Initializes a transducer using supplied iterator function. Returns a single + * item by iterating through the list, successively calling the transformed + * iterator function and passing it an accumulator value and the current value + * from the array, and then passing the result to the next call. * - * The iterator function receives two values: *(acc, value)*. It will be wrapped as a - * transformer to initialize the transducer. A transformer can be passed directly in place - * of an iterator function. In both cases, iteration may be stopped early with the - * `R.reduced` function. + * The iterator function receives two values: *(acc, value)*. It will be + * wrapped as a transformer to initialize the transducer. A transformer can be + * passed directly in place of an iterator function. In both cases, iteration + * may be stopped early with the `R.reduced` function. * - * A transducer is a function that accepts a transformer and returns a transformer and can - * be composed directly. + * A transducer is a function that accepts a transformer and returns a + * transformer and can be composed directly. * - * A transformer is an an object that provides a 2-arity reducing iterator function, step, - * 0-arity initial value function, init, and 1-arity result extraction function, result. - * The step function is used as the iterator function in reduce. The result function is used - * to convert the final accumulator into the return type and in most cases is R.identity. - * The init function can be used to provide an initial accumulator, but is ignored by transduce. + * A transformer is an an object that provides a 2-arity reducing iterator + * function, step, 0-arity initial value function, init, and 1-arity result + * extraction function, result. The step function is used as the iterator + * function in reduce. The result function is used to convert the final + * accumulator into the return type and in most cases is R.identity. The init + * function can be used to provide an initial accumulator, but is ignored by + * transduce. * * The iteration is performed with R.reduce after initializing the transducer. * * @func * @memberOf R + * @since v0.12.0 * @category List - * @see R.reduce, R.reduced, R.into * @sig (c -> c) -> (a,b -> a) -> a -> [b] -> a * @param {Function} xf The transducer function. Receives a transformer and returns a transformer. * @param {Function} fn The iterator function. Receives two values, the accumulator and the @@ -14017,6 +13126,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @param {*} acc The initial accumulator value. * @param {Array} list The list to iterate over. * @return {*} The final, accumulated value. + * @see R.reduce, R.reduced, R.into * @example * * var numbers = [1, 2, 3, 4]; @@ -14029,13 +13139,15 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Combines two lists into a set (i.e. no duplicates) composed of the elements of each list. Duplication is - * determined according to the value returned by applying the supplied predicate to two list elements. + * Combines two lists into a set (i.e. no duplicates) composed of the elements + * of each list. Duplication is determined according to the value returned by + * applying the supplied predicate to two list elements. * * @func * @memberOf R + * @since v0.1.0 * @category Relation - * @sig (a,a -> Boolean) -> [a] -> [a] -> [a] + * @sig (a -> a -> Boolean) -> [*] -> [*] -> [*] * @param {Function} pred A predicate used to test whether two items are equal. * @param {Array} list1 The first list. * @param {Array} list2 The second list. @@ -14044,111 +13156,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @see R.union * @example * - * function cmp(x, y) { return x.a === y.a; } * var l1 = [{a: 1}, {a: 2}]; * var l2 = [{a: 1}, {a: 4}]; - * R.unionWith(cmp, l1, l2); //=> [{a: 1}, {a: 2}, {a: 4}] + * R.unionWith(R.eqBy(R.prop('a')), l1, l2); //=> [{a: 1}, {a: 2}, {a: 4}] */ var unionWith = _curry3(function unionWith(pred, list1, list2) { return uniqWith(pred, _concat(list1, list2)); }); - /** - * Returns a new list containing only one copy of each element in the original list. - * `R.equals` is used to determine equality. - * - * @func - * @memberOf R - * @category List - * @sig [a] -> [a] - * @param {Array} list The array to consider. - * @return {Array} The list of unique items. - * @example - * - * R.uniq([1, 1, 2, 1]); //=> [1, 2] - * R.uniq([1, '1']); //=> [1, '1'] - * R.uniq([[42], [42]]); //=> [[42]] - */ - var uniq = uniqWith(equals); - - /** - * Returns a new list by pulling every item at the first level of nesting out, and putting - * them in a new array. - * - * @func - * @memberOf R - * @category List - * @sig [a] -> [b] - * @param {Array} list The array to consider. - * @return {Array} The flattened list. - * @see R.flatten - * @example - * - * R.unnest([1, [2], [[3]]]); //=> [1, 2, [3]] - * R.unnest([[1, 2], [3, 4], [5, 6]]); //=> [1, 2, 3, 4, 5, 6] - */ - var unnest = _curry1(_makeFlat(false)); - - /** - * Accepts a function `fn` and any number of transformer functions and returns a new - * function. When the new function is invoked, it calls the function `fn` with parameters - * consisting of the result of calling each supplied handler on successive arguments to the - * new function. - * - * If more arguments are passed to the returned function than transformer functions, those - * arguments are passed directly to `fn` as additional parameters. If you expect additional - * arguments that don't need to be transformed, although you can ignore them, it's best to - * pass an identity function so that the new function reports the correct arity. - * - * @func - * @memberOf R - * @category Function - * @sig (x1 -> x2 -> ... -> z) -> ((a -> x1), (b -> x2), ...) -> (a -> b -> ... -> z) - * @param {Function} fn The function to wrap. - * @param {...Function} transformers A variable number of transformer functions - * @return {Function} The wrapped function. - * @example - * - * var double = function(y) { return y * 2; }; - * var square = function(x) { return x * x; }; - * var add = function(a, b) { return a + b; }; - * // Adds any number of arguments together - * var addAll = function() { - * return R.reduce(add, 0, arguments); - * }; - * - * // Basic example - * var addDoubleAndSquare = R.useWith(addAll, double, square); - * - * //≅ addAll(double(10), square(5)); - * addDoubleAndSquare(10, 5); //=> 45 - * - * // Example of passing more arguments than transformers - * //≅ addAll(double(10), square(5), 100); - * addDoubleAndSquare(10, 5, 100); //=> 145 - * - * // If there are extra _expected_ arguments that don't need to be transformed, although - * // you can ignore them, it might be best to pass in the identity function so that the new - * // function correctly reports arity. - * var addDoubleAndSquareWithExtraParams = R.useWith(addAll, double, square, R.identity); - * // addDoubleAndSquareWithExtraParams.length //=> 3 - * //≅ addAll(double(10), square(5), R.identity(100)); - * addDoubleAndSquare(10, 5, 100); //=> 145 - */ - /*, transformers */ - var useWith = curry(function useWith(fn) { - var transformers = _slice(arguments, 1); - var tlen = transformers.length; - return curry(_arity(tlen, function () { - var args = [], idx = 0; - while (idx < tlen) { - args[idx] = transformers[idx](arguments[idx]); - idx += 1; - } - return fn.apply(this, args.concat(_slice(arguments, tlen))); - })); - }); - /** * Takes a spec object and a test object; returns true if the test satisfies * the spec, false otherwise. An object satisfies the spec if, for each of the @@ -14159,6 +13174,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.14.0 * @category Object * @sig {String: *} -> {String: *} -> Boolean * @param {Object} spec @@ -14176,7 +13192,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * pred({a: 1, b: 1}); //=> false */ var whereEq = _curry2(function whereEq(spec, testObj) { - return where(mapObj(equals, spec), testObj); + return where(map(equals, spec), testObj); }); var _flatCat = function () { @@ -14206,10 +13222,59 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }; }(); - var _indexOf = function _indexOf(list, item, from) { - var idx = from; + // Array.prototype.indexOf doesn't exist below IE9 + // manually crawl the list to distinguish between +0 and -0 + // NaN + // non-zero numbers can utilise Set + // all these types can utilise Set + // null can utilise Set + // anything else not covered above, defer to R.equals + var _indexOf = function _indexOf(list, a, idx) { + var inf, item; + // Array.prototype.indexOf doesn't exist below IE9 + if (typeof list.indexOf === 'function') { + switch (typeof a) { + case 'number': + if (a === 0) { + // manually crawl the list to distinguish between +0 and -0 + inf = 1 / a; + while (idx < list.length) { + item = list[idx]; + if (item === 0 && 1 / item === inf) { + return idx; + } + idx += 1; + } + return -1; + } else if (a !== a) { + // NaN + while (idx < list.length) { + item = list[idx]; + if (typeof item === 'number' && item !== item) { + return idx; + } + idx += 1; + } + return -1; + } + // non-zero numbers can utilise Set + return list.indexOf(a, idx); + // all these types can utilise Set + case 'string': + case 'boolean': + case 'function': + case 'undefined': + return list.indexOf(a, idx); + case 'object': + if (a === null) { + // null can utilise Set + return list.indexOf(a, idx); + } + } + } + // anything else not covered above, defer to R.equals while (idx < list.length) { - if (equals(list[idx], item)) { + if (equals(list[idx], a)) { return idx; } idx += 1; @@ -14217,83 +13282,125 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return -1; }; - /** - * Create a predicate wrapper which will call a pick function (all/any) for each predicate - * - * @private - * @see R.all - * @see R.any - */ - // Call function immediately if given arguments - // Return a function which will call the predicates with the provided arguments - var _predicateWrap = function _predicateWrap(predPicker) { - return function (preds) { - var predIterator = function () { - var args = arguments; - return predPicker(function (predicate) { - return predicate.apply(null, args); - }, preds); - }; - return arguments.length > 1 ? // Call function immediately if given arguments - predIterator.apply(null, _slice(arguments, 1)) : // Return a function which will call the predicates with the provided arguments - _arity(Math.max.apply(Math, pluck('length', preds)), predIterator); - }; - }; - var _xchain = _curry2(function _xchain(f, xf) { return map(f, _flatCat(xf)); }); /** - * Given a list of predicates, returns a new predicate that will be true exactly when all of them are. + * Takes a list of predicates and returns a predicate that returns true for a + * given list of arguments if every one of the provided predicates is satisfied + * by those arguments. + * + * The function returned is a curried function whose arity matches that of the + * highest-arity predicate. * * @func * @memberOf R + * @since v0.9.0 * @category Logic * @sig [(*... -> Boolean)] -> (*... -> Boolean) - * @param {Array} list An array of predicate functions - * @param {*} optional Any arguments to pass into the predicates - * @return {Function} a function that applies its arguments to each of - * the predicates, returning `true` if all are satisfied. + * @param {Array} preds + * @return {Function} * @see R.anyPass * @example * - * var gt10 = function(x) { return x > 10; }; - * var even = function(x) { return x % 2 === 0}; - * var f = R.allPass([gt10, even]); - * f(11); //=> false - * f(12); //=> true + * var isQueen = R.propEq('rank', 'Q'); + * var isSpade = R.propEq('suit', '♠︎'); + * var isQueenOfSpades = R.allPass([isQueen, isSpade]); + * + * isQueenOfSpades({rank: 'Q', suit: '♣︎'}); //=> false + * isQueenOfSpades({rank: 'Q', suit: '♠︎'}); //=> true */ - var allPass = _curry1(_predicateWrap(all)); + var allPass = _curry1(function allPass(preds) { + return curryN(reduce(max, 0, pluck('length', preds)), function () { + var idx = 0; + var len = preds.length; + while (idx < len) { + if (!preds[idx].apply(this, arguments)) { + return false; + } + idx += 1; + } + return true; + }); + }); /** - * Given a list of predicates returns a new predicate that will be true exactly when any one of them is. + * Returns `true` if all elements are unique, in `R.equals` terms, otherwise + * `false`. + * + * @func + * @memberOf R + * @since v0.18.0 + * @category List + * @sig [a] -> Boolean + * @param {Array} list The array to consider. + * @return {Boolean} `true` if all elements are unique, else `false`. + * @example + * + * R.allUniq(['1', 1]); //=> true + * R.allUniq([1, 1]); //=> false + * R.allUniq([[42], [42]]); //=> false + */ + var allUniq = _curry1(function allUniq(list) { + var len = list.length; + var idx = 0; + while (idx < len) { + if (_indexOf(list, list[idx], idx + 1) >= 0) { + return false; + } + idx += 1; + } + return true; + }); + + /** + * Takes a list of predicates and returns a predicate that returns true for a + * given list of arguments if at least one of the provided predicates is + * satisfied by those arguments. + * + * The function returned is a curried function whose arity matches that of the + * highest-arity predicate. * * @func * @memberOf R + * @since v0.9.0 * @category Logic * @sig [(*... -> Boolean)] -> (*... -> Boolean) - * @param {Array} list An array of predicate functions - * @param {*} optional Any arguments to pass into the predicates - * @return {Function} A function that applies its arguments to each of the predicates, returning - * `true` if all are satisfied. + * @param {Array} preds + * @return {Function} * @see R.allPass * @example * - * var gt10 = function(x) { return x > 10; }; - * var even = function(x) { return x % 2 === 0}; - * var f = R.anyPass([gt10, even]); - * f(11); //=> true - * f(8); //=> true - * f(9); //=> false + * var gte = R.anyPass([R.gt, R.equals]); + * + * gte(3, 2); //=> true + * gte(2, 2); //=> true + * gte(2, 3); //=> false */ - var anyPass = _curry1(_predicateWrap(any)); + var anyPass = _curry1(function anyPass(preds) { + return curryN(reduce(max, 0, pluck('length', preds)), function () { + var idx = 0; + var len = preds.length; + while (idx < len) { + if (preds[idx].apply(this, arguments)) { + return true; + } + idx += 1; + } + return false; + }); + }); /** * ap applies a list of functions to a list of values. * + * Dispatches to the `ap` method of the second argument, if present. Also + * treats functions as applicatives. + * * @func * @memberOf R + * @since v0.3.0 * @category Function * @sig [f] -> [a] -> [f a] * @param {Array} fns An array of functions @@ -14303,20 +13410,25 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * R.ap([R.multiply(2), R.add(3)], [1,2,3]); //=> [2, 4, 6, 4, 5, 6] */ - var ap = _curry2(function ap(fns, vs) { - return _hasMethod('ap', fns) ? fns.ap(vs) : _reduce(function (acc, fn) { - return _concat(acc, map(fn, vs)); - }, [], fns); + // else + var ap = _curry2(function ap(applicative, fn) { + return typeof applicative.ap === 'function' ? applicative.ap(fn) : typeof applicative === 'function' ? curryN(Math.max(applicative.length, fn.length), function () { + return applicative.apply(this, arguments)(fn.apply(this, arguments)); + }) : // else + _reduce(function (acc, f) { + return _concat(acc, map(f, fn)); + }, [], applicative); }); /** * Returns the result of calling its first argument with the remaining * arguments. This is occasionally useful as a converging function for - * `R.converge`: the left branch can produce a function while the right - * branch produces a value to be passed to that function as an argument. + * `R.converge`: the left branch can produce a function while the right branch + * produces a value to be passed to that function as an argument. * * @func * @memberOf R + * @since v0.9.0 * @category Function * @sig (*... -> a),*... -> a * @param {Function} fn The function to apply to the remaining arguments. @@ -14329,9 +13441,10 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * R.join(''), * R.replace(/^(?!$)/gm)); * - * var format = R.converge(R.call, - * R.pipe(R.prop('indent'), indentN), - * R.prop('value')); + * var format = R.converge(R.call, [ + * R.pipe(R.prop('indent'), indentN), + * R.prop('value') + * ]); * * format({indent: 2, value: 'foo\nbar\nbaz\n'}); //=> ' foo\n bar\n baz\n' */ @@ -14340,13 +13453,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * `chain` maps a function over a list and concatenates the results. - * This implementation is compatible with the - * Fantasy-land Chain spec, and will work with types that implement that spec. - * `chain` is also known as `flatMap` in some libraries + * `chain` maps a function over a list and concatenates the results. `chain` + * is also known as `flatMap` in some libraries + * + * Dispatches to the `chain` method of the second argument, if present. * * @func * @memberOf R + * @since v0.3.0 * @category List * @sig (a -> [b]) -> [a] -> [b] * @param {Function} fn @@ -14354,50 +13468,63 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @return {Array} * @example * - * var duplicate = function(n) { - * return [n, n]; - * }; + * var duplicate = n => [n, n]; * R.chain(duplicate, [1, 2, 3]); //=> [1, 1, 2, 2, 3, 3] */ - var chain = _curry2(_dispatchable('chain', _xchain, function chain(fn, list) { - return unnest(map(fn, list)); + var chain = _curry2(_dispatchable('chain', _xchain, function chain(fn, monad) { + if (typeof monad === 'function') { + return function () { + return monad.call(this, fn.apply(this, arguments)).apply(this, arguments); + }; + } + return _makeFlat(false)(map(fn, monad)); })); /** - * Turns a list of Functors into a Functor of a list, applying - * a mapping function to the elements of the list along the way. + * Turns a list of Functors into a Functor of a list, applying a mapping + * function to the elements of the list along the way. * * @func * @memberOf R + * @since v0.8.0 * @category List - * @see R.commute - * @sig Functor f => (f a -> f b) -> (x -> f x) -> [f a] -> f [b] + * @sig Functor f => (a -> f b) -> (x -> f x) -> [a] -> f [b] * @param {Function} fn The transformation function * @param {Function} of A function that returns the data type to return * @param {Array} list An array of functors of the same type * @return {*} + * @see R.traverse + * @deprecated since v0.19.0 * @example * - * R.commuteMap(R.map(R.add(10)), R.of, [[1], [2, 3]]); //=> [[11, 12], [11, 13]] - * R.commuteMap(R.map(R.add(10)), R.of, [[1, 2], [3]]); //=> [[11, 13], [12, 13]] - * R.commuteMap(R.map(R.add(10)), R.of, [[1], [2], [3]]); //=> [[11, 12, 13]] - * R.commuteMap(R.map(R.add(10)), Maybe.of, [Just(1), Just(2), Just(3)]); //=> Just([11, 12, 13]) - * R.commuteMap(R.map(R.add(10)), Maybe.of, [Just(1), Just(2), Nothing()]); //=> Nothing() + * var add10 = R.map(R.add(10)); + * R.commuteMap(add10, R.of, [[1], [2, 3]]); //=> [[11, 12], [11, 13]] + * R.commuteMap(add10, R.of, [[1, 2], [3]]); //=> [[11, 13], [12, 13]] + * R.commuteMap(add10, R.of, [[1], [2], [3]]); //=> [[11, 12, 13]] + * R.commuteMap(add10, Maybe.of, [Just(1), Just(2), Just(3)]); //=> Just([11, 12, 13]) + * R.commuteMap(add10, Maybe.of, [Just(1), Just(2), Nothing()]); //=> Nothing() + * + * var fetch = url => Future((rej, res) => http.get(url, res).on('error', rej)); + * R.commuteMap(fetch, Future.of, [ + * 'http://ramdajs.com', + * 'http://github.com/ramda' + * ]); //=> Future([IncomingMessage, IncomingMessage]) */ var commuteMap = _curry3(function commuteMap(fn, of, list) { - function consF(acc, ftor) { - return ap(map(append, fn(ftor)), acc); + function consF(acc, x) { + return ap(map(prepend, fn(x)), acc); } - return _reduce(consF, of([]), list); + return reduceRight(consF, of([]), list); }); /** - * Wraps a constructor function inside a curried function that can be called with the same - * arguments and returns the same type. The arity of the function returned is specified - * to allow using variadic constructor functions. + * Wraps a constructor function inside a curried function that can be called + * with the same arguments and returns the same type. The arity of the function + * returned is specified to allow using variadic constructor functions. * * @func * @memberOf R + * @since v0.4.0 * @category Function * @sig Number -> (* -> {*}) -> (* -> {*}) * @param {Number} n The arity of the constructor function. @@ -14406,7 +13533,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @example * * // Variadic constructor function - * var Widget = function() { + * var Widget = () => { * this.children = Array.prototype.slice.call(arguments); * // ... * }; @@ -14454,33 +13581,34 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Accepts at least three functions and returns a new function. When invoked, this new - * function will invoke the first function, `after`, passing as its arguments the - * results of invoking the subsequent functions with whatever arguments are passed to - * the new function. + * Accepts a converging function and a list of branching functions and returns + * a new function. When invoked, this new function is applied to some + * arguments, each branching function is applied to those same arguments. The + * results of each branching function are passed as arguments to the converging + * function to produce the return value. * * @func * @memberOf R + * @since v0.4.2 * @category Function - * @sig (x1 -> x2 -> ... -> z) -> ((a -> b -> ... -> x1), (a -> b -> ... -> x2), ...) -> (a -> b -> ... -> z) + * @sig (x1 -> x2 -> ... -> z) -> [(a -> b -> ... -> x1), (a -> b -> ... -> x2), ...] -> (a -> b -> ... -> z) * @param {Function} after A function. `after` will be invoked with the return values of * `fn1` and `fn2` as its arguments. - * @param {...Function} functions A variable number of functions. + * @param {Array} functions A list of functions. * @return {Function} A new function. * @example * - * var add = function(a, b) { return a + b; }; - * var multiply = function(a, b) { return a * b; }; - * var subtract = function(a, b) { return a - b; }; + * var add = (a, b) => a + b; + * var multiply = (a, b) => a * b; + * var subtract = (a, b) => a - b; * * //≅ multiply( add(1, 2), subtract(1, 2) ); - * R.converge(multiply, add, subtract)(1, 2); //=> -3 + * R.converge(multiply, [add, subtract])(1, 2); //=> -3 * - * var add3 = function(a, b, c) { return a + b + c; }; - * R.converge(add3, multiply, add, subtract)(1, 2); //=> 4 + * var add3 = (a, b, c) => a + b + c; + * R.converge(add3, [multiply, add, subtract])(1, 2); //=> 4 */ - var converge = curryN(3, function converge(after) { - var fns = _slice(arguments, 1); + var converge = _curry2(function converge(after, fns) { return curryN(Math.max.apply(Math, pluck('length', fns)), function () { var args = arguments; var context = this; @@ -14490,76 +13618,29 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); }); - /** - * Returns all but the first `n` elements of the given list, string, or - * transducer/transformer (or object with a `drop` method). - * - * @func - * @memberOf R - * @category List - * @see R.transduce - * @sig Number -> [a] -> [a] - * @sig Number -> String -> String - * @param {Number} n - * @param {*} list - * @return {*} - * @see R.take - * @example - * - * R.drop(1, ['foo', 'bar', 'baz']); //=> ['bar', 'baz'] - * R.drop(2, ['foo', 'bar', 'baz']); //=> ['baz'] - * R.drop(3, ['foo', 'bar', 'baz']); //=> [] - * R.drop(4, ['foo', 'bar', 'baz']); //=> [] - * R.drop(3, 'ramda'); //=> 'da' - */ - var drop = _curry2(_dispatchable('drop', _xdrop, function drop(n, xs) { - return slice(Math.max(0, n), Infinity, xs); - })); - - /** - * Returns a list containing all but the last `n` elements of the given `list`. - * - * @func - * @memberOf R - * @category List - * @sig Number -> [a] -> [a] - * @sig Number -> String -> String - * @param {Number} n The number of elements of `xs` to skip. - * @param {Array} xs The collection to consider. - * @return {Array} - * @see R.takeLast - * @example - * - * R.dropLast(1, ['foo', 'bar', 'baz']); //=> ['foo', 'bar'] - * R.dropLast(2, ['foo', 'bar', 'baz']); //=> ['foo'] - * R.dropLast(3, ['foo', 'bar', 'baz']); //=> [] - * R.dropLast(4, ['foo', 'bar', 'baz']); //=> [] - * R.dropLast(3, 'ramda'); //=> 'ra' - */ - var dropLast = _curry2(function dropLast(n, xs) { - return take(n < xs.length ? xs.length - n : 0, xs); - }); - /** * Returns a new list without any consecutively repeating elements. Equality is - * determined by applying the supplied predicate two consecutive elements. - * The first element in a series of equal element is the one being preserved. + * determined by applying the supplied predicate two consecutive elements. The + * first element in a series of equal element is the one being preserved. + * + * Dispatches to the `dropRepeatsWith` method of the second argument, if present. * * Acts as a transducer if a transformer is given in list position. - * @see R.transduce * * @func * @memberOf R + * @since v0.14.0 * @category List * @sig (a, a -> Boolean) -> [a] -> [a] * @param {Function} pred A predicate used to test whether two items are equal. * @param {Array} list The array to consider. * @return {Array} `list` without repeating elements. + * @see R.transduce * @example * - * function lengthEq(x, y) { return Math.abs(x) === Math.abs(y); }; + * var lengthEq = (x, y) => Math.abs(x) === Math.abs(y); * var l = [1, -1, 1, 3, 4, -4, -4, -5, 5, 3, 3]; - * R.dropRepeatsWith(lengthEq, l); //=> [1, 3, 4, -5, 3] + * R.dropRepeatsWith(R.eqBy(Math.abs), l); //=> [1, 3, 4, -5, 3] */ var dropRepeatsWith = _curry2(_dispatchable('dropRepeatsWith', _xdropRepeatsWith, function dropRepeatsWith(pred, list) { var result = []; @@ -14578,11 +13659,33 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack })); /** - * Reports whether two objects have the same value, in `R.equals` terms, - * for the specified property. Useful as a curried predicate. + * Takes a function and two values in its domain and returns `true` if the + * values map to the same value in the codomain; `false` otherwise. + * + * @func + * @memberOf R + * @since v0.18.0 + * @category Relation + * @sig (a -> b) -> a -> a -> Boolean + * @param {Function} f + * @param {*} x + * @param {*} y + * @return {Boolean} + * @example + * + * R.eqBy(Math.abs, 5, -5); //=> true + */ + var eqBy = _curry3(function eqBy(f, x, y) { + return equals(f(x), f(y)); + }); + + /** + * Reports whether two objects have the same value, in `R.equals` terms, for + * the specified property. Useful as a curried predicate. * * @func * @memberOf R + * @since v0.1.0 * @category Object * @sig k -> {k: v} -> {k: v} -> Boolean * @param {String} prop The name of the property to compare @@ -14602,12 +13705,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns the position of the first occurrence of an item in an array, - * or -1 if the item is not included in the array. `R.equals` is used to - * determine equality. + * Returns the position of the first occurrence of an item in an array, or -1 + * if the item is not included in the array. `R.equals` is used to determine + * equality. * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig a -> [a] -> Number * @param {*} target The item to find. @@ -14620,60 +13724,29 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * R.indexOf(10, [1,2,3,4]); //=> -1 */ var indexOf = _curry2(function indexOf(target, xs) { - return _hasMethod('indexOf', xs) ? xs.indexOf(target) : _indexOf(xs, target, 0); + return typeof xs.indexOf === 'function' && !_isArray(xs) ? xs.indexOf(target) : _indexOf(xs, target, 0); }); /** - * Returns all but the last element of the given list or string. - * - * @func - * @memberOf R - * @category List - * @see R.last, R.head, R.tail - * @sig [a] -> [a] - * @sig String -> String - * @param {*} list - * @return {*} - * @example - * - * R.init([1, 2, 3]); //=> [1, 2] - * R.init([1, 2]); //=> [1] - * R.init([1]); //=> [] - * R.init([]); //=> [] - * - * R.init('abc'); //=> 'ab' - * R.init('ab'); //=> 'a' - * R.init('a'); //=> '' - * R.init(''); //=> '' - */ - var init = slice(0, -1); - - /** - * Returns `true` if all elements are unique, in `R.equals` terms, - * otherwise `false`. + * juxt applies a list of functions to a list of values. * * @func * @memberOf R - * @category List - * @sig [a] -> Boolean - * @param {Array} list The array to consider. - * @return {Boolean} `true` if all elements are unique, else `false`. + * @since 0.19.1 + * @since 0.19.0 + * @category Function + * @sig [(a, b, ..., m) -> n] -> ((a, b, ..., m) -> [n]) + * @param {Array} fns An array of functions + * @return {Function} A function that returns a list of values after applying each of the original `fns` to its parameters. * @example * - * R.isSet(['1', 1]); //=> true - * R.isSet([1, 1]); //=> false - * R.isSet([[42], [42]]); //=> false + * var range = R.juxt([Math.min, Math.max]); + * range(3, 4, 9, -3); //=> [-3, 9] */ - var isSet = _curry1(function isSet(list) { - var len = list.length; - var idx = 0; - while (idx < len) { - if (_indexOf(list, list[idx], idx + 1) >= 0) { - return false; - } - idx += 1; - } - return true; + var juxt = _curry1(function juxt(fns) { + return function () { + return map(apply(__, arguments), fns); + }; }); /** @@ -14683,8 +13756,9 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.8.0 * @category Object - * @typedef Lens s a = Functor f => (a -> f a) -> s -> f s + * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s * @sig (s -> a) -> ((a, s) -> s) -> Lens s a * @param {Function} getter * @param {Function} setter @@ -14713,8 +13787,9 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.14.0 * @category Object - * @typedef Lens s a = Functor f => (a -> f a) -> s -> f s + * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s * @sig Number -> Lens s a * @param {Number} n * @return {Lens} @@ -14731,13 +13806,39 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack return lens(nth(n), update(n)); }); + /** + * Returns a lens whose focus is the specified path. + * + * @func + * @memberOf R + * @since 0.19.1 + * @since 0.19.0 + * @category Object + * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s + * @sig [String] -> Lens s a + * @param {Array} path The path to use. + * @return {Lens} + * @see R.view, R.set, R.over + * @example + * + * var xyLens = R.lensPath(['x', 'y']); + * + * R.view(xyLens, {x: {y: 2, z: 3}}); //=> 2 + * R.set(xyLens, 4, {x: {y: 2, z: 3}}); //=> {x: {y: 4, z: 3}} + * R.over(xyLens, R.negate, {x: {y: 2, z: 3}}); //=> {x: {y: -2, z: 3}} + */ + var lensPath = _curry1(function lensPath(p) { + return lens(path(p), assocPath(p)); + }); + /** * Returns a lens whose focus is the specified property. * * @func * @memberOf R + * @since v0.14.0 * @category Object - * @typedef Lens s a = Functor f => (a -> f a) -> s -> f s + * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s * @sig String -> Lens s a * @param {String} k * @return {Lens} @@ -14755,21 +13856,20 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * "lifts" a function to be the specified arity, so that it may "map over" that many - * lists (or other Functors). + * "lifts" a function to be the specified arity, so that it may "map over" that + * many lists (or other objects that satisfies the [FantasyLand Apply spec](https://github.com/fantasyland/fantasy-land#apply)). * * @func * @memberOf R - * @see R.lift + * @since v0.7.0 * @category Function * @sig Number -> (*... -> *) -> ([*]... -> [*]) * @param {Function} fn The function to lift into higher context - * @return {Function} The function `fn` applicable to mappable objects. + * @return {Function} The lifted function. + * @see R.lift * @example * - * var madd3 = R.liftN(3, R.curryN(3, function() { - * return R.reduce(R.add, 0, arguments); - * })); + * var madd3 = R.liftN(3, R.curryN(3, (...args) => R.sum(args))); * madd3([1,2,3], [1,2,3], [1]); //=> [3, 4, 5, 4, 5, 6, 5, 6, 7] */ var liftN = _curry2(function liftN(arity, fn) { @@ -14784,6 +13884,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.14.0 * @category Math * @sig [Number] -> Number * @param {Array} list @@ -14802,6 +13903,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.14.0 * @category Math * @sig [Number] -> Number * @param {Array} list @@ -14824,11 +13926,38 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }).slice(idx, idx + width)); }); + /** + * Create a new object with the own properties of the first object merged with + * the own properties of the second object. If a key exists in both objects, + * the value from the second object will be used. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category Object + * @sig {k: v} -> {k: v} -> {k: v} + * @param {Object} l + * @param {Object} r + * @return {Object} + * @see R.mergeWith, R.mergeWithKey + * @example + * + * R.merge({ 'name': 'fred', 'age': 10 }, { 'age': 40 }); + * //=> { 'name': 'fred', 'age': 40 } + * + * var resetToDefault = R.merge(R.__, {x: 0}); + * resetToDefault({x: 5, y: 2}); //=> {x: 0, y: 2} + */ + var merge = mergeWith(function (l, r) { + return r; + }); + /** * Merges a list of objects together into one object. * * @func * @memberOf R + * @since v0.10.0 * @category List * @sig [{k: v}] -> {k: v} * @param {Array} list An array of objects @@ -14851,8 +13980,9 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category Function - * @sig (((a, b, ..., n) -> o), (o -> p), ..., (x -> y), (y -> z)) -> (a -> b -> ... -> n -> z) + * @sig (((a, b, ..., n) -> o), (o -> p), ..., (x -> y), (y -> z)) -> ((a, b, ..., n) -> z) * @param {...Function} functions * @return {Function} * @see R.compose @@ -14866,16 +13996,17 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack if (arguments.length === 0) { throw new Error('pipe requires at least one argument'); } - return curryN(arguments[0].length, reduce(_pipe, arguments[0], tail(arguments))); + return _arity(arguments[0].length, reduce(_pipe, arguments[0], tail(arguments))); }; /** * Performs left-to-right composition of one or more Promise-returning - * functions. The leftmost function may have any arity; the remaining - * functions must be unary. + * functions. The leftmost function may have any arity; the remaining functions + * must be unary. * * @func * @memberOf R + * @since v0.10.0 * @category Function * @sig ((a -> Promise b), (b -> Promise c), ..., (y -> Promise z)) -> (a -> Promise z) * @param {...Function} functions @@ -14890,7 +14021,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack if (arguments.length === 0) { throw new Error('pipeP requires at least one argument'); } - return curryN(arguments[0].length, reduce(_pipeP, arguments[0], tail(arguments))); + return _arity(arguments[0].length, reduce(_pipeP, arguments[0], tail(arguments))); }; /** @@ -14898,6 +14029,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category Math * @sig [Number] -> Number * @param {Array} list An array of numbers @@ -14910,57 +14042,130 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var product = reduce(multiply, 1); /** - * Reasonable analog to SQL `select` statement. + * Transforms a [Traversable](https://github.com/fantasyland/fantasy-land#traversable) + * of [Applicative](https://github.com/fantasyland/fantasy-land#applicative) into an + * Applicative of Traversable. + * + * Dispatches to the `sequence` method of the second argument, if present. * * @func * @memberOf R - * @category Object - * @category Relation - * @sig [k] -> [{k: v}] -> [{k: v}] - * @param {Array} props The property names to project - * @param {Array} objs The objects to query - * @return {Array} An array of objects with just the `props` properties. + * @since 0.19.1 + * @since 0.19.0 + * @category List + * @sig (Applicative f, Traversable t) => (a -> f a) -> t (f a) -> f (t a) + * @param {Function} of + * @param {*} traversable + * @return {*} + * @see R.traverse * @example * - * var abby = {name: 'Abby', age: 7, hair: 'blond', grade: 2}; - * var fred = {name: 'Fred', age: 12, hair: 'brown', grade: 7}; - * var kids = [abby, fred]; - * R.project(['name', 'grade'], kids); //=> [{name: 'Abby', grade: 2}, {name: 'Fred', grade: 7}] + * R.sequence(Maybe.of, [Just(1), Just(2), Just(3)]); //=> Just([1, 2, 3]) + * R.sequence(Maybe.of, [Just(1), Just(2), Nothing()]); //=> Nothing() + * + * R.sequence(R.of, Just([1, 2, 3])); //=> [Just(1), Just(2), Just(3)] + * R.sequence(R.of, Nothing()); //=> [Nothing()] */ - // passing `identity` gives correct arity - var project = useWith(_map, pickAll, identity); + var sequence = _curry2(function sequence(of, traversable) { + return typeof traversable.sequence === 'function' ? traversable.sequence(of) : reduceRight(function (acc, x) { + return ap(map(prepend, x), acc); + }, of([]), traversable); + }); /** - * Returns a new list containing the last `n` elements of the given list. - * If `n > list.length`, returns a list of `list.length` elements. + * Maps an [Applicative](https://github.com/fantasyland/fantasy-land#applicative)-returning + * function over a [Traversable](https://github.com/fantasyland/fantasy-land#traversable), + * then uses [`sequence`](#sequence) to transform the resulting Traversable of Applicative + * into an Applicative of Traversable. + * + * Dispatches to the `sequence` method of the third argument, if present. * * @func * @memberOf R + * @since 0.19.1 + * @since 0.19.0 * @category List - * @sig Number -> [a] -> [a] - * @sig Number -> String -> String - * @param {Number} n The number of elements to return. - * @param {Array} xs The collection to consider. - * @return {Array} - * @see R.dropLast + * @sig (Applicative f, Traversable t) => (a -> f a) -> (a -> f b) -> t a -> f (t b) + * @param {Function} of + * @param {Function} f + * @param {*} traversable + * @return {*} + * @see R.sequence * @example * - * R.takeLast(1, ['foo', 'bar', 'baz']); //=> ['baz'] - * R.takeLast(2, ['foo', 'bar', 'baz']); //=> ['for', 'baz'] - * R.takeLast(3, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] - * R.takeLast(4, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] - * R.takeLast(3, 'ramda'); //=> 'mda' + * R.traverse(Maybe.of, R.negate, [Just(1), Just(2), Just(3)]); //=> Just([-1, -2, -3]) + * R.traverse(Maybe.of, R.negate, [Just(1), Just(2), Nothing()]); //=> Nothing() + * + * R.traverse(R.of, R.negate, Just([1, 2, 3])); //=> [Just(-1), Just(-2), Just(-3)] + * R.traverse(R.of, R.negate, Nothing()); //=> [Nothing()] */ - var takeLast = _curry2(function takeLast(n, xs) { - return drop(n >= 0 ? xs.length - n : 0, xs); + var traverse = _curry3(function traverse(of, f, traversable) { + return sequence(of, map(f, traversable)); }); + /** + * Shorthand for `R.chain(R.identity)`, which removes one level of nesting from + * any [Chain](https://github.com/fantasyland/fantasy-land#chain). + * + * @func + * @memberOf R + * @since v0.3.0 + * @category List + * @sig Chain c => c (c a) -> c a + * @param {*} list + * @return {*} + * @see R.flatten, R.chain + * @example + * + * R.unnest([1, [2], [[3]]]); //=> [1, 2, [3]] + * R.unnest([[1, 2], [3, 4], [5, 6]]); //=> [1, 2, 3, 4, 5, 6] + */ + var unnest = chain(_identity); + var _contains = function _contains(a, list) { return _indexOf(list, a, 0) >= 0; }; + var _stepCat = function () { + var _stepCatArray = { + '@@transducer/init': Array, + '@@transducer/step': function (xs, x) { + return _concat(xs, [x]); + }, + '@@transducer/result': _identity + }; + var _stepCatString = { + '@@transducer/init': String, + '@@transducer/step': function (a, b) { + return a + b; + }, + '@@transducer/result': _identity + }; + var _stepCatObject = { + '@@transducer/init': Object, + '@@transducer/step': function (result, input) { + return merge(result, isArrayLike(input) ? objOf(input[0], input[1]) : input); + }, + '@@transducer/result': _identity + }; + return function _stepCat(obj) { + if (_isTransformer(obj)) { + return obj; + } + if (isArrayLike(obj)) { + return _stepCatArray; + } + if (typeof obj === 'string') { + return _stepCatString; + } + if (typeof obj === 'object') { + return _stepCatObject; + } + throw new Error('Cannot create transformer for ' + obj); + }; + }(); + // mapPairs :: (Object, [String]) -> [String] - // Function, RegExp, user-defined types var _toString = function _toString(x, seen) { var recur = function recur(y) { var xs = seen.concat([x]); @@ -14976,11 +14181,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack case '[object Arguments]': return '(function() { return arguments; }(' + _map(recur, x).join(', ') + '))'; case '[object Array]': - return '[' + _map(recur, x).concat(mapPairs(x, reject(test(/^\d+$/), keys(x)))).join(', ') + ']'; + return '[' + _map(recur, x).concat(mapPairs(x, reject(function (k) { + return /^\d+$/.test(k); + }, keys(x)))).join(', ') + ']'; case '[object Boolean]': return typeof x === 'object' ? 'new Boolean(' + recur(x.valueOf()) + ')' : x.toString(); case '[object Date]': - return 'new Date(' + _quote(_toISOString(x)) + ')'; + return 'new Date(' + (isNaN(x.valueOf()) ? recur(NaN) : _quote(_toISOString(x))) + ')'; case '[object Null]': return 'null'; case '[object Number]': @@ -14990,8 +14197,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack case '[object Undefined]': return 'undefined'; default: - return typeof x.constructor === 'function' && x.constructor.name !== 'Object' && typeof x.toString === 'function' && x.toString() !== '[object Object]' ? x.toString() : // Function, RegExp, user-defined types - '{' + mapPairs(x, keys(x)).join(', ') + '}'; + if (typeof x.toString === 'function') { + var repr = x.toString(); + if (repr !== '[object Object]') { + return repr; + } + } + return '{' + mapPairs(x, keys(x)).join(', ') + '}'; } }; @@ -15000,12 +14212,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.8.0 * @category List - * @see R.commuteMap * @sig Functor f => (x -> f x) -> [f a] -> f [a] * @param {Function} of A function that returns the data type to return * @param {Array} list An array of functors of the same type * @return {*} + * @see R.sequence + * @deprecated since v0.19.0 * @example * * R.commute(R.of, [[1], [2, 3]]); //=> [[1, 2], [1, 3]] @@ -15022,8 +14236,9 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category Function - * @sig ((y -> z), (x -> y), ..., (o -> p), ((a, b, ..., n) -> o)) -> (a -> b -> ... -> n -> z) + * @sig ((y -> z), (x -> y), ..., (o -> p), ((a, b, ..., n) -> o)) -> ((a, b, ..., n) -> z) * @param {...Function} functions * @return {Function} * @see R.pipe @@ -15048,11 +14263,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.16.0 * @category Function - * @see R.pipeK * @sig Chain m => ((y -> m z), (x -> m y), ..., (a -> m b)) -> (m a -> m z) * @param {...Function} * @return {Function} + * @see R.pipeK * @example * * // parseJson :: String -> Maybe * @@ -15073,7 +14289,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * //=> Nothing() */ var composeK = function composeK() { - return arguments.length === 0 ? identity : compose.apply(this, map(chain, arguments)); + return compose.apply(this, prepend(identity, map(chain, arguments))); }; /** @@ -15083,6 +14299,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.10.0 * @category Function * @sig ((y -> Promise z), (x -> Promise y), ..., (a -> Promise b)) -> (a -> Promise z) * @param {...Function} functions @@ -15101,11 +14318,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }; /** - * Wraps a constructor function inside a curried function that can be called with the same - * arguments and returns the same type. + * Wraps a constructor function inside a curried function that can be called + * with the same arguments and returns the same type. * * @func * @memberOf R + * @since v0.1.0 * @category Function * @sig (* -> {*}) -> (* -> {*}) * @param {Function} Fn The constructor function to wrap. @@ -15113,7 +14331,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @example * * // Constructor function - * var Widget = function(config) { + * var Widget = config => { * // ... * }; * Widget.prototype = { @@ -15129,17 +14347,18 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns `true` if the specified value is equal, in `R.equals` terms, - * to at least one element of the given list; `false` otherwise. + * Returns `true` if the specified value is equal, in `R.equals` terms, to at + * least one element of the given list; `false` otherwise. * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig a -> [a] -> Boolean * @param {Object} a The item to compare against. * @param {Array} list The array to consider. * @return {Boolean} `true` if the item is in the list, `false` otherwise. - * + * @see R.any * @example * * R.contains(3, [1, 2, 3]); //=> true @@ -15149,12 +14368,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var contains = _curry2(_contains); /** - * Finds the set (i.e. no duplicates) of all elements in the first list not contained in the second list. + * Finds the set (i.e. no duplicates) of all elements in the first list not + * contained in the second list. * * @func * @memberOf R + * @since v0.1.0 * @category Relation - * @sig [a] -> [a] -> [a] + * @sig [*] -> [*] -> [*] * @param {Array} list1 The first list. * @param {Array} list2 The second list. * @return {Array} The elements in `list1` that are not in `list2`. @@ -15178,18 +14399,21 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a new list without any consecutively repeating elements. - * `R.equals` is used to determine equality. + * Returns a new list without any consecutively repeating elements. `R.equals` + * is used to determine equality. + * + * Dispatches to the `dropRepeats` method of the first argument, if present. * * Acts as a transducer if a transformer is given in list position. - * @see R.transduce * * @func * @memberOf R + * @since v0.14.0 * @category List * @sig [a] -> [a] * @param {Array} list The array to consider. * @return {Array} `list` without repeating elements. + * @see R.transduce * @example * * R.dropRepeats([1, 1, 1, 2, 3, 4, 4, 2, 2]); //=> [1, 2, 3, 4, 2] @@ -15197,45 +14421,66 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var dropRepeats = _curry1(_dispatchable('dropRepeats', _xdropRepeatsWith(equals), dropRepeatsWith(equals))); /** - * Combines two lists into a set (i.e. no duplicates) composed of those elements common to both lists. + * Transforms the items of the list with the transducer and appends the + * transformed items to the accumulator using an appropriate iterator function + * based on the accumulator type. + * + * The accumulator can be an array, string, object or a transformer. Iterated + * items will be appended to arrays and concatenated to strings. Objects will + * be merged directly or 2-item arrays will be merged as key, value pairs. + * + * The accumulator can also be a transformer object that provides a 2-arity + * reducing iterator function, step, 0-arity initial value function, init, and + * 1-arity result extraction function result. The step function is used as the + * iterator function in reduce. The result function is used to convert the + * final accumulator into the return type and in most cases is R.identity. The + * init function is used to provide the initial accumulator. + * + * The iteration is performed with R.reduce after initializing the transducer. * * @func * @memberOf R - * @category Relation - * @sig [a] -> [a] -> [a] - * @param {Array} list1 The first list. - * @param {Array} list2 The second list. - * @see R.intersectionWith - * @return {Array} The list of elements found in both `list1` and `list2`. + * @since v0.12.0 + * @category List + * @sig a -> (b -> b) -> [c] -> a + * @param {*} acc The initial accumulator value. + * @param {Function} xf The transducer function. Receives a transformer and returns a transformer. + * @param {Array} list The list to iterate over. + * @return {*} The final, accumulated value. * @example * - * R.intersection([1,2,3,4], [7,6,5,4,3]); //=> [4, 3] + * var numbers = [1, 2, 3, 4]; + * var transducer = R.compose(R.map(R.add(1)), R.take(2)); + * + * R.into([], transducer, numbers); //=> [2, 3] + * + * var intoArray = R.into([]); + * intoArray(transducer, numbers); //=> [2, 3] */ - var intersection = _curry2(function intersection(list1, list2) { - return uniq(_filter(flip(_contains)(list1), list2)); + var into = _curry3(function into(acc, xf, list) { + return _isTransformer(acc) ? _reduce(xf(acc), acc['@@transducer/init'](), list) : _reduce(xf(_stepCat(acc)), acc, list); }); /** - * "lifts" a function of arity > 1 so that it may "map over" an Array or - * other Functor. + * "lifts" a function of arity > 1 so that it may "map over" an Array or other + * object that satisfies the [FantasyLand Apply spec](https://github.com/fantasyland/fantasy-land#apply). * * @func * @memberOf R - * @see R.liftN + * @since v0.7.0 * @category Function * @sig (*... -> *) -> ([*]... -> [*]) * @param {Function} fn The function to lift into higher context - * @return {Function} The function `fn` applicable to mappable objects. + * @return {Function} The lifted function. + * @see R.liftN * @example * - * var madd3 = R.lift(R.curry(function(a, b, c) { - * return a + b + c; - * })); + * var madd3 = R.lift(R.curry((a, b, c) => a + b + c)); + * * madd3([1,2,3], [1,2,3], [1]); //=> [3, 4, 5, 4, 5, 6, 5, 6, 7] * - * var madd5 = R.lift(R.curry(function(a, b, c, d, e) { - * return a + b + c + d + e; - * })); + * var madd5 = R.lift(R.curry((a, b, c, d, e) => a + b + c + d + e)); + * * madd5([1,2], [3], [4, 5], [6], [7, 8]); //=> [21, 22, 22, 23, 22, 23, 23, 24] */ var lift = _curry1(function lift(fn) { @@ -15247,6 +14492,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category Object * @sig [String] -> {String: *} -> {String: *} * @param {Array} names an array of String property names to omit from the new object @@ -15275,11 +14521,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.16.0 * @category Function - * @see R.composeK * @sig Chain m => ((a -> m b), (b -> m c), ..., (y -> m z)) -> (m a -> m z) * @param {...Function} * @return {Function} + * @see R.composeK * @example * * // parseJson :: String -> Maybe * @@ -15326,6 +14573,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.14.0 * @category String * @sig * -> String * @param {*} val @@ -15343,32 +14591,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Combines two lists into a set (i.e. no duplicates) composed of the - * elements of each list. - * - * @func - * @memberOf R - * @category Relation - * @sig [a] -> [a] -> [a] - * @param {Array} as The first list. - * @param {Array} bs The second list. - * @return {Array} The first and second lists concatenated, with - * duplicates removed. - * @example - * - * R.union([1, 2, 3], [2, 3, 4]); //=> [1, 2, 3, 4] - */ - var union = _curry2(compose(uniq, _concat)); - - /** - * Returns a new list containing only one copy of each element in the - * original list, based upon the value returned by applying the supplied - * function to each list element. Prefers the first item if the supplied - * function produces the same value on two items. `R.equals` is used for - * comparison. + * Returns a new list containing only one copy of each element in the original + * list, based upon the value returned by applying the supplied function to + * each list element. Prefers the first item if the supplied function produces + * the same value on two items. `R.equals` is used for comparison. * * @func * @memberOf R + * @since v0.16.0 * @category List * @sig (a -> b) -> [a] -> [a] * @param {Function} fn A function used to produce a value to use during comparisons. @@ -15378,8 +14608,19 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * R.uniqBy(Math.abs, [-1, -5, 2, 10, 1, 2]); //=> [-1, -5, 2, 10] */ - var uniqBy = _curry2(function uniqBy(fn, list) { - var idx = 0, applied = [], result = [], appliedItem, item; + /* globals Set */ + // distinguishing between +0 and -0 is not supported by Set + /* falls through */ + // these types can all utilise Set + // prevent scan for null by tracking as a boolean + /* falls through */ + // scan through all previously applied items + var uniqBy = _curry2(/* globals Set */ + typeof Set === 'undefined' ? function uniqBy(fn, list) { + var idx = 0; + var applied = []; + var result = []; + var appliedItem, item; while (idx < list.length) { item = list[idx]; appliedItem = fn(item); @@ -15390,22 +14631,128 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack idx += 1; } return result; + } : function uniqBySet(fn, list) { + var set = new Set(); + var applied = []; + var prevSetSize = 0; + var result = []; + var nullExists = false; + var negZeroExists = false; + var idx = 0; + var appliedItem, item, newSetSize; + while (idx < list.length) { + item = list[idx]; + appliedItem = fn(item); + switch (typeof appliedItem) { + case 'number': + // distinguishing between +0 and -0 is not supported by Set + if (appliedItem === 0 && !negZeroExists && 1 / appliedItem === -Infinity) { + negZeroExists = true; + result.push(item); + break; + } + /* falls through */ + case 'string': + case 'boolean': + case 'function': + case 'undefined': + // these types can all utilise Set + set.add(appliedItem); + newSetSize = set.size; + if (newSetSize > prevSetSize) { + result.push(item); + prevSetSize = newSetSize; + } + break; + case 'object': + if (appliedItem === null) { + if (!nullExists) { + // prevent scan for null by tracking as a boolean + nullExists = true; + result.push(null); + } + break; + } + /* falls through */ + default: + // scan through all previously applied items + if (!_contains(appliedItem, applied)) { + applied.push(appliedItem); + result.push(item); + } + } + idx += 1; + } + return result; }); /** - * Turns a named method with a specified arity into a function - * that can be called directly supplied with arguments and a target object. + * Returns a new list without values in the first argument. + * `R.equals` is used to determine equality. + * + * Acts as a transducer if a transformer is given in list position. + * + * @func + * @memberOf R + * @since 0.19.1 + * @since 0.19.0 + * @category List + * @sig [a] -> [a] -> [a] + * @param {Array} list1 The values to be removed from `list2`. + * @param {Array} list2 The array to remove values from. + * @return {Array} The new array without values in `list1`. + * @see R.transduce + * @example + * + * R.without([1, 2], [1, 2, 1, 3, 4]); //=> [3, 4] + */ + var without = _curry2(function (xs, list) { + return reject(flip(_contains)(xs), list); + }); + + /** + * Takes a function `f` and returns a function `g` such that: + * + * - applying `g` to zero or more arguments will give __true__ if applying + * the same arguments to `f` gives a logical __false__ value; and + * + * - applying `g` to zero or more arguments will give __false__ if applying + * the same arguments to `f` gives a logical __true__ value. + * + * `R.complement` will work on all other functors as well. + * + * @func + * @memberOf R + * @since v0.12.0 + * @category Logic + * @sig (*... -> *) -> (*... -> Boolean) + * @param {Function} f + * @return {Function} + * @see R.not + * @example + * + * var isEven = n => n % 2 === 0; + * var isOdd = R.complement(isEven); + * isOdd(21); //=> true + * isOdd(42); //=> false + */ + var complement = lift(not); + + /** + * Turns a named method with a specified arity into a function that can be + * called directly supplied with arguments and a target object. * * The returned function is curried and accepts `arity + 1` parameters where * the final parameter is the target object. * * @func * @memberOf R + * @since v0.1.0 * @category Function * @sig Number -> String -> (a -> b -> ... -> n -> Object -> *) * @param {Number} arity Number of arguments the returned function should take * before the target object. - * @param {Function} method Name of the method to call. + * @param {String} method Name of the method to call. * @return {Function} A new curried function. * @example * @@ -15425,11 +14772,12 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); /** - * Returns a string made by inserting the `separator` between each - * element and concatenating all the elements into a single string. + * Returns a string made by inserting the `separator` between each element and + * concatenating all the elements into a single string. * * @func * @memberOf R + * @since v0.1.0 * @category List * @sig String -> [a] -> String * @param {Number|String} separator The string used to separate the elements. @@ -15445,13 +14793,15 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack var join = invoker(1, 'join'); /** - * Creates a new function that, when invoked, caches the result of calling `fn` for a given - * argument set and returns the result. Subsequent calls to the memoized `fn` with the same - * argument set will not result in an additional call to `fn`; instead, the cached result - * for that set of arguments will be returned. + * Creates a new function that, when invoked, caches the result of calling `fn` + * for a given argument set and returns the result. Subsequent calls to the + * memoized `fn` with the same argument set will not result in an additional + * call to `fn`; instead, the cached result for that set of arguments will be + * returned. * * @func * @memberOf R + * @since v0.1.0 * @category Function * @sig (*... -> a) -> (*... -> a) * @param {Function} fn The function to memoize. @@ -15459,7 +14809,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * @example * * var count = 0; - * var factorial = R.memoize(function(n) { + * var factorial = R.memoize(n => { * count += 1; * return R.product(R.range(1, n + 1)); * }); @@ -15470,13 +14820,13 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack */ var memoize = _curry1(function memoize(fn) { var cache = {}; - return function () { + return _arity(fn.length, function () { var key = toString(arguments); if (!_has(key, cache)) { cache[key] = fn.apply(this, arguments); } return cache[key]; - }; + }); }); /** @@ -15485,9 +14835,10 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.1.0 * @category String - * @sig String -> String -> [String] - * @param {String} sep The separator string. + * @sig (String | RegExp) -> String -> [String] + * @param {String|RegExp} sep The pattern. * @param {String} str The string to separate into an array. * @return {Array} The array of strings from `str` separated by `str`. * @see R.join @@ -15500,11 +14851,36 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack */ var split = invoker(1, 'split'); + /** + * Determines whether a given string matches a given regular expression. + * + * @func + * @memberOf R + * @since v0.12.0 + * @category String + * @sig RegExp -> String -> Boolean + * @param {RegExp} pattern + * @param {String} str + * @return {Boolean} + * @see R.match + * @example + * + * R.test(/^x/, 'xyz'); //=> true + * R.test(/^y/, 'xyz'); //=> false + */ + var test = _curry2(function test(pattern, str) { + if (!_isRegExp(pattern)) { + throw new TypeError('\u2018test\u2019 requires a value of type RegExp as its first argument; received ' + toString(pattern)); + } + return _cloneRegExp(pattern).test(str); + }); + /** * The lower case version of a string. * * @func * @memberOf R + * @since v0.9.0 * @category String * @sig String -> String * @param {String} str The string to lower case. @@ -15521,6 +14897,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack * * @func * @memberOf R + * @since v0.9.0 * @category String * @sig String -> String * @param {String} str The string to upper case. @@ -15532,6 +14909,138 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack */ var toUpper = invoker(0, 'toUpperCase'); + /** + * Returns a new list containing only one copy of each element in the original + * list. `R.equals` is used to determine equality. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category List + * @sig [a] -> [a] + * @param {Array} list The array to consider. + * @return {Array} The list of unique items. + * @example + * + * R.uniq([1, 1, 2, 1]); //=> [1, 2] + * R.uniq([1, '1']); //=> [1, '1'] + * R.uniq([[42], [42]]); //=> [[42]] + */ + var uniq = uniqBy(identity); + + /** + * Returns the result of concatenating the given lists or strings. + * + * Dispatches to the `concat` method of the second argument, if present. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category List + * @sig [a] -> [a] -> [a] + * @sig String -> String -> String + * @param {Array|String} a + * @param {Array|String} b + * @return {Array|String} + * + * @example + * + * R.concat([], []); //=> [] + * R.concat([4, 5, 6], [1, 2, 3]); //=> [4, 5, 6, 1, 2, 3] + * R.concat('ABC', 'DEF'); // 'ABCDEF' + */ + var concat = flip(invoker(1, 'concat')); + + /** + * Combines two lists into a set (i.e. no duplicates) composed of those + * elements common to both lists. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category Relation + * @sig [*] -> [*] -> [*] + * @param {Array} list1 The first list. + * @param {Array} list2 The second list. + * @return {Array} The list of elements found in both `list1` and `list2`. + * @see R.intersectionWith + * @example + * + * R.intersection([1,2,3,4], [7,6,5,4,3]); //=> [4, 3] + */ + var intersection = _curry2(function intersection(list1, list2) { + return uniq(_filter(flip(_contains)(list1), list2)); + }); + + /** + * Finds the set (i.e. no duplicates) of all elements contained in the first or + * second list, but not both. + * + * @func + * @memberOf R + * @since 0.19.1 + * @since 0.19.0 + * @category Relation + * @sig [*] -> [*] -> [*] + * @param {Array} list1 The first list. + * @param {Array} list2 The second list. + * @return {Array} The elements in `list1` or `list2`, but not both. + * @see R.symmetricDifferenceWith + * @example + * + * R.symmetricDifference([1,2,3,4], [7,6,5,4,3]); //=> [1,2,7,6,5] + * R.symmetricDifference([7,6,5,4,3], [1,2,3,4]); //=> [7,6,5,1,2] + */ + var symmetricDifference = _curry2(function symmetricDifference(list1, list2) { + return concat(difference(list1, list2), difference(list2, list1)); + }); + + /** + * Finds the set (i.e. no duplicates) of all elements contained in the first or + * second list, but not both. Duplication is determined according to the value + * returned by applying the supplied predicate to two list elements. + * + * @func + * @memberOf R + * @since 0.19.1 + * @since 0.19.0 + * @category Relation + * @sig (a -> a -> Boolean) -> [a] -> [a] -> [a] + * @param {Function} pred A predicate used to test whether two items are equal. + * @param {Array} list1 The first list. + * @param {Array} list2 The second list. + * @return {Array} The elements in `list1` or `list2`, but not both. + * @see R.symmetricDifference + * @example + * + * var eqA = R.eqBy(R.prop('a')); + * var l1 = [{a: 1}, {a: 2}, {a: 3}, {a: 4}]; + * var l2 = [{a: 3}, {a: 4}, {a: 5}, {a: 6}]; + * R.symmetricDifferenceWith(eqA, l1, l2); //=> [{a: 1}, {a: 2}, {a: 5}, {a: 6}] + */ + var symmetricDifferenceWith = _curry3(function symmetricDifferenceWith(pred, list1, list2) { + return concat(differenceWith(pred, list1, list2), differenceWith(pred, list2, list1)); + }); + + /** + * Combines two lists into a set (i.e. no duplicates) composed of the elements + * of each list. + * + * @func + * @memberOf R + * @since v0.1.0 + * @category Relation + * @sig [*] -> [*] -> [*] + * @param {Array} as The first list. + * @param {Array} bs The second list. + * @return {Array} The first and second lists concatenated, with + * duplicates removed. + * @example + * + * R.union([1, 2, 3], [2, 3, 4]); //=> [1, 2, 3, 4] + */ + var union = _curry2(compose(uniq, _concat)); + var R = { F: F, T: T, @@ -15541,6 +15050,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack adjust: adjust, all: all, allPass: allPass, + allUniq: allUniq, always: always, and: and, any: any, @@ -15569,10 +15079,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack construct: construct, constructN: constructN, contains: contains, - containsWith: containsWith, converge: converge, countBy: countBy, - createMapEntry: createMapEntry, curry: curry, curryN: curryN, dec: dec, @@ -15590,6 +15098,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack dropWhile: dropWhile, either: either, empty: empty, + eqBy: eqBy, eqProps: eqProps, equals: equals, evolve: evolve, @@ -15602,8 +15111,6 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack flip: flip, forEach: forEach, fromPairs: fromPairs, - functions: functions, - functionsIn: functionsIn, groupBy: groupBy, gt: gt, gte: gte, @@ -15614,6 +15121,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack identity: identity, ifElse: ifElse, inc: inc, + indexBy: indexBy, indexOf: indexOf, init: init, insert: insert, @@ -15629,8 +15137,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack isArrayLike: isArrayLike, isEmpty: isEmpty, isNil: isNil, - isSet: isSet, join: join, + juxt: juxt, keys: keys, keysIn: keysIn, last: last, @@ -15638,6 +15146,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack length: length, lens: lens, lensIndex: lensIndex, + lensPath: lensPath, lensProp: lensProp, lift: lift, liftN: liftN, @@ -15646,7 +15155,6 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack map: map, mapAccum: mapAccum, mapAccumRight: mapAccumRight, - mapObj: mapObj, mapObjIndexed: mapObjIndexed, match: match, mathMod: mathMod, @@ -15657,6 +15165,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack memoize: memoize, merge: merge, mergeAll: mergeAll, + mergeWith: mergeWith, + mergeWithKey: mergeWithKey, min: min, minBy: minBy, modulo: modulo, @@ -15667,18 +15177,20 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack not: not, nth: nth, nthArg: nthArg, - nthChar: nthChar, - nthCharCode: nthCharCode, + objOf: objOf, of: of, omit: omit, once: once, or: or, over: over, + pair: pair, partial: partial, partialRight: partialRight, partition: partition, path: path, pathEq: pathEq, + pathOr: pathOr, + pathSatisfies: pathSatisfies, pick: pick, pickAll: pickAll, pickBy: pickBy, @@ -15705,14 +15217,19 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack replace: replace, reverse: reverse, scan: scan, + sequence: sequence, set: set, slice: slice, sort: sort, sortBy: sortBy, split: split, + splitAt: splitAt, splitEvery: splitEvery, + splitWhen: splitWhen, subtract: subtract, sum: sum, + symmetricDifference: symmetricDifference, + symmetricDifferenceWith: symmetricDifferenceWith, tail: tail, take: take, takeLast: takeLast, @@ -15727,6 +15244,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack toString: toString, toUpper: toUpper, transduce: transduce, + transpose: transpose, + traverse: traverse, trim: trim, type: type, unapply: unapply, @@ -15738,20 +15257,24 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack uniq: uniq, uniqBy: uniqBy, uniqWith: uniqWith, + unless: unless, unnest: unnest, update: update, useWith: useWith, values: values, valuesIn: valuesIn, view: view, + when: when, where: where, whereEq: whereEq, + without: without, wrap: wrap, xprod: xprod, zip: zip, zipObj: zipObj, zipWith: zipWith }; + /* eslint-env amd */ /* TEST_ENTRY_POINT */ @@ -15767,14258 +15290,13299 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /***/ }, -/* 18 */ -/***/ function(module, exports, __webpack_require__) { - - var _equals = __webpack_require__(17).equals; - - - module.exports = { - - baseMap: function(f) { - return f(this.value); - }, - - getEquals: function(constructor) { - return function equals(that) { - return that instanceof constructor && _equals(this.value, that.value); - }; - }, - - extend: function(Child, Parent) { - function Ctor() { - this.constructor = Child; - } - Ctor.prototype = Parent.prototype; - Child.prototype = new Ctor(); - Child.super_ = Parent.prototype; - }, - - identity: function(x) { return x; }, - - notImplemented: function(str) { - return function() { - throw new Error(str + ' is not implemented'); - }; - }, - - notCallable: function(fn) { - return function() { - throw new Error(fn + ' cannot be called directly'); - }; - }, - - returnThis: function() { return this; } +/* 11 */ +/***/ function(module, exports) { - }; + "use strict"; + Object.defineProperty(exports, "__esModule", { + value: true + }); + const Term_16 = Object.create(Object.prototype, { _attributes: { value: [], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, _descendants: { value: new Map(), writable: false, configurable: false, enumerable: false }, hasDescendant: { value: function (name_110) { + return this._descendants.has(name_110); + }, writable: false, configurable: false, enumerable: true }, getDescendant: { value: function (name_111) { + return this._descendants.get(name_111); + }, writable: false, configurable: false, enumerable: true }, getAttributes: { value: function () { + return this._attributes; + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_112) { + return this._attributes.some(a_113 => a_113.attrName === attr_112); + }, writable: false, configurable: false, enumerable: true } }); + const BindingWithDefault_17 = Object.create(Term_16, { _attributes: { value: [{ attrName: "binding", attrType: { name: "any" } }, { attrName: "init", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_114) { + return this.getAttributes().some(a_115 => a_115.attrName === attr_114); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(BindingWithDefault_17); + Term_16._descendants.set("BindingWithDefault", BindingWithDefault_17); + const BindingIdentifier_18 = Object.create(Term_16, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_116) { + return this.getAttributes().some(a_117 => a_117.attrName === attr_116); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(BindingIdentifier_18); + Term_16._descendants.set("BindingIdentifier", BindingIdentifier_18); + const ArrayBinding_19 = Object.create(Term_16, { _attributes: { value: [{ attrName: "elements", attrType: { name: "any" } }, { attrName: "restElement", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_118) { + return this.getAttributes().some(a_119 => a_119.attrName === attr_118); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(ArrayBinding_19); + Term_16._descendants.set("ArrayBinding", ArrayBinding_19); + const ObjectBinding_20 = Object.create(Term_16, { _attributes: { value: [{ attrName: "properties", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_120) { + return this.getAttributes().some(a_121 => a_121.attrName === attr_120); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(ObjectBinding_20); + Term_16._descendants.set("ObjectBinding", ObjectBinding_20); + const BindingPropertyIdentifier_21 = Object.create(Term_16, { _attributes: { value: [{ attrName: "binding", attrType: { name: "any" } }, { attrName: "init", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_122) { + return this.getAttributes().some(a_123 => a_123.attrName === attr_122); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(BindingPropertyIdentifier_21); + Term_16._descendants.set("BindingPropertyIdentifier", BindingPropertyIdentifier_21); + const BindingPropertyProperty_22 = Object.create(Term_16, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }, { attrName: "binding", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_124) { + return this.getAttributes().some(a_125 => a_125.attrName === attr_124); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(BindingPropertyProperty_22); + Term_16._descendants.set("BindingPropertyProperty", BindingPropertyProperty_22); + const Statement_23 = Object.create(Term_16, { _attributes: { value: [], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_126) { + return this.getAttributes().some(a_127 => a_127.attrName === attr_126); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(Statement_23); + Term_16._descendants.set("Statement", Statement_23); + const Expression_24 = Object.create(Term_16, { _attributes: { value: [], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_128) { + return this.getAttributes().some(a_129 => a_129.attrName === attr_128); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(Expression_24); + Term_16._descendants.set("Expression", Expression_24); + const ClassExpression_25 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }, { attrName: "super", attrType: { name: "any" } }, { attrName: "elements", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_130) { + return this.getAttributes().some(a_131 => a_131.attrName === attr_130); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(ClassExpression_25); + Expression_24._descendants.set("ClassExpression", ClassExpression_25); + const ClassDeclaration_26 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }, { attrName: "super", attrType: { name: "any" } }, { attrName: "elements", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_132) { + return this.getAttributes().some(a_133 => a_133.attrName === attr_132); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(ClassDeclaration_26); + Statement_23._descendants.set("ClassDeclaration", ClassDeclaration_26); + const ClassElement_27 = Object.create(Term_16, { _attributes: { value: [{ attrName: "isStatic", attrType: { name: "any" } }, { attrName: "method", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_134) { + return this.getAttributes().some(a_135 => a_135.attrName === attr_134); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(ClassElement_27); + Term_16._descendants.set("ClassElement", ClassElement_27); + const Module_28 = Object.create(Term_16, { _attributes: { value: [{ attrName: "directives", attrType: { name: "any" } }, { attrName: "items", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_136) { + return this.getAttributes().some(a_137 => a_137.attrName === attr_136); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(Module_28); + Term_16._descendants.set("Module", Module_28); + const Import_29 = Object.create(Term_16, { _attributes: { value: [{ attrName: "moduleSpecifier", attrType: { name: "any" } }, { attrName: "defaultBinding", attrType: { name: "any" } }, { attrName: "namedImports", attrType: { name: "any" } }, { attrName: "forSyntax", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_138) { + return this.getAttributes().some(a_139 => a_139.attrName === attr_138); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(Import_29); + Term_16._descendants.set("Import", Import_29); + const ImportNamespace_30 = Object.create(Term_16, { _attributes: { value: [{ attrName: "moduleSpecifier", attrType: { name: "any" } }, { attrName: "defaultBinding", attrType: { name: "any" } }, { attrName: "namespaceBinding", attrType: { name: "any" } }, { attrName: "forSyntax", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_140) { + return this.getAttributes().some(a_141 => a_141.attrName === attr_140); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(ImportNamespace_30); + Term_16._descendants.set("ImportNamespace", ImportNamespace_30); + const ImportSpecifier_31 = Object.create(Term_16, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }, { attrName: "binding", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_142) { + return this.getAttributes().some(a_143 => a_143.attrName === attr_142); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(ImportSpecifier_31); + Term_16._descendants.set("ImportSpecifier", ImportSpecifier_31); + const ExportAllFrom_32 = Object.create(Term_16, { _attributes: { value: [{ attrName: "moduleSpecifier", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_144) { + return this.getAttributes().some(a_145 => a_145.attrName === attr_144); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(ExportAllFrom_32); + Term_16._descendants.set("ExportAllFrom", ExportAllFrom_32); + const ExportFrom_33 = Object.create(Term_16, { _attributes: { value: [{ attrName: "namedExports", attrType: { name: "any" } }, { attrName: "moduleSpecifier", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_146) { + return this.getAttributes().some(a_147 => a_147.attrName === attr_146); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(ExportFrom_33); + Term_16._descendants.set("ExportFrom", ExportFrom_33); + const Export_34 = Object.create(Term_16, { _attributes: { value: [{ attrName: "declaration", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_148) { + return this.getAttributes().some(a_149 => a_149.attrName === attr_148); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(Export_34); + Term_16._descendants.set("Export", Export_34); + const ExportDefault_35 = Object.create(Term_16, { _attributes: { value: [{ attrName: "body", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_150) { + return this.getAttributes().some(a_151 => a_151.attrName === attr_150); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(ExportDefault_35); + Term_16._descendants.set("ExportDefault", ExportDefault_35); + const ExportSpecifier_36 = Object.create(Term_16, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }, { attrName: "exportedName", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_152) { + return this.getAttributes().some(a_153 => a_153.attrName === attr_152); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(ExportSpecifier_36); + Term_16._descendants.set("ExportSpecifier", ExportSpecifier_36); + const Method_37 = Object.create(Term_16, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }, { attrName: "isGenerator", attrType: { name: "any" } }, { attrName: "params", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_154) { + return this.getAttributes().some(a_155 => a_155.attrName === attr_154); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(Method_37); + Term_16._descendants.set("Method", Method_37); + const Getter_38 = Object.create(Term_16, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_156) { + return this.getAttributes().some(a_157 => a_157.attrName === attr_156); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(Getter_38); + Term_16._descendants.set("Getter", Getter_38); + const Setter_39 = Object.create(Term_16, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }, { attrName: "param", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_158) { + return this.getAttributes().some(a_159 => a_159.attrName === attr_158); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(Setter_39); + Term_16._descendants.set("Setter", Setter_39); + const DataProperty_40 = Object.create(Term_16, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }, { attrName: "expression", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_160) { + return this.getAttributes().some(a_161 => a_161.attrName === attr_160); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(DataProperty_40); + Term_16._descendants.set("DataProperty", DataProperty_40); + const ShorthandProperty_41 = Object.create(Term_16, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_162) { + return this.getAttributes().some(a_163 => a_163.attrName === attr_162); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(ShorthandProperty_41); + Term_16._descendants.set("ShorthandProperty", ShorthandProperty_41); + const StaticPropertyName_42 = Object.create(Term_16, { _attributes: { value: [{ attrName: "value", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_164) { + return this.getAttributes().some(a_165 => a_165.attrName === attr_164); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(StaticPropertyName_42); + Term_16._descendants.set("StaticPropertyName", StaticPropertyName_42); + const ComputedPropertyName_43 = Object.create(Term_16, { _attributes: { value: [{ attrName: "expression", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_166) { + return this.getAttributes().some(a_167 => a_167.attrName === attr_166); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(ComputedPropertyName_43); + Term_16._descendants.set("ComputedPropertyName", ComputedPropertyName_43); + const LiteralBooleanExpression_44 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "value", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_168) { + return this.getAttributes().some(a_169 => a_169.attrName === attr_168); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(LiteralBooleanExpression_44); + Expression_24._descendants.set("LiteralBooleanExpression", LiteralBooleanExpression_44); + const LiteralInfinityExpression_45 = Object.create(Expression_24, { _attributes: { value: [], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_170) { + return this.getAttributes().some(a_171 => a_171.attrName === attr_170); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(LiteralInfinityExpression_45); + Expression_24._descendants.set("LiteralInfinityExpression", LiteralInfinityExpression_45); + const LiteralNullExpression_46 = Object.create(Expression_24, { _attributes: { value: [], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_172) { + return this.getAttributes().some(a_173 => a_173.attrName === attr_172); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(LiteralNullExpression_46); + Expression_24._descendants.set("LiteralNullExpression", LiteralNullExpression_46); + const LiteralNumericExpression_47 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "value", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_174) { + return this.getAttributes().some(a_175 => a_175.attrName === attr_174); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(LiteralNumericExpression_47); + Expression_24._descendants.set("LiteralNumericExpression", LiteralNumericExpression_47); + const LiteralRegExpExpression_48 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "pattern", attrType: { name: "any" } }, { attrName: "flags", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_176) { + return this.getAttributes().some(a_177 => a_177.attrName === attr_176); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(LiteralRegExpExpression_48); + Expression_24._descendants.set("LiteralRegExpExpression", LiteralRegExpExpression_48); + const LiteralStringExpression_49 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "value", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_178) { + return this.getAttributes().some(a_179 => a_179.attrName === attr_178); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(LiteralStringExpression_49); + Expression_24._descendants.set("LiteralStringExpression", LiteralStringExpression_49); + const ArrayExpression_50 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "elements", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_180) { + return this.getAttributes().some(a_181 => a_181.attrName === attr_180); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(ArrayExpression_50); + Expression_24._descendants.set("ArrayExpression", ArrayExpression_50); + const ArrowExpression_51 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "params", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_182) { + return this.getAttributes().some(a_183 => a_183.attrName === attr_182); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(ArrowExpression_51); + Expression_24._descendants.set("ArrowExpression", ArrowExpression_51); + const AssignmentExpression_52 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "binding", attrType: { name: "any" } }, { attrName: "expression", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_184) { + return this.getAttributes().some(a_185 => a_185.attrName === attr_184); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(AssignmentExpression_52); + Expression_24._descendants.set("AssignmentExpression", AssignmentExpression_52); + const BinaryExpression_53 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "operator", attrType: { name: "any" } }, { attrName: "left", attrType: { name: "any" } }, { attrName: "right", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_186) { + return this.getAttributes().some(a_187 => a_187.attrName === attr_186); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(BinaryExpression_53); + Expression_24._descendants.set("BinaryExpression", BinaryExpression_53); + const CallExpression_54 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "callee", attrType: { name: "any" } }, { attrName: "arguments", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_188) { + return this.getAttributes().some(a_189 => a_189.attrName === attr_188); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(CallExpression_54); + Expression_24._descendants.set("CallExpression", CallExpression_54); + const ComputedAssignmentExpression_55 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "operator", attrType: { name: "any" } }, { attrName: "binding", attrType: { name: "any" } }, { attrName: "expression", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_190) { + return this.getAttributes().some(a_191 => a_191.attrName === attr_190); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(ComputedAssignmentExpression_55); + Expression_24._descendants.set("ComputedAssignmentExpression", ComputedAssignmentExpression_55); + const ComputedMemberExpression_56 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "object", attrType: { name: "any" } }, { attrName: "expression", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_192) { + return this.getAttributes().some(a_193 => a_193.attrName === attr_192); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(ComputedMemberExpression_56); + Expression_24._descendants.set("ComputedMemberExpression", ComputedMemberExpression_56); + const ConditionalExpression_57 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "test", attrType: { name: "any" } }, { attrName: "consequent", attrType: { name: "any" } }, { attrName: "alternate", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_194) { + return this.getAttributes().some(a_195 => a_195.attrName === attr_194); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(ConditionalExpression_57); + Expression_24._descendants.set("ConditionalExpression", ConditionalExpression_57); + const FunctionExpression_58 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }, { attrName: "isGenerator", attrType: { name: "any" } }, { attrName: "params", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_196) { + return this.getAttributes().some(a_197 => a_197.attrName === attr_196); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(FunctionExpression_58); + Expression_24._descendants.set("FunctionExpression", FunctionExpression_58); + const IdentifierExpression_59 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_198) { + return this.getAttributes().some(a_199 => a_199.attrName === attr_198); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(IdentifierExpression_59); + Expression_24._descendants.set("IdentifierExpression", IdentifierExpression_59); + const NewExpression_60 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "callee", attrType: { name: "any" } }, { attrName: "arguments", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_200) { + return this.getAttributes().some(a_201 => a_201.attrName === attr_200); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(NewExpression_60); + Expression_24._descendants.set("NewExpression", NewExpression_60); + const NewTargetExpression_61 = Object.create(Expression_24, { _attributes: { value: [], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_202) { + return this.getAttributes().some(a_203 => a_203.attrName === attr_202); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(NewTargetExpression_61); + Expression_24._descendants.set("NewTargetExpression", NewTargetExpression_61); + const ObjectExpression_62 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "properties", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_204) { + return this.getAttributes().some(a_205 => a_205.attrName === attr_204); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(ObjectExpression_62); + Expression_24._descendants.set("ObjectExpression", ObjectExpression_62); + const UnaryExpression_63 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "operator", attrType: { name: "any" } }, { attrName: "operand", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_206) { + return this.getAttributes().some(a_207 => a_207.attrName === attr_206); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(UnaryExpression_63); + Expression_24._descendants.set("UnaryExpression", UnaryExpression_63); + const StaticMemberExpression_64 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "object", attrType: { name: "any" } }, { attrName: "property", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_208) { + return this.getAttributes().some(a_209 => a_209.attrName === attr_208); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(StaticMemberExpression_64); + Expression_24._descendants.set("StaticMemberExpression", StaticMemberExpression_64); + const TemplateExpression_65 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "tag", attrType: { name: "any" } }, { attrName: "elements", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_210) { + return this.getAttributes().some(a_211 => a_211.attrName === attr_210); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(TemplateExpression_65); + Expression_24._descendants.set("TemplateExpression", TemplateExpression_65); + const ThisExpression_66 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "stx", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_212) { + return this.getAttributes().some(a_213 => a_213.attrName === attr_212); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(ThisExpression_66); + Expression_24._descendants.set("ThisExpression", ThisExpression_66); + const UpdateExpression_67 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "isPrefix", attrType: { name: "any" } }, { attrName: "operator", attrType: { name: "any" } }, { attrName: "operand", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_214) { + return this.getAttributes().some(a_215 => a_215.attrName === attr_214); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(UpdateExpression_67); + Expression_24._descendants.set("UpdateExpression", UpdateExpression_67); + const YieldExpression_68 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "expression", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_216) { + return this.getAttributes().some(a_217 => a_217.attrName === attr_216); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(YieldExpression_68); + Expression_24._descendants.set("YieldExpression", YieldExpression_68); + const YieldGeneratorExpression_69 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "expression", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_218) { + return this.getAttributes().some(a_219 => a_219.attrName === attr_218); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(YieldGeneratorExpression_69); + Expression_24._descendants.set("YieldGeneratorExpression", YieldGeneratorExpression_69); + const ParenthesizedExpression_70 = Object.create(Expression_24, { _attributes: { value: [{ attrName: "inner", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Expression_24.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_220) { + return this.getAttributes().some(a_221 => a_221.attrName === attr_220); + }, writable: false, configurable: false, enumerable: true } }); + Expression_24._children.push(ParenthesizedExpression_70); + Expression_24._descendants.set("ParenthesizedExpression", ParenthesizedExpression_70); + const BlockStatement_71 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "block", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_222) { + return this.getAttributes().some(a_223 => a_223.attrName === attr_222); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(BlockStatement_71); + Statement_23._descendants.set("BlockStatement", BlockStatement_71); + const BreakStatement_72 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "label", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_224) { + return this.getAttributes().some(a_225 => a_225.attrName === attr_224); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(BreakStatement_72); + Statement_23._descendants.set("BreakStatement", BreakStatement_72); + const ContinueStatement_73 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "label", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_226) { + return this.getAttributes().some(a_227 => a_227.attrName === attr_226); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(ContinueStatement_73); + Statement_23._descendants.set("ContinueStatement", ContinueStatement_73); + const CompoundAssignmentExpression_74 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "binding", attrType: { name: "any" } }, { attrName: "operator", attrType: { name: "any" } }, { attrName: "expression", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_228) { + return this.getAttributes().some(a_229 => a_229.attrName === attr_228); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(CompoundAssignmentExpression_74); + Statement_23._descendants.set("CompoundAssignmentExpression", CompoundAssignmentExpression_74); + const DebuggerStatement_75 = Object.create(Statement_23, { _attributes: { value: [], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_230) { + return this.getAttributes().some(a_231 => a_231.attrName === attr_230); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(DebuggerStatement_75); + Statement_23._descendants.set("DebuggerStatement", DebuggerStatement_75); + const DoWhileStatement_76 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "test", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_232) { + return this.getAttributes().some(a_233 => a_233.attrName === attr_232); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(DoWhileStatement_76); + Statement_23._descendants.set("DoWhileStatement", DoWhileStatement_76); + const EmptyStatement_77 = Object.create(Statement_23, { _attributes: { value: [], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_234) { + return this.getAttributes().some(a_235 => a_235.attrName === attr_234); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(EmptyStatement_77); + Statement_23._descendants.set("EmptyStatement", EmptyStatement_77); + const ExpressionStatement_78 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "expression", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_236) { + return this.getAttributes().some(a_237 => a_237.attrName === attr_236); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(ExpressionStatement_78); + Statement_23._descendants.set("ExpressionStatement", ExpressionStatement_78); + const ForInStatement_79 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "left", attrType: { name: "any" } }, { attrName: "right", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_238) { + return this.getAttributes().some(a_239 => a_239.attrName === attr_238); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(ForInStatement_79); + Statement_23._descendants.set("ForInStatement", ForInStatement_79); + const ForOfStatement_80 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "left", attrType: { name: "any" } }, { attrName: "right", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_240) { + return this.getAttributes().some(a_241 => a_241.attrName === attr_240); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(ForOfStatement_80); + Statement_23._descendants.set("ForOfStatement", ForOfStatement_80); + const ForStatement_81 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "init", attrType: { name: "any" } }, { attrName: "test", attrType: { name: "any" } }, { attrName: "update", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_242) { + return this.getAttributes().some(a_243 => a_243.attrName === attr_242); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(ForStatement_81); + Statement_23._descendants.set("ForStatement", ForStatement_81); + const IfStatement_82 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "test", attrType: { name: "any" } }, { attrName: "consequent", attrType: { name: "any" } }, { attrName: "alternate", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_244) { + return this.getAttributes().some(a_245 => a_245.attrName === attr_244); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(IfStatement_82); + Statement_23._descendants.set("IfStatement", IfStatement_82); + const LabeledStatement_83 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "label", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_246) { + return this.getAttributes().some(a_247 => a_247.attrName === attr_246); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(LabeledStatement_83); + Statement_23._descendants.set("LabeledStatement", LabeledStatement_83); + const ReturnStatement_84 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "expression", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_248) { + return this.getAttributes().some(a_249 => a_249.attrName === attr_248); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(ReturnStatement_84); + Statement_23._descendants.set("ReturnStatement", ReturnStatement_84); + const SwitchStatement_85 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "discriminant", attrType: { name: "any" } }, { attrName: "cases", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_250) { + return this.getAttributes().some(a_251 => a_251.attrName === attr_250); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(SwitchStatement_85); + Statement_23._descendants.set("SwitchStatement", SwitchStatement_85); + const SwitchStatementWithDefault_86 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "discriminant", attrType: { name: "any" } }, { attrName: "preDefaultCases", attrType: { name: "any" } }, { attrName: "defaultCase", attrType: { name: "any" } }, { attrName: "postDefaultCases", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_252) { + return this.getAttributes().some(a_253 => a_253.attrName === attr_252); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(SwitchStatementWithDefault_86); + Statement_23._descendants.set("SwitchStatementWithDefault", SwitchStatementWithDefault_86); + const ThrowStatement_87 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "expression", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_254) { + return this.getAttributes().some(a_255 => a_255.attrName === attr_254); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(ThrowStatement_87); + Statement_23._descendants.set("ThrowStatement", ThrowStatement_87); + const TryCatchStatement_88 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "body", attrType: { name: "any" } }, { attrName: "catchClause", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_256) { + return this.getAttributes().some(a_257 => a_257.attrName === attr_256); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(TryCatchStatement_88); + Statement_23._descendants.set("TryCatchStatement", TryCatchStatement_88); + const TryFinallyStatement_89 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "body", attrType: { name: "any" } }, { attrName: "catchClause", attrType: { name: "any" } }, { attrName: "finalizer", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_258) { + return this.getAttributes().some(a_259 => a_259.attrName === attr_258); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(TryFinallyStatement_89); + Statement_23._descendants.set("TryFinallyStatement", TryFinallyStatement_89); + const VariableDeclarationStatement_90 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "declaration", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_260) { + return this.getAttributes().some(a_261 => a_261.attrName === attr_260); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(VariableDeclarationStatement_90); + Statement_23._descendants.set("VariableDeclarationStatement", VariableDeclarationStatement_90); + const WithStatement_91 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "object", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_262) { + return this.getAttributes().some(a_263 => a_263.attrName === attr_262); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(WithStatement_91); + Statement_23._descendants.set("WithStatement", WithStatement_91); + const WhileStatement_92 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "test", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_264) { + return this.getAttributes().some(a_265 => a_265.attrName === attr_264); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(WhileStatement_92); + Statement_23._descendants.set("WhileStatement", WhileStatement_92); + const Pragma_93 = Object.create(Term_16, { _attributes: { value: [{ attrName: "kind", attrType: { name: "any" } }, { attrName: "items", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_266) { + return this.getAttributes().some(a_267 => a_267.attrName === attr_266); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(Pragma_93); + Term_16._descendants.set("Pragma", Pragma_93); + const Block_94 = Object.create(Term_16, { _attributes: { value: [{ attrName: "statements", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_268) { + return this.getAttributes().some(a_269 => a_269.attrName === attr_268); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(Block_94); + Term_16._descendants.set("Block", Block_94); + const CatchClause_95 = Object.create(Term_16, { _attributes: { value: [{ attrName: "binding", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_270) { + return this.getAttributes().some(a_271 => a_271.attrName === attr_270); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(CatchClause_95); + Term_16._descendants.set("CatchClause", CatchClause_95); + const Directive_96 = Object.create(Term_16, { _attributes: { value: [{ attrName: "rawValue", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_272) { + return this.getAttributes().some(a_273 => a_273.attrName === attr_272); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(Directive_96); + Term_16._descendants.set("Directive", Directive_96); + const FormalParameters_97 = Object.create(Term_16, { _attributes: { value: [{ attrName: "items", attrType: { name: "any" } }, { attrName: "rest", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_274) { + return this.getAttributes().some(a_275 => a_275.attrName === attr_274); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(FormalParameters_97); + Term_16._descendants.set("FormalParameters", FormalParameters_97); + const FunctionBody_98 = Object.create(Term_16, { _attributes: { value: [{ attrName: "directives", attrType: { name: "any" } }, { attrName: "statements", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_276) { + return this.getAttributes().some(a_277 => a_277.attrName === attr_276); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(FunctionBody_98); + Term_16._descendants.set("FunctionBody", FunctionBody_98); + const FunctionDeclaration_99 = Object.create(Statement_23, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }, { attrName: "isGenerator", attrType: { name: "any" } }, { attrName: "params", attrType: { name: "any" } }, { attrName: "body", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Statement_23.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_278) { + return this.getAttributes().some(a_279 => a_279.attrName === attr_278); + }, writable: false, configurable: false, enumerable: true } }); + Statement_23._children.push(FunctionDeclaration_99); + Statement_23._descendants.set("FunctionDeclaration", FunctionDeclaration_99); + const Script_100 = Object.create(Term_16, { _attributes: { value: [{ attrName: "directives", attrType: { name: "any" } }, { attrName: "statements", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_280) { + return this.getAttributes().some(a_281 => a_281.attrName === attr_280); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(Script_100); + Term_16._descendants.set("Script", Script_100); + const SpreadElement_101 = Object.create(Term_16, { _attributes: { value: [{ attrName: "expression", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_282) { + return this.getAttributes().some(a_283 => a_283.attrName === attr_282); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(SpreadElement_101); + Term_16._descendants.set("SpreadElement", SpreadElement_101); + const Super_102 = Object.create(Term_16, { _attributes: { value: [], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_284) { + return this.getAttributes().some(a_285 => a_285.attrName === attr_284); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(Super_102); + Term_16._descendants.set("Super", Super_102); + const SwitchCase_103 = Object.create(Term_16, { _attributes: { value: [{ attrName: "test", attrType: { name: "any" } }, { attrName: "consequent", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_286) { + return this.getAttributes().some(a_287 => a_287.attrName === attr_286); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(SwitchCase_103); + Term_16._descendants.set("SwitchCase", SwitchCase_103); + const SwitchDefault_104 = Object.create(Term_16, { _attributes: { value: [{ attrName: "consequent", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_288) { + return this.getAttributes().some(a_289 => a_289.attrName === attr_288); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(SwitchDefault_104); + Term_16._descendants.set("SwitchDefault", SwitchDefault_104); + const TemplateElement_105 = Object.create(Term_16, { _attributes: { value: [{ attrName: "rawValue", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_290) { + return this.getAttributes().some(a_291 => a_291.attrName === attr_290); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(TemplateElement_105); + Term_16._descendants.set("TemplateElement", TemplateElement_105); + const SyntaxTemplate_106 = Object.create(Term_16, { _attributes: { value: [{ attrName: "template", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_292) { + return this.getAttributes().some(a_293 => a_293.attrName === attr_292); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(SyntaxTemplate_106); + Term_16._descendants.set("SyntaxTemplate", SyntaxTemplate_106); + const SyntaxQuote_107 = Object.create(Term_16, { _attributes: { value: [{ attrName: "name", attrType: { name: "any" } }, { attrName: "template", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_294) { + return this.getAttributes().some(a_295 => a_295.attrName === attr_294); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(SyntaxQuote_107); + Term_16._descendants.set("SyntaxQuote", SyntaxQuote_107); + const VariableDeclaration_108 = Object.create(Term_16, { _attributes: { value: [{ attrName: "kind", attrType: { name: "any" } }, { attrName: "declarators", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_296) { + return this.getAttributes().some(a_297 => a_297.attrName === attr_296); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(VariableDeclaration_108); + Term_16._descendants.set("VariableDeclaration", VariableDeclaration_108); + const VariableDeclarator_109 = Object.create(Term_16, { _attributes: { value: [{ attrName: "binding", attrType: { name: "any" } }, { attrName: "init", attrType: { name: "any" } }], writable: false, configurable: false, enumerable: false }, _children: { value: [], writable: false, configurable: false, enumerable: false }, getAttributes: { value: function () { + return Term_16.getAttributes().concat(this._attributes); + }, writable: false, configurable: false, enumerable: true }, hasAttribute: { value: function (attr_298) { + return this.getAttributes().some(a_299 => a_299.attrName === attr_298); + }, writable: false, configurable: false, enumerable: true } }); + Term_16._children.push(VariableDeclarator_109); + Term_16._descendants.set("VariableDeclarator", VariableDeclarator_109); + exports.default = Term_16; + //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../build/term-spec.js"],"names":["Term_16","Object","create","prototype","_attributes","value","writable","configurable","enumerable","_children","_descendants","Map","hasDescendant","name_110","has","getDescendant","name_111","get","getAttributes","hasAttribute","attr_112","some","a_113","attrName","BindingWithDefault_17","attrType","name","concat","attr_114","a_115","push","set","BindingIdentifier_18","attr_116","a_117","ArrayBinding_19","attr_118","a_119","ObjectBinding_20","attr_120","a_121","BindingPropertyIdentifier_21","attr_122","a_123","BindingPropertyProperty_22","attr_124","a_125","Statement_23","attr_126","a_127","Expression_24","attr_128","a_129","ClassExpression_25","attr_130","a_131","ClassDeclaration_26","attr_132","a_133","ClassElement_27","attr_134","a_135","Module_28","attr_136","a_137","Import_29","attr_138","a_139","ImportNamespace_30","attr_140","a_141","ImportSpecifier_31","attr_142","a_143","ExportAllFrom_32","attr_144","a_145","ExportFrom_33","attr_146","a_147","Export_34","attr_148","a_149","ExportDefault_35","attr_150","a_151","ExportSpecifier_36","attr_152","a_153","Method_37","attr_154","a_155","Getter_38","attr_156","a_157","Setter_39","attr_158","a_159","DataProperty_40","attr_160","a_161","ShorthandProperty_41","attr_162","a_163","StaticPropertyName_42","attr_164","a_165","ComputedPropertyName_43","attr_166","a_167","LiteralBooleanExpression_44","attr_168","a_169","LiteralInfinityExpression_45","attr_170","a_171","LiteralNullExpression_46","attr_172","a_173","LiteralNumericExpression_47","attr_174","a_175","LiteralRegExpExpression_48","attr_176","a_177","LiteralStringExpression_49","attr_178","a_179","ArrayExpression_50","attr_180","a_181","ArrowExpression_51","attr_182","a_183","AssignmentExpression_52","attr_184","a_185","BinaryExpression_53","attr_186","a_187","CallExpression_54","attr_188","a_189","ComputedAssignmentExpression_55","attr_190","a_191","ComputedMemberExpression_56","attr_192","a_193","ConditionalExpression_57","attr_194","a_195","FunctionExpression_58","attr_196","a_197","IdentifierExpression_59","attr_198","a_199","NewExpression_60","attr_200","a_201","NewTargetExpression_61","attr_202","a_203","ObjectExpression_62","attr_204","a_205","UnaryExpression_63","attr_206","a_207","StaticMemberExpression_64","attr_208","a_209","TemplateExpression_65","attr_210","a_211","ThisExpression_66","attr_212","a_213","UpdateExpression_67","attr_214","a_215","YieldExpression_68","attr_216","a_217","YieldGeneratorExpression_69","attr_218","a_219","ParenthesizedExpression_70","attr_220","a_221","BlockStatement_71","attr_222","a_223","BreakStatement_72","attr_224","a_225","ContinueStatement_73","attr_226","a_227","CompoundAssignmentExpression_74","attr_228","a_229","DebuggerStatement_75","attr_230","a_231","DoWhileStatement_76","attr_232","a_233","EmptyStatement_77","attr_234","a_235","ExpressionStatement_78","attr_236","a_237","ForInStatement_79","attr_238","a_239","ForOfStatement_80","attr_240","a_241","ForStatement_81","attr_242","a_243","IfStatement_82","attr_244","a_245","LabeledStatement_83","attr_246","a_247","ReturnStatement_84","attr_248","a_249","SwitchStatement_85","attr_250","a_251","SwitchStatementWithDefault_86","attr_252","a_253","ThrowStatement_87","attr_254","a_255","TryCatchStatement_88","attr_256","a_257","TryFinallyStatement_89","attr_258","a_259","VariableDeclarationStatement_90","attr_260","a_261","WithStatement_91","attr_262","a_263","WhileStatement_92","attr_264","a_265","Pragma_93","attr_266","a_267","Block_94","attr_268","a_269","CatchClause_95","attr_270","a_271","Directive_96","attr_272","a_273","FormalParameters_97","attr_274","a_275","FunctionBody_98","attr_276","a_277","FunctionDeclaration_99","attr_278","a_279","Script_100","attr_280","a_281","SpreadElement_101","attr_282","a_283","Super_102","attr_284","a_285","SwitchCase_103","attr_286","a_287","SwitchDefault_104","attr_288","a_289","TemplateElement_105","attr_290","a_291","SyntaxTemplate_106","attr_292","a_293","SyntaxQuote_107","attr_294","a_295","VariableDeclaration_108","attr_296","a_297","VariableDeclarator_109","attr_298","a_299"],"mappings":";;;;;AAAA,MAAMA,UAAUC,OAAOC,MAAP,CAAcD,OAAOE,SAArB,EAAgC,EAACC,aAAa,EAACC,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAd,EAAoFC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/F,EAAqKE,cAAc,EAACL,OAAO,IAAIM,GAAJ,EAAR,EAAiBL,UAAU,KAA3B,EAAkCC,cAAc,KAAhD,EAAuDC,YAAY,KAAnE,EAAnL,EAA8PI,eAAe,EAACP,OAAO,UAAUQ,QAAV,EAAoB;AACvV,aAAO,KAAKH,YAAL,CAAkBI,GAAlB,CAAsBD,QAAtB,CAAP;AACD,KAF4T,EAE1TP,UAAU,KAFgT,EAEzSC,cAAc,KAF2R,EAEpRC,YAAY,IAFwQ,EAA7Q,EAEYO,eAAe,EAACV,OAAO,UAAUW,QAAV,EAAoB;AACrG,aAAO,KAAKN,YAAL,CAAkBO,GAAlB,CAAsBD,QAAtB,CAAP;AACD,KAF0E,EAExEV,UAAU,KAF8D,EAEvDC,cAAc,KAFyC,EAElCC,YAAY,IAFsB,EAF3B,EAIYU,eAAe,EAACb,OAAO,YAAY;AAC7F,aAAO,KAAKD,WAAZ;AACD,KAF0E,EAExEE,UAAU,KAF8D,EAEvDC,cAAc,KAFyC,EAElCC,YAAY,IAFsB,EAJ3B,EAMYW,cAAc,EAACd,OAAO,UAAUe,QAAV,EAAoB;AACpG,aAAO,KAAKhB,WAAL,CAAiBiB,IAAjB,CAAsBC,SAASA,MAAMC,QAAN,KAAmBH,QAAlD,CAAP;AACD,KAFyE,EAEvEd,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAN1B,EAAhC,CAAhB;AASA,MAAMgB,wBAAwBvB,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,SAAX,EAAsBE,UAAU,EAACC,MAAM,KAAP,EAAhC,EAAD,EAAiD,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAjD,CAAR,EAAuGpB,UAAU,KAAjH,EAAwHC,cAAc,KAAtI,EAA6IC,YAAY,KAAzJ,EAAd,EAA+KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1L,EAAgQU,eAAe,EAACb,OAAO,YAAY;AACtV,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFmU,EAEjUE,UAAU,KAFuT,EAEhTC,cAAc,KAFkS,EAE3RC,YAAY,IAF+Q,EAA/Q,EAEOW,cAAc,EAACd,OAAO,UAAUuB,QAAV,EAAoB;AACpG,aAAO,KAAKV,aAAL,GAAqBG,IAArB,CAA0BQ,SAASA,MAAMN,QAAN,KAAmBK,QAAtD,CAAP;AACD,KAFyE,EAEvEtB,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFrB,EAAvB,CAA9B;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBN,qBAAvB;AACAxB,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,oBAAzB,EAA+CP,qBAA/C;AACA,MAAMQ,uBAAuB/B,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,CAAR,EAAuDpB,UAAU,KAAjE,EAAwEC,cAAc,KAAtF,EAA6FC,YAAY,KAAzG,EAAd,EAA+HC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1I,EAAgNU,eAAe,EAACb,OAAO,YAAY;AACrS,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFkR,EAEhRE,UAAU,KAFsQ,EAE/PC,cAAc,KAFiP,EAE1OC,YAAY,IAF8N,EAA/N,EAEQW,cAAc,EAACd,OAAO,UAAU4B,QAAV,EAAoB;AACpG,aAAO,KAAKf,aAAL,GAAqBG,IAArB,CAA0Ba,SAASA,MAAMX,QAAN,KAAmBU,QAAtD,CAAP;AACD,KAFyE,EAEvE3B,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFtB,EAAvB,CAA7B;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBE,oBAAvB;AACAhC,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,mBAAzB,EAA8CC,oBAA9C;AACA,MAAMG,kBAAkBlC,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAAD,EAAkD,EAACH,UAAU,aAAX,EAA0BE,UAAU,EAACC,MAAM,KAAP,EAApC,EAAlD,CAAR,EAA+GpB,UAAU,KAAzH,EAAgIC,cAAc,KAA9I,EAAqJC,YAAY,KAAjK,EAAd,EAAuLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAlM,EAAwQU,eAAe,EAACb,OAAO,YAAY;AACxV,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFqU,EAEnUE,UAAU,KAFyT,EAElTC,cAAc,KAFoS,EAE7RC,YAAY,IAFiR,EAAvR,EAEaW,cAAc,EAACd,OAAO,UAAU+B,QAAV,EAAoB;AACpG,aAAO,KAAKlB,aAAL,GAAqBG,IAArB,CAA0BgB,SAASA,MAAMd,QAAN,KAAmBa,QAAtD,CAAP;AACD,KAFyE,EAEvE9B,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF3B,EAAvB,CAAxB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBK,eAAvB;AACAnC,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,cAAzB,EAAyCI,eAAzC;AACA,MAAMG,mBAAmBrC,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,CAAR,EAA6DpB,UAAU,KAAvE,EAA8EC,cAAc,KAA5F,EAAmGC,YAAY,KAA/G,EAAd,EAAqIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhJ,EAAsNU,eAAe,EAACb,OAAO,YAAY;AACvS,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFoR,EAElRE,UAAU,KAFwQ,EAEjQC,cAAc,KAFmP,EAE5OC,YAAY,IAFgO,EAArO,EAEYW,cAAc,EAACd,OAAO,UAAUkC,QAAV,EAAoB;AACpG,aAAO,KAAKrB,aAAL,GAAqBG,IAArB,CAA0BmB,SAASA,MAAMjB,QAAN,KAAmBgB,QAAtD,CAAP;AACD,KAFyE,EAEvEjC,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF1B,EAAvB,CAAzB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBQ,gBAAvB;AACAtC,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,eAAzB,EAA0CO,gBAA1C;AACA,MAAMG,+BAA+BxC,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,SAAX,EAAsBE,UAAU,EAACC,MAAM,KAAP,EAAhC,EAAD,EAAiD,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAjD,CAAR,EAAuGpB,UAAU,KAAjH,EAAwHC,cAAc,KAAtI,EAA6IC,YAAY,KAAzJ,EAAd,EAA+KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1L,EAAgQU,eAAe,EAACb,OAAO,YAAY;AAC7V,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF0U,EAExUE,UAAU,KAF8T,EAEvTC,cAAc,KAFyS,EAElSC,YAAY,IAFsR,EAA/Q,EAEAW,cAAc,EAACd,OAAO,UAAUqC,QAAV,EAAoB;AACpG,aAAO,KAAKxB,aAAL,GAAqBG,IAArB,CAA0BsB,SAASA,MAAMpB,QAAN,KAAmBmB,QAAtD,CAAP;AACD,KAFyE,EAEvEpC,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFd,EAAvB,CAArC;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBW,4BAAvB;AACAzC,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,2BAAzB,EAAsDU,4BAAtD;AACA,MAAMG,6BAA6B3C,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,SAAX,EAAsBE,UAAU,EAACC,MAAM,KAAP,EAAhC,EAA9C,CAAR,EAAuGpB,UAAU,KAAjH,EAAwHC,cAAc,KAAtI,EAA6IC,YAAY,KAAzJ,EAAd,EAA+KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1L,EAAgQU,eAAe,EAACb,OAAO,YAAY;AAC3V,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFwU,EAEtUE,UAAU,KAF4T,EAErTC,cAAc,KAFuS,EAEhSC,YAAY,IAFoR,EAA/Q,EAEEW,cAAc,EAACd,OAAO,UAAUwC,QAAV,EAAoB;AACpG,aAAO,KAAK3B,aAAL,GAAqBG,IAArB,CAA0ByB,SAASA,MAAMvB,QAAN,KAAmBsB,QAAtD,CAAP;AACD,KAFyE,EAEvEvC,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFhB,EAAvB,CAAnC;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBc,0BAAvB;AACA5C,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,yBAAzB,EAAoDa,0BAApD;AACA,MAAMG,eAAe9C,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAd,EAAoFC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/F,EAAqKU,eAAe,EAACb,OAAO,YAAY;AAClP,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF+N,EAE7NE,UAAU,KAFmN,EAE5MC,cAAc,KAF8L,EAEvLC,YAAY,IAF2K,EAApL,EAEgBW,cAAc,EAACd,OAAO,UAAU2C,QAAV,EAAoB;AACpG,aAAO,KAAK9B,aAAL,GAAqBG,IAArB,CAA0B4B,SAASA,MAAM1B,QAAN,KAAmByB,QAAtD,CAAP;AACD,KAFyE,EAEvE1C,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF9B,EAAvB,CAArB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBiB,YAAvB;AACA/C,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,WAAzB,EAAsCgB,YAAtC;AACA,MAAMG,gBAAgBjD,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAd,EAAoFC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/F,EAAqKU,eAAe,EAACb,OAAO,YAAY;AACnP,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFgO,EAE9NE,UAAU,KAFoN,EAE7MC,cAAc,KAF+L,EAExLC,YAAY,IAF4K,EAApL,EAEeW,cAAc,EAACd,OAAO,UAAU8C,QAAV,EAAoB;AACpG,aAAO,KAAKjC,aAAL,GAAqBG,IAArB,CAA0B+B,SAASA,MAAM7B,QAAN,KAAmB4B,QAAtD,CAAP;AACD,KAFyE,EAEvE7C,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF7B,EAAvB,CAAtB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBoB,aAAvB;AACAlD,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,YAAzB,EAAuCmB,aAAvC;AACA,MAAMG,qBAAqBpD,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAA9C,EAA4F,EAACH,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAA5F,CAAR,EAAsJpB,UAAU,KAAhK,EAAuKC,cAAc,KAArL,EAA4LC,YAAY,KAAxM,EAAd,EAA8NC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAzO,EAA+SU,eAAe,EAACb,OAAO,YAAY;AACxY,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFqX,EAEnXE,UAAU,KAFyW,EAElWC,cAAc,KAFoV,EAE7UC,YAAY,IAFiU,EAA9T,EAEIW,cAAc,EAACd,OAAO,UAAUiD,QAAV,EAAoB;AACpG,aAAO,KAAKpC,aAAL,GAAqBG,IAArB,CAA0BkC,SAASA,MAAMhC,QAAN,KAAmB+B,QAAtD,CAAP;AACD,KAFyE,EAEvEhD,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFlB,EAA7B,CAA3B;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BuB,kBAA7B;AACAH,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,iBAA/B,EAAkDsB,kBAAlD;AACA,MAAMG,sBAAsBvD,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAA9C,EAA4F,EAACH,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAA5F,CAAR,EAAsJpB,UAAU,KAAhK,EAAuKC,cAAc,KAArL,EAA4LC,YAAY,KAAxM,EAAd,EAA8NC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAzO,EAA+SU,eAAe,EAACb,OAAO,YAAY;AACxY,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAFqX,EAEnXE,UAAU,KAFyW,EAElWC,cAAc,KAFoV,EAE7UC,YAAY,IAFiU,EAA9T,EAEIW,cAAc,EAACd,OAAO,UAAUoD,QAAV,EAAoB;AACpG,aAAO,KAAKvC,aAAL,GAAqBG,IAArB,CAA0BqC,SAASA,MAAMnC,QAAN,KAAmBkC,QAAtD,CAAP;AACD,KAFyE,EAEvEnD,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFlB,EAA5B,CAA5B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4B0B,mBAA5B;AACAT,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,kBAA9B,EAAkDyB,mBAAlD;AACA,MAAMG,kBAAkB1D,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAAD,EAAkD,EAACH,UAAU,QAAX,EAAqBE,UAAU,EAACC,MAAM,KAAP,EAA/B,EAAlD,CAAR,EAA0GpB,UAAU,KAApH,EAA2HC,cAAc,KAAzI,EAAgJC,YAAY,KAA5J,EAAd,EAAkLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA7L,EAAmQU,eAAe,EAACb,OAAO,YAAY;AACnV,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFgU,EAE9TE,UAAU,KAFoT,EAE7SC,cAAc,KAF+R,EAExRC,YAAY,IAF4Q,EAAlR,EAEaW,cAAc,EAACd,OAAO,UAAUuD,QAAV,EAAoB;AACpG,aAAO,KAAK1C,aAAL,GAAqBG,IAArB,CAA0BwC,SAASA,MAAMtC,QAAN,KAAmBqC,QAAtD,CAAP;AACD,KAFyE,EAEvEtD,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF3B,EAAvB,CAAxB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuB6B,eAAvB;AACA3D,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,cAAzB,EAAyC4B,eAAzC;AACA,MAAMG,YAAY7D,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,EAAoD,EAACH,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAApD,CAAR,EAA2GpB,UAAU,KAArH,EAA4HC,cAAc,KAA1I,EAAiJC,YAAY,KAA7J,EAAd,EAAmLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA9L,EAAoQU,eAAe,EAACb,OAAO,YAAY;AAC9U,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF2T,EAEzTE,UAAU,KAF+S,EAExSC,cAAc,KAF0R,EAEnRC,YAAY,IAFuQ,EAAnR,EAEmBW,cAAc,EAACd,OAAO,UAAU0D,QAAV,EAAoB;AACpG,aAAO,KAAK7C,aAAL,GAAqBG,IAArB,CAA0B2C,SAASA,MAAMzC,QAAN,KAAmBwC,QAAtD,CAAP;AACD,KAFyE,EAEvEzD,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjC,EAAvB,CAAlB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBgC,SAAvB;AACA9D,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,QAAzB,EAAmC+B,SAAnC;AACA,MAAMG,YAAYhE,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,iBAAX,EAA8BE,UAAU,EAACC,MAAM,KAAP,EAAxC,EAAD,EAAyD,EAACH,UAAU,gBAAX,EAA6BE,UAAU,EAACC,MAAM,KAAP,EAAvC,EAAzD,EAAgH,EAACH,UAAU,cAAX,EAA2BE,UAAU,EAACC,MAAM,KAAP,EAArC,EAAhH,EAAqK,EAACH,UAAU,WAAX,EAAwBE,UAAU,EAACC,MAAM,KAAP,EAAlC,EAArK,CAAR,EAAgOpB,UAAU,KAA1O,EAAiPC,cAAc,KAA/P,EAAsQC,YAAY,KAAlR,EAAd,EAAwSC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAnT,EAAyXU,eAAe,EAACb,OAAO,YAAY;AACnc,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFgb,EAE9aE,UAAU,KAFoa,EAE7ZC,cAAc,KAF+Y,EAExYC,YAAY,IAF4X,EAAxY,EAEmBW,cAAc,EAACd,OAAO,UAAU6D,QAAV,EAAoB;AACpG,aAAO,KAAKhD,aAAL,GAAqBG,IAArB,CAA0B8C,SAASA,MAAM5C,QAAN,KAAmB2C,QAAtD,CAAP;AACD,KAFyE,EAEvE5D,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjC,EAAvB,CAAlB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBmC,SAAvB;AACAjE,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,QAAzB,EAAmCkC,SAAnC;AACA,MAAMG,qBAAqBnE,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,iBAAX,EAA8BE,UAAU,EAACC,MAAM,KAAP,EAAxC,EAAD,EAAyD,EAACH,UAAU,gBAAX,EAA6BE,UAAU,EAACC,MAAM,KAAP,EAAvC,EAAzD,EAAgH,EAACH,UAAU,kBAAX,EAA+BE,UAAU,EAACC,MAAM,KAAP,EAAzC,EAAhH,EAAyK,EAACH,UAAU,WAAX,EAAwBE,UAAU,EAACC,MAAM,KAAP,EAAlC,EAAzK,CAAR,EAAoOpB,UAAU,KAA9O,EAAqPC,cAAc,KAAnQ,EAA0QC,YAAY,KAAtR,EAAd,EAA4SC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAvT,EAA6XU,eAAe,EAACb,OAAO,YAAY;AAChd,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF6b,EAE3bE,UAAU,KAFib,EAE1aC,cAAc,KAF4Z,EAErZC,YAAY,IAFyY,EAA5Y,EAEUW,cAAc,EAACd,OAAO,UAAUgE,QAAV,EAAoB;AACpG,aAAO,KAAKnD,aAAL,GAAqBG,IAArB,CAA0BiD,SAASA,MAAM/C,QAAN,KAAmB8C,QAAtD,CAAP;AACD,KAFyE,EAEvE/D,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFxB,EAAvB,CAA3B;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBsC,kBAAvB;AACApE,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,iBAAzB,EAA4CqC,kBAA5C;AACA,MAAMG,qBAAqBtE,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,SAAX,EAAsBE,UAAU,EAACC,MAAM,KAAP,EAAhC,EAA9C,CAAR,EAAuGpB,UAAU,KAAjH,EAAwHC,cAAc,KAAtI,EAA6IC,YAAY,KAAzJ,EAAd,EAA+KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1L,EAAgQU,eAAe,EAACb,OAAO,YAAY;AACnV,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFgU,EAE9TE,UAAU,KAFoT,EAE7SC,cAAc,KAF+R,EAExRC,YAAY,IAF4Q,EAA/Q,EAEUW,cAAc,EAACd,OAAO,UAAUmE,QAAV,EAAoB;AACpG,aAAO,KAAKtD,aAAL,GAAqBG,IAArB,CAA0BoD,SAASA,MAAMlD,QAAN,KAAmBiD,QAAtD,CAAP;AACD,KAFyE,EAEvElE,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFxB,EAAvB,CAA3B;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuByC,kBAAvB;AACAvE,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,iBAAzB,EAA4CwC,kBAA5C;AACA,MAAMG,mBAAmBzE,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,iBAAX,EAA8BE,UAAU,EAACC,MAAM,KAAP,EAAxC,EAAD,CAAR,EAAkEpB,UAAU,KAA5E,EAAmFC,cAAc,KAAjG,EAAwGC,YAAY,KAApH,EAAd,EAA0IC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAArJ,EAA2NU,eAAe,EAACb,OAAO,YAAY;AAC5S,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFyR,EAEvRE,UAAU,KAF6Q,EAEtQC,cAAc,KAFwP,EAEjPC,YAAY,IAFqO,EAA1O,EAEYW,cAAc,EAACd,OAAO,UAAUsE,QAAV,EAAoB;AACpG,aAAO,KAAKzD,aAAL,GAAqBG,IAArB,CAA0BuD,SAASA,MAAMrD,QAAN,KAAmBoD,QAAtD,CAAP;AACD,KAFyE,EAEvErE,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF1B,EAAvB,CAAzB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuB4C,gBAAvB;AACA1E,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,eAAzB,EAA0C2C,gBAA1C;AACA,MAAMG,gBAAgB5E,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,cAAX,EAA2BE,UAAU,EAACC,MAAM,KAAP,EAArC,EAAD,EAAsD,EAACH,UAAU,iBAAX,EAA8BE,UAAU,EAACC,MAAM,KAAP,EAAxC,EAAtD,CAAR,EAAuHpB,UAAU,KAAjI,EAAwIC,cAAc,KAAtJ,EAA6JC,YAAY,KAAzK,EAAd,EAA+LC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1M,EAAgRU,eAAe,EAACb,OAAO,YAAY;AAC9V,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF2U,EAEzUE,UAAU,KAF+T,EAExTC,cAAc,KAF0S,EAEnSC,YAAY,IAFuR,EAA/R,EAEeW,cAAc,EAACd,OAAO,UAAUyE,QAAV,EAAoB;AACpG,aAAO,KAAK5D,aAAL,GAAqBG,IAArB,CAA0B0D,SAASA,MAAMxD,QAAN,KAAmBuD,QAAtD,CAAP;AACD,KAFyE,EAEvExE,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF7B,EAAvB,CAAtB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuB+C,aAAvB;AACA7E,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,YAAzB,EAAuC8C,aAAvC;AACA,MAAMG,YAAY/E,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,aAAX,EAA0BE,UAAU,EAACC,MAAM,KAAP,EAApC,EAAD,CAAR,EAA8DpB,UAAU,KAAxE,EAA+EC,cAAc,KAA7F,EAAoGC,YAAY,KAAhH,EAAd,EAAsIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAjJ,EAAuNU,eAAe,EAACb,OAAO,YAAY;AACjS,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF8Q,EAE5QE,UAAU,KAFkQ,EAE3PC,cAAc,KAF6O,EAEtOC,YAAY,IAF0N,EAAtO,EAEmBW,cAAc,EAACd,OAAO,UAAU4E,QAAV,EAAoB;AACpG,aAAO,KAAK/D,aAAL,GAAqBG,IAArB,CAA0B6D,SAASA,MAAM3D,QAAN,KAAmB0D,QAAtD,CAAP;AACD,KAFyE,EAEvE3E,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjC,EAAvB,CAAlB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBkD,SAAvB;AACAhF,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,QAAzB,EAAmCiD,SAAnC;AACA,MAAMG,mBAAmBlF,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,CAAR,EAAuDpB,UAAU,KAAjE,EAAwEC,cAAc,KAAtF,EAA6FC,YAAY,KAAzG,EAAd,EAA+HC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1I,EAAgNU,eAAe,EAACb,OAAO,YAAY;AACjS,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF8Q,EAE5QE,UAAU,KAFkQ,EAE3PC,cAAc,KAF6O,EAEtOC,YAAY,IAF0N,EAA/N,EAEYW,cAAc,EAACd,OAAO,UAAU+E,QAAV,EAAoB;AACpG,aAAO,KAAKlE,aAAL,GAAqBG,IAArB,CAA0BgE,SAASA,MAAM9D,QAAN,KAAmB6D,QAAtD,CAAP;AACD,KAFyE,EAEvE9E,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF1B,EAAvB,CAAzB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBqD,gBAAvB;AACAnF,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,eAAzB,EAA0CoD,gBAA1C;AACA,MAAMG,qBAAqBrF,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,cAAX,EAA2BE,UAAU,EAACC,MAAM,KAAP,EAArC,EAA9C,CAAR,EAA4GpB,UAAU,KAAtH,EAA6HC,cAAc,KAA3I,EAAkJC,YAAY,KAA9J,EAAd,EAAoLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/L,EAAqQU,eAAe,EAACb,OAAO,YAAY;AACxV,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFqU,EAEnUE,UAAU,KAFyT,EAElTC,cAAc,KAFoS,EAE7RC,YAAY,IAFiR,EAApR,EAEUW,cAAc,EAACd,OAAO,UAAUkF,QAAV,EAAoB;AACpG,aAAO,KAAKrE,aAAL,GAAqBG,IAArB,CAA0BmE,SAASA,MAAMjE,QAAN,KAAmBgE,QAAtD,CAAP;AACD,KAFyE,EAEvEjF,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFxB,EAAvB,CAA3B;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBwD,kBAAvB;AACAtF,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,iBAAzB,EAA4CuD,kBAA5C;AACA,MAAMG,YAAYxF,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAA9C,EAA2F,EAACH,UAAU,aAAX,EAA0BE,UAAU,EAACC,MAAM,KAAP,EAApC,EAA3F,EAA+I,EAACH,UAAU,QAAX,EAAqBE,UAAU,EAACC,MAAM,KAAP,EAA/B,EAA/I,CAAR,EAAuMpB,UAAU,KAAjN,EAAwNC,cAAc,KAAtO,EAA6OC,YAAY,KAAzP,EAAd,EAA+QC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1R,EAAgWU,eAAe,EAACb,OAAO,YAAY;AAC1a,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFuZ,EAErZE,UAAU,KAF2Y,EAEpYC,cAAc,KAFsX,EAE/WC,YAAY,IAFmW,EAA/W,EAEmBW,cAAc,EAACd,OAAO,UAAUqF,QAAV,EAAoB;AACpG,aAAO,KAAKxE,aAAL,GAAqBG,IAArB,CAA0BsE,SAASA,MAAMpE,QAAN,KAAmBmE,QAAtD,CAAP;AACD,KAFyE,EAEvEpF,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjC,EAAvB,CAAlB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuB2D,SAAvB;AACAzF,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,QAAzB,EAAmC0D,SAAnC;AACA,MAAMG,YAAY3F,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAA9C,CAAR,EAAoGpB,UAAU,KAA9G,EAAqHC,cAAc,KAAnI,EAA0IC,YAAY,KAAtJ,EAAd,EAA4KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAvL,EAA6PU,eAAe,EAACb,OAAO,YAAY;AACvU,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFoT,EAElTE,UAAU,KAFwS,EAEjSC,cAAc,KAFmR,EAE5QC,YAAY,IAFgQ,EAA5Q,EAEmBW,cAAc,EAACd,OAAO,UAAUwF,QAAV,EAAoB;AACpG,aAAO,KAAK3E,aAAL,GAAqBG,IAArB,CAA0ByE,SAASA,MAAMvE,QAAN,KAAmBsE,QAAtD,CAAP;AACD,KAFyE,EAEvEvF,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjC,EAAvB,CAAlB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuB8D,SAAvB;AACA5F,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,QAAzB,EAAmC6D,SAAnC;AACA,MAAMG,YAAY9F,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAA9C,EAA2F,EAACH,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAA3F,CAAR,EAAkJpB,UAAU,KAA5J,EAAmKC,cAAc,KAAjL,EAAwLC,YAAY,KAApM,EAAd,EAA0NC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAArO,EAA2SU,eAAe,EAACb,OAAO,YAAY;AACrX,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFkW,EAEhWE,UAAU,KAFsV,EAE/UC,cAAc,KAFiU,EAE1TC,YAAY,IAF8S,EAA1T,EAEmBW,cAAc,EAACd,OAAO,UAAU2F,QAAV,EAAoB;AACpG,aAAO,KAAK9E,aAAL,GAAqBG,IAArB,CAA0B4E,SAASA,MAAM1E,QAAN,KAAmByE,QAAtD,CAAP;AACD,KAFyE,EAEvE1F,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjC,EAAvB,CAAlB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBiE,SAAvB;AACA/F,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,QAAzB,EAAmCgE,SAAnC;AACA,MAAMG,kBAAkBjG,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAA9C,CAAR,EAA0GpB,UAAU,KAApH,EAA2HC,cAAc,KAAzI,EAAgJC,YAAY,KAA5J,EAAd,EAAkLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA7L,EAAmQU,eAAe,EAACb,OAAO,YAAY;AACnV,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFgU,EAE9TE,UAAU,KAFoT,EAE7SC,cAAc,KAF+R,EAExRC,YAAY,IAF4Q,EAAlR,EAEaW,cAAc,EAACd,OAAO,UAAU8F,QAAV,EAAoB;AACpG,aAAO,KAAKjF,aAAL,GAAqBG,IAArB,CAA0B+E,SAASA,MAAM7E,QAAN,KAAmB4E,QAAtD,CAAP;AACD,KAFyE,EAEvE7F,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF3B,EAAvB,CAAxB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBoE,eAAvB;AACAlG,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,cAAzB,EAAyCmE,eAAzC;AACA,MAAMG,uBAAuBpG,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,CAAR,EAAuDpB,UAAU,KAAjE,EAAwEC,cAAc,KAAtF,EAA6FC,YAAY,KAAzG,EAAd,EAA+HC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1I,EAAgNU,eAAe,EAACb,OAAO,YAAY;AACrS,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFkR,EAEhRE,UAAU,KAFsQ,EAE/PC,cAAc,KAFiP,EAE1OC,YAAY,IAF8N,EAA/N,EAEQW,cAAc,EAACd,OAAO,UAAUiG,QAAV,EAAoB;AACpG,aAAO,KAAKpF,aAAL,GAAqBG,IAArB,CAA0BkF,SAASA,MAAMhF,QAAN,KAAmB+E,QAAtD,CAAP;AACD,KAFyE,EAEvEhG,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFtB,EAAvB,CAA7B;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBuE,oBAAvB;AACArG,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,mBAAzB,EAA8CsE,oBAA9C;AACA,MAAMG,wBAAwBvG,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAAD,CAAR,EAAwDpB,UAAU,KAAlE,EAAyEC,cAAc,KAAvF,EAA8FC,YAAY,KAA1G,EAAd,EAAgIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA3I,EAAiNU,eAAe,EAACb,OAAO,YAAY;AACvS,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFoR,EAElRE,UAAU,KAFwQ,EAEjQC,cAAc,KAFmP,EAE5OC,YAAY,IAFgO,EAAhO,EAEOW,cAAc,EAACd,OAAO,UAAUoG,QAAV,EAAoB;AACpG,aAAO,KAAKvF,aAAL,GAAqBG,IAArB,CAA0BqF,SAASA,MAAMnF,QAAN,KAAmBkF,QAAtD,CAAP;AACD,KAFyE,EAEvEnG,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFrB,EAAvB,CAA9B;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuB0E,qBAAvB;AACAxG,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,oBAAzB,EAA+CyE,qBAA/C;AACA,MAAMG,0BAA0B1G,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,CAAR,EAA6DpB,UAAU,KAAvE,EAA8EC,cAAc,KAA5F,EAAmGC,YAAY,KAA/G,EAAd,EAAqIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhJ,EAAsNU,eAAe,EAACb,OAAO,YAAY;AAC9S,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF2R,EAEzRE,UAAU,KAF+Q,EAExQC,cAAc,KAF0P,EAEnPC,YAAY,IAFuO,EAArO,EAEKW,cAAc,EAACd,OAAO,UAAUuG,QAAV,EAAoB;AACpG,aAAO,KAAK1F,aAAL,GAAqBG,IAArB,CAA0BwF,SAASA,MAAMtF,QAAN,KAAmBqF,QAAtD,CAAP;AACD,KAFyE,EAEvEtG,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFnB,EAAvB,CAAhC;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuB6E,uBAAvB;AACA3G,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,sBAAzB,EAAiD4E,uBAAjD;AACA,MAAMG,8BAA8B7G,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAAD,CAAR,EAAwDpB,UAAU,KAAlE,EAAyEC,cAAc,KAAvF,EAA8FC,YAAY,KAA1G,EAAd,EAAgIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA3I,EAAiNU,eAAe,EAACb,OAAO,YAAY;AACnT,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFgS,EAE9RE,UAAU,KAFoR,EAE7QC,cAAc,KAF+P,EAExPC,YAAY,IAF4O,EAAhO,EAELW,cAAc,EAACd,OAAO,UAAU0G,QAAV,EAAoB;AACpG,aAAO,KAAK7F,aAAL,GAAqBG,IAArB,CAA0B2F,SAASA,MAAMzF,QAAN,KAAmBwF,QAAtD,CAAP;AACD,KAFyE,EAEvEzG,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFT,EAA7B,CAApC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BgF,2BAA7B;AACA5D,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,0BAA/B,EAA2D+E,2BAA3D;AACA,MAAMG,+BAA+BhH,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAd,EAAoFC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/F,EAAqKU,eAAe,EAACb,OAAO,YAAY;AACxQ,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFqP,EAEnPE,UAAU,KAFyO,EAElOC,cAAc,KAFoN,EAE7MC,YAAY,IAFiM,EAApL,EAENW,cAAc,EAACd,OAAO,UAAU6G,QAAV,EAAoB;AACpG,aAAO,KAAKhG,aAAL,GAAqBG,IAArB,CAA0B8F,SAASA,MAAM5F,QAAN,KAAmB2F,QAAtD,CAAP;AACD,KAFyE,EAEvE5G,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFR,EAA7B,CAArC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BmF,4BAA7B;AACA/D,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,2BAA/B,EAA4DkF,4BAA5D;AACA,MAAMG,2BAA2BnH,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAd,EAAoFC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/F,EAAqKU,eAAe,EAACb,OAAO,YAAY;AACpQ,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFiP,EAE/OE,UAAU,KAFqO,EAE9NC,cAAc,KAFgN,EAEzMC,YAAY,IAF6L,EAApL,EAEFW,cAAc,EAACd,OAAO,UAAUgH,QAAV,EAAoB;AACpG,aAAO,KAAKnG,aAAL,GAAqBG,IAArB,CAA0BiG,SAASA,MAAM/F,QAAN,KAAmB8F,QAAtD,CAAP;AACD,KAFyE,EAEvE/G,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFZ,EAA7B,CAAjC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BsF,wBAA7B;AACAlE,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,uBAA/B,EAAwDqF,wBAAxD;AACA,MAAMG,8BAA8BtH,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAAD,CAAR,EAAwDpB,UAAU,KAAlE,EAAyEC,cAAc,KAAvF,EAA8FC,YAAY,KAA1G,EAAd,EAAgIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA3I,EAAiNU,eAAe,EAACb,OAAO,YAAY;AACnT,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFgS,EAE9RE,UAAU,KAFoR,EAE7QC,cAAc,KAF+P,EAExPC,YAAY,IAF4O,EAAhO,EAELW,cAAc,EAACd,OAAO,UAAUmH,QAAV,EAAoB;AACpG,aAAO,KAAKtG,aAAL,GAAqBG,IAArB,CAA0BoG,SAASA,MAAMlG,QAAN,KAAmBiG,QAAtD,CAAP;AACD,KAFyE,EAEvElH,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFT,EAA7B,CAApC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6ByF,2BAA7B;AACArE,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,0BAA/B,EAA2DwF,2BAA3D;AACA,MAAMG,6BAA6BzH,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,SAAX,EAAsBE,UAAU,EAACC,MAAM,KAAP,EAAhC,EAAD,EAAiD,EAACH,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAAjD,CAAR,EAAwGpB,UAAU,KAAlH,EAAyHC,cAAc,KAAvI,EAA8IC,YAAY,KAA1J,EAAd,EAAgLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA3L,EAAiQU,eAAe,EAACb,OAAO,YAAY;AAClW,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAF+U,EAE7UE,UAAU,KAFmU,EAE5TC,cAAc,KAF8S,EAEvSC,YAAY,IAF2R,EAAhR,EAEJW,cAAc,EAACd,OAAO,UAAUsH,QAAV,EAAoB;AACpG,aAAO,KAAKzG,aAAL,GAAqBG,IAArB,CAA0BuG,SAASA,MAAMrG,QAAN,KAAmBoG,QAAtD,CAAP;AACD,KAFyE,EAEvErH,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFV,EAA7B,CAAnC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6B4F,0BAA7B;AACAxE,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,yBAA/B,EAA0D2F,0BAA1D;AACA,MAAMG,6BAA6B5H,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAAD,CAAR,EAAwDpB,UAAU,KAAlE,EAAyEC,cAAc,KAAvF,EAA8FC,YAAY,KAA1G,EAAd,EAAgIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA3I,EAAiNU,eAAe,EAACb,OAAO,YAAY;AAClT,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAF+R,EAE7RE,UAAU,KAFmR,EAE5QC,cAAc,KAF8P,EAEvPC,YAAY,IAF2O,EAAhO,EAEJW,cAAc,EAACd,OAAO,UAAUyH,QAAV,EAAoB;AACpG,aAAO,KAAK5G,aAAL,GAAqBG,IAArB,CAA0B0G,SAASA,MAAMxG,QAAN,KAAmBuG,QAAtD,CAAP;AACD,KAFyE,EAEvExH,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFV,EAA7B,CAAnC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6B+F,0BAA7B;AACA3E,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,yBAA/B,EAA0D8F,0BAA1D;AACA,MAAMG,qBAAqB/H,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAAD,CAAR,EAA2DpB,UAAU,KAArE,EAA4EC,cAAc,KAA1F,EAAiGC,YAAY,KAA7G,EAAd,EAAmIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA9I,EAAoNU,eAAe,EAACb,OAAO,YAAY;AAC7S,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAF0R,EAExRE,UAAU,KAF8Q,EAEvQC,cAAc,KAFyP,EAElPC,YAAY,IAFsO,EAAnO,EAEIW,cAAc,EAACd,OAAO,UAAU4H,QAAV,EAAoB;AACpG,aAAO,KAAK/G,aAAL,GAAqBG,IAArB,CAA0B6G,SAASA,MAAM3G,QAAN,KAAmB0G,QAAtD,CAAP;AACD,KAFyE,EAEvE3H,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFlB,EAA7B,CAA3B;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BkG,kBAA7B;AACA9E,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,iBAA/B,EAAkDiG,kBAAlD;AACA,MAAMG,qBAAqBlI,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,QAAX,EAAqBE,UAAU,EAACC,MAAM,KAAP,EAA/B,EAAD,EAAgD,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAhD,CAAR,EAAsGpB,UAAU,KAAhH,EAAuHC,cAAc,KAArI,EAA4IC,YAAY,KAAxJ,EAAd,EAA8KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAzL,EAA+PU,eAAe,EAACb,OAAO,YAAY;AACxV,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFqU,EAEnUE,UAAU,KAFyT,EAElTC,cAAc,KAFoS,EAE7RC,YAAY,IAFiR,EAA9Q,EAEIW,cAAc,EAACd,OAAO,UAAU+H,QAAV,EAAoB;AACpG,aAAO,KAAKlH,aAAL,GAAqBG,IAArB,CAA0BgH,SAASA,MAAM9G,QAAN,KAAmB6G,QAAtD,CAAP;AACD,KAFyE,EAEvE9H,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFlB,EAA7B,CAA3B;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BqG,kBAA7B;AACAjF,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,iBAA/B,EAAkDoG,kBAAlD;AACA,MAAMG,0BAA0BrI,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,SAAX,EAAsBE,UAAU,EAACC,MAAM,KAAP,EAAhC,EAAD,EAAiD,EAACH,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAjD,CAAR,EAA6GpB,UAAU,KAAvH,EAA8HC,cAAc,KAA5I,EAAmJC,YAAY,KAA/J,EAAd,EAAqLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhM,EAAsQU,eAAe,EAACb,OAAO,YAAY;AACpW,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFiV,EAE/UE,UAAU,KAFqU,EAE9TC,cAAc,KAFgT,EAEzSC,YAAY,IAF6R,EAArR,EAEDW,cAAc,EAACd,OAAO,UAAUkI,QAAV,EAAoB;AACpG,aAAO,KAAKrH,aAAL,GAAqBG,IAArB,CAA0BmH,SAASA,MAAMjH,QAAN,KAAmBgH,QAAtD,CAAP;AACD,KAFyE,EAEvEjI,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFb,EAA7B,CAAhC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BwG,uBAA7B;AACApF,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,sBAA/B,EAAuDuG,uBAAvD;AACA,MAAMG,sBAAsBxI,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAAD,EAAkD,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAlD,EAA+F,EAACH,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAA/F,CAAR,EAAsJpB,UAAU,KAAhK,EAAuKC,cAAc,KAArL,EAA4LC,YAAY,KAAxM,EAAd,EAA8NC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAzO,EAA+SU,eAAe,EAACb,OAAO,YAAY;AACzY,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFsX,EAEpXE,UAAU,KAF0W,EAEnWC,cAAc,KAFqV,EAE9UC,YAAY,IAFkU,EAA9T,EAEGW,cAAc,EAACd,OAAO,UAAUqI,QAAV,EAAoB;AACpG,aAAO,KAAKxH,aAAL,GAAqBG,IAArB,CAA0BsH,SAASA,MAAMpH,QAAN,KAAmBmH,QAAtD,CAAP;AACD,KAFyE,EAEvEpI,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjB,EAA7B,CAA5B;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6B2G,mBAA7B;AACAvF,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,kBAA/B,EAAmD0G,mBAAnD;AACA,MAAMG,oBAAoB3I,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,QAAX,EAAqBE,UAAU,EAACC,MAAM,KAAP,EAA/B,EAAD,EAAgD,EAACH,UAAU,WAAX,EAAwBE,UAAU,EAACC,MAAM,KAAP,EAAlC,EAAhD,CAAR,EAA2GpB,UAAU,KAArH,EAA4HC,cAAc,KAA1I,EAAiJC,YAAY,KAA7J,EAAd,EAAmLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA9L,EAAoQU,eAAe,EAACb,OAAO,YAAY;AAC5V,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFyU,EAEvUE,UAAU,KAF6T,EAEtTC,cAAc,KAFwS,EAEjSC,YAAY,IAFqR,EAAnR,EAEKW,cAAc,EAACd,OAAO,UAAUwI,QAAV,EAAoB;AACpG,aAAO,KAAK3H,aAAL,GAAqBG,IAArB,CAA0ByH,SAASA,MAAMvH,QAAN,KAAmBsH,QAAtD,CAAP;AACD,KAFyE,EAEvEvI,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFnB,EAA7B,CAA1B;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6B8G,iBAA7B;AACA1F,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,gBAA/B,EAAiD6G,iBAAjD;AACA,MAAMG,kCAAkC9I,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAAD,EAAkD,EAACH,UAAU,SAAX,EAAsBE,UAAU,EAACC,MAAM,KAAP,EAAhC,EAAlD,EAAkG,EAACH,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAlG,CAAR,EAA8JpB,UAAU,KAAxK,EAA+KC,cAAc,KAA7L,EAAoMC,YAAY,KAAhN,EAAd,EAAsOC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAjP,EAAuTU,eAAe,EAACb,OAAO,YAAY;AAC7Z,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAF0Y,EAExYE,UAAU,KAF8X,EAEvXC,cAAc,KAFyW,EAElWC,YAAY,IAFsV,EAAtU,EAETW,cAAc,EAACd,OAAO,UAAU2I,QAAV,EAAoB;AACpG,aAAO,KAAK9H,aAAL,GAAqBG,IAArB,CAA0B4H,SAASA,MAAM1H,QAAN,KAAmByH,QAAtD,CAAP;AACD,KAFyE,EAEvE1I,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFL,EAA7B,CAAxC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BiH,+BAA7B;AACA7F,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,8BAA/B,EAA+DgH,+BAA/D;AACA,MAAMG,8BAA8BjJ,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,QAAX,EAAqBE,UAAU,EAACC,MAAM,KAAP,EAA/B,EAAD,EAAgD,EAACH,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAhD,CAAR,EAA4GpB,UAAU,KAAtH,EAA6HC,cAAc,KAA3I,EAAkJC,YAAY,KAA9J,EAAd,EAAoLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/L,EAAqQU,eAAe,EAACb,OAAO,YAAY;AACvW,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFoV,EAElVE,UAAU,KAFwU,EAEjUC,cAAc,KAFmT,EAE5SC,YAAY,IAFgS,EAApR,EAELW,cAAc,EAACd,OAAO,UAAU8I,QAAV,EAAoB;AACpG,aAAO,KAAKjI,aAAL,GAAqBG,IAArB,CAA0B+H,SAASA,MAAM7H,QAAN,KAAmB4H,QAAtD,CAAP;AACD,KAFyE,EAEvE7I,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFT,EAA7B,CAApC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BoH,2BAA7B;AACAhG,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,0BAA/B,EAA2DmH,2BAA3D;AACA,MAAMG,2BAA2BpJ,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAA9C,EAAiG,EAACH,UAAU,WAAX,EAAwBE,UAAU,EAACC,MAAM,KAAP,EAAlC,EAAjG,CAAR,EAA4JpB,UAAU,KAAtK,EAA6KC,cAAc,KAA3L,EAAkMC,YAAY,KAA9M,EAAd,EAAoOC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/O,EAAqTU,eAAe,EAACb,OAAO,YAAY;AACpZ,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFiY,EAE/XE,UAAU,KAFqX,EAE9WC,cAAc,KAFgW,EAEzVC,YAAY,IAF6U,EAApU,EAEFW,cAAc,EAACd,OAAO,UAAUiJ,QAAV,EAAoB;AACpG,aAAO,KAAKpI,aAAL,GAAqBG,IAArB,CAA0BkI,SAASA,MAAMhI,QAAN,KAAmB+H,QAAtD,CAAP;AACD,KAFyE,EAEvEhJ,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFZ,EAA7B,CAAjC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BuH,wBAA7B;AACAnG,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,uBAA/B,EAAwDsH,wBAAxD;AACA,MAAMG,wBAAwBvJ,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,aAAX,EAA0BE,UAAU,EAACC,MAAM,KAAP,EAApC,EAA9C,EAAkG,EAACH,UAAU,QAAX,EAAqBE,UAAU,EAACC,MAAM,KAAP,EAA/B,EAAlG,EAAiJ,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAjJ,CAAR,EAAuMpB,UAAU,KAAjN,EAAwNC,cAAc,KAAtO,EAA6OC,YAAY,KAAzP,EAAd,EAA+QC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1R,EAAgWU,eAAe,EAACb,OAAO,YAAY;AAC5b,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFya,EAEvaE,UAAU,KAF6Z,EAEtZC,cAAc,KAFwY,EAEjYC,YAAY,IAFqX,EAA/W,EAECW,cAAc,EAACd,OAAO,UAAUoJ,QAAV,EAAoB;AACpG,aAAO,KAAKvI,aAAL,GAAqBG,IAArB,CAA0BqI,SAASA,MAAMnI,QAAN,KAAmBkI,QAAtD,CAAP;AACD,KAFyE,EAEvEnJ,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFf,EAA7B,CAA9B;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6B0H,qBAA7B;AACAtG,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,oBAA/B,EAAqDyH,qBAArD;AACA,MAAMG,0BAA0B1J,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,CAAR,EAAuDpB,UAAU,KAAjE,EAAwEC,cAAc,KAAtF,EAA6FC,YAAY,KAAzG,EAAd,EAA+HC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1I,EAAgNU,eAAe,EAACb,OAAO,YAAY;AAC9S,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAF2R,EAEzRE,UAAU,KAF+Q,EAExQC,cAAc,KAF0P,EAEnPC,YAAY,IAFuO,EAA/N,EAEDW,cAAc,EAACd,OAAO,UAAUuJ,QAAV,EAAoB;AACpG,aAAO,KAAK1I,aAAL,GAAqBG,IAArB,CAA0BwI,SAASA,MAAMtI,QAAN,KAAmBqI,QAAtD,CAAP;AACD,KAFyE,EAEvEtJ,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFb,EAA7B,CAAhC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6B6H,uBAA7B;AACAzG,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,sBAA/B,EAAuD4H,uBAAvD;AACA,MAAMG,mBAAmB7J,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,QAAX,EAAqBE,UAAU,EAACC,MAAM,KAAP,EAA/B,EAAD,EAAgD,EAACH,UAAU,WAAX,EAAwBE,UAAU,EAACC,MAAM,KAAP,EAAlC,EAAhD,CAAR,EAA2GpB,UAAU,KAArH,EAA4HC,cAAc,KAA1I,EAAiJC,YAAY,KAA7J,EAAd,EAAmLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA9L,EAAoQU,eAAe,EAACb,OAAO,YAAY;AAC3V,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFwU,EAEtUE,UAAU,KAF4T,EAErTC,cAAc,KAFuS,EAEhSC,YAAY,IAFoR,EAAnR,EAEMW,cAAc,EAACd,OAAO,UAAU0J,QAAV,EAAoB;AACpG,aAAO,KAAK7I,aAAL,GAAqBG,IAArB,CAA0B2I,SAASA,MAAMzI,QAAN,KAAmBwI,QAAtD,CAAP;AACD,KAFyE,EAEvEzJ,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFpB,EAA7B,CAAzB;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BgI,gBAA7B;AACA5G,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,eAA/B,EAAgD+H,gBAAhD;AACA,MAAMG,yBAAyBhK,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAd,EAAoFC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/F,EAAqKU,eAAe,EAACb,OAAO,YAAY;AAClQ,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAF+O,EAE7OE,UAAU,KAFmO,EAE5NC,cAAc,KAF8M,EAEvMC,YAAY,IAF2L,EAApL,EAEAW,cAAc,EAACd,OAAO,UAAU6J,QAAV,EAAoB;AACpG,aAAO,KAAKhJ,aAAL,GAAqBG,IAArB,CAA0B8I,SAASA,MAAM5I,QAAN,KAAmB2I,QAAtD,CAAP;AACD,KAFyE,EAEvE5J,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFd,EAA7B,CAA/B;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BmI,sBAA7B;AACA/G,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,qBAA/B,EAAsDkI,sBAAtD;AACA,MAAMG,sBAAsBnK,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,CAAR,EAA6DpB,UAAU,KAAvE,EAA8EC,cAAc,KAA5F,EAAmGC,YAAY,KAA/G,EAAd,EAAqIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhJ,EAAsNU,eAAe,EAACb,OAAO,YAAY;AAChT,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAF6R,EAE3RE,UAAU,KAFiR,EAE1QC,cAAc,KAF4P,EAErPC,YAAY,IAFyO,EAArO,EAEGW,cAAc,EAACd,OAAO,UAAUgK,QAAV,EAAoB;AACpG,aAAO,KAAKnJ,aAAL,GAAqBG,IAArB,CAA0BiJ,SAASA,MAAM/I,QAAN,KAAmB8I,QAAtD,CAAP;AACD,KAFyE,EAEvE/J,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjB,EAA7B,CAA5B;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BsI,mBAA7B;AACAlH,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,kBAA/B,EAAmDqI,mBAAnD;AACA,MAAMG,qBAAqBtK,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAAD,EAAkD,EAACH,UAAU,SAAX,EAAsBE,UAAU,EAACC,MAAM,KAAP,EAAhC,EAAlD,CAAR,EAA2GpB,UAAU,KAArH,EAA4HC,cAAc,KAA1I,EAAiJC,YAAY,KAA7J,EAAd,EAAmLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA9L,EAAoQU,eAAe,EAACb,OAAO,YAAY;AAC7V,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAF0U,EAExUE,UAAU,KAF8T,EAEvTC,cAAc,KAFyS,EAElSC,YAAY,IAFsR,EAAnR,EAEIW,cAAc,EAACd,OAAO,UAAUmK,QAAV,EAAoB;AACpG,aAAO,KAAKtJ,aAAL,GAAqBG,IAArB,CAA0BoJ,SAASA,MAAMlJ,QAAN,KAAmBiJ,QAAtD,CAAP;AACD,KAFyE,EAEvElK,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFlB,EAA7B,CAA3B;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6ByI,kBAA7B;AACArH,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,iBAA/B,EAAkDwI,kBAAlD;AACA,MAAMG,4BAA4BzK,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,QAAX,EAAqBE,UAAU,EAACC,MAAM,KAAP,EAA/B,EAAD,EAAgD,EAACH,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAAhD,CAAR,EAA0GpB,UAAU,KAApH,EAA2HC,cAAc,KAAzI,EAAgJC,YAAY,KAA5J,EAAd,EAAkLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA7L,EAAmQU,eAAe,EAACb,OAAO,YAAY;AACnW,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFgV,EAE9UE,UAAU,KAFoU,EAE7TC,cAAc,KAF+S,EAExSC,YAAY,IAF4R,EAAlR,EAEHW,cAAc,EAACd,OAAO,UAAUsK,QAAV,EAAoB;AACpG,aAAO,KAAKzJ,aAAL,GAAqBG,IAArB,CAA0BuJ,SAASA,MAAMrJ,QAAN,KAAmBoJ,QAAtD,CAAP;AACD,KAFyE,EAEvErK,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFX,EAA7B,CAAlC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6B4I,yBAA7B;AACAxH,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,wBAA/B,EAAyD2I,yBAAzD;AACA,MAAMG,wBAAwB5K,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,KAAX,EAAkBE,UAAU,EAACC,MAAM,KAAP,EAA5B,EAAD,EAA6C,EAACH,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAA7C,CAAR,EAAuGpB,UAAU,KAAjH,EAAwHC,cAAc,KAAtI,EAA6IC,YAAY,KAAzJ,EAAd,EAA+KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1L,EAAgQU,eAAe,EAACb,OAAO,YAAY;AAC5V,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFyU,EAEvUE,UAAU,KAF6T,EAEtTC,cAAc,KAFwS,EAEjSC,YAAY,IAFqR,EAA/Q,EAECW,cAAc,EAACd,OAAO,UAAUyK,QAAV,EAAoB;AACpG,aAAO,KAAK5J,aAAL,GAAqBG,IAArB,CAA0B0J,SAASA,MAAMxJ,QAAN,KAAmBuJ,QAAtD,CAAP;AACD,KAFyE,EAEvExK,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFf,EAA7B,CAA9B;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6B+I,qBAA7B;AACA3H,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,oBAA/B,EAAqD8I,qBAArD;AACA,MAAMG,oBAAoB/K,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,KAAX,EAAkBE,UAAU,EAACC,MAAM,KAAP,EAA5B,EAAD,CAAR,EAAsDpB,UAAU,KAAhE,EAAuEC,cAAc,KAArF,EAA4FC,YAAY,KAAxG,EAAd,EAA8HC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAzI,EAA+MU,eAAe,EAACb,OAAO,YAAY;AACvS,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFoR,EAElRE,UAAU,KAFwQ,EAEjQC,cAAc,KAFmP,EAE5OC,YAAY,IAFgO,EAA9N,EAEKW,cAAc,EAACd,OAAO,UAAU4K,QAAV,EAAoB;AACpG,aAAO,KAAK/J,aAAL,GAAqBG,IAArB,CAA0B6J,SAASA,MAAM3J,QAAN,KAAmB0J,QAAtD,CAAP;AACD,KAFyE,EAEvE3K,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFnB,EAA7B,CAA1B;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BkJ,iBAA7B;AACA9H,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,gBAA/B,EAAiDiJ,iBAAjD;AACA,MAAMG,sBAAsBlL,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAAD,EAAkD,EAACH,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAAlD,EAAmG,EAACH,UAAU,SAAX,EAAsBE,UAAU,EAACC,MAAM,KAAP,EAAhC,EAAnG,CAAR,EAA4JpB,UAAU,KAAtK,EAA6KC,cAAc,KAA3L,EAAkMC,YAAY,KAA9M,EAAd,EAAoOC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/O,EAAqTU,eAAe,EAACb,OAAO,YAAY;AAC/Y,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAF4X,EAE1XE,UAAU,KAFgX,EAEzWC,cAAc,KAF2V,EAEpVC,YAAY,IAFwU,EAApU,EAEGW,cAAc,EAACd,OAAO,UAAU+K,QAAV,EAAoB;AACpG,aAAO,KAAKlK,aAAL,GAAqBG,IAArB,CAA0BgK,SAASA,MAAM9J,QAAN,KAAmB6J,QAAtD,CAAP;AACD,KAFyE,EAEvE9K,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjB,EAA7B,CAA5B;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BqJ,mBAA7B;AACAjI,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,kBAA/B,EAAmDoJ,mBAAnD;AACA,MAAMG,qBAAqBrL,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,CAAR,EAA6DpB,UAAU,KAAvE,EAA8EC,cAAc,KAA5F,EAAmGC,YAAY,KAA/G,EAAd,EAAqIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhJ,EAAsNU,eAAe,EAACb,OAAO,YAAY;AAC/S,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAF4R,EAE1RE,UAAU,KAFgR,EAEzQC,cAAc,KAF2P,EAEpPC,YAAY,IAFwO,EAArO,EAEIW,cAAc,EAACd,OAAO,UAAUkL,QAAV,EAAoB;AACpG,aAAO,KAAKrK,aAAL,GAAqBG,IAArB,CAA0BmK,SAASA,MAAMjK,QAAN,KAAmBgK,QAAtD,CAAP;AACD,KAFyE,EAEvEjL,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFlB,EAA7B,CAA3B;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6BwJ,kBAA7B;AACApI,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,iBAA/B,EAAkDuJ,kBAAlD;AACA,MAAMG,8BAA8BxL,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,CAAR,EAA6DpB,UAAU,KAAvE,EAA8EC,cAAc,KAA5F,EAAmGC,YAAY,KAA/G,EAAd,EAAqIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhJ,EAAsNU,eAAe,EAACb,OAAO,YAAY;AACxT,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAFqS,EAEnSE,UAAU,KAFyR,EAElRC,cAAc,KAFoQ,EAE7PC,YAAY,IAFiP,EAArO,EAELW,cAAc,EAACd,OAAO,UAAUqL,QAAV,EAAoB;AACpG,aAAO,KAAKxK,aAAL,GAAqBG,IAArB,CAA0BsK,SAASA,MAAMpK,QAAN,KAAmBmK,QAAtD,CAAP;AACD,KAFyE,EAEvEpL,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFT,EAA7B,CAApC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6B2J,2BAA7B;AACAvI,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,0BAA/B,EAA2D0J,2BAA3D;AACA,MAAMG,6BAA6B3L,OAAOC,MAAP,CAAcgD,aAAd,EAA6B,EAAC9C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAAD,CAAR,EAAwDpB,UAAU,KAAlE,EAAyEC,cAAc,KAAvF,EAA8FC,YAAY,KAA1G,EAAd,EAAgIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA3I,EAAiNU,eAAe,EAACb,OAAO,YAAY;AAClT,aAAO6C,cAAchC,aAAd,GAA8BS,MAA9B,CAAqC,KAAKvB,WAA1C,CAAP;AACD,KAF+R,EAE7RE,UAAU,KAFmR,EAE5QC,cAAc,KAF8P,EAEvPC,YAAY,IAF2O,EAAhO,EAEJW,cAAc,EAACd,OAAO,UAAUwL,QAAV,EAAoB;AACpG,aAAO,KAAK3K,aAAL,GAAqBG,IAArB,CAA0ByK,SAASA,MAAMvK,QAAN,KAAmBsK,QAAtD,CAAP;AACD,KAFyE,EAEvEvL,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFV,EAA7B,CAAnC;AAKA0C,cAAczC,SAAd,CAAwBqB,IAAxB,CAA6B8J,0BAA7B;AACA1I,cAAcxC,YAAd,CAA2BqB,GAA3B,CAA+B,yBAA/B,EAA0D6J,0BAA1D;AACA,MAAMG,oBAAoB9L,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAAD,CAAR,EAAwDpB,UAAU,KAAlE,EAAyEC,cAAc,KAAvF,EAA8FC,YAAY,KAA1G,EAAd,EAAgIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA3I,EAAiNU,eAAe,EAACb,OAAO,YAAY;AACxS,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAFqR,EAEnRE,UAAU,KAFyQ,EAElQC,cAAc,KAFoP,EAE7OC,YAAY,IAFiO,EAAhO,EAEMW,cAAc,EAACd,OAAO,UAAU2L,QAAV,EAAoB;AACpG,aAAO,KAAK9K,aAAL,GAAqBG,IAArB,CAA0B4K,SAASA,MAAM1K,QAAN,KAAmByK,QAAtD,CAAP;AACD,KAFyE,EAEvE1L,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFpB,EAA5B,CAA1B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BiK,iBAA5B;AACAhJ,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,gBAA9B,EAAgDgK,iBAAhD;AACA,MAAMG,oBAAoBjM,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAAD,CAAR,EAAwDpB,UAAU,KAAlE,EAAyEC,cAAc,KAAvF,EAA8FC,YAAY,KAA1G,EAAd,EAAgIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA3I,EAAiNU,eAAe,EAACb,OAAO,YAAY;AACxS,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAFqR,EAEnRE,UAAU,KAFyQ,EAElQC,cAAc,KAFoP,EAE7OC,YAAY,IAFiO,EAAhO,EAEMW,cAAc,EAACd,OAAO,UAAU8L,QAAV,EAAoB;AACpG,aAAO,KAAKjL,aAAL,GAAqBG,IAArB,CAA0B+K,SAASA,MAAM7K,QAAN,KAAmB4K,QAAtD,CAAP;AACD,KAFyE,EAEvE7L,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFpB,EAA5B,CAA1B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BoK,iBAA5B;AACAnJ,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,gBAA9B,EAAgDmK,iBAAhD;AACA,MAAMG,uBAAuBpM,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAAD,CAAR,EAAwDpB,UAAU,KAAlE,EAAyEC,cAAc,KAAvF,EAA8FC,YAAY,KAA1G,EAAd,EAAgIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA3I,EAAiNU,eAAe,EAACb,OAAO,YAAY;AAC3S,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAFwR,EAEtRE,UAAU,KAF4Q,EAErQC,cAAc,KAFuP,EAEhPC,YAAY,IAFoO,EAAhO,EAEGW,cAAc,EAACd,OAAO,UAAUiM,QAAV,EAAoB;AACpG,aAAO,KAAKpL,aAAL,GAAqBG,IAArB,CAA0BkL,SAASA,MAAMhL,QAAN,KAAmB+K,QAAtD,CAAP;AACD,KAFyE,EAEvEhM,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjB,EAA5B,CAA7B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BuK,oBAA5B;AACAtJ,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,mBAA9B,EAAmDsK,oBAAnD;AACA,MAAMG,kCAAkCvM,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,SAAX,EAAsBE,UAAU,EAACC,MAAM,KAAP,EAAhC,EAAD,EAAiD,EAACH,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAAjD,EAAkG,EAACH,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAlG,CAAR,EAA8JpB,UAAU,KAAxK,EAA+KC,cAAc,KAA7L,EAAoMC,YAAY,KAAhN,EAAd,EAAsOC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAjP,EAAuTU,eAAe,EAACb,OAAO,YAAY;AAC5Z,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAFyY,EAEvYE,UAAU,KAF6X,EAEtXC,cAAc,KAFwW,EAEjWC,YAAY,IAFqV,EAAtU,EAERW,cAAc,EAACd,OAAO,UAAUoM,QAAV,EAAoB;AACpG,aAAO,KAAKvL,aAAL,GAAqBG,IAArB,CAA0BqL,SAASA,MAAMnL,QAAN,KAAmBkL,QAAtD,CAAP;AACD,KAFyE,EAEvEnM,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFN,EAA5B,CAAxC;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4B0K,+BAA5B;AACAzJ,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,8BAA9B,EAA8DyK,+BAA9D;AACA,MAAMG,uBAAuB1M,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAd,EAAoFC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/F,EAAqKU,eAAe,EAACb,OAAO,YAAY;AAC/P,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAF4O,EAE1OE,UAAU,KAFgO,EAEzNC,cAAc,KAF2M,EAEpMC,YAAY,IAFwL,EAApL,EAEGW,cAAc,EAACd,OAAO,UAAUuM,QAAV,EAAoB;AACpG,aAAO,KAAK1L,aAAL,GAAqBG,IAArB,CAA0BwL,SAASA,MAAMtL,QAAN,KAAmBqL,QAAtD,CAAP;AACD,KAFyE,EAEvEtM,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjB,EAA5B,CAA7B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4B6K,oBAA5B;AACA5J,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,mBAA9B,EAAmD4K,oBAAnD;AACA,MAAMG,sBAAsB7M,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAA9C,CAAR,EAAoGpB,UAAU,KAA9G,EAAqHC,cAAc,KAAnI,EAA0IC,YAAY,KAAtJ,EAAd,EAA4KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAvL,EAA6PU,eAAe,EAACb,OAAO,YAAY;AACtV,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAFmU,EAEjUE,UAAU,KAFuT,EAEhTC,cAAc,KAFkS,EAE3RC,YAAY,IAF+Q,EAA5Q,EAEIW,cAAc,EAACd,OAAO,UAAU0M,QAAV,EAAoB;AACpG,aAAO,KAAK7L,aAAL,GAAqBG,IAArB,CAA0B2L,SAASA,MAAMzL,QAAN,KAAmBwL,QAAtD,CAAP;AACD,KAFyE,EAEvEzM,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFlB,EAA5B,CAA5B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BgL,mBAA5B;AACA/J,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,kBAA9B,EAAkD+K,mBAAlD;AACA,MAAMG,oBAAoBhN,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAd,EAAoFC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/F,EAAqKU,eAAe,EAACb,OAAO,YAAY;AAC5P,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAFyO,EAEvOE,UAAU,KAF6N,EAEtNC,cAAc,KAFwM,EAEjMC,YAAY,IAFqL,EAApL,EAEMW,cAAc,EAACd,OAAO,UAAU6M,QAAV,EAAoB;AACpG,aAAO,KAAKhM,aAAL,GAAqBG,IAArB,CAA0B8L,SAASA,MAAM5L,QAAN,KAAmB2L,QAAtD,CAAP;AACD,KAFyE,EAEvE5M,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFpB,EAA5B,CAA1B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BmL,iBAA5B;AACAlK,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,gBAA9B,EAAgDkL,iBAAhD;AACA,MAAMG,yBAAyBnN,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,CAAR,EAA6DpB,UAAU,KAAvE,EAA8EC,cAAc,KAA5F,EAAmGC,YAAY,KAA/G,EAAd,EAAqIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhJ,EAAsNU,eAAe,EAACb,OAAO,YAAY;AAClT,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAF+R,EAE7RE,UAAU,KAFmR,EAE5QC,cAAc,KAF8P,EAEvPC,YAAY,IAF2O,EAArO,EAECW,cAAc,EAACd,OAAO,UAAUgN,QAAV,EAAoB;AACpG,aAAO,KAAKnM,aAAL,GAAqBG,IAArB,CAA0BiM,SAASA,MAAM/L,QAAN,KAAmB8L,QAAtD,CAAP;AACD,KAFyE,EAEvE/M,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFf,EAA5B,CAA/B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BsL,sBAA5B;AACArK,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,qBAA9B,EAAqDqL,sBAArD;AACA,MAAMG,oBAAoBtN,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAA9C,EAA4F,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAA5F,CAAR,EAAkJpB,UAAU,KAA5J,EAAmKC,cAAc,KAAjL,EAAwLC,YAAY,KAApM,EAAd,EAA0NC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAArO,EAA2SU,eAAe,EAACb,OAAO,YAAY;AAClY,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAF+W,EAE7WE,UAAU,KAFmW,EAE5VC,cAAc,KAF8U,EAEvUC,YAAY,IAF2T,EAA1T,EAEMW,cAAc,EAACd,OAAO,UAAUmN,QAAV,EAAoB;AACpG,aAAO,KAAKtM,aAAL,GAAqBG,IAArB,CAA0BoM,SAASA,MAAMlM,QAAN,KAAmBiM,QAAtD,CAAP;AACD,KAFyE,EAEvElN,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFpB,EAA5B,CAA1B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4ByL,iBAA5B;AACAxK,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,gBAA9B,EAAgDwL,iBAAhD;AACA,MAAMG,oBAAoBzN,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAA9C,EAA4F,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAA5F,CAAR,EAAkJpB,UAAU,KAA5J,EAAmKC,cAAc,KAAjL,EAAwLC,YAAY,KAApM,EAAd,EAA0NC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAArO,EAA2SU,eAAe,EAACb,OAAO,YAAY;AAClY,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAF+W,EAE7WE,UAAU,KAFmW,EAE5VC,cAAc,KAF8U,EAEvUC,YAAY,IAF2T,EAA1T,EAEMW,cAAc,EAACd,OAAO,UAAUsN,QAAV,EAAoB;AACpG,aAAO,KAAKzM,aAAL,GAAqBG,IAArB,CAA0BuM,SAASA,MAAMrM,QAAN,KAAmBoM,QAAtD,CAAP;AACD,KAFyE,EAEvErN,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFpB,EAA5B,CAA1B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4B4L,iBAA5B;AACA3K,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,gBAA9B,EAAgD2L,iBAAhD;AACA,MAAMG,kBAAkB5N,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAA9C,EAA2F,EAACH,UAAU,QAAX,EAAqBE,UAAU,EAACC,MAAM,KAAP,EAA/B,EAA3F,EAA0I,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAA1I,CAAR,EAAgMpB,UAAU,KAA1M,EAAiNC,cAAc,KAA/N,EAAsOC,YAAY,KAAlP,EAAd,EAAwQC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAnR,EAAyVU,eAAe,EAACb,OAAO,YAAY;AAC9a,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAF2Z,EAEzZE,UAAU,KAF+Y,EAExYC,cAAc,KAF0X,EAEnXC,YAAY,IAFuW,EAAxW,EAEQW,cAAc,EAACd,OAAO,UAAUyN,QAAV,EAAoB;AACpG,aAAO,KAAK5M,aAAL,GAAqBG,IAArB,CAA0B0M,SAASA,MAAMxM,QAAN,KAAmBuM,QAAtD,CAAP;AACD,KAFyE,EAEvExN,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFtB,EAA5B,CAAxB;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4B+L,eAA5B;AACA9K,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,cAA9B,EAA8C8L,eAA9C;AACA,MAAMG,iBAAiB/N,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAA9C,EAAiG,EAACH,UAAU,WAAX,EAAwBE,UAAU,EAACC,MAAM,KAAP,EAAlC,EAAjG,CAAR,EAA4JpB,UAAU,KAAtK,EAA6KC,cAAc,KAA3L,EAAkMC,YAAY,KAA9M,EAAd,EAAoOC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/O,EAAqTU,eAAe,EAACb,OAAO,YAAY;AACzY,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAFsX,EAEpXE,UAAU,KAF0W,EAEnWC,cAAc,KAFqV,EAE9UC,YAAY,IAFkU,EAApU,EAESW,cAAc,EAACd,OAAO,UAAU4N,QAAV,EAAoB;AACpG,aAAO,KAAK/M,aAAL,GAAqBG,IAArB,CAA0B6M,SAASA,MAAM3M,QAAN,KAAmB0M,QAAtD,CAAP;AACD,KAFyE,EAEvE3N,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFvB,EAA5B,CAAvB;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BkM,cAA5B;AACAjL,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,aAA9B,EAA6CiM,cAA7C;AACA,MAAMG,sBAAsBlO,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAAD,EAA+C,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAA/C,CAAR,EAAqGpB,UAAU,KAA/G,EAAsHC,cAAc,KAApI,EAA2IC,YAAY,KAAvJ,EAAd,EAA6KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAxL,EAA8PU,eAAe,EAACb,OAAO,YAAY;AACvV,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAFoU,EAElUE,UAAU,KAFwT,EAEjTC,cAAc,KAFmS,EAE5RC,YAAY,IAFgR,EAA7Q,EAEIW,cAAc,EAACd,OAAO,UAAU+N,QAAV,EAAoB;AACpG,aAAO,KAAKlN,aAAL,GAAqBG,IAArB,CAA0BgN,SAASA,MAAM9M,QAAN,KAAmB6M,QAAtD,CAAP;AACD,KAFyE,EAEvE9N,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFlB,EAA5B,CAA5B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BqM,mBAA5B;AACApL,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,kBAA9B,EAAkDoM,mBAAlD;AACA,MAAMG,qBAAqBrO,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,CAAR,EAA6DpB,UAAU,KAAvE,EAA8EC,cAAc,KAA5F,EAAmGC,YAAY,KAA/G,EAAd,EAAqIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhJ,EAAsNU,eAAe,EAACb,OAAO,YAAY;AAC9S,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAF2R,EAEzRE,UAAU,KAF+Q,EAExQC,cAAc,KAF0P,EAEnPC,YAAY,IAFuO,EAArO,EAEKW,cAAc,EAACd,OAAO,UAAUkO,QAAV,EAAoB;AACpG,aAAO,KAAKrN,aAAL,GAAqBG,IAArB,CAA0BmN,SAASA,MAAMjN,QAAN,KAAmBgN,QAAtD,CAAP;AACD,KAFyE,EAEvEjO,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFnB,EAA5B,CAA3B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BwM,kBAA5B;AACAvL,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,iBAA9B,EAAiDuM,kBAAjD;AACA,MAAMG,qBAAqBxO,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,cAAX,EAA2BE,UAAU,EAACC,MAAM,KAAP,EAArC,EAAD,EAAsD,EAACH,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAAtD,CAAR,EAA6GpB,UAAU,KAAvH,EAA8HC,cAAc,KAA5I,EAAmJC,YAAY,KAA/J,EAAd,EAAqLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhM,EAAsQU,eAAe,EAACb,OAAO,YAAY;AAC9V,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAF2U,EAEzUE,UAAU,KAF+T,EAExTC,cAAc,KAF0S,EAEnSC,YAAY,IAFuR,EAArR,EAEKW,cAAc,EAACd,OAAO,UAAUqO,QAAV,EAAoB;AACpG,aAAO,KAAKxN,aAAL,GAAqBG,IAArB,CAA0BsN,SAASA,MAAMpN,QAAN,KAAmBmN,QAAtD,CAAP;AACD,KAFyE,EAEvEpO,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFnB,EAA5B,CAA3B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4B2M,kBAA5B;AACA1L,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,iBAA9B,EAAiD0M,kBAAjD;AACA,MAAMG,gCAAgC3O,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,cAAX,EAA2BE,UAAU,EAACC,MAAM,KAAP,EAArC,EAAD,EAAsD,EAACH,UAAU,iBAAX,EAA8BE,UAAU,EAACC,MAAM,KAAP,EAAxC,EAAtD,EAA8G,EAACH,UAAU,aAAX,EAA0BE,UAAU,EAACC,MAAM,KAAP,EAApC,EAA9G,EAAkK,EAACH,UAAU,kBAAX,EAA+BE,UAAU,EAACC,MAAM,KAAP,EAAzC,EAAlK,CAAR,EAAoOpB,UAAU,KAA9O,EAAqPC,cAAc,KAAnQ,EAA0QC,YAAY,KAAtR,EAAd,EAA4SC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAvT,EAA6XU,eAAe,EAACb,OAAO,YAAY;AAChe,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAF6c,EAE3cE,UAAU,KAFic,EAE1bC,cAAc,KAF4a,EAEraC,YAAY,IAFyZ,EAA5Y,EAENW,cAAc,EAACd,OAAO,UAAUwO,QAAV,EAAoB;AACpG,aAAO,KAAK3N,aAAL,GAAqBG,IAArB,CAA0ByN,SAASA,MAAMvN,QAAN,KAAmBsN,QAAtD,CAAP;AACD,KAFyE,EAEvEvO,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFR,EAA5B,CAAtC;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4B8M,6BAA5B;AACA7L,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,4BAA9B,EAA4D6M,6BAA5D;AACA,MAAMG,oBAAoB9O,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,CAAR,EAA6DpB,UAAU,KAAvE,EAA8EC,cAAc,KAA5F,EAAmGC,YAAY,KAA/G,EAAd,EAAqIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhJ,EAAsNU,eAAe,EAACb,OAAO,YAAY;AAC7S,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAF0R,EAExRE,UAAU,KAF8Q,EAEvQC,cAAc,KAFyP,EAElPC,YAAY,IAFsO,EAArO,EAEMW,cAAc,EAACd,OAAO,UAAU2O,QAAV,EAAoB;AACpG,aAAO,KAAK9N,aAAL,GAAqBG,IAArB,CAA0B4N,SAASA,MAAM1N,QAAN,KAAmByN,QAAtD,CAAP;AACD,KAFyE,EAEvE1O,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFpB,EAA5B,CAA1B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BiN,iBAA5B;AACAhM,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,gBAA9B,EAAgDgN,iBAAhD;AACA,MAAMG,uBAAuBjP,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,aAAX,EAA0BE,UAAU,EAACC,MAAM,KAAP,EAApC,EAA9C,CAAR,EAA2GpB,UAAU,KAArH,EAA4HC,cAAc,KAA1I,EAAiJC,YAAY,KAA7J,EAAd,EAAmLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA9L,EAAoQU,eAAe,EAACb,OAAO,YAAY;AAC9V,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAF2U,EAEzUE,UAAU,KAF+T,EAExTC,cAAc,KAF0S,EAEnSC,YAAY,IAFuR,EAAnR,EAEGW,cAAc,EAACd,OAAO,UAAU8O,QAAV,EAAoB;AACpG,aAAO,KAAKjO,aAAL,GAAqBG,IAArB,CAA0B+N,SAASA,MAAM7N,QAAN,KAAmB4N,QAAtD,CAAP;AACD,KAFyE,EAEvE7O,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjB,EAA5B,CAA7B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BoN,oBAA5B;AACAnM,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,mBAA9B,EAAmDmN,oBAAnD;AACA,MAAMG,yBAAyBpP,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,aAAX,EAA0BE,UAAU,EAACC,MAAM,KAAP,EAApC,EAA9C,EAAkG,EAACH,UAAU,WAAX,EAAwBE,UAAU,EAACC,MAAM,KAAP,EAAlC,EAAlG,CAAR,EAA6JpB,UAAU,KAAvK,EAA8KC,cAAc,KAA5L,EAAmMC,YAAY,KAA/M,EAAd,EAAqOC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhP,EAAsTU,eAAe,EAACb,OAAO,YAAY;AAClZ,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAF+X,EAE7XE,UAAU,KAFmX,EAE5WC,cAAc,KAF8V,EAEvVC,YAAY,IAF2U,EAArU,EAECW,cAAc,EAACd,OAAO,UAAUiP,QAAV,EAAoB;AACpG,aAAO,KAAKpO,aAAL,GAAqBG,IAArB,CAA0BkO,SAASA,MAAMhO,QAAN,KAAmB+N,QAAtD,CAAP;AACD,KAFyE,EAEvEhP,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFf,EAA5B,CAA/B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BuN,sBAA5B;AACAtM,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,qBAA9B,EAAqDsN,sBAArD;AACA,MAAMG,kCAAkCvP,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,aAAX,EAA0BE,UAAU,EAACC,MAAM,KAAP,EAApC,EAAD,CAAR,EAA8DpB,UAAU,KAAxE,EAA+EC,cAAc,KAA7F,EAAoGC,YAAY,KAAhH,EAAd,EAAsIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAjJ,EAAuNU,eAAe,EAACb,OAAO,YAAY;AAC5T,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAFyS,EAEvSE,UAAU,KAF6R,EAEtRC,cAAc,KAFwQ,EAEjQC,YAAY,IAFqP,EAAtO,EAERW,cAAc,EAACd,OAAO,UAAUoP,QAAV,EAAoB;AACpG,aAAO,KAAKvO,aAAL,GAAqBG,IAArB,CAA0BqO,SAASA,MAAMnO,QAAN,KAAmBkO,QAAtD,CAAP;AACD,KAFyE,EAEvEnP,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFN,EAA5B,CAAxC;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4B0N,+BAA5B;AACAzM,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,8BAA9B,EAA8DyN,+BAA9D;AACA,MAAMG,mBAAmB1P,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,QAAX,EAAqBE,UAAU,EAACC,MAAM,KAAP,EAA/B,EAAD,EAAgD,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAhD,CAAR,EAAsGpB,UAAU,KAAhH,EAAuHC,cAAc,KAArI,EAA4IC,YAAY,KAAxJ,EAAd,EAA8KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAzL,EAA+PU,eAAe,EAACb,OAAO,YAAY;AACrV,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAFkU,EAEhUE,UAAU,KAFsT,EAE/SC,cAAc,KAFiS,EAE1RC,YAAY,IAF8Q,EAA9Q,EAEOW,cAAc,EAACd,OAAO,UAAUuP,QAAV,EAAoB;AACpG,aAAO,KAAK1O,aAAL,GAAqBG,IAArB,CAA0BwO,SAASA,MAAMtO,QAAN,KAAmBqO,QAAtD,CAAP;AACD,KAFyE,EAEvEtP,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFrB,EAA5B,CAAzB;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4B6N,gBAA5B;AACA5M,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,eAA9B,EAA+C4N,gBAA/C;AACA,MAAMG,oBAAoB7P,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAA9C,CAAR,EAAoGpB,UAAU,KAA9G,EAAqHC,cAAc,KAAnI,EAA0IC,YAAY,KAAtJ,EAAd,EAA4KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAvL,EAA6PU,eAAe,EAACb,OAAO,YAAY;AACpV,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAFiU,EAE/TE,UAAU,KAFqT,EAE9SC,cAAc,KAFgS,EAEzRC,YAAY,IAF6Q,EAA5Q,EAEMW,cAAc,EAACd,OAAO,UAAU0P,QAAV,EAAoB;AACpG,aAAO,KAAK7O,aAAL,GAAqBG,IAArB,CAA0B2O,SAASA,MAAMzO,QAAN,KAAmBwO,QAAtD,CAAP;AACD,KAFyE,EAEvEzP,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFpB,EAA5B,CAA1B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BgO,iBAA5B;AACA/M,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,gBAA9B,EAAgD+N,iBAAhD;AACA,MAAMG,YAAYhQ,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAA9C,CAAR,EAAqGpB,UAAU,KAA/G,EAAsHC,cAAc,KAApI,EAA2IC,YAAY,KAAvJ,EAAd,EAA6KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAxL,EAA8PU,eAAe,EAACb,OAAO,YAAY;AACxU,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFqT,EAEnTE,UAAU,KAFyS,EAElSC,cAAc,KAFoR,EAE7QC,YAAY,IAFiQ,EAA7Q,EAEmBW,cAAc,EAACd,OAAO,UAAU6P,QAAV,EAAoB;AACpG,aAAO,KAAKhP,aAAL,GAAqBG,IAArB,CAA0B8O,SAASA,MAAM5O,QAAN,KAAmB2O,QAAtD,CAAP;AACD,KAFyE,EAEvE5P,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjC,EAAvB,CAAlB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBmO,SAAvB;AACAjQ,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,QAAzB,EAAmCkO,SAAnC;AACA,MAAMG,WAAWnQ,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,CAAR,EAA6DpB,UAAU,KAAvE,EAA8EC,cAAc,KAA5F,EAAmGC,YAAY,KAA/G,EAAd,EAAqIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhJ,EAAsNU,eAAe,EAACb,OAAO,YAAY;AAC/R,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF4Q,EAE1QE,UAAU,KAFgQ,EAEzPC,cAAc,KAF2O,EAEpOC,YAAY,IAFwN,EAArO,EAEoBW,cAAc,EAACd,OAAO,UAAUgQ,QAAV,EAAoB;AACpG,aAAO,KAAKnP,aAAL,GAAqBG,IAArB,CAA0BiP,SAASA,MAAM/O,QAAN,KAAmB8O,QAAtD,CAAP;AACD,KAFyE,EAEvE/P,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFlC,EAAvB,CAAjB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBsO,QAAvB;AACApQ,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,OAAzB,EAAkCqO,QAAlC;AACA,MAAMG,iBAAiBtQ,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,SAAX,EAAsBE,UAAU,EAACC,MAAM,KAAP,EAAhC,EAAD,EAAiD,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAjD,CAAR,EAAuGpB,UAAU,KAAjH,EAAwHC,cAAc,KAAtI,EAA6IC,YAAY,KAAzJ,EAAd,EAA+KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1L,EAAgQU,eAAe,EAACb,OAAO,YAAY;AAC/U,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF4T,EAE1TE,UAAU,KAFgT,EAEzSC,cAAc,KAF2R,EAEpRC,YAAY,IAFwQ,EAA/Q,EAEcW,cAAc,EAACd,OAAO,UAAUmQ,QAAV,EAAoB;AACpG,aAAO,KAAKtP,aAAL,GAAqBG,IAArB,CAA0BoP,SAASA,MAAMlP,QAAN,KAAmBiP,QAAtD,CAAP;AACD,KAFyE,EAEvElQ,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF5B,EAAvB,CAAvB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuByO,cAAvB;AACAvQ,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,aAAzB,EAAwCwO,cAAxC;AACA,MAAMG,eAAezQ,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAAD,CAAR,EAA2DpB,UAAU,KAArE,EAA4EC,cAAc,KAA1F,EAAiGC,YAAY,KAA7G,EAAd,EAAmIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA9I,EAAoNU,eAAe,EAACb,OAAO,YAAY;AACjS,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF8Q,EAE5QE,UAAU,KAFkQ,EAE3PC,cAAc,KAF6O,EAEtOC,YAAY,IAF0N,EAAnO,EAEgBW,cAAc,EAACd,OAAO,UAAUsQ,QAAV,EAAoB;AACpG,aAAO,KAAKzP,aAAL,GAAqBG,IAArB,CAA0BuP,SAASA,MAAMrP,QAAN,KAAmBoP,QAAtD,CAAP;AACD,KAFyE,EAEvErQ,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF9B,EAAvB,CAArB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuB4O,YAAvB;AACA1Q,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,WAAzB,EAAsC2O,YAAtC;AACA,MAAMG,sBAAsB5Q,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,OAAX,EAAoBE,UAAU,EAACC,MAAM,KAAP,EAA9B,EAAD,EAA+C,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAA/C,CAAR,EAAqGpB,UAAU,KAA/G,EAAsHC,cAAc,KAApI,EAA2IC,YAAY,KAAvJ,EAAd,EAA6KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAxL,EAA8PU,eAAe,EAACb,OAAO,YAAY;AAClV,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF+T,EAE7TE,UAAU,KAFmT,EAE5SC,cAAc,KAF8R,EAEvRC,YAAY,IAF2Q,EAA7Q,EAESW,cAAc,EAACd,OAAO,UAAUyQ,QAAV,EAAoB;AACpG,aAAO,KAAK5P,aAAL,GAAqBG,IAArB,CAA0B0P,SAASA,MAAMxP,QAAN,KAAmBuP,QAAtD,CAAP;AACD,KAFyE,EAEvExQ,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFvB,EAAvB,CAA5B;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuB+O,mBAAvB;AACA7Q,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,kBAAzB,EAA6C8O,mBAA7C;AACA,MAAMG,kBAAkB/Q,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,EAAoD,EAACH,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAApD,CAAR,EAAgHpB,UAAU,KAA1H,EAAiIC,cAAc,KAA/I,EAAsJC,YAAY,KAAlK,EAAd,EAAwLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAnM,EAAyQU,eAAe,EAACb,OAAO,YAAY;AACzV,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFsU,EAEpUE,UAAU,KAF0T,EAEnTC,cAAc,KAFqS,EAE9RC,YAAY,IAFkR,EAAxR,EAEaW,cAAc,EAACd,OAAO,UAAU4Q,QAAV,EAAoB;AACpG,aAAO,KAAK/P,aAAL,GAAqBG,IAArB,CAA0B6P,SAASA,MAAM3P,QAAN,KAAmB0P,QAAtD,CAAP;AACD,KAFyE,EAEvE3Q,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF3B,EAAvB,CAAxB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBkP,eAAvB;AACAhR,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,cAAzB,EAAyCiP,eAAzC;AACA,MAAMG,yBAAyBlR,OAAOC,MAAP,CAAc6C,YAAd,EAA4B,EAAC3C,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,aAAX,EAA0BE,UAAU,EAACC,MAAM,KAAP,EAApC,EAA9C,EAAkG,EAACH,UAAU,QAAX,EAAqBE,UAAU,EAACC,MAAM,KAAP,EAA/B,EAAlG,EAAiJ,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAjJ,CAAR,EAAuMpB,UAAU,KAAjN,EAAwNC,cAAc,KAAtO,EAA6OC,YAAY,KAAzP,EAAd,EAA+QC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1R,EAAgWU,eAAe,EAACb,OAAO,YAAY;AAC5b,aAAO0C,aAAa7B,aAAb,GAA6BS,MAA7B,CAAoC,KAAKvB,WAAzC,CAAP;AACD,KAFya,EAEvaE,UAAU,KAF6Z,EAEtZC,cAAc,KAFwY,EAEjYC,YAAY,IAFqX,EAA/W,EAECW,cAAc,EAACd,OAAO,UAAU+Q,QAAV,EAAoB;AACpG,aAAO,KAAKlQ,aAAL,GAAqBG,IAArB,CAA0BgQ,SAASA,MAAM9P,QAAN,KAAmB6P,QAAtD,CAAP;AACD,KAFyE,EAEvE9Q,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFf,EAA5B,CAA/B;AAKAuC,aAAatC,SAAb,CAAuBqB,IAAvB,CAA4BqP,sBAA5B;AACApO,aAAarC,YAAb,CAA0BqB,GAA1B,CAA8B,qBAA9B,EAAqDoP,sBAArD;AACA,MAAMG,aAAarR,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,EAAoD,EAACH,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAApD,CAAR,EAAgHpB,UAAU,KAA1H,EAAiIC,cAAc,KAA/I,EAAsJC,YAAY,KAAlK,EAAd,EAAwLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAnM,EAAyQU,eAAe,EAACb,OAAO,YAAY;AACpV,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFiU,EAE/TE,UAAU,KAFqT,EAE9SC,cAAc,KAFgS,EAEzRC,YAAY,IAF6Q,EAAxR,EAEkBW,cAAc,EAACd,OAAO,UAAUkR,QAAV,EAAoB;AACpG,aAAO,KAAKrQ,aAAL,GAAqBG,IAArB,CAA0BmQ,SAASA,MAAMjQ,QAAN,KAAmBgQ,QAAtD,CAAP;AACD,KAFyE,EAEvEjR,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFhC,EAAvB,CAAnB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBwP,UAAvB;AACAtR,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,QAAzB,EAAmCuP,UAAnC;AACA,MAAMG,oBAAoBxR,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,CAAR,EAA6DpB,UAAU,KAAvE,EAA8EC,cAAc,KAA5F,EAAmGC,YAAY,KAA/G,EAAd,EAAqIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhJ,EAAsNU,eAAe,EAACb,OAAO,YAAY;AACxS,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFqR,EAEnRE,UAAU,KAFyQ,EAElQC,cAAc,KAFoP,EAE7OC,YAAY,IAFiO,EAArO,EAEWW,cAAc,EAACd,OAAO,UAAUqR,QAAV,EAAoB;AACpG,aAAO,KAAKxQ,aAAL,GAAqBG,IAArB,CAA0BsQ,SAASA,MAAMpQ,QAAN,KAAmBmQ,QAAtD,CAAP;AACD,KAFyE,EAEvEpR,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFzB,EAAvB,CAA1B;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuB2P,iBAAvB;AACAzR,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,eAAzB,EAA0C0P,iBAA1C;AACA,MAAMG,YAAY3R,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAd,EAAoFC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA/F,EAAqKU,eAAe,EAACb,OAAO,YAAY;AAC/O,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF4N,EAE1NE,UAAU,KAFgN,EAEzMC,cAAc,KAF2L,EAEpLC,YAAY,IAFwK,EAApL,EAEmBW,cAAc,EAACd,OAAO,UAAUwR,QAAV,EAAoB;AACpG,aAAO,KAAK3Q,aAAL,GAAqBG,IAArB,CAA0ByQ,SAASA,MAAMvQ,QAAN,KAAmBsQ,QAAtD,CAAP;AACD,KAFyE,EAEvEvR,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFjC,EAAvB,CAAlB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuB8P,SAAvB;AACA5R,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,OAAzB,EAAkC6P,SAAlC;AACA,MAAMG,iBAAiB9R,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAA9C,CAAR,EAA0GpB,UAAU,KAApH,EAA2HC,cAAc,KAAzI,EAAgJC,YAAY,KAA5J,EAAd,EAAkLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA7L,EAAmQU,eAAe,EAACb,OAAO,YAAY;AAClV,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF+T,EAE7TE,UAAU,KAFmT,EAE5SC,cAAc,KAF8R,EAEvRC,YAAY,IAF2Q,EAAlR,EAEcW,cAAc,EAACd,OAAO,UAAU2R,QAAV,EAAoB;AACpG,aAAO,KAAK9Q,aAAL,GAAqBG,IAArB,CAA0B4Q,SAASA,MAAM1Q,QAAN,KAAmByQ,QAAtD,CAAP;AACD,KAFyE,EAEvE1R,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF5B,EAAvB,CAAvB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBiQ,cAAvB;AACA/R,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,YAAzB,EAAuCgQ,cAAvC;AACA,MAAMG,oBAAoBjS,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,YAAX,EAAyBE,UAAU,EAACC,MAAM,KAAP,EAAnC,EAAD,CAAR,EAA6DpB,UAAU,KAAvE,EAA8EC,cAAc,KAA5F,EAAmGC,YAAY,KAA/G,EAAd,EAAqIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAAhJ,EAAsNU,eAAe,EAACb,OAAO,YAAY;AACxS,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFqR,EAEnRE,UAAU,KAFyQ,EAElQC,cAAc,KAFoP,EAE7OC,YAAY,IAFiO,EAArO,EAEWW,cAAc,EAACd,OAAO,UAAU8R,QAAV,EAAoB;AACpG,aAAO,KAAKjR,aAAL,GAAqBG,IAArB,CAA0B+Q,SAASA,MAAM7Q,QAAN,KAAmB4Q,QAAtD,CAAP;AACD,KAFyE,EAEvE7R,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFzB,EAAvB,CAA1B;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBoQ,iBAAvB;AACAlS,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,eAAzB,EAA0CmQ,iBAA1C;AACA,MAAMG,sBAAsBpS,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAAD,CAAR,EAA2DpB,UAAU,KAArE,EAA4EC,cAAc,KAA1F,EAAiGC,YAAY,KAA7G,EAAd,EAAmIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA9I,EAAoNU,eAAe,EAACb,OAAO,YAAY;AACxS,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFqR,EAEnRE,UAAU,KAFyQ,EAElQC,cAAc,KAFoP,EAE7OC,YAAY,IAFiO,EAAnO,EAESW,cAAc,EAACd,OAAO,UAAUiS,QAAV,EAAoB;AACpG,aAAO,KAAKpR,aAAL,GAAqBG,IAArB,CAA0BkR,SAASA,MAAMhR,QAAN,KAAmB+Q,QAAtD,CAAP;AACD,KAFyE,EAEvEhS,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFvB,EAAvB,CAA5B;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBuQ,mBAAvB;AACArS,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,iBAAzB,EAA4CsQ,mBAA5C;AACA,MAAMG,qBAAqBvS,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAAD,CAAR,EAA2DpB,UAAU,KAArE,EAA4EC,cAAc,KAA1F,EAAiGC,YAAY,KAA7G,EAAd,EAAmIC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA9I,EAAoNU,eAAe,EAACb,OAAO,YAAY;AACvS,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFoR,EAElRE,UAAU,KAFwQ,EAEjQC,cAAc,KAFmP,EAE5OC,YAAY,IAFgO,EAAnO,EAEUW,cAAc,EAACd,OAAO,UAAUoS,QAAV,EAAoB;AACpG,aAAO,KAAKvR,aAAL,GAAqBG,IAArB,CAA0BqR,SAASA,MAAMnR,QAAN,KAAmBkR,QAAtD,CAAP;AACD,KAFyE,EAEvEnS,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFxB,EAAvB,CAA3B;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuB0Q,kBAAvB;AACAxS,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,gBAAzB,EAA2CyQ,kBAA3C;AACA,MAAMG,kBAAkB1S,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,UAAX,EAAuBE,UAAU,EAACC,MAAM,KAAP,EAAjC,EAA9C,CAAR,EAAwGpB,UAAU,KAAlH,EAAyHC,cAAc,KAAvI,EAA8IC,YAAY,KAA1J,EAAd,EAAgLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA3L,EAAiQU,eAAe,EAACb,OAAO,YAAY;AACjV,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAF8T,EAE5TE,UAAU,KAFkT,EAE3SC,cAAc,KAF6R,EAEtRC,YAAY,IAF0Q,EAAhR,EAEaW,cAAc,EAACd,OAAO,UAAUuS,QAAV,EAAoB;AACpG,aAAO,KAAK1R,aAAL,GAAqBG,IAArB,CAA0BwR,SAASA,MAAMtR,QAAN,KAAmBqR,QAAtD,CAAP;AACD,KAFyE,EAEvEtS,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAF3B,EAAvB,CAAxB;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuB6Q,eAAvB;AACA3S,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,aAAzB,EAAwC4Q,eAAxC;AACA,MAAMG,0BAA0B7S,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAD,EAA8C,EAACH,UAAU,aAAX,EAA0BE,UAAU,EAACC,MAAM,KAAP,EAApC,EAA9C,CAAR,EAA2GpB,UAAU,KAArH,EAA4HC,cAAc,KAA1I,EAAiJC,YAAY,KAA7J,EAAd,EAAmLC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA9L,EAAoQU,eAAe,EAACb,OAAO,YAAY;AAC5V,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFyU,EAEvUE,UAAU,KAF6T,EAEtTC,cAAc,KAFwS,EAEjSC,YAAY,IAFqR,EAAnR,EAEKW,cAAc,EAACd,OAAO,UAAU0S,QAAV,EAAoB;AACpG,aAAO,KAAK7R,aAAL,GAAqBG,IAArB,CAA0B2R,SAASA,MAAMzR,QAAN,KAAmBwR,QAAtD,CAAP;AACD,KAFyE,EAEvEzS,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFnB,EAAvB,CAAhC;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBgR,uBAAvB;AACA9S,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,qBAAzB,EAAgD+Q,uBAAhD;AACA,MAAMG,yBAAyBhT,OAAOC,MAAP,CAAcF,OAAd,EAAuB,EAACI,aAAa,EAACC,OAAO,CAAC,EAACkB,UAAU,SAAX,EAAsBE,UAAU,EAACC,MAAM,KAAP,EAAhC,EAAD,EAAiD,EAACH,UAAU,MAAX,EAAmBE,UAAU,EAACC,MAAM,KAAP,EAA7B,EAAjD,CAAR,EAAuGpB,UAAU,KAAjH,EAAwHC,cAAc,KAAtI,EAA6IC,YAAY,KAAzJ,EAAd,EAA+KC,WAAW,EAACJ,OAAO,EAAR,EAAYC,UAAU,KAAtB,EAA6BC,cAAc,KAA3C,EAAkDC,YAAY,KAA9D,EAA1L,EAAgQU,eAAe,EAACb,OAAO,YAAY;AACvV,aAAOL,QAAQkB,aAAR,GAAwBS,MAAxB,CAA+B,KAAKvB,WAApC,CAAP;AACD,KAFoU,EAElUE,UAAU,KAFwT,EAEjTC,cAAc,KAFmS,EAE5RC,YAAY,IAFgR,EAA/Q,EAEMW,cAAc,EAACd,OAAO,UAAU6S,QAAV,EAAoB;AACpG,aAAO,KAAKhS,aAAL,GAAqBG,IAArB,CAA0B8R,SAASA,MAAM5R,QAAN,KAAmB2R,QAAtD,CAAP;AACD,KAFyE,EAEvE5S,UAAU,KAF6D,EAEtDC,cAAc,KAFwC,EAEjCC,YAAY,IAFqB,EAFpB,EAAvB,CAA/B;AAKAR,QAAQS,SAAR,CAAkBqB,IAAlB,CAAuBmR,sBAAvB;AACAjT,QAAQU,YAAR,CAAqBqB,GAArB,CAAyB,oBAAzB,EAA+CkR,sBAA/C;kBACejT,O","file":"term-spec.js","sourcesContent":["const Term_16 = Object.create(Object.prototype, {_attributes: {value: [], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, _descendants: {value: new Map, writable: false, configurable: false, enumerable: false}, hasDescendant: {value: function (name_110) {\n  return this._descendants.has(name_110);\n}, writable: false, configurable: false, enumerable: true}, getDescendant: {value: function (name_111) {\n  return this._descendants.get(name_111);\n}, writable: false, configurable: false, enumerable: true}, getAttributes: {value: function () {\n  return this._attributes;\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_112) {\n  return this._attributes.some(a_113 => a_113.attrName === attr_112);\n}, writable: false, configurable: false, enumerable: true}});\nconst BindingWithDefault_17 = Object.create(Term_16, {_attributes: {value: [{attrName: \"binding\", attrType: {name: \"any\"}}, {attrName: \"init\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_114) {\n  return this.getAttributes().some(a_115 => a_115.attrName === attr_114);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(BindingWithDefault_17);\nTerm_16._descendants.set(\"BindingWithDefault\", BindingWithDefault_17);\nconst BindingIdentifier_18 = Object.create(Term_16, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_116) {\n  return this.getAttributes().some(a_117 => a_117.attrName === attr_116);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(BindingIdentifier_18);\nTerm_16._descendants.set(\"BindingIdentifier\", BindingIdentifier_18);\nconst ArrayBinding_19 = Object.create(Term_16, {_attributes: {value: [{attrName: \"elements\", attrType: {name: \"any\"}}, {attrName: \"restElement\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_118) {\n  return this.getAttributes().some(a_119 => a_119.attrName === attr_118);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(ArrayBinding_19);\nTerm_16._descendants.set(\"ArrayBinding\", ArrayBinding_19);\nconst ObjectBinding_20 = Object.create(Term_16, {_attributes: {value: [{attrName: \"properties\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_120) {\n  return this.getAttributes().some(a_121 => a_121.attrName === attr_120);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(ObjectBinding_20);\nTerm_16._descendants.set(\"ObjectBinding\", ObjectBinding_20);\nconst BindingPropertyIdentifier_21 = Object.create(Term_16, {_attributes: {value: [{attrName: \"binding\", attrType: {name: \"any\"}}, {attrName: \"init\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_122) {\n  return this.getAttributes().some(a_123 => a_123.attrName === attr_122);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(BindingPropertyIdentifier_21);\nTerm_16._descendants.set(\"BindingPropertyIdentifier\", BindingPropertyIdentifier_21);\nconst BindingPropertyProperty_22 = Object.create(Term_16, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}, {attrName: \"binding\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_124) {\n  return this.getAttributes().some(a_125 => a_125.attrName === attr_124);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(BindingPropertyProperty_22);\nTerm_16._descendants.set(\"BindingPropertyProperty\", BindingPropertyProperty_22);\nconst Statement_23 = Object.create(Term_16, {_attributes: {value: [], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_126) {\n  return this.getAttributes().some(a_127 => a_127.attrName === attr_126);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(Statement_23);\nTerm_16._descendants.set(\"Statement\", Statement_23);\nconst Expression_24 = Object.create(Term_16, {_attributes: {value: [], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_128) {\n  return this.getAttributes().some(a_129 => a_129.attrName === attr_128);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(Expression_24);\nTerm_16._descendants.set(\"Expression\", Expression_24);\nconst ClassExpression_25 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}, {attrName: \"super\", attrType: {name: \"any\"}}, {attrName: \"elements\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_130) {\n  return this.getAttributes().some(a_131 => a_131.attrName === attr_130);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(ClassExpression_25);\nExpression_24._descendants.set(\"ClassExpression\", ClassExpression_25);\nconst ClassDeclaration_26 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}, {attrName: \"super\", attrType: {name: \"any\"}}, {attrName: \"elements\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_132) {\n  return this.getAttributes().some(a_133 => a_133.attrName === attr_132);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(ClassDeclaration_26);\nStatement_23._descendants.set(\"ClassDeclaration\", ClassDeclaration_26);\nconst ClassElement_27 = Object.create(Term_16, {_attributes: {value: [{attrName: \"isStatic\", attrType: {name: \"any\"}}, {attrName: \"method\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_134) {\n  return this.getAttributes().some(a_135 => a_135.attrName === attr_134);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(ClassElement_27);\nTerm_16._descendants.set(\"ClassElement\", ClassElement_27);\nconst Module_28 = Object.create(Term_16, {_attributes: {value: [{attrName: \"directives\", attrType: {name: \"any\"}}, {attrName: \"items\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_136) {\n  return this.getAttributes().some(a_137 => a_137.attrName === attr_136);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(Module_28);\nTerm_16._descendants.set(\"Module\", Module_28);\nconst Import_29 = Object.create(Term_16, {_attributes: {value: [{attrName: \"moduleSpecifier\", attrType: {name: \"any\"}}, {attrName: \"defaultBinding\", attrType: {name: \"any\"}}, {attrName: \"namedImports\", attrType: {name: \"any\"}}, {attrName: \"forSyntax\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_138) {\n  return this.getAttributes().some(a_139 => a_139.attrName === attr_138);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(Import_29);\nTerm_16._descendants.set(\"Import\", Import_29);\nconst ImportNamespace_30 = Object.create(Term_16, {_attributes: {value: [{attrName: \"moduleSpecifier\", attrType: {name: \"any\"}}, {attrName: \"defaultBinding\", attrType: {name: \"any\"}}, {attrName: \"namespaceBinding\", attrType: {name: \"any\"}}, {attrName: \"forSyntax\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_140) {\n  return this.getAttributes().some(a_141 => a_141.attrName === attr_140);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(ImportNamespace_30);\nTerm_16._descendants.set(\"ImportNamespace\", ImportNamespace_30);\nconst ImportSpecifier_31 = Object.create(Term_16, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}, {attrName: \"binding\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_142) {\n  return this.getAttributes().some(a_143 => a_143.attrName === attr_142);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(ImportSpecifier_31);\nTerm_16._descendants.set(\"ImportSpecifier\", ImportSpecifier_31);\nconst ExportAllFrom_32 = Object.create(Term_16, {_attributes: {value: [{attrName: \"moduleSpecifier\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_144) {\n  return this.getAttributes().some(a_145 => a_145.attrName === attr_144);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(ExportAllFrom_32);\nTerm_16._descendants.set(\"ExportAllFrom\", ExportAllFrom_32);\nconst ExportFrom_33 = Object.create(Term_16, {_attributes: {value: [{attrName: \"namedExports\", attrType: {name: \"any\"}}, {attrName: \"moduleSpecifier\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_146) {\n  return this.getAttributes().some(a_147 => a_147.attrName === attr_146);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(ExportFrom_33);\nTerm_16._descendants.set(\"ExportFrom\", ExportFrom_33);\nconst Export_34 = Object.create(Term_16, {_attributes: {value: [{attrName: \"declaration\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_148) {\n  return this.getAttributes().some(a_149 => a_149.attrName === attr_148);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(Export_34);\nTerm_16._descendants.set(\"Export\", Export_34);\nconst ExportDefault_35 = Object.create(Term_16, {_attributes: {value: [{attrName: \"body\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_150) {\n  return this.getAttributes().some(a_151 => a_151.attrName === attr_150);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(ExportDefault_35);\nTerm_16._descendants.set(\"ExportDefault\", ExportDefault_35);\nconst ExportSpecifier_36 = Object.create(Term_16, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}, {attrName: \"exportedName\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_152) {\n  return this.getAttributes().some(a_153 => a_153.attrName === attr_152);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(ExportSpecifier_36);\nTerm_16._descendants.set(\"ExportSpecifier\", ExportSpecifier_36);\nconst Method_37 = Object.create(Term_16, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}, {attrName: \"isGenerator\", attrType: {name: \"any\"}}, {attrName: \"params\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_154) {\n  return this.getAttributes().some(a_155 => a_155.attrName === attr_154);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(Method_37);\nTerm_16._descendants.set(\"Method\", Method_37);\nconst Getter_38 = Object.create(Term_16, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_156) {\n  return this.getAttributes().some(a_157 => a_157.attrName === attr_156);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(Getter_38);\nTerm_16._descendants.set(\"Getter\", Getter_38);\nconst Setter_39 = Object.create(Term_16, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}, {attrName: \"param\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_158) {\n  return this.getAttributes().some(a_159 => a_159.attrName === attr_158);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(Setter_39);\nTerm_16._descendants.set(\"Setter\", Setter_39);\nconst DataProperty_40 = Object.create(Term_16, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}, {attrName: \"expression\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_160) {\n  return this.getAttributes().some(a_161 => a_161.attrName === attr_160);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(DataProperty_40);\nTerm_16._descendants.set(\"DataProperty\", DataProperty_40);\nconst ShorthandProperty_41 = Object.create(Term_16, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_162) {\n  return this.getAttributes().some(a_163 => a_163.attrName === attr_162);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(ShorthandProperty_41);\nTerm_16._descendants.set(\"ShorthandProperty\", ShorthandProperty_41);\nconst StaticPropertyName_42 = Object.create(Term_16, {_attributes: {value: [{attrName: \"value\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_164) {\n  return this.getAttributes().some(a_165 => a_165.attrName === attr_164);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(StaticPropertyName_42);\nTerm_16._descendants.set(\"StaticPropertyName\", StaticPropertyName_42);\nconst ComputedPropertyName_43 = Object.create(Term_16, {_attributes: {value: [{attrName: \"expression\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_166) {\n  return this.getAttributes().some(a_167 => a_167.attrName === attr_166);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(ComputedPropertyName_43);\nTerm_16._descendants.set(\"ComputedPropertyName\", ComputedPropertyName_43);\nconst LiteralBooleanExpression_44 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"value\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_168) {\n  return this.getAttributes().some(a_169 => a_169.attrName === attr_168);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(LiteralBooleanExpression_44);\nExpression_24._descendants.set(\"LiteralBooleanExpression\", LiteralBooleanExpression_44);\nconst LiteralInfinityExpression_45 = Object.create(Expression_24, {_attributes: {value: [], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_170) {\n  return this.getAttributes().some(a_171 => a_171.attrName === attr_170);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(LiteralInfinityExpression_45);\nExpression_24._descendants.set(\"LiteralInfinityExpression\", LiteralInfinityExpression_45);\nconst LiteralNullExpression_46 = Object.create(Expression_24, {_attributes: {value: [], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_172) {\n  return this.getAttributes().some(a_173 => a_173.attrName === attr_172);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(LiteralNullExpression_46);\nExpression_24._descendants.set(\"LiteralNullExpression\", LiteralNullExpression_46);\nconst LiteralNumericExpression_47 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"value\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_174) {\n  return this.getAttributes().some(a_175 => a_175.attrName === attr_174);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(LiteralNumericExpression_47);\nExpression_24._descendants.set(\"LiteralNumericExpression\", LiteralNumericExpression_47);\nconst LiteralRegExpExpression_48 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"pattern\", attrType: {name: \"any\"}}, {attrName: \"flags\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_176) {\n  return this.getAttributes().some(a_177 => a_177.attrName === attr_176);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(LiteralRegExpExpression_48);\nExpression_24._descendants.set(\"LiteralRegExpExpression\", LiteralRegExpExpression_48);\nconst LiteralStringExpression_49 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"value\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_178) {\n  return this.getAttributes().some(a_179 => a_179.attrName === attr_178);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(LiteralStringExpression_49);\nExpression_24._descendants.set(\"LiteralStringExpression\", LiteralStringExpression_49);\nconst ArrayExpression_50 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"elements\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_180) {\n  return this.getAttributes().some(a_181 => a_181.attrName === attr_180);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(ArrayExpression_50);\nExpression_24._descendants.set(\"ArrayExpression\", ArrayExpression_50);\nconst ArrowExpression_51 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"params\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_182) {\n  return this.getAttributes().some(a_183 => a_183.attrName === attr_182);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(ArrowExpression_51);\nExpression_24._descendants.set(\"ArrowExpression\", ArrowExpression_51);\nconst AssignmentExpression_52 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"binding\", attrType: {name: \"any\"}}, {attrName: \"expression\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_184) {\n  return this.getAttributes().some(a_185 => a_185.attrName === attr_184);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(AssignmentExpression_52);\nExpression_24._descendants.set(\"AssignmentExpression\", AssignmentExpression_52);\nconst BinaryExpression_53 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"operator\", attrType: {name: \"any\"}}, {attrName: \"left\", attrType: {name: \"any\"}}, {attrName: \"right\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_186) {\n  return this.getAttributes().some(a_187 => a_187.attrName === attr_186);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(BinaryExpression_53);\nExpression_24._descendants.set(\"BinaryExpression\", BinaryExpression_53);\nconst CallExpression_54 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"callee\", attrType: {name: \"any\"}}, {attrName: \"arguments\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_188) {\n  return this.getAttributes().some(a_189 => a_189.attrName === attr_188);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(CallExpression_54);\nExpression_24._descendants.set(\"CallExpression\", CallExpression_54);\nconst ComputedAssignmentExpression_55 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"operator\", attrType: {name: \"any\"}}, {attrName: \"binding\", attrType: {name: \"any\"}}, {attrName: \"expression\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_190) {\n  return this.getAttributes().some(a_191 => a_191.attrName === attr_190);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(ComputedAssignmentExpression_55);\nExpression_24._descendants.set(\"ComputedAssignmentExpression\", ComputedAssignmentExpression_55);\nconst ComputedMemberExpression_56 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"object\", attrType: {name: \"any\"}}, {attrName: \"expression\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_192) {\n  return this.getAttributes().some(a_193 => a_193.attrName === attr_192);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(ComputedMemberExpression_56);\nExpression_24._descendants.set(\"ComputedMemberExpression\", ComputedMemberExpression_56);\nconst ConditionalExpression_57 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"test\", attrType: {name: \"any\"}}, {attrName: \"consequent\", attrType: {name: \"any\"}}, {attrName: \"alternate\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_194) {\n  return this.getAttributes().some(a_195 => a_195.attrName === attr_194);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(ConditionalExpression_57);\nExpression_24._descendants.set(\"ConditionalExpression\", ConditionalExpression_57);\nconst FunctionExpression_58 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}, {attrName: \"isGenerator\", attrType: {name: \"any\"}}, {attrName: \"params\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_196) {\n  return this.getAttributes().some(a_197 => a_197.attrName === attr_196);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(FunctionExpression_58);\nExpression_24._descendants.set(\"FunctionExpression\", FunctionExpression_58);\nconst IdentifierExpression_59 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_198) {\n  return this.getAttributes().some(a_199 => a_199.attrName === attr_198);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(IdentifierExpression_59);\nExpression_24._descendants.set(\"IdentifierExpression\", IdentifierExpression_59);\nconst NewExpression_60 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"callee\", attrType: {name: \"any\"}}, {attrName: \"arguments\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_200) {\n  return this.getAttributes().some(a_201 => a_201.attrName === attr_200);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(NewExpression_60);\nExpression_24._descendants.set(\"NewExpression\", NewExpression_60);\nconst NewTargetExpression_61 = Object.create(Expression_24, {_attributes: {value: [], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_202) {\n  return this.getAttributes().some(a_203 => a_203.attrName === attr_202);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(NewTargetExpression_61);\nExpression_24._descendants.set(\"NewTargetExpression\", NewTargetExpression_61);\nconst ObjectExpression_62 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"properties\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_204) {\n  return this.getAttributes().some(a_205 => a_205.attrName === attr_204);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(ObjectExpression_62);\nExpression_24._descendants.set(\"ObjectExpression\", ObjectExpression_62);\nconst UnaryExpression_63 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"operator\", attrType: {name: \"any\"}}, {attrName: \"operand\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_206) {\n  return this.getAttributes().some(a_207 => a_207.attrName === attr_206);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(UnaryExpression_63);\nExpression_24._descendants.set(\"UnaryExpression\", UnaryExpression_63);\nconst StaticMemberExpression_64 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"object\", attrType: {name: \"any\"}}, {attrName: \"property\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_208) {\n  return this.getAttributes().some(a_209 => a_209.attrName === attr_208);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(StaticMemberExpression_64);\nExpression_24._descendants.set(\"StaticMemberExpression\", StaticMemberExpression_64);\nconst TemplateExpression_65 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"tag\", attrType: {name: \"any\"}}, {attrName: \"elements\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_210) {\n  return this.getAttributes().some(a_211 => a_211.attrName === attr_210);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(TemplateExpression_65);\nExpression_24._descendants.set(\"TemplateExpression\", TemplateExpression_65);\nconst ThisExpression_66 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"stx\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_212) {\n  return this.getAttributes().some(a_213 => a_213.attrName === attr_212);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(ThisExpression_66);\nExpression_24._descendants.set(\"ThisExpression\", ThisExpression_66);\nconst UpdateExpression_67 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"isPrefix\", attrType: {name: \"any\"}}, {attrName: \"operator\", attrType: {name: \"any\"}}, {attrName: \"operand\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_214) {\n  return this.getAttributes().some(a_215 => a_215.attrName === attr_214);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(UpdateExpression_67);\nExpression_24._descendants.set(\"UpdateExpression\", UpdateExpression_67);\nconst YieldExpression_68 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"expression\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_216) {\n  return this.getAttributes().some(a_217 => a_217.attrName === attr_216);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(YieldExpression_68);\nExpression_24._descendants.set(\"YieldExpression\", YieldExpression_68);\nconst YieldGeneratorExpression_69 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"expression\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_218) {\n  return this.getAttributes().some(a_219 => a_219.attrName === attr_218);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(YieldGeneratorExpression_69);\nExpression_24._descendants.set(\"YieldGeneratorExpression\", YieldGeneratorExpression_69);\nconst ParenthesizedExpression_70 = Object.create(Expression_24, {_attributes: {value: [{attrName: \"inner\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Expression_24.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_220) {\n  return this.getAttributes().some(a_221 => a_221.attrName === attr_220);\n}, writable: false, configurable: false, enumerable: true}});\nExpression_24._children.push(ParenthesizedExpression_70);\nExpression_24._descendants.set(\"ParenthesizedExpression\", ParenthesizedExpression_70);\nconst BlockStatement_71 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"block\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_222) {\n  return this.getAttributes().some(a_223 => a_223.attrName === attr_222);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(BlockStatement_71);\nStatement_23._descendants.set(\"BlockStatement\", BlockStatement_71);\nconst BreakStatement_72 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"label\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_224) {\n  return this.getAttributes().some(a_225 => a_225.attrName === attr_224);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(BreakStatement_72);\nStatement_23._descendants.set(\"BreakStatement\", BreakStatement_72);\nconst ContinueStatement_73 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"label\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_226) {\n  return this.getAttributes().some(a_227 => a_227.attrName === attr_226);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(ContinueStatement_73);\nStatement_23._descendants.set(\"ContinueStatement\", ContinueStatement_73);\nconst CompoundAssignmentExpression_74 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"binding\", attrType: {name: \"any\"}}, {attrName: \"operator\", attrType: {name: \"any\"}}, {attrName: \"expression\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_228) {\n  return this.getAttributes().some(a_229 => a_229.attrName === attr_228);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(CompoundAssignmentExpression_74);\nStatement_23._descendants.set(\"CompoundAssignmentExpression\", CompoundAssignmentExpression_74);\nconst DebuggerStatement_75 = Object.create(Statement_23, {_attributes: {value: [], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_230) {\n  return this.getAttributes().some(a_231 => a_231.attrName === attr_230);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(DebuggerStatement_75);\nStatement_23._descendants.set(\"DebuggerStatement\", DebuggerStatement_75);\nconst DoWhileStatement_76 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"test\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_232) {\n  return this.getAttributes().some(a_233 => a_233.attrName === attr_232);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(DoWhileStatement_76);\nStatement_23._descendants.set(\"DoWhileStatement\", DoWhileStatement_76);\nconst EmptyStatement_77 = Object.create(Statement_23, {_attributes: {value: [], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_234) {\n  return this.getAttributes().some(a_235 => a_235.attrName === attr_234);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(EmptyStatement_77);\nStatement_23._descendants.set(\"EmptyStatement\", EmptyStatement_77);\nconst ExpressionStatement_78 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"expression\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_236) {\n  return this.getAttributes().some(a_237 => a_237.attrName === attr_236);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(ExpressionStatement_78);\nStatement_23._descendants.set(\"ExpressionStatement\", ExpressionStatement_78);\nconst ForInStatement_79 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"left\", attrType: {name: \"any\"}}, {attrName: \"right\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_238) {\n  return this.getAttributes().some(a_239 => a_239.attrName === attr_238);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(ForInStatement_79);\nStatement_23._descendants.set(\"ForInStatement\", ForInStatement_79);\nconst ForOfStatement_80 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"left\", attrType: {name: \"any\"}}, {attrName: \"right\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_240) {\n  return this.getAttributes().some(a_241 => a_241.attrName === attr_240);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(ForOfStatement_80);\nStatement_23._descendants.set(\"ForOfStatement\", ForOfStatement_80);\nconst ForStatement_81 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"init\", attrType: {name: \"any\"}}, {attrName: \"test\", attrType: {name: \"any\"}}, {attrName: \"update\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_242) {\n  return this.getAttributes().some(a_243 => a_243.attrName === attr_242);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(ForStatement_81);\nStatement_23._descendants.set(\"ForStatement\", ForStatement_81);\nconst IfStatement_82 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"test\", attrType: {name: \"any\"}}, {attrName: \"consequent\", attrType: {name: \"any\"}}, {attrName: \"alternate\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_244) {\n  return this.getAttributes().some(a_245 => a_245.attrName === attr_244);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(IfStatement_82);\nStatement_23._descendants.set(\"IfStatement\", IfStatement_82);\nconst LabeledStatement_83 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"label\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_246) {\n  return this.getAttributes().some(a_247 => a_247.attrName === attr_246);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(LabeledStatement_83);\nStatement_23._descendants.set(\"LabeledStatement\", LabeledStatement_83);\nconst ReturnStatement_84 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"expression\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_248) {\n  return this.getAttributes().some(a_249 => a_249.attrName === attr_248);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(ReturnStatement_84);\nStatement_23._descendants.set(\"ReturnStatement\", ReturnStatement_84);\nconst SwitchStatement_85 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"discriminant\", attrType: {name: \"any\"}}, {attrName: \"cases\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_250) {\n  return this.getAttributes().some(a_251 => a_251.attrName === attr_250);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(SwitchStatement_85);\nStatement_23._descendants.set(\"SwitchStatement\", SwitchStatement_85);\nconst SwitchStatementWithDefault_86 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"discriminant\", attrType: {name: \"any\"}}, {attrName: \"preDefaultCases\", attrType: {name: \"any\"}}, {attrName: \"defaultCase\", attrType: {name: \"any\"}}, {attrName: \"postDefaultCases\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_252) {\n  return this.getAttributes().some(a_253 => a_253.attrName === attr_252);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(SwitchStatementWithDefault_86);\nStatement_23._descendants.set(\"SwitchStatementWithDefault\", SwitchStatementWithDefault_86);\nconst ThrowStatement_87 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"expression\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_254) {\n  return this.getAttributes().some(a_255 => a_255.attrName === attr_254);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(ThrowStatement_87);\nStatement_23._descendants.set(\"ThrowStatement\", ThrowStatement_87);\nconst TryCatchStatement_88 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"body\", attrType: {name: \"any\"}}, {attrName: \"catchClause\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_256) {\n  return this.getAttributes().some(a_257 => a_257.attrName === attr_256);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(TryCatchStatement_88);\nStatement_23._descendants.set(\"TryCatchStatement\", TryCatchStatement_88);\nconst TryFinallyStatement_89 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"body\", attrType: {name: \"any\"}}, {attrName: \"catchClause\", attrType: {name: \"any\"}}, {attrName: \"finalizer\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_258) {\n  return this.getAttributes().some(a_259 => a_259.attrName === attr_258);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(TryFinallyStatement_89);\nStatement_23._descendants.set(\"TryFinallyStatement\", TryFinallyStatement_89);\nconst VariableDeclarationStatement_90 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"declaration\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_260) {\n  return this.getAttributes().some(a_261 => a_261.attrName === attr_260);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(VariableDeclarationStatement_90);\nStatement_23._descendants.set(\"VariableDeclarationStatement\", VariableDeclarationStatement_90);\nconst WithStatement_91 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"object\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_262) {\n  return this.getAttributes().some(a_263 => a_263.attrName === attr_262);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(WithStatement_91);\nStatement_23._descendants.set(\"WithStatement\", WithStatement_91);\nconst WhileStatement_92 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"test\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_264) {\n  return this.getAttributes().some(a_265 => a_265.attrName === attr_264);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(WhileStatement_92);\nStatement_23._descendants.set(\"WhileStatement\", WhileStatement_92);\nconst Pragma_93 = Object.create(Term_16, {_attributes: {value: [{attrName: \"kind\", attrType: {name: \"any\"}}, {attrName: \"items\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_266) {\n  return this.getAttributes().some(a_267 => a_267.attrName === attr_266);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(Pragma_93);\nTerm_16._descendants.set(\"Pragma\", Pragma_93);\nconst Block_94 = Object.create(Term_16, {_attributes: {value: [{attrName: \"statements\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_268) {\n  return this.getAttributes().some(a_269 => a_269.attrName === attr_268);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(Block_94);\nTerm_16._descendants.set(\"Block\", Block_94);\nconst CatchClause_95 = Object.create(Term_16, {_attributes: {value: [{attrName: \"binding\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_270) {\n  return this.getAttributes().some(a_271 => a_271.attrName === attr_270);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(CatchClause_95);\nTerm_16._descendants.set(\"CatchClause\", CatchClause_95);\nconst Directive_96 = Object.create(Term_16, {_attributes: {value: [{attrName: \"rawValue\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_272) {\n  return this.getAttributes().some(a_273 => a_273.attrName === attr_272);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(Directive_96);\nTerm_16._descendants.set(\"Directive\", Directive_96);\nconst FormalParameters_97 = Object.create(Term_16, {_attributes: {value: [{attrName: \"items\", attrType: {name: \"any\"}}, {attrName: \"rest\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_274) {\n  return this.getAttributes().some(a_275 => a_275.attrName === attr_274);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(FormalParameters_97);\nTerm_16._descendants.set(\"FormalParameters\", FormalParameters_97);\nconst FunctionBody_98 = Object.create(Term_16, {_attributes: {value: [{attrName: \"directives\", attrType: {name: \"any\"}}, {attrName: \"statements\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_276) {\n  return this.getAttributes().some(a_277 => a_277.attrName === attr_276);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(FunctionBody_98);\nTerm_16._descendants.set(\"FunctionBody\", FunctionBody_98);\nconst FunctionDeclaration_99 = Object.create(Statement_23, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}, {attrName: \"isGenerator\", attrType: {name: \"any\"}}, {attrName: \"params\", attrType: {name: \"any\"}}, {attrName: \"body\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Statement_23.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_278) {\n  return this.getAttributes().some(a_279 => a_279.attrName === attr_278);\n}, writable: false, configurable: false, enumerable: true}});\nStatement_23._children.push(FunctionDeclaration_99);\nStatement_23._descendants.set(\"FunctionDeclaration\", FunctionDeclaration_99);\nconst Script_100 = Object.create(Term_16, {_attributes: {value: [{attrName: \"directives\", attrType: {name: \"any\"}}, {attrName: \"statements\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_280) {\n  return this.getAttributes().some(a_281 => a_281.attrName === attr_280);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(Script_100);\nTerm_16._descendants.set(\"Script\", Script_100);\nconst SpreadElement_101 = Object.create(Term_16, {_attributes: {value: [{attrName: \"expression\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_282) {\n  return this.getAttributes().some(a_283 => a_283.attrName === attr_282);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(SpreadElement_101);\nTerm_16._descendants.set(\"SpreadElement\", SpreadElement_101);\nconst Super_102 = Object.create(Term_16, {_attributes: {value: [], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_284) {\n  return this.getAttributes().some(a_285 => a_285.attrName === attr_284);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(Super_102);\nTerm_16._descendants.set(\"Super\", Super_102);\nconst SwitchCase_103 = Object.create(Term_16, {_attributes: {value: [{attrName: \"test\", attrType: {name: \"any\"}}, {attrName: \"consequent\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_286) {\n  return this.getAttributes().some(a_287 => a_287.attrName === attr_286);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(SwitchCase_103);\nTerm_16._descendants.set(\"SwitchCase\", SwitchCase_103);\nconst SwitchDefault_104 = Object.create(Term_16, {_attributes: {value: [{attrName: \"consequent\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_288) {\n  return this.getAttributes().some(a_289 => a_289.attrName === attr_288);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(SwitchDefault_104);\nTerm_16._descendants.set(\"SwitchDefault\", SwitchDefault_104);\nconst TemplateElement_105 = Object.create(Term_16, {_attributes: {value: [{attrName: \"rawValue\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_290) {\n  return this.getAttributes().some(a_291 => a_291.attrName === attr_290);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(TemplateElement_105);\nTerm_16._descendants.set(\"TemplateElement\", TemplateElement_105);\nconst SyntaxTemplate_106 = Object.create(Term_16, {_attributes: {value: [{attrName: \"template\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_292) {\n  return this.getAttributes().some(a_293 => a_293.attrName === attr_292);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(SyntaxTemplate_106);\nTerm_16._descendants.set(\"SyntaxTemplate\", SyntaxTemplate_106);\nconst SyntaxQuote_107 = Object.create(Term_16, {_attributes: {value: [{attrName: \"name\", attrType: {name: \"any\"}}, {attrName: \"template\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_294) {\n  return this.getAttributes().some(a_295 => a_295.attrName === attr_294);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(SyntaxQuote_107);\nTerm_16._descendants.set(\"SyntaxQuote\", SyntaxQuote_107);\nconst VariableDeclaration_108 = Object.create(Term_16, {_attributes: {value: [{attrName: \"kind\", attrType: {name: \"any\"}}, {attrName: \"declarators\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_296) {\n  return this.getAttributes().some(a_297 => a_297.attrName === attr_296);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(VariableDeclaration_108);\nTerm_16._descendants.set(\"VariableDeclaration\", VariableDeclaration_108);\nconst VariableDeclarator_109 = Object.create(Term_16, {_attributes: {value: [{attrName: \"binding\", attrType: {name: \"any\"}}, {attrName: \"init\", attrType: {name: \"any\"}}], writable: false, configurable: false, enumerable: false}, _children: {value: [], writable: false, configurable: false, enumerable: false}, getAttributes: {value: function () {\n  return Term_16.getAttributes().concat(this._attributes);\n}, writable: false, configurable: false, enumerable: true}, hasAttribute: {value: function (attr_298) {\n  return this.getAttributes().some(a_299 => a_299.attrName === attr_298);\n}, writable: false, configurable: false, enumerable: true}});\nTerm_16._children.push(VariableDeclarator_109);\nTerm_16._descendants.set(\"VariableDeclarator\", VariableDeclarator_109);\nexport default Term_16;\n"]} /***/ }, -/* 19 */ +/* 12 */ /***/ function(module, exports, __webpack_require__) { - var R = __webpack_require__(17); - - // `f` is a function that takes two function arguments: `reject` (failure) and `resolve` (success) - function Future(f) { - if (!(this instanceof Future)) { - return new Future(f); - } - this._fork = f; - } - - Future.prototype.fork = function(reject, resolve) { - try { - this._fork(reject, resolve); - } catch(e) { - reject(e); - } - }; - - // functor - Future.prototype.map = function(f) { - return this.chain(function(a) { return Future.of(f(a)); }); - }; - - // apply - Future.prototype.ap = function(m) { - var self = this; - - return new Future(function(rej, res) { - var applyFn, val; - var doReject = R.once(rej); - - function resolveIfDone() { - if (applyFn != null && val != null) { - return res(applyFn(val)); - } - } - - self.fork(doReject, function(fn) { - applyFn = fn; - resolveIfDone(); - }); + "use strict"; - m.fork(doReject, function(v) { - val = v; - resolveIfDone(); - }); + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.SemiOp = exports.CommaSep = exports.Semi = exports.Seq = exports.ContainsIn = exports.NoIn = exports.Brace = exports.Bracket = exports.Paren = exports.NumberCodeRep = exports.Token = exports.Empty = exports.CodeRep = exports.escapeStringLiteral = exports.getPrecedence = exports.Precedence = exports.Sep = exports.FormattedCodeGen = exports.ExtensibleCodeGen = exports.MinimalCodeGen = undefined; + exports.default = codeGen; - }); + var _minimalCodegen = __webpack_require__(13); - }; + Object.defineProperty(exports, "MinimalCodeGen", { + enumerable: true, + get: function get() { + return _minimalCodegen.default; + } + }); - // applicative - Future.of = function(x) { - // should include a default rejection? - return new Future(function(_, resolve) { return resolve(x); }); - }; + var _formattedCodegen = __webpack_require__(20); - Future.prototype.of = Future.of; + Object.defineProperty(exports, "ExtensibleCodeGen", { + enumerable: true, + get: function get() { + return _formattedCodegen.ExtensibleCodeGen; + } + }); + Object.defineProperty(exports, "FormattedCodeGen", { + enumerable: true, + get: function get() { + return _formattedCodegen.FormattedCodeGen; + } + }); + Object.defineProperty(exports, "Sep", { + enumerable: true, + get: function get() { + return _formattedCodegen.Sep; + } + }); - // chain - // f must be a function which returns a value - // f must return a value of the same Chain - // chain must return a value of the same Chain - //:: Future a, b => (b -> Future c) -> Future c - Future.prototype.chain = function(f) { // Sorella's: - return new Future(function(reject, resolve) { - return this.fork(function(a) { return reject(a); }, - function(b) { return f(b).fork(reject, resolve); }); - }.bind(this)); - }; + var _coderep = __webpack_require__(19); - // chainReject - // Like chain but operates on the reject instead of the resolve case. - //:: Future a, b => (a -> Future c) -> Future c - Future.prototype.chainReject = function(f) { - return new Future(function(reject, resolve) { - return this.fork(function(a) { return f(a).fork(reject, resolve); }, - function(b) { return resolve(b); - }); - }.bind(this)); - }; - - // monad - // A value that implements the Monad specification must also implement the Applicative and Chain specifications. - // see above. - - Future.prototype.bimap = function(errFn, successFn) { - var self = this; - return new Future(function(reject, resolve) { - self.fork(function(err) { - reject(errFn(err)); - }, function(val) { - resolve(successFn(val)); - }); - }); - }; - - Future.reject = function(val) { - return new Future(function(reject) { - reject(val); - }); - }; - - Future.prototype.toString = function() { - return 'Future(' + R.toString(this._fork) + ')'; - }; - - Future.cache = function(f) { - var status = 'IDLE'; - var listeners = []; - var cachedValue; - - var handleCompletion = R.curry(function(newStatus, cb, val) { - status = newStatus; - cachedValue = val; - cb(val); - R.forEach(function(listener) { - listener[status](cachedValue); - }, listeners); - }); - - function addListeners(reject, resolve) { - listeners.push({ REJECTED: reject, RESOLVED: resolve } ); + Object.defineProperty(exports, "Precedence", { + enumerable: true, + get: function get() { + return _coderep.Precedence; } - - function doResolve(reject, resolve) { - status = 'PENDING'; - return f.fork( - handleCompletion('REJECTED', reject), - handleCompletion('RESOLVED', resolve) - ); + }); + Object.defineProperty(exports, "getPrecedence", { + enumerable: true, + get: function get() { + return _coderep.getPrecedence; + } + }); + Object.defineProperty(exports, "escapeStringLiteral", { + enumerable: true, + get: function get() { + return _coderep.escapeStringLiteral; + } + }); + Object.defineProperty(exports, "CodeRep", { + enumerable: true, + get: function get() { + return _coderep.CodeRep; + } + }); + Object.defineProperty(exports, "Empty", { + enumerable: true, + get: function get() { + return _coderep.Empty; + } + }); + Object.defineProperty(exports, "Token", { + enumerable: true, + get: function get() { + return _coderep.Token; + } + }); + Object.defineProperty(exports, "NumberCodeRep", { + enumerable: true, + get: function get() { + return _coderep.NumberCodeRep; + } + }); + Object.defineProperty(exports, "Paren", { + enumerable: true, + get: function get() { + return _coderep.Paren; + } + }); + Object.defineProperty(exports, "Bracket", { + enumerable: true, + get: function get() { + return _coderep.Bracket; + } + }); + Object.defineProperty(exports, "Brace", { + enumerable: true, + get: function get() { + return _coderep.Brace; + } + }); + Object.defineProperty(exports, "NoIn", { + enumerable: true, + get: function get() { + return _coderep.NoIn; + } + }); + Object.defineProperty(exports, "ContainsIn", { + enumerable: true, + get: function get() { + return _coderep.ContainsIn; + } + }); + Object.defineProperty(exports, "Seq", { + enumerable: true, + get: function get() { + return _coderep.Seq; } + }); + Object.defineProperty(exports, "Semi", { + enumerable: true, + get: function get() { + return _coderep.Semi; + } + }); + Object.defineProperty(exports, "CommaSep", { + enumerable: true, + get: function get() { + return _coderep.CommaSep; + } + }); + Object.defineProperty(exports, "SemiOp", { + enumerable: true, + get: function get() { + return _coderep.SemiOp; + } + }); - return new Future(function(reject, resolve) { + var _shiftReducer = __webpack_require__(4); - switch(status) { - case 'IDLE': doResolve(reject, resolve); break; - case 'PENDING': addListeners(reject, resolve); break; - case 'REJECTED': reject(cachedValue); break; - case 'RESOLVED': resolve(cachedValue); break; - } + var _shiftReducer2 = _interopRequireDefault(_shiftReducer); - }); - }; + var _token_stream = __webpack_require__(21); - module.exports = Future; + var _minimalCodegen2 = _interopRequireDefault(_minimalCodegen); + + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + + function codeGen(script) { + var generator = arguments.length <= 1 || arguments[1] === undefined ? new _minimalCodegen2.default() : arguments[1]; + var ts = new _token_stream.TokenStream(); + var rep = (0, _shiftReducer2.default)(generator, script); + rep.emit(ts); + return ts.result; + } /***/ }, -/* 20 */ +/* 13 */ /***/ function(module, exports, __webpack_require__) { - var R = __webpack_require__(17); - - var util = __webpack_require__(18); + "use strict"; + var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); - /** - * A data type that holds a value and exposes a monadic api. - */ + Object.defineProperty(exports, "__esModule", { + value: true + }); - /** - * Constructs a new `Identity[a]` data type that holds a single - * value `a`. - * @param {*} a Value of any type - * @sig a -> Identity[a] - */ - function Identity(x) { - if (!(this instanceof Identity)) { - return new Identity(x); - } - this.value = x; - } + var _objectAssign = __webpack_require__(14); - /** - * Applicative specification. Creates a new `Identity[a]` holding the value `a`. - * @param {*} a Value of any type - * @returns Identity[a] - * @sig a -> Identity[a] - */ - Identity.of = function(x) { - return new Identity(x); - }; - Identity.prototype.of = Identity.of; + var _objectAssign2 = _interopRequireDefault(_objectAssign); - /** - * Functor specification. Creates a new `Identity[a]` mapping function `f` onto - * `a` returning any value b. - * @param {Function} f Maps `a` to any value `b` - * @returns Identity[b] - * @sig @Identity[a] => (a -> b) -> Identity[b] - */ - Identity.prototype.map = function(f) { - return new Identity(f(this.value)); - }; + var _esutils = __webpack_require__(15); - /** - * Apply specification. Applies the function inside the `Identity[a]` - * type to another applicative type. - * @param {Applicative[a]} app Applicative that will apply its function - * @returns Applicative[b] - * @sig (Identity[a -> b], f: Applicative[_]) => f[a] -> f[b] - */ - Identity.prototype.ap = function(app) { - return app.map(this.value); - }; + var _coderep = __webpack_require__(19); - /** - * Chain specification. Transforms the value of the `Identity[a]` - * type using an unary function to monads. The `Identity[a]` type - * should contain a function, otherwise an error is thrown. - * - * @param {Function} fn Transforms `a` into a `Monad[b]` - * @returns Monad[b] - * @sig (Identity[a], m: Monad[_]) => (a -> m[b]) -> m[b] - */ - Identity.prototype.chain = function(fn) { - return fn(this.value); - }; + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - /** - * Returns the value of `Identity[a]` - * - * @returns a - * @sig (Identity[a]) => a - */ - Identity.prototype.get = function() { - return this.value; - }; + function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } - // equality method to enable testing - Identity.prototype.equals = util.getEquals(Identity); + function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - Identity.prototype.toString = function() { - return 'Identity(' + R.toString(this.value) + ')'; - }; + function p(node, precedence, a) { + return (0, _coderep.getPrecedence)(node) < precedence ? paren(a) : a; + } - module.exports = Identity; + function t(token) { + return new _coderep.Token(token); + } + function paren(rep) { + return new _coderep.Paren(rep); + } -/***/ }, -/* 21 */ -/***/ function(module, exports, __webpack_require__) { + function brace(rep) { + return new _coderep.Brace(rep); + } - var R = __webpack_require__(17); + function bracket(rep) { + return new _coderep.Bracket(rep); + } - module.exports = IO; + function noIn(rep) { + return new _coderep.NoIn(rep); + } - var compose = R.compose; + function markContainsIn(state) { + return state.containsIn ? new _coderep.ContainsIn(state) : state; + } - function IO(fn) { - if (!(this instanceof IO)) { - return new IO(fn); + function seq() { + for (var _len = arguments.length, reps = Array(_len), _key = 0; _key < _len; _key++) { + reps[_key] = arguments[_key]; } - this.fn = fn; + + return new _coderep.Seq(reps); } - // `f` must return an IO - IO.prototype.chain = function(f) { - var io = this; - return new IO(function() { - var next = f(io.fn.apply(io, arguments)); - return next.fn.apply(next, arguments); - }); - }; + function semi() { + return new _coderep.Semi(); + } - IO.prototype.map = function(f) { - var io = this; - return new IO(compose(f, io.fn)); - }; + function semiOp() { + return new _coderep.SemiOp(); + } - // `this` IO must wrap a function `f` that takes an IO (`thatIo`) as input - // `f` must return an IO - IO.prototype.ap = function(thatIo) { - return this.chain(function(f) { - return thatIo.map(f); - }); - }; + function empty() { + return new _coderep.Empty(); + } - IO.runIO = function(io) { - return io.runIO.apply(io, [].slice.call(arguments, 1)); - }; + function commaSep(pieces) { + return new _coderep.CommaSep(pieces); + } - IO.prototype.runIO = function() { - return this.fn.apply(this, arguments); - }; + function getAssignmentExpr(state) { + return state ? state.containsGroup ? paren(state) : state : empty(); + } - IO.prototype.of = function(x) { - return new IO(function() { return x; }); - }; + var MinimalCodeGen = function () { + function MinimalCodeGen() { + _classCallCheck(this, MinimalCodeGen); + } - IO.of = IO.prototype.of; + _createClass(MinimalCodeGen, [{ + key: "parenToAvoidBeingDirective", + value: function parenToAvoidBeingDirective(element, original) { + if (element && element.type === "ExpressionStatement" && element.expression.type === "LiteralStringExpression") { + return seq(paren(original.children[0]), semiOp()); + } + return original; + } + }, { + key: "reduceArrayExpression", + value: function reduceArrayExpression(node, _ref) { + var elements = _ref.elements; - IO.prototype.toString = function() { - return 'IO(' + R.toString(this.fn) + ')'; - }; + if (elements.length === 0) { + return bracket(empty()); + } + var content = commaSep(elements.map(getAssignmentExpr)); + if (elements.length > 0 && elements[elements.length - 1] == null) { + content = seq(content, t(",")); + } + return bracket(content); + } + }, { + key: "reduceSpreadElement", + value: function reduceSpreadElement(node, _ref2) { + var expression = _ref2.expression; -/***/ }, -/* 22 */ -/***/ function(module, exports, __webpack_require__) { + return seq(t("..."), p(node.expression, _coderep.Precedence.Assignment, expression)); + } + }, { + key: "reduceAssignmentExpression", + value: function reduceAssignmentExpression(node, _ref3) { + var binding = _ref3.binding; + var expression = _ref3.expression; - var R = __webpack_require__(17); + var leftCode = binding; + var rightCode = expression; + var containsIn = expression.containsIn; + var startsWithCurly = binding.startsWithCurly; + var startsWithLetSquareBracket = binding.startsWithLetSquareBracket; + var startsWithFunctionOrClass = binding.startsWithFunctionOrClass; + if ((0, _coderep.getPrecedence)(node.expression) < (0, _coderep.getPrecedence)(node)) { + rightCode = paren(rightCode); + containsIn = false; + } + return (0, _objectAssign2.default)(seq(leftCode, t("="), rightCode), { containsIn: containsIn, startsWithCurly: startsWithCurly, startsWithLetSquareBracket: startsWithLetSquareBracket, startsWithFunctionOrClass: startsWithFunctionOrClass }); + } + }, { + key: "reduceCompoundAssignmentExpression", + value: function reduceCompoundAssignmentExpression(node, _ref4) { + var binding = _ref4.binding; + var expression = _ref4.expression; - module.exports = R.curryN(3, function lift2(f, a1, a2) { - return a1.map(f).ap(a2); - }); + var leftCode = binding; + var rightCode = expression; + var containsIn = expression.containsIn; + var startsWithCurly = binding.startsWithCurly; + var startsWithLetSquareBracket = binding.startsWithLetSquareBracket; + var startsWithFunctionOrClass = binding.startsWithFunctionOrClass; + if ((0, _coderep.getPrecedence)(node.expression) < (0, _coderep.getPrecedence)(node)) { + rightCode = paren(rightCode); + containsIn = false; + } + return (0, _objectAssign2.default)(seq(leftCode, t(node.operator), rightCode), { containsIn: containsIn, startsWithCurly: startsWithCurly, startsWithLetSquareBracket: startsWithLetSquareBracket, startsWithFunctionOrClass: startsWithFunctionOrClass }); + } + }, { + key: "reduceBinaryExpression", + value: function reduceBinaryExpression(node, _ref5) { + var left = _ref5.left; + var right = _ref5.right; + var leftCode = left; + var startsWithCurly = left.startsWithCurly; + var startsWithLetSquareBracket = left.startsWithLetSquareBracket; + var startsWithFunctionOrClass = left.startsWithFunctionOrClass; + var leftContainsIn = left.containsIn; + if ((0, _coderep.getPrecedence)(node.left) < (0, _coderep.getPrecedence)(node)) { + leftCode = paren(leftCode); + startsWithCurly = false; + startsWithLetSquareBracket = false; + startsWithFunctionOrClass = false; + leftContainsIn = false; + } + var rightCode = right; + var rightContainsIn = right.containsIn; + if ((0, _coderep.getPrecedence)(node.right) <= (0, _coderep.getPrecedence)(node)) { + rightCode = paren(rightCode); + rightContainsIn = false; + } + return (0, _objectAssign2.default)(seq(leftCode, t(node.operator), rightCode), { + containsIn: leftContainsIn || rightContainsIn || node.operator === "in", + containsGroup: node.operator == ",", + startsWithCurly: startsWithCurly, + startsWithLetSquareBracket: startsWithLetSquareBracket, + startsWithFunctionOrClass: startsWithFunctionOrClass + }); + } + }, { + key: "reduceBindingWithDefault", + value: function reduceBindingWithDefault(node, _ref6) { + var binding = _ref6.binding; + var init = _ref6.init; -/***/ }, -/* 23 */ -/***/ function(module, exports, __webpack_require__) { + return seq(binding, t("="), init); + } + }, { + key: "reduceBindingIdentifier", + value: function reduceBindingIdentifier(node) { + var a = t(node.name); + if (node.name === "let") { + a.startsWithLet = true; + } + return a; + } + }, { + key: "reduceArrayBinding", + value: function reduceArrayBinding(node, _ref7) { + var elements = _ref7.elements; + var restElement = _ref7.restElement; - var R = __webpack_require__(17); + var content = undefined; + if (elements.length === 0) { + content = restElement == null ? empty() : seq(t("..."), restElement); + } else { + elements = elements.concat(restElement == null ? [] : [seq(t("..."), restElement)]); + content = commaSep(elements.map(getAssignmentExpr)); + if (elements.length > 0 && elements[elements.length - 1] == null) { + content = seq(content, t(",")); + } + } + return bracket(content); + } + }, { + key: "reduceObjectBinding", + value: function reduceObjectBinding(node, _ref8) { + var properties = _ref8.properties; - module.exports = R.curryN(4, function lift3(f, a1, a2, a3) { - return a1.map(f).ap(a2).ap(a3); - }); + var state = brace(commaSep(properties)); + state.startsWithCurly = true; + return state; + } + }, { + key: "reduceBindingPropertyIdentifier", + value: function reduceBindingPropertyIdentifier(node, _ref9) { + var binding = _ref9.binding; + var init = _ref9.init; + if (node.init == null) return binding; + return seq(binding, t("="), init); + } + }, { + key: "reduceBindingPropertyProperty", + value: function reduceBindingPropertyProperty(node, _ref10) { + var name = _ref10.name; + var binding = _ref10.binding; -/***/ }, -/* 24 */ -/***/ function(module, exports, __webpack_require__) { + return seq(name, t(":"), binding); + } + }, { + key: "reduceBlock", + value: function reduceBlock(node, _ref11) { + var statements = _ref11.statements; - var R = __webpack_require__(17); + return brace(seq.apply(undefined, _toConsumableArray(statements))); + } + }, { + key: "reduceBlockStatement", + value: function reduceBlockStatement(node, _ref12) { + var block = _ref12.block; - var util = __webpack_require__(18); - - function Maybe(x) { - return x == null ? _nothing : Maybe.Just(x); - } - - function _Just(x) { - this.value = x; - } - util.extend(_Just, Maybe); - - function _Nothing() {} - util.extend(_Nothing, Maybe); + return block; + } + }, { + key: "reduceBreakStatement", + value: function reduceBreakStatement(node, _ref13) { + var label = _ref13.label; - var _nothing = new _Nothing(); + return seq(t("break"), label ? t(label) : empty(), semiOp()); + } + }, { + key: "reduceCallExpression", + value: function reduceCallExpression(node, _ref14) { + var callee = _ref14.callee; + var args = _ref14.arguments; - Maybe.Nothing = function() { - return _nothing; - }; + return (0, _objectAssign2.default)(seq(p(node.callee, (0, _coderep.getPrecedence)(node), callee), paren(commaSep(args))), { + startsWithCurly: callee.startsWithCurly, + startsWithLetSquareBracket: callee.startsWithLetSquareBracket, + startsWithFunctionOrClass: callee.startsWithFunctionOrClass + }); + } + }, { + key: "reduceCatchClause", + value: function reduceCatchClause(node, _ref15) { + var binding = _ref15.binding; + var body = _ref15.body; - Maybe.Just = function(x) { - return new _Just(x); - }; + return seq(t("catch"), paren(binding), body); + } + }, { + key: "reduceClassDeclaration", + value: function reduceClassDeclaration(node, _ref16) { + var name = _ref16.name; + var _super = _ref16.super; + var elements = _ref16.elements; - Maybe.of = Maybe.Just; + var state = seq(t("class"), name); + if (_super != null) { + state = seq(state, t("extends"), _super); + } + state = seq.apply(undefined, [state, t("{")].concat(_toConsumableArray(elements), [t("}")])); + return state; + } + }, { + key: "reduceClassExpression", + value: function reduceClassExpression(node, _ref17) { + var name = _ref17.name; + var _super = _ref17.super; + var elements = _ref17.elements; - Maybe.prototype.of = Maybe.Just; + var state = t("class"); + if (name != null) { + state = seq(state, name); + } + if (_super != null) { + state = seq(state, t("extends"), _super); + } + state = seq.apply(undefined, [state, t("{")].concat(_toConsumableArray(elements), [t("}")])); + state.startsWithFunctionOrClass = true; + return state; + } + }, { + key: "reduceClassElement", + value: function reduceClassElement(node, _ref18) { + var method = _ref18.method; - Maybe.isJust = function(x) { - return x instanceof _Just; - }; + if (!node.isStatic) return method; + return seq(t("static"), method); + } + }, { + key: "reduceComputedMemberExpression", + value: function reduceComputedMemberExpression(node, _ref19) { + var object = _ref19.object; + var expression = _ref19.expression; - Maybe.isNothing = function(x) { - return x === _nothing; - }; + var startsWithLetSquareBracket = object.startsWithLetSquareBracket || node.object.type === "IdentifierExpression" && node.object.name === "let"; + return (0, _objectAssign2.default)(seq(p(node.object, (0, _coderep.getPrecedence)(node), object), bracket(expression)), { + startsWithLet: object.startsWithLet, + startsWithLetSquareBracket: startsWithLetSquareBracket, + startsWithCurly: object.startsWithCurly, + startsWithFunctionOrClass: object.startsWithFunctionOrClass + }); + } + }, { + key: "reduceComputedPropertyName", + value: function reduceComputedPropertyName(node, _ref20) { + var expression = _ref20.expression; - Maybe.maybe = R.curry(function(nothingVal, justFn, m) { - return m.reduce(function(_, x) { - return justFn(x); - }, nothingVal); - }); + return bracket(expression); + } + }, { + key: "reduceConditionalExpression", + value: function reduceConditionalExpression(node, _ref21) { + var test = _ref21.test; + var consequent = _ref21.consequent; + var alternate = _ref21.alternate; - // functor - _Just.prototype.map = function(f) { - return this.of(f(this.value)); - }; + var containsIn = test.containsIn || alternate.containsIn; + var startsWithCurly = test.startsWithCurly; + var startsWithLetSquareBracket = test.startsWithLetSquareBracket; + var startsWithFunctionOrClass = test.startsWithFunctionOrClass; + return (0, _objectAssign2.default)(seq(p(node.test, _coderep.Precedence.LogicalOR, test), t("?"), p(node.consequent, _coderep.Precedence.Assignment, consequent), t(":"), p(node.alternate, _coderep.Precedence.Assignment, alternate)), { + containsIn: containsIn, + startsWithCurly: startsWithCurly, + startsWithLetSquareBracket: startsWithLetSquareBracket, + startsWithFunctionOrClass: startsWithFunctionOrClass + }); + } + }, { + key: "reduceContinueStatement", + value: function reduceContinueStatement(node, _ref22) { + var label = _ref22.label; - _Nothing.prototype.map = util.returnThis; + return seq(t("continue"), label ? t(label) : empty(), semiOp()); + } + }, { + key: "reduceDataProperty", + value: function reduceDataProperty(node, _ref23) { + var name = _ref23.name; + var expression = _ref23.expression; - // apply - // takes a Maybe that wraps a function (`app`) and applies its `map` - // method to this Maybe's value, which must be a function. - _Just.prototype.ap = function(m) { - return m.map(this.value); - }; + return seq(name, t(":"), getAssignmentExpr(expression)); + } + }, { + key: "reduceDebuggerStatement", + value: function reduceDebuggerStatement(node) { + return seq(t("debugger"), semiOp()); + } + }, { + key: "reduceDoWhileStatement", + value: function reduceDoWhileStatement(node, _ref24) { + var body = _ref24.body; + var test = _ref24.test; - _Nothing.prototype.ap = util.returnThis; + return seq(t("do"), body, t("while"), paren(test), semiOp()); + } + }, { + key: "reduceEmptyStatement", + value: function reduceEmptyStatement(node) { + return semi(); + } + }, { + key: "reduceExpressionStatement", + value: function reduceExpressionStatement(node, _ref25) { + var expression = _ref25.expression; - // applicative - // `of` inherited from `Maybe` + var needsParens = expression.startsWithCurly || expression.startsWithLetSquareBracket || expression.startsWithFunctionOrClass; + return seq(needsParens ? paren(expression) : expression, semiOp()); + } + }, { + key: "reduceForInStatement", + value: function reduceForInStatement(node, _ref26) { + var left = _ref26.left; + var right = _ref26.right; + var body = _ref26.body; + var leftP = left; + switch (node.left.type) { + case "VariableDeclaration": + leftP = noIn(markContainsIn(left)); + break; + case "BindingIdentifier": + if (node.left.name === "let") { + leftP = paren(left); + } + break; + } + return (0, _objectAssign2.default)(seq(t("for"), paren(seq(leftP, t("in"), right)), body), { endsWithMissingElse: body.endsWithMissingElse }); + } + }, { + key: "reduceForOfStatement", + value: function reduceForOfStatement(node, _ref27) { + var left = _ref27.left; + var right = _ref27.right; + var body = _ref27.body; - // chain - // f must be a function which returns a value - // f must return a value of the same Chain - // chain must return a value of the same Chain - _Just.prototype.chain = util.baseMap; + left = node.left.type === "VariableDeclaration" ? noIn(markContainsIn(left)) : left; + return (0, _objectAssign2.default)(seq(t("for"), paren(seq(left.startsWithLet ? paren(left) : left, t("of"), right)), body), { endsWithMissingElse: body.endsWithMissingElse }); + } + }, { + key: "reduceForStatement", + value: function reduceForStatement(node, _ref28) { + var init = _ref28.init; + var test = _ref28.test; + var update = _ref28.update; + var body = _ref28.body; - _Nothing.prototype.chain = util.returnThis; + return (0, _objectAssign2.default)(seq(t("for"), paren(seq(init ? noIn(markContainsIn(init)) : empty(), semi(), test || empty(), semi(), update || empty())), body), { + endsWithMissingElse: body.endsWithMissingElse + }); + } + }, { + key: "reduceFunctionBody", + value: function reduceFunctionBody(node, _ref29) { + var directives = _ref29.directives; + var statements = _ref29.statements; + if (statements.length) { + statements[0] = this.parenToAvoidBeingDirective(node.statements[0], statements[0]); + } + return seq.apply(undefined, _toConsumableArray(directives).concat(_toConsumableArray(statements))); + } + }, { + key: "reduceFunctionDeclaration", + value: function reduceFunctionDeclaration(node, _ref30) { + var name = _ref30.name; + var params = _ref30.params; + var body = _ref30.body; - // - _Just.prototype.datatype = _Just; + return seq(t("function"), node.isGenerator ? t("*") : empty(), node.name.name === "*default*" ? empty() : name, paren(params), brace(body)); + } + }, { + key: "reduceFunctionExpression", + value: function reduceFunctionExpression(node, _ref31) { + var name = _ref31.name; + var params = _ref31.params; + var body = _ref31.body; - _Nothing.prototype.datatype = _Nothing; + var state = seq(t("function"), node.isGenerator ? t("*") : empty(), name ? name : empty(), paren(params), brace(body)); + state.startsWithFunctionOrClass = true; + return state; + } + }, { + key: "reduceFormalParameters", + value: function reduceFormalParameters(node, _ref32) { + var items = _ref32.items; + var rest = _ref32.rest; - // monad - // A value that implements the Monad specification must also implement the Applicative and Chain specifications. - // see above. + return commaSep(items.concat(rest == null ? [] : [seq(t("..."), rest)])); + } + }, { + key: "reduceArrowExpression", + value: function reduceArrowExpression(node, _ref33) { + var params = _ref33.params; + var body = _ref33.body; - // equality method to enable testing - _Just.prototype.equals = util.getEquals(_Just); + if (node.params.rest != null || node.params.items.length !== 1 || node.params.items[0].type !== "BindingIdentifier") { + params = paren(params); + } + if (node.body.type === "FunctionBody") { + body = brace(body); + } else if (body.startsWithCurly) { + body = paren(body); + } + return seq(params, t("=>"), p(node.body, _coderep.Precedence.Assignment, body)); + } + }, { + key: "reduceGetter", + value: function reduceGetter(node, _ref34) { + var name = _ref34.name; + var body = _ref34.body; - _Nothing.prototype.equals = function(that) { - return that === _nothing; - }; + return seq(t("get"), name, paren(empty()), brace(body)); + } + }, { + key: "reduceIdentifierExpression", + value: function reduceIdentifierExpression(node) { + var a = t(node.name); + if (node.name === "let") { + a.startsWithLet = true; + } + return a; + } + }, { + key: "reduceIfStatement", + value: function reduceIfStatement(node, _ref35) { + var test = _ref35.test; + var consequent = _ref35.consequent; + var alternate = _ref35.alternate; - Maybe.prototype.isNothing = function() { - return this === _nothing; - }; + if (alternate && consequent.endsWithMissingElse) { + consequent = brace(consequent); + } + return (0, _objectAssign2.default)(seq(t("if"), paren(test), consequent, alternate ? seq(t("else"), alternate) : empty()), { endsWithMissingElse: alternate ? alternate.endsWithMissingElse : true }); + } + }, { + key: "reduceImport", + value: function reduceImport(node, _ref36) { + var defaultBinding = _ref36.defaultBinding; + var namedImports = _ref36.namedImports; - Maybe.prototype.isJust = function() { - return this instanceof _Just; - }; + var bindings = []; + if (defaultBinding != null) { + bindings.push(defaultBinding); + } + if (namedImports.length > 0) { + bindings.push(brace(commaSep(namedImports))); + } + if (bindings.length === 0) { + return seq(t("import"), t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), semiOp()); + } + return seq(t("import"), commaSep(bindings), t("from"), t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), semiOp()); + } + }, { + key: "reduceImportNamespace", + value: function reduceImportNamespace(node, _ref37) { + var defaultBinding = _ref37.defaultBinding; + var namespaceBinding = _ref37.namespaceBinding; - _Just.prototype.getOrElse = function() { - return this.value; - }; + return seq(t("import"), defaultBinding == null ? empty() : seq(defaultBinding, t(",")), t("*"), t("as"), namespaceBinding, t("from"), t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), semiOp()); + } + }, { + key: "reduceImportSpecifier", + value: function reduceImportSpecifier(node, _ref38) { + var binding = _ref38.binding; - _Nothing.prototype.getOrElse = function(a) { - return a; - }; + if (node.name == null) return binding; + return seq(t(node.name), t("as"), binding); + } + }, { + key: "reduceExportAllFrom", + value: function reduceExportAllFrom(node) { + return seq(t("export"), t("*"), t("from"), t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), semiOp()); + } + }, { + key: "reduceExportFrom", + value: function reduceExportFrom(node, _ref39) { + var namedExports = _ref39.namedExports; - _Just.prototype.reduce = function(f, x) { - return f(x, this.value); - }; + return seq(t("export"), brace(commaSep(namedExports)), node.moduleSpecifier == null ? empty() : seq(t("from"), t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), semiOp())); + } + }, { + key: "reduceExport", + value: function reduceExport(node, _ref40) { + var declaration = _ref40.declaration; - _Nothing.prototype.reduce = function(f, x) { - return x; - }; + switch (node.declaration.type) { + case "FunctionDeclaration": + case "ClassDeclaration": + break; + default: + declaration = seq(declaration, semiOp()); + } + return seq(t("export"), declaration); + } + }, { + key: "reduceExportDefault", + value: function reduceExportDefault(node, _ref41) { + var body = _ref41.body; - _Just.prototype.toString = function() { - return 'Maybe.Just(' + R.toString(this.value) + ')'; - }; + body = body.startsWithFunctionOrClass ? paren(body) : body; + switch (node.body.type) { + case "FunctionDeclaration": + case "ClassDeclaration": + break; + default: + body = seq(body, semiOp()); + } + return seq(t("export default"), body); + } + }, { + key: "reduceExportSpecifier", + value: function reduceExportSpecifier(node) { + if (node.name == null) return t(node.exportedName); + return seq(t(node.name), t("as"), t(node.exportedName)); + } + }, { + key: "reduceLabeledStatement", + value: function reduceLabeledStatement(node, _ref42) { + var label = _ref42.label; + var body = _ref42.body; - _Nothing.prototype.toString = function() { - return 'Maybe.Nothing()'; - }; + return (0, _objectAssign2.default)(seq(t(label + ":"), body), { endsWithMissingElse: body.endsWithMissingElse }); + } + }, { + key: "reduceLiteralBooleanExpression", + value: function reduceLiteralBooleanExpression(node) { + return t(node.value.toString()); + } + }, { + key: "reduceLiteralNullExpression", + value: function reduceLiteralNullExpression(node) { + return t("null"); + } + }, { + key: "reduceLiteralInfinityExpression", + value: function reduceLiteralInfinityExpression(node) { + return t("2e308"); + } + }, { + key: "reduceLiteralNumericExpression", + value: function reduceLiteralNumericExpression(node) { + return new _coderep.NumberCodeRep(node.value); + } + }, { + key: "reduceLiteralRegExpExpression", + value: function reduceLiteralRegExpExpression(node) { + return t("/" + node.pattern + "/" + node.flags); + } + }, { + key: "reduceLiteralStringExpression", + value: function reduceLiteralStringExpression(node) { + return t((0, _coderep.escapeStringLiteral)(node.value)); + } + }, { + key: "reduceMethod", + value: function reduceMethod(node, _ref43) { + var name = _ref43.name; + var params = _ref43.params; + var body = _ref43.body; - module.exports = Maybe; + return seq(node.isGenerator ? t("*") : empty(), name, paren(params), brace(body)); + } + }, { + key: "reduceModule", + value: function reduceModule(node, _ref44) { + var directives = _ref44.directives; + var items = _ref44.items; + if (items.length) { + items[0] = this.parenToAvoidBeingDirective(node.items[0], items[0]); + } + return seq.apply(undefined, _toConsumableArray(directives).concat(_toConsumableArray(items))); + } + }, { + key: "reduceNewExpression", + value: function reduceNewExpression(node, _ref45) { + var callee = _ref45.callee; + var args = _ref45.arguments; -/***/ }, -/* 25 */ -/***/ function(module, exports, __webpack_require__) { + var calleeRep = (0, _coderep.getPrecedence)(node.callee) == _coderep.Precedence.Call ? paren(callee) : p(node.callee, (0, _coderep.getPrecedence)(node), callee); + return seq(t("new"), calleeRep, args.length === 0 ? empty() : paren(commaSep(args))); + } + }, { + key: "reduceNewTargetExpression", + value: function reduceNewTargetExpression() { + return t("new.target"); + } + }, { + key: "reduceObjectExpression", + value: function reduceObjectExpression(node, _ref46) { + var properties = _ref46.properties; - var R = __webpack_require__(17); + var state = brace(commaSep(properties)); + state.startsWithCurly = true; + return state; + } + }, { + key: "reduceUpdateExpression", + value: function reduceUpdateExpression(node, _ref47) { + var operand = _ref47.operand; + if (node.isPrefix) { + return this.reduceUnaryExpression.apply(this, arguments); + } else { + return (0, _objectAssign2.default)(seq(p(node.operand, _coderep.Precedence.New, operand), t(node.operator)), { + startsWithCurly: operand.startsWithCurly, + startsWithLetSquareBracket: operand.startsWithLetSquareBracket, + startsWithFunctionOrClass: operand.startsWithFunctionOrClass + }); + } + } + }, { + key: "reduceUnaryExpression", + value: function reduceUnaryExpression(node, _ref48) { + var operand = _ref48.operand; - function Tuple(x, y) { - switch (arguments.length) { - case 0: - throw new TypeError('no arguments to Tuple'); - case 1: - return function(y) { - return new _Tuple(x, y); - }; - default: - return new _Tuple(x, y); - } - } + return seq(t(node.operator), p(node.operand, (0, _coderep.getPrecedence)(node), operand)); + } + }, { + key: "reduceReturnStatement", + value: function reduceReturnStatement(node, _ref49) { + var expression = _ref49.expression; - function _Tuple(x, y) { - this[0] = x; - this[1] = y; - this.length = 2; - } + return seq(t("return"), expression || empty(), semiOp()); + } + }, { + key: "reduceScript", + value: function reduceScript(node, _ref50) { + var directives = _ref50.directives; + var statements = _ref50.statements; - function ensureConcat(xs) { - xs.forEach(function(x) { - if (typeof x.concat != 'function') { - throw new TypeError(R.toString(x) + ' must be a semigroup to perform this operation'); + if (statements.length) { + statements[0] = this.parenToAvoidBeingDirective(node.statements[0], statements[0]); + } + return seq.apply(undefined, _toConsumableArray(directives).concat(_toConsumableArray(statements))); } - }); - } + }, { + key: "reduceSetter", + value: function reduceSetter(node, _ref51) { + var name = _ref51.name; + var param = _ref51.param; + var body = _ref51.body; - Tuple.fst = function(x) { - return x[0]; - }; + return seq(t("set"), name, paren(param), brace(body)); + } + }, { + key: "reduceShorthandProperty", + value: function reduceShorthandProperty(node) { + return t(node.name); + } + }, { + key: "reduceStaticMemberExpression", + value: function reduceStaticMemberExpression(node, _ref52) { + var object = _ref52.object; + var property = _ref52.property; - Tuple.snd = function(x) { - return x[1]; - }; + var state = seq(p(node.object, (0, _coderep.getPrecedence)(node), object), t("."), t(property)); + state.startsWithLet = object.startsWithLet; + state.startsWithCurly = object.startsWithCurly; + state.startsWithLetSquareBracket = object.startsWithLetSquareBracket; + state.startsWithFunctionOrClass = object.startsWithFunctionOrClass; + return state; + } + }, { + key: "reduceStaticPropertyName", + value: function reduceStaticPropertyName(node) { + var n; + if (_esutils.keyword.isIdentifierNameES6(node.value)) { + return t(node.value); + } else if (n = parseFloat(node.value), n === n) { + return new _coderep.NumberCodeRep(n); + } + return t((0, _coderep.escapeStringLiteral)(node.value)); + } + }, { + key: "reduceSuper", + value: function reduceSuper() { + return t("super"); + } + }, { + key: "reduceSwitchCase", + value: function reduceSwitchCase(node, _ref53) { + var test = _ref53.test; + var consequent = _ref53.consequent; - // semigroup - _Tuple.prototype.concat = function(x) { - ensureConcat([this[0], this[1]]); - return Tuple(this[0].concat(x[0]), this[1].concat(x[1])); - }; + return seq(t("case"), test, t(":"), seq.apply(undefined, _toConsumableArray(consequent))); + } + }, { + key: "reduceSwitchDefault", + value: function reduceSwitchDefault(node, _ref54) { + var consequent = _ref54.consequent; - // functor - _Tuple.prototype.map = function(f) { - return Tuple(this[0], f(this[1])); - }; + return seq(t("default:"), seq.apply(undefined, _toConsumableArray(consequent))); + } + }, { + key: "reduceSwitchStatement", + value: function reduceSwitchStatement(node, _ref55) { + var discriminant = _ref55.discriminant; + var cases = _ref55.cases; - // apply - _Tuple.prototype.ap = function(m) { - ensureConcat([this[0]]); - return Tuple(this[0].concat(m[0]), this[1](m[1])); - }; + return seq(t("switch"), paren(discriminant), brace(seq.apply(undefined, _toConsumableArray(cases)))); + } + }, { + key: "reduceSwitchStatementWithDefault", + value: function reduceSwitchStatementWithDefault(node, _ref56) { + var discriminant = _ref56.discriminant; + var preDefaultCases = _ref56.preDefaultCases; + var defaultCase = _ref56.defaultCase; + var postDefaultCases = _ref56.postDefaultCases; - // setoid - _Tuple.prototype.equals = function(that) { - return that instanceof _Tuple && R.equals(this[0], that[0]) && R.equals(this[1], that[1]); - }; + return seq(t("switch"), paren(discriminant), brace(seq.apply(undefined, _toConsumableArray(preDefaultCases).concat([defaultCase], _toConsumableArray(postDefaultCases))))); + } + }, { + key: "reduceTemplateExpression", + value: function reduceTemplateExpression(node, _ref57) { + var tag = _ref57.tag; + var elements = _ref57.elements; - _Tuple.prototype.toString = function() { - return 'Tuple(' + R.toString(this[0]) + ', ' + R.toString(this[1]) + ')'; - }; + var state = node.tag == null ? empty() : p(node.tag, (0, _coderep.getPrecedence)(node), tag); + var templateData = ""; + state = seq(state, t("`")); + for (var i = 0, l = node.elements.length; i < l; ++i) { + if (node.elements[i].type === "TemplateElement") { + var d = ""; + if (i > 0) d += "}"; + d += node.elements[i].rawValue; + if (i < l - 1) d += "${"; + state = seq(state, t(d)); + } else { + state = seq(state, elements[i]); + } + } + state = seq(state, t("`")); + if (node.tag != null) { + state.startsWithCurly = tag.startsWithCurly; + state.startsWithLetSquareBracket = tag.startsWithLetSquareBracket; + state.startsWithFunctionOrClass = tag.startsWithFunctionOrClass; + } + return state; + } + }, { + key: "reduceTemplateElement", + value: function reduceTemplateElement(node) { + return t(node.rawValue); + } + }, { + key: "reduceThisExpression", + value: function reduceThisExpression(node) { + return t("this"); + } + }, { + key: "reduceThrowStatement", + value: function reduceThrowStatement(node, _ref58) { + var expression = _ref58.expression; - module.exports = Tuple; + return seq(t("throw"), expression, semiOp()); + } + }, { + key: "reduceTryCatchStatement", + value: function reduceTryCatchStatement(node, _ref59) { + var body = _ref59.body; + var catchClause = _ref59.catchClause; + return seq(t("try"), body, catchClause); + } + }, { + key: "reduceTryFinallyStatement", + value: function reduceTryFinallyStatement(node, _ref60) { + var body = _ref60.body; + var catchClause = _ref60.catchClause; + var finalizer = _ref60.finalizer; -/***/ }, -/* 26 */ -/***/ function(module, exports, __webpack_require__) { + return seq(t("try"), body, catchClause || empty(), t("finally"), finalizer); + } + }, { + key: "reduceYieldExpression", + value: function reduceYieldExpression(node, _ref61) { + var expression = _ref61.expression; - var R = __webpack_require__(17); + if (node.expression == null) return t("yield"); + return seq(t("yield"), p(node.expression, (0, _coderep.getPrecedence)(node), expression)); + } + }, { + key: "reduceYieldGeneratorExpression", + value: function reduceYieldGeneratorExpression(node, _ref62) { + var expression = _ref62.expression; + return seq(t("yield"), t("*"), p(node.expression, (0, _coderep.getPrecedence)(node), expression)); + } + }, { + key: "reduceDirective", + value: function reduceDirective(node) { + var delim = /^(?:[^"\\]|\\.)*$/.test(node.rawValue) ? "\"" : "'"; + return seq(t(delim + node.rawValue + delim), semiOp()); + } + }, { + key: "reduceVariableDeclaration", + value: function reduceVariableDeclaration(node, _ref63) { + var declarators = _ref63.declarators; - function Reader(run) { - if (!(this instanceof Reader)) { - return new Reader(run); - } - this.run = run; - } + return seq(t(node.kind), commaSep(declarators)); + } + }, { + key: "reduceVariableDeclarationStatement", + value: function reduceVariableDeclarationStatement(node, _ref64) { + var declaration = _ref64.declaration; - Reader.run = function(reader) { - return reader.run.apply(reader, [].slice.call(arguments, 1)); - }; + return seq(declaration, semiOp()); + } + }, { + key: "reduceVariableDeclarator", + value: function reduceVariableDeclarator(node, _ref65) { + var binding = _ref65.binding; + var init = _ref65.init; - Reader.prototype.chain = function(f) { - var reader = this; - return new Reader(function(r) { - return f(reader.run(r)).run(r); - }); - }; + var containsIn = init && init.containsIn && !init.containsGroup; + if (init) { + if (init.containsGroup) { + init = paren(init); + } else { + init = markContainsIn(init); + } + } + return (0, _objectAssign2.default)(init == null ? binding : seq(binding, t("="), init), { containsIn: containsIn }); + } + }, { + key: "reduceWhileStatement", + value: function reduceWhileStatement(node, _ref66) { + var test = _ref66.test; + var body = _ref66.body; - Reader.prototype.ap = function(a) { - return this.chain(function(f) { - return a.map(f); - }); - }; + return (0, _objectAssign2.default)(seq(t("while"), paren(test), body), { endsWithMissingElse: body.endsWithMissingElse }); + } + }, { + key: "reduceWithStatement", + value: function reduceWithStatement(node, _ref67) { + var object = _ref67.object; + var body = _ref67.body; - Reader.prototype.map = function(f) { - return this.chain(function(a) { - return Reader.of(f(a)); - }); - }; + return (0, _objectAssign2.default)(seq(t("with"), paren(object), body), { endsWithMissingElse: body.endsWithMissingElse }); + } + }]); - Reader.prototype.of = function(a) { - return new Reader(function() { - return a; - }); - }; - Reader.of = Reader.prototype.of; + return MinimalCodeGen; + }(); - Reader.ask = Reader(R.identity); + exports.default = MinimalCodeGen; - Reader.prototype.toString = function() { - return 'Reader(' + R.toString(this.run) + ')'; - }; +/***/ }, +/* 14 */ +/***/ function(module, exports) { - Reader.T = function(M) { - var ReaderT = function ReaderT(run) { - if (!(this instanceof ReaderT)) { - return new ReaderT(run); - } - this.run = run; - }; + 'use strict'; + var propIsEnumerable = Object.prototype.propertyIsEnumerable; - ReaderT.lift = R.compose(ReaderT, R.always); + function ToObject(val) { + if (val == null) { + throw new TypeError('Object.assign cannot be called with null or undefined'); + } - ReaderT.ask = ReaderT(M.of); + return Object(val); + } - ReaderT.prototype.of = ReaderT.of = function(a) { - return ReaderT(function() { - return M.of(a); - }); - }; + function ownEnumerableKeys(obj) { + var keys = Object.getOwnPropertyNames(obj); - ReaderT.prototype.chain = function(f) { - var readerT = this; - return ReaderT(function(e) { - var m = readerT.run(e); - return m.chain(function(a) { - return f(a).run(e); - }); - }); - }; + if (Object.getOwnPropertySymbols) { + keys = keys.concat(Object.getOwnPropertySymbols(obj)); + } - ReaderT.prototype.map = function(f) { - return this.chain(function(a) { - return ReaderT.of(f(a)); - }); - }; + return keys.filter(function (key) { + return propIsEnumerable.call(obj, key); + }); + } - ReaderT.prototype.ap = function(a) { - var readerT = this; - return ReaderT(function(e) { - return readerT.run(e).ap(a.run(e)); - }); - }; + module.exports = Object.assign || function (target, source) { + var from; + var keys; + var to = ToObject(target); - ReaderT.prototype.equals = function(that) { - return this === that || - this.run === that.run || - R.equals(this.run().get(), that.run().get()); - }; + for (var s = 1; s < arguments.length; s++) { + from = arguments[s]; + keys = ownEnumerableKeys(Object(from)); - ReaderT.prototype.toString = function() { - return 'ReaderT[' + M.name + '](' + R.toString(this.run) + ')'; - }; + for (var i = 0; i < keys.length; i++) { + to[keys[i]] = from[keys[i]]; + } + } - return ReaderT; + return to; }; - module.exports = Reader; - /***/ }, -/* 27 */ +/* 15 */ /***/ function(module, exports, __webpack_require__) { - // Ramda v0.19.1 - // https://github.com/ramda/ramda - // (c) 2013-2016 Scott Sauyet, Michael Hurley, and David Chambers - // Ramda may be freely distributed under the MIT license. + /* + Copyright (C) 2013 Yusuke Suzuki - ;(function() { + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: - 'use strict'; + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. - /** - * A special placeholder value used to specify "gaps" within curried functions, - * allowing partial application of any combination of arguments, regardless of - * their positions. - * - * If `g` is a curried ternary function and `_` is `R.__`, the following are - * equivalent: - * - * - `g(1, 2, 3)` - * - `g(_, 2, 3)(1)` - * - `g(_, _, 3)(1)(2)` - * - `g(_, _, 3)(1, 2)` - * - `g(_, 2, _)(1, 3)` - * - `g(_, 2)(1)(3)` - * - `g(_, 2)(1, 3)` - * - `g(_, 2)(_, 3)(1)` - * - * @constant - * @memberOf R - * @since v0.6.0 - * @category Function - * @example - * - * var greet = R.replace('{name}', R.__, 'Hello, {name}!'); - * greet('Alice'); //=> 'Hello, Alice!' - */ - var __ = { '@@functional/placeholder': true }; + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY + DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND + ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF + THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ - /* eslint-disable no-unused-vars */ - var _arity = function _arity(n, fn) { - /* eslint-disable no-unused-vars */ - switch (n) { - case 0: - return function () { - return fn.apply(this, arguments); - }; - case 1: - return function (a0) { - return fn.apply(this, arguments); - }; - case 2: - return function (a0, a1) { - return fn.apply(this, arguments); - }; - case 3: - return function (a0, a1, a2) { - return fn.apply(this, arguments); - }; - case 4: - return function (a0, a1, a2, a3) { - return fn.apply(this, arguments); - }; - case 5: - return function (a0, a1, a2, a3, a4) { - return fn.apply(this, arguments); - }; - case 6: - return function (a0, a1, a2, a3, a4, a5) { - return fn.apply(this, arguments); - }; - case 7: - return function (a0, a1, a2, a3, a4, a5, a6) { - return fn.apply(this, arguments); - }; - case 8: - return function (a0, a1, a2, a3, a4, a5, a6, a7) { - return fn.apply(this, arguments); - }; - case 9: - return function (a0, a1, a2, a3, a4, a5, a6, a7, a8) { - return fn.apply(this, arguments); - }; - case 10: - return function (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9) { - return fn.apply(this, arguments); - }; - default: - throw new Error('First argument to _arity must be a non-negative integer no greater than ten'); - } - }; - var _arrayFromIterator = function _arrayFromIterator(iter) { - var list = []; - var next; - while (!(next = iter.next()).done) { - list.push(next.value); - } - return list; - }; + (function () { + 'use strict'; - var _cloneRegExp = function _cloneRegExp(pattern) { - return new RegExp(pattern.source, (pattern.global ? 'g' : '') + (pattern.ignoreCase ? 'i' : '') + (pattern.multiline ? 'm' : '') + (pattern.sticky ? 'y' : '') + (pattern.unicode ? 'u' : '')); - }; + exports.ast = __webpack_require__(16); + exports.code = __webpack_require__(17); + exports.keyword = __webpack_require__(18); + }()); + /* vim: set sw=4 ts=4 et tw=80 : */ - var _complement = function _complement(f) { - return function () { - return !f.apply(this, arguments); - }; - }; - /** - * Private `concat` function to merge two array-like objects. - * - * @private - * @param {Array|Arguments} [set1=[]] An array-like object. - * @param {Array|Arguments} [set2=[]] An array-like object. - * @return {Array} A new, merged array. - * @example - * - * _concat([4, 5, 6], [1, 2, 3]); //=> [4, 5, 6, 1, 2, 3] - */ - var _concat = function _concat(set1, set2) { - set1 = set1 || []; - set2 = set2 || []; - var idx; - var len1 = set1.length; - var len2 = set2.length; - var result = []; - idx = 0; - while (idx < len1) { - result[result.length] = set1[idx]; - idx += 1; +/***/ }, +/* 16 */ +/***/ function(module, exports) { + + /* + Copyright (C) 2013 Yusuke Suzuki + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 'AS IS' + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY + DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND + ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF + THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + + (function () { + 'use strict'; + + function isExpression(node) { + if (node == null) { return false; } + switch (node.type) { + case 'ArrayExpression': + case 'AssignmentExpression': + case 'BinaryExpression': + case 'CallExpression': + case 'ConditionalExpression': + case 'FunctionExpression': + case 'Identifier': + case 'Literal': + case 'LogicalExpression': + case 'MemberExpression': + case 'NewExpression': + case 'ObjectExpression': + case 'SequenceExpression': + case 'ThisExpression': + case 'UnaryExpression': + case 'UpdateExpression': + return true; } - idx = 0; - while (idx < len2) { - result[result.length] = set2[idx]; - idx += 1; + return false; + } + + function isIterationStatement(node) { + if (node == null) { return false; } + switch (node.type) { + case 'DoWhileStatement': + case 'ForInStatement': + case 'ForStatement': + case 'WhileStatement': + return true; } - return result; - }; + return false; + } - var _containsWith = function _containsWith(pred, x, list) { - var idx = 0; - var len = list.length; - while (idx < len) { - if (pred(x, list[idx])) { + function isStatement(node) { + if (node == null) { return false; } + switch (node.type) { + case 'BlockStatement': + case 'BreakStatement': + case 'ContinueStatement': + case 'DebuggerStatement': + case 'DoWhileStatement': + case 'EmptyStatement': + case 'ExpressionStatement': + case 'ForInStatement': + case 'ForStatement': + case 'IfStatement': + case 'LabeledStatement': + case 'ReturnStatement': + case 'SwitchStatement': + case 'ThrowStatement': + case 'TryStatement': + case 'VariableDeclaration': + case 'WhileStatement': + case 'WithStatement': return true; - } - idx += 1; } return false; - }; + } - var _filter = function _filter(fn, list) { - var idx = 0; - var len = list.length; - var result = []; - while (idx < len) { - if (fn(list[idx])) { - result[result.length] = list[idx]; + function isSourceElement(node) { + return isStatement(node) || node != null && node.type === 'FunctionDeclaration'; + } + + function trailingStatement(node) { + switch (node.type) { + case 'IfStatement': + if (node.alternate != null) { + return node.alternate; } - idx += 1; + return node.consequent; + + case 'LabeledStatement': + case 'ForStatement': + case 'ForInStatement': + case 'WhileStatement': + case 'WithStatement': + return node.body; } - return result; - }; + return null; + } - var _forceReduced = function _forceReduced(x) { - return { - '@@transducer/value': x, - '@@transducer/reduced': true - }; - }; + function isProblematicIfStatement(node) { + var current; - var _has = function _has(prop, obj) { - return Object.prototype.hasOwnProperty.call(obj, prop); - }; + if (node.type !== 'IfStatement') { + return false; + } + if (node.alternate == null) { + return false; + } + current = node.consequent; + do { + if (current.type === 'IfStatement') { + if (current.alternate == null) { + return true; + } + } + current = trailingStatement(current); + } while (current); - var _identity = function _identity(x) { - return x; - }; + return false; + } - var _isArguments = function () { - var toString = Object.prototype.toString; - return toString.call(arguments) === '[object Arguments]' ? function _isArguments(x) { - return toString.call(x) === '[object Arguments]'; - } : function _isArguments(x) { - return _has('callee', x); - }; - }(); + module.exports = { + isExpression: isExpression, + isStatement: isStatement, + isIterationStatement: isIterationStatement, + isSourceElement: isSourceElement, + isProblematicIfStatement: isProblematicIfStatement, - /** - * Tests whether or not an object is an array. - * - * @private - * @param {*} val The object to test. - * @return {Boolean} `true` if `val` is an array, `false` otherwise. - * @example - * - * _isArray([]); //=> true - * _isArray(null); //=> false - * _isArray({}); //=> false - */ - var _isArray = Array.isArray || function _isArray(val) { - return val != null && val.length >= 0 && Object.prototype.toString.call(val) === '[object Array]'; + trailingStatement: trailingStatement }; + }()); + /* vim: set sw=4 ts=4 et tw=80 : */ - /** - * Determine if the passed argument is an integer. - * - * @private - * @param {*} n - * @category Type - * @return {Boolean} - */ - var _isInteger = Number.isInteger || function _isInteger(n) { - return n << 0 === n; - }; - var _isNumber = function _isNumber(x) { - return Object.prototype.toString.call(x) === '[object Number]'; - }; +/***/ }, +/* 17 */ +/***/ function(module, exports) { - var _isObject = function _isObject(x) { - return Object.prototype.toString.call(x) === '[object Object]'; - }; + /* + Copyright (C) 2013-2014 Yusuke Suzuki + Copyright (C) 2014 Ivan Nikulin - var _isPlaceholder = function _isPlaceholder(a) { - return a != null && typeof a === 'object' && a['@@functional/placeholder'] === true; - }; + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: - var _isRegExp = function _isRegExp(x) { - return Object.prototype.toString.call(x) === '[object RegExp]'; - }; + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. - var _isString = function _isString(x) { - return Object.prototype.toString.call(x) === '[object String]'; - }; + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY + DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND + ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF + THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ - var _isTransformer = function _isTransformer(obj) { - return typeof obj['@@transducer/step'] === 'function'; - }; + (function () { + 'use strict'; - var _map = function _map(fn, functor) { - var idx = 0; - var len = functor.length; - var result = Array(len); - while (idx < len) { - result[idx] = fn(functor[idx]); - idx += 1; - } - return result; - }; + var ES6Regex, ES5Regex, NON_ASCII_WHITESPACES, IDENTIFIER_START, IDENTIFIER_PART, ch; - var _of = function _of(x) { - return [x]; + // See `tools/generate-identifier-regex.js`. + ES5Regex = { + // ECMAScript 5.1/Unicode v7.0.0 NonAsciiIdentifierStart: + NonAsciiIdentifierStart: /[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0-\u08B2\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA78E\uA790-\uA7AD\uA7B0\uA7B1\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB5F\uAB64\uAB65\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]/, + // ECMAScript 5.1/Unicode v7.0.0 NonAsciiIdentifierPart: + NonAsciiIdentifierPart: /[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u08A0-\u08B2\u08E4-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58\u0C59\u0C60-\u0C63\u0C66-\u0C6F\u0C81-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D01-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D57\u0D60-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1380-\u138F\u13A0-\u13F4\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19D9\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1CD0-\u1CD2\u1CD4-\u1CF6\u1CF8\u1CF9\u1D00-\u1DF5\u1DFC-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u200C\u200D\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u2E2F\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099\u309A\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA69D\uA69F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA78E\uA790-\uA7AD\uA7B0\uA7B1\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C4\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB5F\uAB64\uAB65\uABC0-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2D\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]/ }; - var _pipe = function _pipe(f, g) { - return function () { - return g.call(this, f.apply(this, arguments)); - }; + ES6Regex = { + // ECMAScript 6/Unicode v7.0.0 NonAsciiIdentifierStart: + NonAsciiIdentifierStart: /[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0-\u08B2\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2118-\u211D\u2124\u2126\u2128\u212A-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309B-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA78E\uA790-\uA7AD\uA7B0\uA7B1\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB5F\uAB64\uAB65\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF30-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDE00-\uDE11\uDE13-\uDE2B\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF5D-\uDF61]|\uD805[\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDE00-\uDE2F\uDE44\uDE80-\uDEAA]|\uD806[\uDCA0-\uDCDF\uDCFF\uDEC0-\uDEF8]|\uD808[\uDC00-\uDF98]|\uD809[\uDC00-\uDC6E]|[\uD80C\uD840-\uD868\uD86A-\uD86C][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50\uDF93-\uDF9F]|\uD82C[\uDC00\uDC01]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD83A[\uDC00-\uDCC4]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D]|\uD87E[\uDC00-\uDE1D]/, + // ECMAScript 6/Unicode v7.0.0 NonAsciiIdentifierPart: + NonAsciiIdentifierPart: /[\xAA\xB5\xB7\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u08A0-\u08B2\u08E4-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58\u0C59\u0C60-\u0C63\u0C66-\u0C6F\u0C81-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D01-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D57\u0D60-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1369-\u1371\u1380-\u138F\u13A0-\u13F4\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19DA\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1CD0-\u1CD2\u1CD4-\u1CF6\u1CF8\u1CF9\u1D00-\u1DF5\u1DFC-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u200C\u200D\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2118-\u211D\u2124\u2126\u2128\u212A-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA69D\uA69F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA78E\uA790-\uA7AD\uA7B0\uA7B1\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C4\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB5F\uAB64\uAB65\uABC0-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2D\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDDFD\uDE80-\uDE9C\uDEA0-\uDED0\uDEE0\uDF00-\uDF1F\uDF30-\uDF4A\uDF50-\uDF7A\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00-\uDE03\uDE05\uDE06\uDE0C-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE38-\uDE3A\uDE3F\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE6\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48]|\uD804[\uDC00-\uDC46\uDC66-\uDC6F\uDC7F-\uDCBA\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD00-\uDD34\uDD36-\uDD3F\uDD50-\uDD73\uDD76\uDD80-\uDDC4\uDDD0-\uDDDA\uDE00-\uDE11\uDE13-\uDE37\uDEB0-\uDEEA\uDEF0-\uDEF9\uDF01-\uDF03\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3C-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF57\uDF5D-\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC80-\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDB5\uDDB8-\uDDC0\uDE00-\uDE40\uDE44\uDE50-\uDE59\uDE80-\uDEB7\uDEC0-\uDEC9]|\uD806[\uDCA0-\uDCE9\uDCFF\uDEC0-\uDEF8]|\uD808[\uDC00-\uDF98]|\uD809[\uDC00-\uDC6E]|[\uD80C\uD840-\uD868\uD86A-\uD86C][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDED0-\uDEED\uDEF0-\uDEF4\uDF00-\uDF36\uDF40-\uDF43\uDF50-\uDF59\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50-\uDF7E\uDF8F-\uDF9F]|\uD82C[\uDC00\uDC01]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD83A[\uDC00-\uDCC4\uDCD0-\uDCD6]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D]|\uD87E[\uDC00-\uDE1D]|\uDB40[\uDD00-\uDDEF]/ }; - var _pipeP = function _pipeP(f, g) { - return function () { - var ctx = this; - return f.apply(ctx, arguments).then(function (x) { - return g.call(ctx, x); - }); - }; - }; + function isDecimalDigit(ch) { + return 0x30 <= ch && ch <= 0x39; // 0..9 + } - // \b matches word boundary; [\b] matches backspace - var _quote = function _quote(s) { - var escaped = s.replace(/\\/g, '\\\\').replace(/[\b]/g, '\\b') // \b matches word boundary; [\b] matches backspace - .replace(/\f/g, '\\f').replace(/\n/g, '\\n').replace(/\r/g, '\\r').replace(/\t/g, '\\t').replace(/\v/g, '\\v').replace(/\0/g, '\\0'); - return '"' + escaped.replace(/"/g, '\\"') + '"'; - }; + function isHexDigit(ch) { + return 0x30 <= ch && ch <= 0x39 || // 0..9 + 0x61 <= ch && ch <= 0x66 || // a..f + 0x41 <= ch && ch <= 0x46; // A..F + } - var _reduced = function _reduced(x) { - return x && x['@@transducer/reduced'] ? x : { - '@@transducer/value': x, - '@@transducer/reduced': true - }; - }; + function isOctalDigit(ch) { + return ch >= 0x30 && ch <= 0x37; // 0..7 + } - /** - * An optimized, private array `slice` implementation. - * - * @private - * @param {Arguments|Array} args The array or arguments object to consider. - * @param {Number} [from=0] The array index to slice from, inclusive. - * @param {Number} [to=args.length] The array index to slice to, exclusive. - * @return {Array} A new, sliced array. - * @example - * - * _slice([1, 2, 3, 4, 5], 1, 3); //=> [2, 3] - * - * var firstThreeArgs = function(a, b, c, d) { - * return _slice(arguments, 0, 3); - * }; - * firstThreeArgs(1, 2, 3, 4); //=> [1, 2, 3] - */ - var _slice = function _slice(args, from, to) { - switch (arguments.length) { - case 1: - return _slice(args, 0, args.length); - case 2: - return _slice(args, from, args.length); - default: - var list = []; - var idx = 0; - var len = Math.max(0, Math.min(args.length, to) - from); - while (idx < len) { - list[idx] = args[from + idx]; - idx += 1; - } - return list; - } - }; + // 7.2 White Space - /** - * Polyfill from . - */ - var _toISOString = function () { - var pad = function pad(n) { - return (n < 10 ? '0' : '') + n; - }; - return typeof Date.prototype.toISOString === 'function' ? function _toISOString(d) { - return d.toISOString(); - } : function _toISOString(d) { - return d.getUTCFullYear() + '-' + pad(d.getUTCMonth() + 1) + '-' + pad(d.getUTCDate()) + 'T' + pad(d.getUTCHours()) + ':' + pad(d.getUTCMinutes()) + ':' + pad(d.getUTCSeconds()) + '.' + (d.getUTCMilliseconds() / 1000).toFixed(3).slice(2, 5) + 'Z'; - }; - }(); + NON_ASCII_WHITESPACES = [ + 0x1680, 0x180E, + 0x2000, 0x2001, 0x2002, 0x2003, 0x2004, 0x2005, 0x2006, 0x2007, 0x2008, 0x2009, 0x200A, + 0x202F, 0x205F, + 0x3000, + 0xFEFF + ]; - var _xfBase = { - init: function () { - return this.xf['@@transducer/init'](); - }, - result: function (result) { - return this.xf['@@transducer/result'](result); - } - }; + function isWhiteSpace(ch) { + return ch === 0x20 || ch === 0x09 || ch === 0x0B || ch === 0x0C || ch === 0xA0 || + ch >= 0x1680 && NON_ASCII_WHITESPACES.indexOf(ch) >= 0; + } - var _xwrap = function () { - function XWrap(fn) { - this.f = fn; - } - XWrap.prototype['@@transducer/init'] = function () { - throw new Error('init not implemented on XWrap'); - }; - XWrap.prototype['@@transducer/result'] = function (acc) { - return acc; - }; - XWrap.prototype['@@transducer/step'] = function (acc, x) { - return this.f(acc, x); - }; - return function _xwrap(fn) { - return new XWrap(fn); - }; - }(); + // 7.3 Line Terminators - var _aperture = function _aperture(n, list) { - var idx = 0; - var limit = list.length - (n - 1); - var acc = new Array(limit >= 0 ? limit : 0); - while (idx < limit) { - acc[idx] = _slice(list, idx, idx + n); - idx += 1; - } - return acc; - }; + function isLineTerminator(ch) { + return ch === 0x0A || ch === 0x0D || ch === 0x2028 || ch === 0x2029; + } - /** - * Similar to hasMethod, this checks whether a function has a [methodname] - * function. If it isn't an array it will execute that function otherwise it - * will default to the ramda implementation. - * - * @private - * @param {Function} fn ramda implemtation - * @param {String} methodname property to check for a custom implementation - * @return {Object} Whatever the return value of the method is. - */ - var _checkForMethod = function _checkForMethod(methodname, fn) { - return function () { - var length = arguments.length; - if (length === 0) { - return fn(); - } - var obj = arguments[length - 1]; - return _isArray(obj) || typeof obj[methodname] !== 'function' ? fn.apply(this, arguments) : obj[methodname].apply(obj, _slice(arguments, 0, length - 1)); - }; - }; + // 7.6 Identifier Names and Identifiers - /** - * Optimized internal one-arity curry function. - * - * @private - * @category Function - * @param {Function} fn The function to curry. - * @return {Function} The curried function. - */ - var _curry1 = function _curry1(fn) { - return function f1(a) { - if (arguments.length === 0 || _isPlaceholder(a)) { - return f1; - } else { - return fn.apply(this, arguments); - } - }; - }; + function fromCodePoint(cp) { + if (cp <= 0xFFFF) { return String.fromCharCode(cp); } + var cu1 = String.fromCharCode(Math.floor((cp - 0x10000) / 0x400) + 0xD800); + var cu2 = String.fromCharCode(((cp - 0x10000) % 0x400) + 0xDC00); + return cu1 + cu2; + } - /** - * Optimized internal two-arity curry function. - * - * @private - * @category Function - * @param {Function} fn The function to curry. - * @return {Function} The curried function. - */ - var _curry2 = function _curry2(fn) { - return function f2(a, b) { - switch (arguments.length) { - case 0: - return f2; - case 1: - return _isPlaceholder(a) ? f2 : _curry1(function (_b) { - return fn(a, _b); - }); - default: - return _isPlaceholder(a) && _isPlaceholder(b) ? f2 : _isPlaceholder(a) ? _curry1(function (_a) { - return fn(_a, b); - }) : _isPlaceholder(b) ? _curry1(function (_b) { - return fn(a, _b); - }) : fn(a, b); - } - }; - }; + IDENTIFIER_START = new Array(0x80); + for(ch = 0; ch < 0x80; ++ch) { + IDENTIFIER_START[ch] = + ch >= 0x61 && ch <= 0x7A || // a..z + ch >= 0x41 && ch <= 0x5A || // A..Z + ch === 0x24 || ch === 0x5F; // $ (dollar) and _ (underscore) + } - /** - * Optimized internal three-arity curry function. - * - * @private - * @category Function - * @param {Function} fn The function to curry. - * @return {Function} The curried function. - */ - var _curry3 = function _curry3(fn) { - return function f3(a, b, c) { - switch (arguments.length) { - case 0: - return f3; - case 1: - return _isPlaceholder(a) ? f3 : _curry2(function (_b, _c) { - return fn(a, _b, _c); - }); - case 2: - return _isPlaceholder(a) && _isPlaceholder(b) ? f3 : _isPlaceholder(a) ? _curry2(function (_a, _c) { - return fn(_a, b, _c); - }) : _isPlaceholder(b) ? _curry2(function (_b, _c) { - return fn(a, _b, _c); - }) : _curry1(function (_c) { - return fn(a, b, _c); - }); - default: - return _isPlaceholder(a) && _isPlaceholder(b) && _isPlaceholder(c) ? f3 : _isPlaceholder(a) && _isPlaceholder(b) ? _curry2(function (_a, _b) { - return fn(_a, _b, c); - }) : _isPlaceholder(a) && _isPlaceholder(c) ? _curry2(function (_a, _c) { - return fn(_a, b, _c); - }) : _isPlaceholder(b) && _isPlaceholder(c) ? _curry2(function (_b, _c) { - return fn(a, _b, _c); - }) : _isPlaceholder(a) ? _curry1(function (_a) { - return fn(_a, b, c); - }) : _isPlaceholder(b) ? _curry1(function (_b) { - return fn(a, _b, c); - }) : _isPlaceholder(c) ? _curry1(function (_c) { - return fn(a, b, _c); - }) : fn(a, b, c); - } - }; - }; + IDENTIFIER_PART = new Array(0x80); + for(ch = 0; ch < 0x80; ++ch) { + IDENTIFIER_PART[ch] = + ch >= 0x61 && ch <= 0x7A || // a..z + ch >= 0x41 && ch <= 0x5A || // A..Z + ch >= 0x30 && ch <= 0x39 || // 0..9 + ch === 0x24 || ch === 0x5F; // $ (dollar) and _ (underscore) + } - /** - * Internal curryN function. - * - * @private - * @category Function - * @param {Number} length The arity of the curried function. - * @param {Array} received An array of arguments received thus far. - * @param {Function} fn The function to curry. - * @return {Function} The curried function. - */ - var _curryN = function _curryN(length, received, fn) { - return function () { - var combined = []; - var argsIdx = 0; - var left = length; - var combinedIdx = 0; - while (combinedIdx < received.length || argsIdx < arguments.length) { - var result; - if (combinedIdx < received.length && (!_isPlaceholder(received[combinedIdx]) || argsIdx >= arguments.length)) { - result = received[combinedIdx]; - } else { - result = arguments[argsIdx]; - argsIdx += 1; - } - combined[combinedIdx] = result; - if (!_isPlaceholder(result)) { - left -= 1; - } - combinedIdx += 1; - } - return left <= 0 ? fn.apply(this, combined) : _arity(left, _curryN(length, combined, fn)); - }; - }; + function isIdentifierStartES5(ch) { + return ch < 0x80 ? IDENTIFIER_START[ch] : ES5Regex.NonAsciiIdentifierStart.test(fromCodePoint(ch)); + } - /** - * Returns a function that dispatches with different strategies based on the - * object in list position (last argument). If it is an array, executes [fn]. - * Otherwise, if it has a function with [methodname], it will execute that - * function (functor case). Otherwise, if it is a transformer, uses transducer - * [xf] to return a new transformer (transducer case). Otherwise, it will - * default to executing [fn]. - * - * @private - * @param {String} methodname property to check for a custom implementation - * @param {Function} xf transducer to initialize if object is transformer - * @param {Function} fn default ramda implementation - * @return {Function} A function that dispatches on object in list position - */ - var _dispatchable = function _dispatchable(methodname, xf, fn) { - return function () { - var length = arguments.length; - if (length === 0) { - return fn(); - } - var obj = arguments[length - 1]; - if (!_isArray(obj)) { - var args = _slice(arguments, 0, length - 1); - if (typeof obj[methodname] === 'function') { - return obj[methodname].apply(obj, args); - } - if (_isTransformer(obj)) { - var transducer = xf.apply(null, args); - return transducer(obj); - } - } - return fn.apply(this, arguments); - }; - }; + function isIdentifierPartES5(ch) { + return ch < 0x80 ? IDENTIFIER_PART[ch] : ES5Regex.NonAsciiIdentifierPart.test(fromCodePoint(ch)); + } - var _dropLastWhile = function dropLastWhile(pred, list) { - var idx = list.length - 1; - while (idx >= 0 && pred(list[idx])) { - idx -= 1; - } - return _slice(list, 0, idx + 1); + function isIdentifierStartES6(ch) { + return ch < 0x80 ? IDENTIFIER_START[ch] : ES6Regex.NonAsciiIdentifierStart.test(fromCodePoint(ch)); + } + + function isIdentifierPartES6(ch) { + return ch < 0x80 ? IDENTIFIER_PART[ch] : ES6Regex.NonAsciiIdentifierPart.test(fromCodePoint(ch)); + } + + module.exports = { + isDecimalDigit: isDecimalDigit, + isHexDigit: isHexDigit, + isOctalDigit: isOctalDigit, + isWhiteSpace: isWhiteSpace, + isLineTerminator: isLineTerminator, + isIdentifierStartES5: isIdentifierStartES5, + isIdentifierPartES5: isIdentifierPartES5, + isIdentifierStartES6: isIdentifierStartES6, + isIdentifierPartES6: isIdentifierPartES6 }; + }()); + /* vim: set sw=4 ts=4 et tw=80 : */ - var _xall = function () { - function XAll(f, xf) { - this.xf = xf; - this.f = f; - this.all = true; - } - XAll.prototype['@@transducer/init'] = _xfBase.init; - XAll.prototype['@@transducer/result'] = function (result) { - if (this.all) { - result = this.xf['@@transducer/step'](result, true); - } - return this.xf['@@transducer/result'](result); - }; - XAll.prototype['@@transducer/step'] = function (result, input) { - if (!this.f(input)) { - this.all = false; - result = _reduced(this.xf['@@transducer/step'](result, false)); - } - return result; - }; - return _curry2(function _xall(f, xf) { - return new XAll(f, xf); - }); - }(); - var _xany = function () { - function XAny(f, xf) { - this.xf = xf; - this.f = f; - this.any = false; - } - XAny.prototype['@@transducer/init'] = _xfBase.init; - XAny.prototype['@@transducer/result'] = function (result) { - if (!this.any) { - result = this.xf['@@transducer/step'](result, false); - } - return this.xf['@@transducer/result'](result); - }; - XAny.prototype['@@transducer/step'] = function (result, input) { - if (this.f(input)) { - this.any = true; - result = _reduced(this.xf['@@transducer/step'](result, true)); - } - return result; - }; - return _curry2(function _xany(f, xf) { - return new XAny(f, xf); - }); - }(); +/***/ }, +/* 18 */ +/***/ function(module, exports, __webpack_require__) { - var _xaperture = function () { - function XAperture(n, xf) { - this.xf = xf; - this.pos = 0; - this.full = false; - this.acc = new Array(n); - } - XAperture.prototype['@@transducer/init'] = _xfBase.init; - XAperture.prototype['@@transducer/result'] = function (result) { - this.acc = null; - return this.xf['@@transducer/result'](result); - }; - XAperture.prototype['@@transducer/step'] = function (result, input) { - this.store(input); - return this.full ? this.xf['@@transducer/step'](result, this.getCopy()) : result; - }; - XAperture.prototype.store = function (input) { - this.acc[this.pos] = input; - this.pos += 1; - if (this.pos === this.acc.length) { - this.pos = 0; - this.full = true; - } - }; - XAperture.prototype.getCopy = function () { - return _concat(_slice(this.acc, this.pos), _slice(this.acc, 0, this.pos)); - }; - return _curry2(function _xaperture(n, xf) { - return new XAperture(n, xf); - }); - }(); + /* + Copyright (C) 2013 Yusuke Suzuki - var _xdrop = function () { - function XDrop(n, xf) { - this.xf = xf; - this.n = n; - } - XDrop.prototype['@@transducer/init'] = _xfBase.init; - XDrop.prototype['@@transducer/result'] = _xfBase.result; - XDrop.prototype['@@transducer/step'] = function (result, input) { - if (this.n > 0) { - this.n -= 1; - return result; - } - return this.xf['@@transducer/step'](result, input); - }; - return _curry2(function _xdrop(n, xf) { - return new XDrop(n, xf); - }); - }(); + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: - var _xdropLast = function () { - function XDropLast(n, xf) { - this.xf = xf; - this.pos = 0; - this.full = false; - this.acc = new Array(n); + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY + DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND + ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF + THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + + (function () { + 'use strict'; + + var code = __webpack_require__(17); + + function isStrictModeReservedWordES6(id) { + switch (id) { + case 'implements': + case 'interface': + case 'package': + case 'private': + case 'protected': + case 'public': + case 'static': + case 'let': + return true; + default: + return false; } - XDropLast.prototype['@@transducer/init'] = _xfBase.init; - XDropLast.prototype['@@transducer/result'] = function (result) { - this.acc = null; - return this.xf['@@transducer/result'](result); - }; - XDropLast.prototype['@@transducer/step'] = function (result, input) { - if (this.full) { - result = this.xf['@@transducer/step'](result, this.acc[this.pos]); - } - this.store(input); - return result; - }; - XDropLast.prototype.store = function (input) { - this.acc[this.pos] = input; - this.pos += 1; - if (this.pos === this.acc.length) { - this.pos = 0; - this.full = true; - } - }; - return _curry2(function _xdropLast(n, xf) { - return new XDropLast(n, xf); - }); - }(); + } - var _xdropRepeatsWith = function () { - function XDropRepeatsWith(pred, xf) { - this.xf = xf; - this.pred = pred; - this.lastValue = undefined; - this.seenFirstValue = false; + function isKeywordES5(id, strict) { + // yield should not be treated as keyword under non-strict mode. + if (!strict && id === 'yield') { + return false; } - XDropRepeatsWith.prototype['@@transducer/init'] = function () { - return this.xf['@@transducer/init'](); - }; - XDropRepeatsWith.prototype['@@transducer/result'] = function (result) { - return this.xf['@@transducer/result'](result); - }; - XDropRepeatsWith.prototype['@@transducer/step'] = function (result, input) { - var sameAsLast = false; - if (!this.seenFirstValue) { - this.seenFirstValue = true; - } else if (this.pred(this.lastValue, input)) { - sameAsLast = true; - } - this.lastValue = input; - return sameAsLast ? result : this.xf['@@transducer/step'](result, input); - }; - return _curry2(function _xdropRepeatsWith(pred, xf) { - return new XDropRepeatsWith(pred, xf); - }); - }(); + return isKeywordES6(id, strict); + } - var _xdropWhile = function () { - function XDropWhile(f, xf) { - this.xf = xf; - this.f = f; + function isKeywordES6(id, strict) { + if (strict && isStrictModeReservedWordES6(id)) { + return true; } - XDropWhile.prototype['@@transducer/init'] = _xfBase.init; - XDropWhile.prototype['@@transducer/result'] = _xfBase.result; - XDropWhile.prototype['@@transducer/step'] = function (result, input) { - if (this.f) { - if (this.f(input)) { - return result; - } - this.f = null; - } - return this.xf['@@transducer/step'](result, input); - }; - return _curry2(function _xdropWhile(f, xf) { - return new XDropWhile(f, xf); - }); - }(); - var _xfilter = function () { - function XFilter(f, xf) { - this.xf = xf; - this.f = f; + switch (id.length) { + case 2: + return (id === 'if') || (id === 'in') || (id === 'do'); + case 3: + return (id === 'var') || (id === 'for') || (id === 'new') || (id === 'try'); + case 4: + return (id === 'this') || (id === 'else') || (id === 'case') || + (id === 'void') || (id === 'with') || (id === 'enum'); + case 5: + return (id === 'while') || (id === 'break') || (id === 'catch') || + (id === 'throw') || (id === 'const') || (id === 'yield') || + (id === 'class') || (id === 'super'); + case 6: + return (id === 'return') || (id === 'typeof') || (id === 'delete') || + (id === 'switch') || (id === 'export') || (id === 'import'); + case 7: + return (id === 'default') || (id === 'finally') || (id === 'extends'); + case 8: + return (id === 'function') || (id === 'continue') || (id === 'debugger'); + case 10: + return (id === 'instanceof'); + default: + return false; } - XFilter.prototype['@@transducer/init'] = _xfBase.init; - XFilter.prototype['@@transducer/result'] = _xfBase.result; - XFilter.prototype['@@transducer/step'] = function (result, input) { - return this.f(input) ? this.xf['@@transducer/step'](result, input) : result; - }; - return _curry2(function _xfilter(f, xf) { - return new XFilter(f, xf); - }); - }(); + } - var _xfind = function () { - function XFind(f, xf) { - this.xf = xf; - this.f = f; - this.found = false; + function isReservedWordES5(id, strict) { + return id === 'null' || id === 'true' || id === 'false' || isKeywordES5(id, strict); + } + + function isReservedWordES6(id, strict) { + return id === 'null' || id === 'true' || id === 'false' || isKeywordES6(id, strict); + } + + function isRestrictedWord(id) { + return id === 'eval' || id === 'arguments'; + } + + function isIdentifierNameES5(id) { + var i, iz, ch; + + if (id.length === 0) { return false; } + + ch = id.charCodeAt(0); + if (!code.isIdentifierStartES5(ch)) { + return false; } - XFind.prototype['@@transducer/init'] = _xfBase.init; - XFind.prototype['@@transducer/result'] = function (result) { - if (!this.found) { - result = this.xf['@@transducer/step'](result, void 0); - } - return this.xf['@@transducer/result'](result); - }; - XFind.prototype['@@transducer/step'] = function (result, input) { - if (this.f(input)) { - this.found = true; - result = _reduced(this.xf['@@transducer/step'](result, input)); - } - return result; - }; - return _curry2(function _xfind(f, xf) { - return new XFind(f, xf); - }); - }(); - var _xfindIndex = function () { - function XFindIndex(f, xf) { - this.xf = xf; - this.f = f; - this.idx = -1; - this.found = false; + for (i = 1, iz = id.length; i < iz; ++i) { + ch = id.charCodeAt(i); + if (!code.isIdentifierPartES5(ch)) { + return false; + } } - XFindIndex.prototype['@@transducer/init'] = _xfBase.init; - XFindIndex.prototype['@@transducer/result'] = function (result) { - if (!this.found) { - result = this.xf['@@transducer/step'](result, -1); + return true; + } + + function decodeUtf16(lead, trail) { + return (lead - 0xD800) * 0x400 + (trail - 0xDC00) + 0x10000; + } + + function isIdentifierNameES6(id) { + var i, iz, ch, lowCh, check; + + if (id.length === 0) { return false; } + + check = code.isIdentifierStartES6; + for (i = 0, iz = id.length; i < iz; ++i) { + ch = id.charCodeAt(i); + if (0xD800 <= ch && ch <= 0xDBFF) { + ++i; + if (i >= iz) { return false; } + lowCh = id.charCodeAt(i); + if (!(0xDC00 <= lowCh && lowCh <= 0xDFFF)) { + return false; + } + ch = decodeUtf16(ch, lowCh); } - return this.xf['@@transducer/result'](result); - }; - XFindIndex.prototype['@@transducer/step'] = function (result, input) { - this.idx += 1; - if (this.f(input)) { - this.found = true; - result = _reduced(this.xf['@@transducer/step'](result, this.idx)); + if (!check(ch)) { + return false; } - return result; - }; - return _curry2(function _xfindIndex(f, xf) { - return new XFindIndex(f, xf); - }); - }(); - - var _xfindLast = function () { - function XFindLast(f, xf) { - this.xf = xf; - this.f = f; + check = code.isIdentifierPartES6; } - XFindLast.prototype['@@transducer/init'] = _xfBase.init; - XFindLast.prototype['@@transducer/result'] = function (result) { - return this.xf['@@transducer/result'](this.xf['@@transducer/step'](result, this.last)); - }; - XFindLast.prototype['@@transducer/step'] = function (result, input) { - if (this.f(input)) { - this.last = input; - } - return result; - }; - return _curry2(function _xfindLast(f, xf) { - return new XFindLast(f, xf); - }); - }(); + return true; + } - var _xfindLastIndex = function () { - function XFindLastIndex(f, xf) { - this.xf = xf; - this.f = f; - this.idx = -1; - this.lastIdx = -1; - } - XFindLastIndex.prototype['@@transducer/init'] = _xfBase.init; - XFindLastIndex.prototype['@@transducer/result'] = function (result) { - return this.xf['@@transducer/result'](this.xf['@@transducer/step'](result, this.lastIdx)); - }; - XFindLastIndex.prototype['@@transducer/step'] = function (result, input) { - this.idx += 1; - if (this.f(input)) { - this.lastIdx = this.idx; - } - return result; - }; - return _curry2(function _xfindLastIndex(f, xf) { - return new XFindLastIndex(f, xf); - }); - }(); + function isIdentifierES5(id, strict) { + return isIdentifierNameES5(id) && !isReservedWordES5(id, strict); + } - var _xmap = function () { - function XMap(f, xf) { - this.xf = xf; - this.f = f; - } - XMap.prototype['@@transducer/init'] = _xfBase.init; - XMap.prototype['@@transducer/result'] = _xfBase.result; - XMap.prototype['@@transducer/step'] = function (result, input) { - return this.xf['@@transducer/step'](result, this.f(input)); - }; - return _curry2(function _xmap(f, xf) { - return new XMap(f, xf); - }); - }(); + function isIdentifierES6(id, strict) { + return isIdentifierNameES6(id) && !isReservedWordES6(id, strict); + } - var _xtake = function () { - function XTake(n, xf) { - this.xf = xf; - this.n = n; - } - XTake.prototype['@@transducer/init'] = _xfBase.init; - XTake.prototype['@@transducer/result'] = _xfBase.result; - XTake.prototype['@@transducer/step'] = function (result, input) { - if (this.n === 0) { - return _reduced(result); - } else { - this.n -= 1; - return this.xf['@@transducer/step'](result, input); - } - }; - return _curry2(function _xtake(n, xf) { - return new XTake(n, xf); - }); - }(); + module.exports = { + isKeywordES5: isKeywordES5, + isKeywordES6: isKeywordES6, + isReservedWordES5: isReservedWordES5, + isReservedWordES6: isReservedWordES6, + isRestrictedWord: isRestrictedWord, + isIdentifierNameES5: isIdentifierNameES5, + isIdentifierNameES6: isIdentifierNameES6, + isIdentifierES5: isIdentifierES5, + isIdentifierES6: isIdentifierES6 + }; + }()); + /* vim: set sw=4 ts=4 et tw=80 : */ - var _xtakeWhile = function () { - function XTakeWhile(f, xf) { - this.xf = xf; - this.f = f; - } - XTakeWhile.prototype['@@transducer/init'] = _xfBase.init; - XTakeWhile.prototype['@@transducer/result'] = _xfBase.result; - XTakeWhile.prototype['@@transducer/step'] = function (result, input) { - return this.f(input) ? this.xf['@@transducer/step'](result, input) : _reduced(result); - }; - return _curry2(function _xtakeWhile(f, xf) { - return new XTakeWhile(f, xf); - }); - }(); - /** - * Adds two numbers. Equivalent to `a + b` but curried. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Math - * @sig Number -> Number -> Number - * @param {Number} a - * @param {Number} b - * @return {Number} - * @see R.subtract - * @example - * - * R.add(2, 3); //=> 5 - * R.add(7)(10); //=> 17 - */ - var add = _curry2(function add(a, b) { - return a + b; - }); +/***/ }, +/* 19 */ +/***/ function(module, exports) { - /** - * Applies a function to the value at the given index of an array, returning a - * new copy of the array with the element at the given index replaced with the - * result of the function application. - * - * @func - * @memberOf R - * @since v0.14.0 - * @category List - * @sig (a -> a) -> Number -> [a] -> [a] - * @param {Function} fn The function to apply. - * @param {Number} idx The index. - * @param {Array|Arguments} list An array-like object whose value - * at the supplied index will be replaced. - * @return {Array} A copy of the supplied array-like object with - * the element at index `idx` replaced with the value - * returned by applying `fn` to the existing element. - * @see R.update - * @example - * - * R.adjust(R.add(10), 1, [0, 1, 2]); //=> [0, 11, 2] - * R.adjust(R.add(10))(1)([0, 1, 2]); //=> [0, 11, 2] - */ - var adjust = _curry3(function adjust(fn, idx, list) { - if (idx >= list.length || idx < -list.length) { - return list; - } - var start = idx < 0 ? list.length : 0; - var _idx = start + idx; - var _list = _concat(list); - _list[_idx] = fn(list[_idx]); - return _list; - }); + "use strict"; - /** - * Returns `true` if all elements of the list match the predicate, `false` if - * there are any that don't. - * - * Dispatches to the `all` method of the second argument, if present. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig (a -> Boolean) -> [a] -> Boolean - * @param {Function} fn The predicate function. - * @param {Array} list The array to consider. - * @return {Boolean} `true` if the predicate is satisfied by every element, `false` - * otherwise. - * @see R.any, R.none, R.transduce - * @example - * - * var lessThan2 = R.flip(R.lt)(2); - * var lessThan3 = R.flip(R.lt)(3); - * R.all(lessThan2)([1, 2]); //=> false - * R.all(lessThan3)([1, 2]); //=> true - */ - var all = _curry2(_dispatchable('all', _xall, function all(fn, list) { - var idx = 0; - while (idx < list.length) { - if (!fn(list[idx])) { - return false; - } - idx += 1; - } - return true; - })); + var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); - /** - * Returns a function that always returns the given value. Note that for - * non-primitives the value returned is a reference to the original value. - * - * This function is known as `const`, `constant`, or `K` (for K combinator) in - * other languages and libraries. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig a -> (* -> a) - * @param {*} val The value to wrap in a function - * @return {Function} A Function :: * -> val. - * @example - * - * var t = R.always('Tee'); - * t(); //=> 'Tee' - */ - var always = _curry1(function always(val) { - return function () { - return val; - }; - }); + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.getPrecedence = getPrecedence; + exports.escapeStringLiteral = escapeStringLiteral; - /** - * Returns `true` if both arguments are `true`; `false` otherwise. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Logic - * @sig * -> * -> * - * @param {Boolean} a A boolean value - * @param {Boolean} b A boolean value - * @return {Boolean} `true` if both arguments are `true`, `false` otherwise - * @see R.both - * @example - * - * R.and(true, true); //=> true - * R.and(true, false); //=> false - * R.and(false, true); //=> false - * R.and(false, false); //=> false - */ - var and = _curry2(function and(a, b) { - return a && b; - }); + function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } - /** - * Returns `true` if at least one of elements of the list match the predicate, - * `false` otherwise. - * - * Dispatches to the `any` method of the second argument, if present. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig (a -> Boolean) -> [a] -> Boolean - * @param {Function} fn The predicate function. - * @param {Array} list The array to consider. - * @return {Boolean} `true` if the predicate is satisfied by at least one element, `false` - * otherwise. - * @see R.all, R.none, R.transduce - * @example - * - * var lessThan0 = R.flip(R.lt)(0); - * var lessThan2 = R.flip(R.lt)(2); - * R.any(lessThan0)([1, 2]); //=> false - * R.any(lessThan2)([1, 2]); //=> true - */ - var any = _curry2(_dispatchable('any', _xany, function any(fn, list) { - var idx = 0; - while (idx < list.length) { - if (fn(list[idx])) { - return true; - } - idx += 1; - } - return false; - })); + function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } - /** - * Returns a new list, composed of n-tuples of consecutive elements If `n` is - * greater than the length of the list, an empty list is returned. - * - * Dispatches to the `aperture` method of the second argument, if present. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since v0.12.0 - * @category List - * @sig Number -> [a] -> [[a]] - * @param {Number} n The size of the tuples to create - * @param {Array} list The list to split into `n`-tuples - * @return {Array} The new list. - * @see R.transduce - * @example - * - * R.aperture(2, [1, 2, 3, 4, 5]); //=> [[1, 2], [2, 3], [3, 4], [4, 5]] - * R.aperture(3, [1, 2, 3, 4, 5]); //=> [[1, 2, 3], [2, 3, 4], [3, 4, 5]] - * R.aperture(7, [1, 2, 3, 4, 5]); //=> [] - */ - var aperture = _curry2(_dispatchable('aperture', _xaperture, _aperture)); + function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - /** - * Returns a new list containing the contents of the given list, followed by - * the given element. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig a -> [a] -> [a] - * @param {*} el The element to add to the end of the new list. - * @param {Array} list The list whose contents will be added to the beginning of the output - * list. - * @return {Array} A new list containing the contents of the old list followed by `el`. - * @see R.prepend - * @example - * - * R.append('tests', ['write', 'more']); //=> ['write', 'more', 'tests'] - * R.append('tests', []); //=> ['tests'] - * R.append(['tests'], ['write', 'more']); //=> ['write', 'more', ['tests']] - */ - var append = _curry2(function append(el, list) { - return _concat(list, [el]); - }); + var Precedence = { + Sequence: 0, + Yield: 1, + Assignment: 1, + Conditional: 2, + ArrowFunction: 2, + LogicalOR: 3, + LogicalAND: 4, + BitwiseOR: 5, + BitwiseXOR: 6, + BitwiseAND: 7, + Equality: 8, + Relational: 9, + BitwiseSHIFT: 10, + Additive: 11, + Multiplicative: 12, + Prefix: 13, + Postfix: 14, + New: 15, + Call: 16, + TaggedTemplate: 17, + Member: 18, + Primary: 19 + }; - /** - * Applies function `fn` to the argument list `args`. This is useful for - * creating a fixed-arity function from a variadic function. `fn` should be a - * bound function if context is significant. - * - * @func - * @memberOf R - * @since v0.7.0 - * @category Function - * @sig (*... -> a) -> [*] -> a - * @param {Function} fn - * @param {Array} args - * @return {*} - * @see R.call, R.unapply - * @example - * - * var nums = [1, 2, 3, -99, 42, 6, 7]; - * R.apply(Math.max, nums); //=> 42 - */ - var apply = _curry2(function apply(fn, args) { - return fn.apply(this, args); - }); + exports.Precedence = Precedence; - /** - * Makes a shallow clone of an object, setting or overriding the specified - * property with the given value. Note that this copies and flattens prototype - * properties onto the new object as well. All non-primitive properties are - * copied by reference. - * - * @func - * @memberOf R - * @since v0.8.0 - * @category Object - * @sig String -> a -> {k: v} -> {k: v} - * @param {String} prop the property name to set - * @param {*} val the new value - * @param {Object} obj the object to clone - * @return {Object} a new object similar to the original except for the specified property. - * @see R.dissoc - * @example - * - * R.assoc('c', 3, {a: 1, b: 2}); //=> {a: 1, b: 2, c: 3} - */ - var assoc = _curry3(function assoc(prop, val, obj) { - var result = {}; - for (var p in obj) { - result[p] = obj[p]; - } - result[prop] = val; - return result; - }); + var BinaryPrecedence = { + ",": Precedence.Sequence, + "||": Precedence.LogicalOR, + "&&": Precedence.LogicalAND, + "|": Precedence.BitwiseOR, + "^": Precedence.BitwiseXOR, + "&": Precedence.BitwiseAND, + "==": Precedence.Equality, + "!=": Precedence.Equality, + "===": Precedence.Equality, + "!==": Precedence.Equality, + "<": Precedence.Relational, + ">": Precedence.Relational, + "<=": Precedence.Relational, + ">=": Precedence.Relational, + "in": Precedence.Relational, + "instanceof": Precedence.Relational, + "<<": Precedence.BitwiseSHIFT, + ">>": Precedence.BitwiseSHIFT, + ">>>": Precedence.BitwiseSHIFT, + "+": Precedence.Additive, + "-": Precedence.Additive, + "*": Precedence.Multiplicative, + "%": Precedence.Multiplicative, + "/": Precedence.Multiplicative + }; - /** - * Makes a shallow clone of an object, setting or overriding the nodes required - * to create the given path, and placing the specific value at the tail end of - * that path. Note that this copies and flattens prototype properties onto the - * new object as well. All non-primitive properties are copied by reference. - * - * @func - * @memberOf R - * @since v0.8.0 - * @category Object - * @sig [String] -> a -> {k: v} -> {k: v} - * @param {Array} path the path to set - * @param {*} val the new value - * @param {Object} obj the object to clone - * @return {Object} a new object similar to the original except along the specified path. - * @see R.dissocPath - * @example - * - * R.assocPath(['a', 'b', 'c'], 42, {a: {b: {c: 0}}}); //=> {a: {b: {c: 42}}} - */ - var assocPath = _curry3(function assocPath(path, val, obj) { - switch (path.length) { - case 0: - return val; - case 1: - return assoc(path[0], val, obj); + function getPrecedence(node) { + switch (node.type) { + case "ArrayExpression": + case "FunctionExpression": + case "IdentifierExpression": + case "LiteralBooleanExpression": + case "LiteralNullExpression": + case "LiteralNumericExpression": + case "LiteralInfinityExpression": + case "LiteralRegExpExpression": + case "LiteralStringExpression": + case "ObjectExpression": + case "ThisExpression": + return Precedence.Primary; + + case "ArrowExpression": + case "AssignmentExpression": + case "CompoundAssignmentExpression": + case "YieldExpression": + case "YieldGeneratorExpression": + return Precedence.Assignment; + + case "ConditionalExpression": + return Precedence.Conditional; + + case "ComputedMemberExpression": + case "StaticMemberExpression": + switch (node.object.type) { + case "CallExpression": + case "ComputedMemberExpression": + case "StaticMemberExpression": + case "TemplateExpression": + return getPrecedence(node.object); default: - return assoc(path[0], assocPath(_slice(path, 1), val, Object(obj[path[0]])), obj); - } - }); + return Precedence.Member; + } - /** - * Creates a function that is bound to a context. - * Note: `R.bind` does not provide the additional argument-binding capabilities of - * [Function.prototype.bind](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/bind). - * - * @func - * @memberOf R - * @since v0.6.0 - * @category Function - * @category Object - * @sig (* -> *) -> {*} -> (* -> *) - * @param {Function} fn The function to bind to context - * @param {Object} thisObj The context to bind `fn` to - * @return {Function} A function that will execute in the context of `thisObj`. - * @see R.partial - */ - var bind = _curry2(function bind(fn, thisObj) { - return _arity(fn.length, function () { - return fn.apply(thisObj, arguments); - }); - }); + case "TemplateExpression": + if (node.tag == null) return Precedence.Member; + switch (node.tag.type) { + case "CallExpression": + case "ComputedMemberExpression": + case "StaticMemberExpression": + case "TemplateExpression": + return getPrecedence(node.tag); + default: + return Precedence.Member; + } - /** - * A function wrapping calls to the two functions in an `&&` operation, - * returning the result of the first function if it is false-y and the result - * of the second function otherwise. Note that this is short-circuited, - * meaning that the second function will not be invoked if the first returns a - * false-y value. - * - * @func - * @memberOf R - * @since v0.12.0 - * @category Logic - * @sig (*... -> Boolean) -> (*... -> Boolean) -> (*... -> Boolean) - * @param {Function} f a predicate - * @param {Function} g another predicate - * @return {Function} a function that applies its arguments to `f` and `g` and `&&`s their outputs together. - * @see R.and - * @example - * - * var gt10 = x => x > 10; - * var even = x => x % 2 === 0; - * var f = R.both(gt10, even); - * f(100); //=> true - * f(101); //=> false - */ - var both = _curry2(function both(f, g) { - return function _both() { - return f.apply(this, arguments) && g.apply(this, arguments); - }; - }); + case "BinaryExpression": + return BinaryPrecedence[node.operator]; - /** - * Makes a comparator function out of a function that reports whether the first - * element is less than the second. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig (a, b -> Boolean) -> (a, b -> Number) - * @param {Function} pred A predicate function of arity two. - * @return {Function} A Function :: a -> b -> Int that returns `-1` if a < b, `1` if b < a, otherwise `0`. - * @example - * - * var cmp = R.comparator((a, b) => a.age < b.age); - * var people = [ - * // ... - * ]; - * R.sort(cmp, people); - */ - var comparator = _curry1(function comparator(pred) { - return function (a, b) { - return pred(a, b) ? -1 : pred(b, a) ? 1 : 0; - }; - }); + case "CallExpression": + return Precedence.Call; + case "NewExpression": + return node.arguments.length === 0 ? Precedence.New : Precedence.Member; + case "UpdateExpression": + return node.isPrefix ? Precedence.Prefix : Precedence.Postfix; + case "UnaryExpression": + return Precedence.Prefix; + } + } - /** - * Returns a function, `fn`, which encapsulates if/else-if/else logic. - * `R.cond` takes a list of [predicate, transform] pairs. All of the arguments - * to `fn` are applied to each of the predicates in turn until one returns a - * "truthy" value, at which point `fn` returns the result of applying its - * arguments to the corresponding transformer. If none of the predicates - * matches, `fn` returns undefined. - * - * @func - * @memberOf R - * @since v0.6.0 - * @category Logic - * @sig [[(*... -> Boolean),(*... -> *)]] -> (*... -> *) - * @param {Array} pairs - * @return {Function} - * @example - * - * var fn = R.cond([ - * [R.equals(0), R.always('water freezes at 0°C')], - * [R.equals(100), R.always('water boils at 100°C')], - * [R.T, temp => 'nothing special happens at ' + temp + '°C'] - * ]); - * fn(0); //=> 'water freezes at 0°C' - * fn(50); //=> 'nothing special happens at 50°C' - * fn(100); //=> 'water boils at 100°C' - */ - var cond = _curry1(function cond(pairs) { - return function () { - var idx = 0; - while (idx < pairs.length) { - if (pairs[idx][0].apply(this, arguments)) { - return pairs[idx][1].apply(this, arguments); - } - idx += 1; - } - }; - }); + function escapeStringLiteral(stringValue) { + var result = ""; + var nSingle = 0, + nDouble = 0; + for (var i = 0, l = stringValue.length; i < l; ++i) { + var ch = stringValue[i]; + if (ch === "\"") { + ++nDouble; + } else if (ch === "'") { + ++nSingle; + } + } + var delim = nDouble > nSingle ? "'" : "\""; + result += delim; + for (var i = 0; i < stringValue.length; i++) { + var ch = stringValue.charAt(i); + switch (ch) { + case delim: + result += "\\" + delim; + break; + case "\b": + result += "\\b"; + break; + case "\t": + result += "\\t"; + break; + case "\n": + result += "\\n"; + break; + case "\u000b": + result += "\\v"; + break; + case "\f": + result += "\\f"; + break; + case "\r": + result += "\\r"; + break; + case "\\": + result += "\\\\"; + break; + case "\u2028": + result += "\\u2028"; + break; + case "\u2029": + result += "\\u2029"; + break; + default: + result += ch; + break; + } + } + result += delim; + return result; + } - /** - * Counts the elements of a list according to how many match each value of a - * key generated by the supplied function. Returns an object mapping the keys - * produced by `fn` to the number of occurrences in the list. Note that all - * keys are coerced to strings because of how JavaScript objects work. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig (a -> String) -> [a] -> {*} - * @param {Function} fn The function used to map values to keys. - * @param {Array} list The list to count elements from. - * @return {Object} An object mapping keys to number of occurrences in the list. - * @example - * - * var numbers = [1.0, 1.1, 1.2, 2.0, 3.0, 2.2]; - * var letters = R.split('', 'abcABCaaaBBc'); - * R.countBy(Math.floor)(numbers); //=> {'1': 3, '2': 2, '3': 1} - * R.countBy(R.toLower)(letters); //=> {'a': 5, 'b': 4, 'c': 3} - */ - var countBy = _curry2(function countBy(fn, list) { - var counts = {}; - var len = list.length; - var idx = 0; - while (idx < len) { - var key = fn(list[idx]); - counts[key] = (_has(key, counts) ? counts[key] : 0) + 1; - idx += 1; - } - return counts; - }); + var CodeRep = exports.CodeRep = function () { + function CodeRep() { + _classCallCheck(this, CodeRep); - /** - * Returns a curried equivalent of the provided function, with the specified - * arity. The curried function has two unusual capabilities. First, its - * arguments needn't be provided one at a time. If `g` is `R.curryN(3, f)`, the - * following are equivalent: - * - * - `g(1)(2)(3)` - * - `g(1)(2, 3)` - * - `g(1, 2)(3)` - * - `g(1, 2, 3)` - * - * Secondly, the special placeholder value `R.__` may be used to specify - * "gaps", allowing partial application of any combination of arguments, - * regardless of their positions. If `g` is as above and `_` is `R.__`, the - * following are equivalent: - * - * - `g(1, 2, 3)` - * - `g(_, 2, 3)(1)` - * - `g(_, _, 3)(1)(2)` - * - `g(_, _, 3)(1, 2)` - * - `g(_, 2)(1)(3)` - * - `g(_, 2)(1, 3)` - * - `g(_, 2)(_, 3)(1)` - * - * @func - * @memberOf R - * @since v0.5.0 - * @category Function - * @sig Number -> (* -> a) -> (* -> a) - * @param {Number} length The arity for the returned function. - * @param {Function} fn The function to curry. - * @return {Function} A new, curried function. - * @see R.curry - * @example - * - * var sumArgs = (...args) => R.sum(args); - * - * var curriedAddFourNumbers = R.curryN(4, sumArgs); - * var f = curriedAddFourNumbers(1, 2); - * var g = f(3); - * g(4); //=> 10 - */ - var curryN = _curry2(function curryN(length, fn) { - if (length === 1) { - return _curry1(fn); - } - return _arity(length, _curryN(length, [], fn)); - }); + this.containsIn = false; + this.containsGroup = false; + // restricted lookaheads: {, function, class, let, let [ + this.startsWithCurly = false; + this.startsWithFunctionOrClass = false; + this.startsWithLet = false; + this.startsWithLetSquareBracket = false; + this.endsWithMissingElse = false; + } - /** - * Decrements its argument. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Math - * @sig Number -> Number - * @param {Number} n - * @return {Number} - * @see R.inc - * @example - * - * R.dec(42); //=> 41 - */ - var dec = add(-1); + _createClass(CodeRep, [{ + key: "forEach", + value: function forEach(f) { + // Call a function on every CodeRep represented by this node. Always calls f on a node and then its children, so if you're careful you can modify a node's children online. + f(this); + } + }]); - /** - * Returns the second argument if it is not `null`, `undefined` or `NaN` - * otherwise the first argument is returned. - * - * @func - * @memberOf R - * @since v0.10.0 - * @category Logic - * @sig a -> b -> a | b - * @param {a} val The default value. - * @param {b} val The value to return if it is not null or undefined - * @return {*} The the second value or the default value - * @example - * - * var defaultTo42 = R.defaultTo(42); - * - * defaultTo42(null); //=> 42 - * defaultTo42(undefined); //=> 42 - * defaultTo42('Ramda'); //=> 'Ramda' - * defaultTo42(parseInt('string')); //=> 42 - */ - var defaultTo = _curry2(function defaultTo(d, v) { - return v == null || v !== v ? d : v; - }); + return CodeRep; + }(); - /** - * Finds the set (i.e. no duplicates) of all elements in the first list not - * contained in the second list. Duplication is determined according to the - * value returned by applying the supplied predicate to two list elements. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig (a -> a -> Boolean) -> [*] -> [*] -> [*] - * @param {Function} pred A predicate used to test whether two items are equal. - * @param {Array} list1 The first list. - * @param {Array} list2 The second list. - * @return {Array} The elements in `list1` that are not in `list2`. - * @see R.difference - * @example - * - * function cmp(x, y) => x.a === y.a; - * var l1 = [{a: 1}, {a: 2}, {a: 3}]; - * var l2 = [{a: 3}, {a: 4}]; - * R.differenceWith(cmp, l1, l2); //=> [{a: 1}, {a: 2}] - */ - var differenceWith = _curry3(function differenceWith(pred, first, second) { - var out = []; - var idx = 0; - var firstLen = first.length; - while (idx < firstLen) { - if (!_containsWith(pred, first[idx], second) && !_containsWith(pred, first[idx], out)) { - out.push(first[idx]); - } - idx += 1; - } - return out; - }); + var Empty = exports.Empty = function (_CodeRep) { + _inherits(Empty, _CodeRep); - /** - * Returns a new object that does not contain a `prop` property. - * - * @func - * @memberOf R - * @since v0.10.0 - * @category Object - * @sig String -> {k: v} -> {k: v} - * @param {String} prop the name of the property to dissociate - * @param {Object} obj the object to clone - * @return {Object} a new object similar to the original but without the specified property - * @see R.assoc - * @example - * - * R.dissoc('b', {a: 1, b: 2, c: 3}); //=> {a: 1, c: 3} - */ - var dissoc = _curry2(function dissoc(prop, obj) { - var result = {}; - for (var p in obj) { - if (p !== prop) { - result[p] = obj[p]; - } - } - return result; - }); + function Empty() { + _classCallCheck(this, Empty); - /** - * Makes a shallow clone of an object, omitting the property at the given path. - * Note that this copies and flattens prototype properties onto the new object - * as well. All non-primitive properties are copied by reference. - * - * @func - * @memberOf R - * @since v0.11.0 - * @category Object - * @sig [String] -> {k: v} -> {k: v} - * @param {Array} path the path to set - * @param {Object} obj the object to clone - * @return {Object} a new object without the property at path - * @see R.assocPath - * @example - * - * R.dissocPath(['a', 'b', 'c'], {a: {b: {c: 42}}}); //=> {a: {b: {}}} - */ - var dissocPath = _curry2(function dissocPath(path, obj) { - switch (path.length) { - case 0: - return obj; - case 1: - return dissoc(path[0], obj); - default: - var head = path[0]; - var tail = _slice(path, 1); - return obj[head] == null ? obj : assoc(head, dissocPath(tail, obj[head]), obj); - } - }); + return _possibleConstructorReturn(this, Object.getPrototypeOf(Empty).call(this)); + } - /** - * Divides two numbers. Equivalent to `a / b`. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Math - * @sig Number -> Number -> Number - * @param {Number} a The first value. - * @param {Number} b The second value. - * @return {Number} The result of `a / b`. - * @see R.multiply - * @example - * - * R.divide(71, 100); //=> 0.71 - * - * var half = R.divide(R.__, 2); - * half(42); //=> 21 - * - * var reciprocal = R.divide(1); - * reciprocal(4); //=> 0.25 - */ - var divide = _curry2(function divide(a, b) { - return a / b; - }); + _createClass(Empty, [{ + key: "emit", + value: function emit() {} + }]); - /** - * Returns a new list containing the last `n` elements of a given list, passing - * each value to the supplied predicate function, skipping elements while the - * predicate function returns `true`. The predicate function is passed one - * argument: *(value)*. - * - * Dispatches to the `dropWhile` method of the second argument, if present. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category List - * @sig (a -> Boolean) -> [a] -> [a] - * @param {Function} fn The function called per iteration. - * @param {Array} list The collection to iterate over. - * @return {Array} A new array. - * @see R.takeWhile, R.transduce, R.addIndex - * @example - * - * var lteTwo = x => x <= 2; - * - * R.dropWhile(lteTwo, [1, 2, 3, 4, 3, 2, 1]); //=> [3, 4, 3, 2, 1] - */ - var dropWhile = _curry2(_dispatchable('dropWhile', _xdropWhile, function dropWhile(pred, list) { - var idx = 0; - var len = list.length; - while (idx < len && pred(list[idx])) { - idx += 1; - } - return _slice(list, idx); - })); + return Empty; + }(CodeRep); - /** - * A function wrapping calls to the two functions in an `||` operation, - * returning the result of the first function if it is truth-y and the result - * of the second function otherwise. Note that this is short-circuited, - * meaning that the second function will not be invoked if the first returns a - * truth-y value. - * - * @func - * @memberOf R - * @since v0.12.0 - * @category Logic - * @sig (*... -> Boolean) -> (*... -> Boolean) -> (*... -> Boolean) - * @param {Function} f a predicate - * @param {Function} g another predicate - * @return {Function} a function that applies its arguments to `f` and `g` and `||`s their outputs together. - * @see R.or - * @example - * - * var gt10 = x => x > 10; - * var even = x => x % 2 === 0; - * var f = R.either(gt10, even); - * f(101); //=> true - * f(8); //=> true - */ - var either = _curry2(function either(f, g) { - return function _either() { - return f.apply(this, arguments) || g.apply(this, arguments); - }; - }); + var Token = exports.Token = function (_CodeRep2) { + _inherits(Token, _CodeRep2); - /** - * Returns the empty value of its argument's type. Ramda defines the empty - * value of Array (`[]`), Object (`{}`), String (`''`), and Arguments. Other - * types are supported if they define `.empty` and/or - * `.prototype.empty`. - * - * Dispatches to the `empty` method of the first argument, if present. - * - * @func - * @memberOf R - * @since v0.3.0 - * @category Function - * @sig a -> a - * @param {*} x - * @return {*} - * @example - * - * R.empty(Just(42)); //=> Nothing() - * R.empty([1, 2, 3]); //=> [] - * R.empty('unicorns'); //=> '' - * R.empty({x: 1, y: 2}); //=> {} - */ - // else - var empty = _curry1(function empty(x) { - return x != null && typeof x.empty === 'function' ? x.empty() : x != null && x.constructor != null && typeof x.constructor.empty === 'function' ? x.constructor.empty() : _isArray(x) ? [] : _isString(x) ? '' : _isObject(x) ? {} : _isArguments(x) ? function () { - return arguments; - }() : // else - void 0; - }); + function Token(token) { + _classCallCheck(this, Token); - /** - * Creates a new object by recursively evolving a shallow copy of `object`, - * according to the `transformation` functions. All non-primitive properties - * are copied by reference. - * - * A `transformation` function will not be invoked if its corresponding key - * does not exist in the evolved object. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Object - * @sig {k: (v -> v)} -> {k: v} -> {k: v} - * @param {Object} transformations The object specifying transformation functions to apply - * to the object. - * @param {Object} object The object to be transformed. - * @return {Object} The transformed object. - * @example - * - * var tomato = {firstName: ' Tomato ', data: {elapsed: 100, remaining: 1400}, id:123}; - * var transformations = { - * firstName: R.trim, - * lastName: R.trim, // Will not get invoked. - * data: {elapsed: R.add(1), remaining: R.add(-1)} - * }; - * R.evolve(transformations, tomato); //=> {firstName: 'Tomato', data: {elapsed: 101, remaining: 1399}, id:123} - */ - var evolve = _curry2(function evolve(transformations, object) { - var result = {}; - var transformation, key, type; - for (key in object) { - transformation = transformations[key]; - type = typeof transformation; - result[key] = type === 'function' ? transformation(object[key]) : type === 'object' ? evolve(transformations[key], object[key]) : object[key]; - } - return result; - }); + var _this2 = _possibleConstructorReturn(this, Object.getPrototypeOf(Token).call(this)); - /** - * Returns the first element of the list which matches the predicate, or - * `undefined` if no element matches. - * - * Dispatches to the `find` method of the second argument, if present. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig (a -> Boolean) -> [a] -> a | undefined - * @param {Function} fn The predicate function used to determine if the element is the - * desired one. - * @param {Array} list The array to consider. - * @return {Object} The element found, or `undefined`. - * @see R.transduce - * @example - * - * var xs = [{a: 1}, {a: 2}, {a: 3}]; - * R.find(R.propEq('a', 2))(xs); //=> {a: 2} - * R.find(R.propEq('a', 4))(xs); //=> undefined - */ - var find = _curry2(_dispatchable('find', _xfind, function find(fn, list) { - var idx = 0; - var len = list.length; - while (idx < len) { - if (fn(list[idx])) { - return list[idx]; - } - idx += 1; - } - })); + _this2.token = token; + return _this2; + } - /** - * Returns the index of the first element of the list which matches the - * predicate, or `-1` if no element matches. - * - * Dispatches to the `findIndex` method of the second argument, if present. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since v0.1.1 - * @category List - * @sig (a -> Boolean) -> [a] -> Number - * @param {Function} fn The predicate function used to determine if the element is the - * desired one. - * @param {Array} list The array to consider. - * @return {Number} The index of the element found, or `-1`. - * @see R.transduce - * @example - * - * var xs = [{a: 1}, {a: 2}, {a: 3}]; - * R.findIndex(R.propEq('a', 2))(xs); //=> 1 - * R.findIndex(R.propEq('a', 4))(xs); //=> -1 - */ - var findIndex = _curry2(_dispatchable('findIndex', _xfindIndex, function findIndex(fn, list) { - var idx = 0; - var len = list.length; - while (idx < len) { - if (fn(list[idx])) { - return idx; - } - idx += 1; - } - return -1; - })); + _createClass(Token, [{ + key: "emit", + value: function emit(ts) { + ts.put(this.token); + } + }]); - /** - * Returns the last element of the list which matches the predicate, or - * `undefined` if no element matches. - * - * Dispatches to the `findLast` method of the second argument, if present. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since v0.1.1 - * @category List - * @sig (a -> Boolean) -> [a] -> a | undefined - * @param {Function} fn The predicate function used to determine if the element is the - * desired one. - * @param {Array} list The array to consider. - * @return {Object} The element found, or `undefined`. - * @see R.transduce - * @example - * - * var xs = [{a: 1, b: 0}, {a:1, b: 1}]; - * R.findLast(R.propEq('a', 1))(xs); //=> {a: 1, b: 1} - * R.findLast(R.propEq('a', 4))(xs); //=> undefined - */ - var findLast = _curry2(_dispatchable('findLast', _xfindLast, function findLast(fn, list) { - var idx = list.length - 1; - while (idx >= 0) { - if (fn(list[idx])) { - return list[idx]; - } - idx -= 1; - } - })); + return Token; + }(CodeRep); - /** - * Returns the index of the last element of the list which matches the - * predicate, or `-1` if no element matches. - * - * Dispatches to the `findLastIndex` method of the second argument, if present. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since v0.1.1 - * @category List - * @sig (a -> Boolean) -> [a] -> Number - * @param {Function} fn The predicate function used to determine if the element is the - * desired one. - * @param {Array} list The array to consider. - * @return {Number} The index of the element found, or `-1`. - * @see R.transduce - * @example - * - * var xs = [{a: 1, b: 0}, {a:1, b: 1}]; - * R.findLastIndex(R.propEq('a', 1))(xs); //=> 1 - * R.findLastIndex(R.propEq('a', 4))(xs); //=> -1 - */ - var findLastIndex = _curry2(_dispatchable('findLastIndex', _xfindLastIndex, function findLastIndex(fn, list) { - var idx = list.length - 1; - while (idx >= 0) { - if (fn(list[idx])) { - return idx; - } - idx -= 1; - } - return -1; - })); + var NumberCodeRep = exports.NumberCodeRep = function (_CodeRep3) { + _inherits(NumberCodeRep, _CodeRep3); - /** - * Iterate over an input `list`, calling a provided function `fn` for each - * element in the list. - * - * `fn` receives one argument: *(value)*. - * - * Note: `R.forEach` does not skip deleted or unassigned indices (sparse - * arrays), unlike the native `Array.prototype.forEach` method. For more - * details on this behavior, see: - * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach#Description - * - * Also note that, unlike `Array.prototype.forEach`, Ramda's `forEach` returns - * the original array. In some libraries this function is named `each`. - * - * Dispatches to the `forEach` method of the second argument, if present. - * - * @func - * @memberOf R - * @since v0.1.1 - * @category List - * @sig (a -> *) -> [a] -> [a] - * @param {Function} fn The function to invoke. Receives one argument, `value`. - * @param {Array} list The list to iterate over. - * @return {Array} The original list. - * @see R.addIndex - * @example - * - * var printXPlusFive = x => console.log(x + 5); - * R.forEach(printXPlusFive, [1, 2, 3]); //=> [1, 2, 3] - * //-> 6 - * //-> 7 - * //-> 8 - */ - var forEach = _curry2(_checkForMethod('forEach', function forEach(fn, list) { - var len = list.length; - var idx = 0; - while (idx < len) { - fn(list[idx]); - idx += 1; - } - return list; - })); + function NumberCodeRep(number) { + _classCallCheck(this, NumberCodeRep); - /** - * Creates a new object out of a list key-value pairs. - * - * @func - * @memberOf R - * @since v0.3.0 - * @category List - * @sig [[k,v]] -> {k: v} - * @param {Array} pairs An array of two-element arrays that will be the keys and values of the output object. - * @return {Object} The object made by pairing up `keys` and `values`. - * @see R.toPairs, R.pair - * @example - * - * R.fromPairs([['a', 1], ['b', 2], ['c', 3]]); //=> {a: 1, b: 2, c: 3} - */ - var fromPairs = _curry1(function fromPairs(pairs) { - var idx = 0; - var len = pairs.length; - var out = {}; - while (idx < len) { - if (_isArray(pairs[idx]) && pairs[idx].length) { - out[pairs[idx][0]] = pairs[idx][1]; - } - idx += 1; - } - return out; - }); + var _this3 = _possibleConstructorReturn(this, Object.getPrototypeOf(NumberCodeRep).call(this)); - /** - * Returns `true` if the first argument is greater than the second; `false` - * otherwise. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig Ord a => a -> a -> Boolean - * @param {*} a - * @param {*} b - * @return {Boolean} - * @see R.lt - * @example - * - * R.gt(2, 1); //=> true - * R.gt(2, 2); //=> false - * R.gt(2, 3); //=> false - * R.gt('a', 'z'); //=> false - * R.gt('z', 'a'); //=> true - */ - var gt = _curry2(function gt(a, b) { - return a > b; - }); + _this3.number = number; + return _this3; + } - /** - * Returns `true` if the first argument is greater than or equal to the second; - * `false` otherwise. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig Ord a => a -> a -> Boolean - * @param {Number} a - * @param {Number} b - * @return {Boolean} - * @see R.lte - * @example - * - * R.gte(2, 1); //=> true - * R.gte(2, 2); //=> true - * R.gte(2, 3); //=> false - * R.gte('a', 'z'); //=> false - * R.gte('z', 'a'); //=> true - */ - var gte = _curry2(function gte(a, b) { - return a >= b; - }); + _createClass(NumberCodeRep, [{ + key: "emit", + value: function emit(ts) { + ts.putNumber(this.number); + } + }]); - /** - * Returns whether or not an object has an own property with the specified name - * - * @func - * @memberOf R - * @since v0.7.0 - * @category Object - * @sig s -> {s: x} -> Boolean - * @param {String} prop The name of the property to check for. - * @param {Object} obj The object to query. - * @return {Boolean} Whether the property exists. - * @example - * - * var hasName = R.has('name'); - * hasName({name: 'alice'}); //=> true - * hasName({name: 'bob'}); //=> true - * hasName({}); //=> false - * - * var point = {x: 0, y: 0}; - * var pointHas = R.has(R.__, point); - * pointHas('x'); //=> true - * pointHas('y'); //=> true - * pointHas('z'); //=> false - */ - var has = _curry2(_has); + return NumberCodeRep; + }(CodeRep); - /** - * Returns whether or not an object or its prototype chain has a property with - * the specified name - * - * @func - * @memberOf R - * @since v0.7.0 - * @category Object - * @sig s -> {s: x} -> Boolean - * @param {String} prop The name of the property to check for. - * @param {Object} obj The object to query. - * @return {Boolean} Whether the property exists. - * @example - * - * function Rectangle(width, height) { - * this.width = width; - * this.height = height; - * } - * Rectangle.prototype.area = function() { - * return this.width * this.height; - * }; - * - * var square = new Rectangle(2, 2); - * R.hasIn('width', square); //=> true - * R.hasIn('area', square); //=> true - */ - var hasIn = _curry2(function hasIn(prop, obj) { - return prop in obj; - }); + var Paren = exports.Paren = function (_CodeRep4) { + _inherits(Paren, _CodeRep4); - /** - * Returns true if its arguments are identical, false otherwise. Values are - * identical if they reference the same memory. `NaN` is identical to `NaN`; - * `0` and `-0` are not identical. - * - * @func - * @memberOf R - * @since v0.15.0 - * @category Relation - * @sig a -> a -> Boolean - * @param {*} a - * @param {*} b - * @return {Boolean} - * @example - * - * var o = {}; - * R.identical(o, o); //=> true - * R.identical(1, 1); //=> true - * R.identical(1, '1'); //=> false - * R.identical([], []); //=> false - * R.identical(0, -0); //=> false - * R.identical(NaN, NaN); //=> true - */ - // SameValue algorithm - // Steps 1-5, 7-10 - // Steps 6.b-6.e: +0 != -0 - // Step 6.a: NaN == NaN - var identical = _curry2(function identical(a, b) { - // SameValue algorithm - if (a === b) { - // Steps 1-5, 7-10 - // Steps 6.b-6.e: +0 != -0 - return a !== 0 || 1 / a === 1 / b; - } else { - // Step 6.a: NaN == NaN - return a !== a && b !== b; - } - }); + function Paren(expr) { + _classCallCheck(this, Paren); - /** - * A function that does nothing but return the parameter supplied to it. Good - * as a default or placeholder function. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig a -> a - * @param {*} x The value to return. - * @return {*} The input value, `x`. - * @example - * - * R.identity(1); //=> 1 - * - * var obj = {}; - * R.identity(obj) === obj; //=> true - */ - var identity = _curry1(_identity); + var _this4 = _possibleConstructorReturn(this, Object.getPrototypeOf(Paren).call(this)); - /** - * Creates a function that will process either the `onTrue` or the `onFalse` - * function depending upon the result of the `condition` predicate. - * - * @func - * @memberOf R - * @since v0.8.0 - * @category Logic - * @sig (*... -> Boolean) -> (*... -> *) -> (*... -> *) -> (*... -> *) - * @param {Function} condition A predicate function - * @param {Function} onTrue A function to invoke when the `condition` evaluates to a truthy value. - * @param {Function} onFalse A function to invoke when the `condition` evaluates to a falsy value. - * @return {Function} A new unary function that will process either the `onTrue` or the `onFalse` - * function depending upon the result of the `condition` predicate. - * @see R.unless, R.when - * @example - * - * var incCount = R.ifElse( - * R.has('count'), - * R.over(R.lensProp('count'), R.inc), - * R.assoc('count', 1) - * ); - * incCount({}); //=> { count: 1 } - * incCount({ count: 1 }); //=> { count: 2 } - */ - var ifElse = _curry3(function ifElse(condition, onTrue, onFalse) { - return curryN(Math.max(condition.length, onTrue.length, onFalse.length), function _ifElse() { - return condition.apply(this, arguments) ? onTrue.apply(this, arguments) : onFalse.apply(this, arguments); - }); - }); + _this4.expr = expr; + return _this4; + } - /** - * Increments its argument. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Math - * @sig Number -> Number - * @param {Number} n - * @return {Number} - * @see R.dec - * @example - * - * R.inc(42); //=> 43 - */ - var inc = add(1); + _createClass(Paren, [{ + key: "emit", + value: function emit(ts) { + ts.put("("); + this.expr.emit(ts, false); + ts.put(")"); + } + }, { + key: "forEach", + value: function forEach(f) { + f(this); + this.expr.forEach(f); + } + }]); - /** - * Inserts the supplied element into the list, at index `index`. _Note that - * this is not destructive_: it returns a copy of the list with the changes. - * No lists have been harmed in the application of this function. - * - * @func - * @memberOf R - * @since v0.2.2 - * @category List - * @sig Number -> a -> [a] -> [a] - * @param {Number} index The position to insert the element - * @param {*} elt The element to insert into the Array - * @param {Array} list The list to insert into - * @return {Array} A new Array with `elt` inserted at `index`. - * @example - * - * R.insert(2, 'x', [1,2,3,4]); //=> [1,2,'x',3,4] - */ - var insert = _curry3(function insert(idx, elt, list) { - idx = idx < list.length && idx >= 0 ? idx : list.length; - var result = _slice(list); - result.splice(idx, 0, elt); - return result; - }); + return Paren; + }(CodeRep); - /** - * Inserts the sub-list into the list, at index `index`. _Note that this is not - * destructive_: it returns a copy of the list with the changes. - * No lists have been harmed in the application of this function. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category List - * @sig Number -> [a] -> [a] -> [a] - * @param {Number} index The position to insert the sub-list - * @param {Array} elts The sub-list to insert into the Array - * @param {Array} list The list to insert the sub-list into - * @return {Array} A new Array with `elts` inserted starting at `index`. - * @example - * - * R.insertAll(2, ['x','y','z'], [1,2,3,4]); //=> [1,2,'x','y','z',3,4] - */ - var insertAll = _curry3(function insertAll(idx, elts, list) { - idx = idx < list.length && idx >= 0 ? idx : list.length; - return _concat(_concat(_slice(list, 0, idx), elts), _slice(list, idx)); - }); + var Bracket = exports.Bracket = function (_CodeRep5) { + _inherits(Bracket, _CodeRep5); - /** - * Creates a new list with the separator interposed between elements. - * - * Dispatches to the `intersperse` method of the second argument, if present. - * - * @func - * @memberOf R - * @since v0.14.0 - * @category List - * @sig a -> [a] -> [a] - * @param {*} separator The element to add to the list. - * @param {Array} list The list to be interposed. - * @return {Array} The new list. - * @example - * - * R.intersperse('n', ['ba', 'a', 'a']); //=> ['ba', 'n', 'a', 'n', 'a'] - */ - var intersperse = _curry2(_checkForMethod('intersperse', function intersperse(separator, list) { - var out = []; - var idx = 0; - var length = list.length; - while (idx < length) { - if (idx === length - 1) { - out.push(list[idx]); - } else { - out.push(list[idx], separator); - } - idx += 1; - } - return out; - })); + function Bracket(expr) { + _classCallCheck(this, Bracket); - /** - * See if an object (`val`) is an instance of the supplied constructor. This - * function will check up the inheritance chain, if any. - * - * @func - * @memberOf R - * @since v0.3.0 - * @category Type - * @sig (* -> {*}) -> a -> Boolean - * @param {Object} ctor A constructor - * @param {*} val The value to test - * @return {Boolean} - * @example - * - * R.is(Object, {}); //=> true - * R.is(Number, 1); //=> true - * R.is(Object, 1); //=> false - * R.is(String, 's'); //=> true - * R.is(String, new String('')); //=> true - * R.is(Object, new String('')); //=> true - * R.is(Object, 's'); //=> false - * R.is(Number, {}); //=> false - */ - var is = _curry2(function is(Ctor, val) { - return val != null && val.constructor === Ctor || val instanceof Ctor; - }); + var _this5 = _possibleConstructorReturn(this, Object.getPrototypeOf(Bracket).call(this)); - /** - * Tests whether or not an object is similar to an array. - * - * @func - * @memberOf R - * @since v0.5.0 - * @category Type - * @category List - * @sig * -> Boolean - * @param {*} x The object to test. - * @return {Boolean} `true` if `x` has a numeric length property and extreme indices defined; `false` otherwise. - * @example - * - * R.isArrayLike([]); //=> true - * R.isArrayLike(true); //=> false - * R.isArrayLike({}); //=> false - * R.isArrayLike({length: 10}); //=> false - * R.isArrayLike({0: 'zero', 9: 'nine', length: 10}); //=> true - */ - var isArrayLike = _curry1(function isArrayLike(x) { - if (_isArray(x)) { - return true; - } - if (!x) { - return false; - } - if (typeof x !== 'object') { - return false; - } - if (x instanceof String) { - return false; - } - if (x.nodeType === 1) { - return !!x.length; - } - if (x.length === 0) { - return true; - } - if (x.length > 0) { - return x.hasOwnProperty(0) && x.hasOwnProperty(x.length - 1); - } - return false; - }); + _this5.expr = expr; + return _this5; + } - /** - * Checks if the input value is `null` or `undefined`. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Type - * @sig * -> Boolean - * @param {*} x The value to test. - * @return {Boolean} `true` if `x` is `undefined` or `null`, otherwise `false`. - * @example - * - * R.isNil(null); //=> true - * R.isNil(undefined); //=> true - * R.isNil(0); //=> false - * R.isNil([]); //=> false - */ - var isNil = _curry1(function isNil(x) { - return x == null; - }); + _createClass(Bracket, [{ + key: "emit", + value: function emit(ts) { + ts.put("["); + this.expr.emit(ts, false); + ts.put("]"); + } + }, { + key: "forEach", + value: function forEach(f) { + f(this); + this.expr.forEach(f); + } + }]); - /** - * Returns a list containing the names of all the enumerable own properties of - * the supplied object. - * Note that the order of the output array is not guaranteed to be consistent - * across different JS platforms. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Object - * @sig {k: v} -> [k] - * @param {Object} obj The object to extract properties from - * @return {Array} An array of the object's own properties. - * @example - * - * R.keys({a: 1, b: 2, c: 3}); //=> ['a', 'b', 'c'] - */ - // cover IE < 9 keys issues - // Safari bug - var keys = function () { - // cover IE < 9 keys issues - var hasEnumBug = !{ toString: null }.propertyIsEnumerable('toString'); - var nonEnumerableProps = [ - 'constructor', - 'valueOf', - 'isPrototypeOf', - 'toString', - 'propertyIsEnumerable', - 'hasOwnProperty', - 'toLocaleString' - ]; - // Safari bug - var hasArgsEnumBug = function () { - 'use strict'; - return arguments.propertyIsEnumerable('length'); - }(); - var contains = function contains(list, item) { - var idx = 0; - while (idx < list.length) { - if (list[idx] === item) { - return true; - } - idx += 1; - } - return false; - }; - return typeof Object.keys === 'function' && !hasArgsEnumBug ? _curry1(function keys(obj) { - return Object(obj) !== obj ? [] : Object.keys(obj); - }) : _curry1(function keys(obj) { - if (Object(obj) !== obj) { - return []; - } - var prop, nIdx; - var ks = []; - var checkArgsLength = hasArgsEnumBug && _isArguments(obj); - for (prop in obj) { - if (_has(prop, obj) && (!checkArgsLength || prop !== 'length')) { - ks[ks.length] = prop; - } - } - if (hasEnumBug) { - nIdx = nonEnumerableProps.length - 1; - while (nIdx >= 0) { - prop = nonEnumerableProps[nIdx]; - if (_has(prop, obj) && !contains(ks, prop)) { - ks[ks.length] = prop; - } - nIdx -= 1; - } - } - return ks; - }); - }(); + return Bracket; + }(CodeRep); - /** - * Returns a list containing the names of all the properties of the supplied - * object, including prototype properties. - * Note that the order of the output array is not guaranteed to be consistent - * across different JS platforms. - * - * @func - * @memberOf R - * @since v0.2.0 - * @category Object - * @sig {k: v} -> [k] - * @param {Object} obj The object to extract properties from - * @return {Array} An array of the object's own and prototype properties. - * @example - * - * var F = function() { this.x = 'X'; }; - * F.prototype.y = 'Y'; - * var f = new F(); - * R.keysIn(f); //=> ['x', 'y'] - */ - var keysIn = _curry1(function keysIn(obj) { - var prop; - var ks = []; - for (prop in obj) { - ks[ks.length] = prop; - } - return ks; - }); + var Brace = exports.Brace = function (_CodeRep6) { + _inherits(Brace, _CodeRep6); - /** - * Returns the number of elements in the array by returning `list.length`. - * - * @func - * @memberOf R - * @since v0.3.0 - * @category List - * @sig [a] -> Number - * @param {Array} list The array to inspect. - * @return {Number} The length of the array. - * @example - * - * R.length([]); //=> 0 - * R.length([1, 2, 3]); //=> 3 - */ - var length = _curry1(function length(list) { - return list != null && is(Number, list.length) ? list.length : NaN; - }); + function Brace(expr) { + _classCallCheck(this, Brace); - /** - * Returns `true` if the first argument is less than the second; `false` - * otherwise. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig Ord a => a -> a -> Boolean - * @param {*} a - * @param {*} b - * @return {Boolean} - * @see R.gt - * @example - * - * R.lt(2, 1); //=> false - * R.lt(2, 2); //=> false - * R.lt(2, 3); //=> true - * R.lt('a', 'z'); //=> true - * R.lt('z', 'a'); //=> false - */ - var lt = _curry2(function lt(a, b) { - return a < b; - }); + var _this6 = _possibleConstructorReturn(this, Object.getPrototypeOf(Brace).call(this)); - /** - * Returns `true` if the first argument is less than or equal to the second; - * `false` otherwise. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig Ord a => a -> a -> Boolean - * @param {Number} a - * @param {Number} b - * @return {Boolean} - * @see R.gte - * @example - * - * R.lte(2, 1); //=> false - * R.lte(2, 2); //=> true - * R.lte(2, 3); //=> true - * R.lte('a', 'z'); //=> true - * R.lte('z', 'a'); //=> false - */ - var lte = _curry2(function lte(a, b) { - return a <= b; - }); + _this6.expr = expr; + return _this6; + } - /** - * The mapAccum function behaves like a combination of map and reduce; it - * applies a function to each element of a list, passing an accumulating - * parameter from left to right, and returning a final value of this - * accumulator together with the new list. - * - * The iterator function receives two arguments, *acc* and *value*, and should - * return a tuple *[acc, value]*. - * - * @func - * @memberOf R - * @since v0.10.0 - * @category List - * @sig (acc -> x -> (acc, y)) -> acc -> [x] -> (acc, [y]) - * @param {Function} fn The function to be called on every element of the input `list`. - * @param {*} acc The accumulator value. - * @param {Array} list The list to iterate over. - * @return {*} The final, accumulated value. - * @see R.addIndex - * @example - * - * var digits = ['1', '2', '3', '4']; - * var append = (a, b) => [a + b, a + b]; - * - * R.mapAccum(append, 0, digits); //=> ['01234', ['01', '012', '0123', '01234']] - */ - var mapAccum = _curry3(function mapAccum(fn, acc, list) { - var idx = 0; - var len = list.length; - var result = []; - var tuple = [acc]; - while (idx < len) { - tuple = fn(tuple[0], list[idx]); - result[idx] = tuple[1]; - idx += 1; - } - return [ - tuple[0], - result - ]; - }); + _createClass(Brace, [{ + key: "emit", + value: function emit(ts) { + ts.put("{"); + this.expr.emit(ts, false); + ts.put("}"); + } + }, { + key: "forEach", + value: function forEach(f) { + f(this); + this.expr.forEach(f); + } + }]); - /** - * The mapAccumRight function behaves like a combination of map and reduce; it - * applies a function to each element of a list, passing an accumulating - * parameter from right to left, and returning a final value of this - * accumulator together with the new list. - * - * Similar to `mapAccum`, except moves through the input list from the right to - * the left. - * - * The iterator function receives two arguments, *acc* and *value*, and should - * return a tuple *[acc, value]*. - * - * @func - * @memberOf R - * @since v0.10.0 - * @category List - * @sig (acc -> x -> (acc, y)) -> acc -> [x] -> (acc, [y]) - * @param {Function} fn The function to be called on every element of the input `list`. - * @param {*} acc The accumulator value. - * @param {Array} list The list to iterate over. - * @return {*} The final, accumulated value. - * @see R.addIndex - * @example - * - * var digits = ['1', '2', '3', '4']; - * var append = (a, b) => [a + b, a + b]; - * - * R.mapAccumRight(append, 0, digits); //=> ['04321', ['04321', '0432', '043', '04']] - */ - var mapAccumRight = _curry3(function mapAccumRight(fn, acc, list) { - var idx = list.length - 1; - var result = []; - var tuple = [acc]; - while (idx >= 0) { - tuple = fn(tuple[0], list[idx]); - result[idx] = tuple[1]; - idx -= 1; - } - return [ - tuple[0], - result - ]; - }); + return Brace; + }(CodeRep); - /** - * Tests a regular expression against a String. Note that this function will - * return an empty array when there are no matches. This differs from - * [`String.prototype.match`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/match) - * which returns `null` when there are no matches. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category String - * @sig RegExp -> String -> [String | Undefined] - * @param {RegExp} rx A regular expression. - * @param {String} str The string to match against - * @return {Array} The list of matches or empty array. - * @see R.test - * @example - * - * R.match(/([a-z]a)/g, 'bananas'); //=> ['ba', 'na', 'na'] - * R.match(/a/, 'b'); //=> [] - * R.match(/a/, null); //=> TypeError: null does not have a method named "match" - */ - var match = _curry2(function match(rx, str) { - return str.match(rx) || []; - }); + var NoIn = exports.NoIn = function (_CodeRep7) { + _inherits(NoIn, _CodeRep7); - /** - * mathMod behaves like the modulo operator should mathematically, unlike the - * `%` operator (and by extension, R.modulo). So while "-17 % 5" is -2, - * mathMod(-17, 5) is 3. mathMod requires Integer arguments, and returns NaN - * when the modulus is zero or negative. - * - * @func - * @memberOf R - * @since v0.3.0 - * @category Math - * @sig Number -> Number -> Number - * @param {Number} m The dividend. - * @param {Number} p the modulus. - * @return {Number} The result of `b mod a`. - * @example - * - * R.mathMod(-17, 5); //=> 3 - * R.mathMod(17, 5); //=> 2 - * R.mathMod(17, -5); //=> NaN - * R.mathMod(17, 0); //=> NaN - * R.mathMod(17.2, 5); //=> NaN - * R.mathMod(17, 5.3); //=> NaN - * - * var clock = R.mathMod(R.__, 12); - * clock(15); //=> 3 - * clock(24); //=> 0 - * - * var seventeenMod = R.mathMod(17); - * seventeenMod(3); //=> 2 - * seventeenMod(4); //=> 1 - * seventeenMod(10); //=> 7 - */ - var mathMod = _curry2(function mathMod(m, p) { - if (!_isInteger(m)) { - return NaN; - } - if (!_isInteger(p) || p < 1) { - return NaN; - } - return (m % p + p) % p; - }); + function NoIn(expr) { + _classCallCheck(this, NoIn); - /** - * Returns the larger of its two arguments. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig Ord a => a -> a -> a - * @param {*} a - * @param {*} b - * @return {*} - * @see R.maxBy, R.min - * @example - * - * R.max(789, 123); //=> 789 - * R.max('a', 'b'); //=> 'b' - */ - var max = _curry2(function max(a, b) { - return b > a ? b : a; - }); + var _this7 = _possibleConstructorReturn(this, Object.getPrototypeOf(NoIn).call(this)); - /** - * Takes a function and two values, and returns whichever value produces the - * larger result when passed to the provided function. - * - * @func - * @memberOf R - * @since v0.8.0 - * @category Relation - * @sig Ord b => (a -> b) -> a -> a -> a - * @param {Function} f - * @param {*} a - * @param {*} b - * @return {*} - * @see R.max, R.minBy - * @example - * - * // square :: Number -> Number - * var square = n => n * n; - * - * R.maxBy(square, -3, 2); //=> -3 - * - * R.reduce(R.maxBy(square), 0, [3, -5, 4, 1, -2]); //=> -5 - * R.reduce(R.maxBy(square), 0, []); //=> 0 - */ - var maxBy = _curry3(function maxBy(f, a, b) { - return f(b) > f(a) ? b : a; - }); + _this7.expr = expr; + return _this7; + } - /** - * Creates a new object with the own properties of the two provided objects. If - * a key exists in both objects, the provided function is applied to the key - * and the values associated with the key in each object, with the result being - * used as the value associated with the key in the returned object. The key - * will be excluded from the returned object if the resulting value is - * `undefined`. - * - * @func - * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category Object - * @sig (String -> a -> a -> a) -> {a} -> {a} -> {a} - * @param {Function} fn - * @param {Object} l - * @param {Object} r - * @return {Object} - * @see R.merge, R.mergeWith - * @example - * - * let concatValues = (k, l, r) => k == 'values' ? R.concat(l, r) : r - * R.mergeWithKey(concatValues, - * { a: true, thing: 'foo', values: [10, 20] }, - * { b: true, thing: 'bar', values: [15, 35] }); - * //=> { a: true, b: true, thing: 'bar', values: [10, 20, 15, 35] } - */ - var mergeWithKey = _curry3(function mergeWithKey(fn, l, r) { - var result = {}; - var k; - for (k in l) { - if (_has(k, l)) { - result[k] = _has(k, r) ? fn(k, l[k], r[k]) : l[k]; - } - } - for (k in r) { - if (_has(k, r) && !_has(k, result)) { - result[k] = r[k]; - } - } - return result; - }); + _createClass(NoIn, [{ + key: "emit", + value: function emit(ts) { + this.expr.emit(ts, true); + } + }, { + key: "forEach", + value: function forEach(f) { + f(this); + this.expr.forEach(f); + } + }]); - /** - * Returns the smaller of its two arguments. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig Ord a => a -> a -> a - * @param {*} a - * @param {*} b - * @return {*} - * @see R.minBy, R.max - * @example - * - * R.min(789, 123); //=> 123 - * R.min('a', 'b'); //=> 'a' - */ - var min = _curry2(function min(a, b) { - return b < a ? b : a; - }); + return NoIn; + }(CodeRep); - /** - * Takes a function and two values, and returns whichever value produces the - * smaller result when passed to the provided function. - * - * @func - * @memberOf R - * @since v0.8.0 - * @category Relation - * @sig Ord b => (a -> b) -> a -> a -> a - * @param {Function} f - * @param {*} a - * @param {*} b - * @return {*} - * @see R.min, R.maxBy - * @example - * - * // square :: Number -> Number - * var square = n => n * n; - * - * R.minBy(square, -3, 2); //=> 2 - * - * R.reduce(R.minBy(square), Infinity, [3, -5, 4, 1, -2]); //=> 1 - * R.reduce(R.minBy(square), Infinity, []); //=> Infinity - */ - var minBy = _curry3(function minBy(f, a, b) { - return f(b) < f(a) ? b : a; - }); + var ContainsIn = exports.ContainsIn = function (_CodeRep8) { + _inherits(ContainsIn, _CodeRep8); - /** - * Divides the second parameter by the first and returns the remainder. Note - * that this function preserves the JavaScript-style behavior for modulo. For - * mathematical modulo see `mathMod`. - * - * @func - * @memberOf R - * @since v0.1.1 - * @category Math - * @sig Number -> Number -> Number - * @param {Number} a The value to the divide. - * @param {Number} b The pseudo-modulus - * @return {Number} The result of `b % a`. - * @see R.mathMod - * @example - * - * R.modulo(17, 3); //=> 2 - * // JS behavior: - * R.modulo(-17, 3); //=> -2 - * R.modulo(17, -3); //=> 2 - * - * var isOdd = R.modulo(R.__, 2); - * isOdd(42); //=> 0 - * isOdd(21); //=> 1 - */ - var modulo = _curry2(function modulo(a, b) { - return a % b; - }); + function ContainsIn(expr) { + _classCallCheck(this, ContainsIn); - /** - * Multiplies two numbers. Equivalent to `a * b` but curried. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Math - * @sig Number -> Number -> Number - * @param {Number} a The first value. - * @param {Number} b The second value. - * @return {Number} The result of `a * b`. - * @see R.divide - * @example - * - * var double = R.multiply(2); - * var triple = R.multiply(3); - * double(3); //=> 6 - * triple(4); //=> 12 - * R.multiply(2, 5); //=> 10 - */ - var multiply = _curry2(function multiply(a, b) { - return a * b; - }); + var _this8 = _possibleConstructorReturn(this, Object.getPrototypeOf(ContainsIn).call(this)); - /** - * Wraps a function of any arity (including nullary) in a function that accepts - * exactly `n` parameters. Any extraneous parameters will not be passed to the - * supplied function. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig Number -> (* -> a) -> (* -> a) - * @param {Number} n The desired arity of the new function. - * @param {Function} fn The function to wrap. - * @return {Function} A new function wrapping `fn`. The new function is guaranteed to be of - * arity `n`. - * @example - * - * var takesTwoArgs = (a, b) => [a, b]; - * - * takesTwoArgs.length; //=> 2 - * takesTwoArgs(1, 2); //=> [1, 2] - * - * var takesOneArg = R.nAry(1, takesTwoArgs); - * takesOneArg.length; //=> 1 - * // Only `n` arguments are passed to the wrapped function - * takesOneArg(1, 2); //=> [1, undefined] - */ - var nAry = _curry2(function nAry(n, fn) { - switch (n) { - case 0: - return function () { - return fn.call(this); - }; - case 1: - return function (a0) { - return fn.call(this, a0); - }; - case 2: - return function (a0, a1) { - return fn.call(this, a0, a1); - }; - case 3: - return function (a0, a1, a2) { - return fn.call(this, a0, a1, a2); - }; - case 4: - return function (a0, a1, a2, a3) { - return fn.call(this, a0, a1, a2, a3); - }; - case 5: - return function (a0, a1, a2, a3, a4) { - return fn.call(this, a0, a1, a2, a3, a4); - }; - case 6: - return function (a0, a1, a2, a3, a4, a5) { - return fn.call(this, a0, a1, a2, a3, a4, a5); - }; - case 7: - return function (a0, a1, a2, a3, a4, a5, a6) { - return fn.call(this, a0, a1, a2, a3, a4, a5, a6); - }; - case 8: - return function (a0, a1, a2, a3, a4, a5, a6, a7) { - return fn.call(this, a0, a1, a2, a3, a4, a5, a6, a7); - }; - case 9: - return function (a0, a1, a2, a3, a4, a5, a6, a7, a8) { - return fn.call(this, a0, a1, a2, a3, a4, a5, a6, a7, a8); - }; - case 10: - return function (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9) { - return fn.call(this, a0, a1, a2, a3, a4, a5, a6, a7, a8, a9); - }; - default: - throw new Error('First argument to nAry must be a non-negative integer no greater than ten'); - } - }); + _this8.expr = expr; + return _this8; + } - /** - * Negates its argument. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Math - * @sig Number -> Number - * @param {Number} n - * @return {Number} - * @example - * - * R.negate(42); //=> -42 - */ - var negate = _curry1(function negate(n) { - return -n; - }); + _createClass(ContainsIn, [{ + key: "emit", + value: function emit(ts, noIn) { + if (noIn) { + ts.put("("); + this.expr.emit(ts, false); + ts.put(")"); + } else { + this.expr.emit(ts, false); + } + } + }, { + key: "forEach", + value: function forEach(f) { + f(this); + this.expr.forEach(f); + } + }]); - /** - * Returns `true` if no elements of the list match the predicate, `false` - * otherwise. - * - * Dispatches to the `any` method of the second argument, if present. - * - * @func - * @memberOf R - * @since v0.12.0 - * @category List - * @sig (a -> Boolean) -> [a] -> Boolean - * @param {Function} fn The predicate function. - * @param {Array} list The array to consider. - * @return {Boolean} `true` if the predicate is not satisfied by every element, `false` otherwise. - * @see R.all, R.any - * @example - * - * var isEven = n => n % 2 === 0; - * - * R.none(isEven, [1, 3, 5, 7, 9, 11]); //=> true - * R.none(isEven, [1, 3, 5, 7, 8, 11]); //=> false - */ - var none = _curry2(_complement(_dispatchable('any', _xany, any))); + return ContainsIn; + }(CodeRep); - /** - * A function that returns the `!` of its argument. It will return `true` when - * passed false-y value, and `false` when passed a truth-y one. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Logic - * @sig * -> Boolean - * @param {*} a any value - * @return {Boolean} the logical inverse of passed argument. - * @see R.complement - * @example - * - * R.not(true); //=> false - * R.not(false); //=> true - * R.not(0); => true - * R.not(1); => false - */ - var not = _curry1(function not(a) { - return !a; - }); + var Seq = exports.Seq = function (_CodeRep9) { + _inherits(Seq, _CodeRep9); - /** - * Returns the nth element of the given list or string. If n is negative the - * element at index length + n is returned. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig Number -> [a] -> a | Undefined - * @sig Number -> String -> String - * @param {Number} offset - * @param {*} list - * @return {*} - * @example - * - * var list = ['foo', 'bar', 'baz', 'quux']; - * R.nth(1, list); //=> 'bar' - * R.nth(-1, list); //=> 'quux' - * R.nth(-99, list); //=> undefined - * - * R.nth('abc', 2); //=> 'c' - * R.nth('abc', 3); //=> '' - */ - var nth = _curry2(function nth(offset, list) { - var idx = offset < 0 ? list.length + offset : offset; - return _isString(list) ? list.charAt(idx) : list[idx]; - }); + function Seq(children) { + _classCallCheck(this, Seq); - /** - * Returns a function which returns its nth argument. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Function - * @sig Number -> *... -> * - * @param {Number} n - * @return {Function} - * @example - * - * R.nthArg(1)('a', 'b', 'c'); //=> 'b' - * R.nthArg(-1)('a', 'b', 'c'); //=> 'c' - */ - var nthArg = _curry1(function nthArg(n) { - return function () { - return nth(n, arguments); - }; - }); + var _this9 = _possibleConstructorReturn(this, Object.getPrototypeOf(Seq).call(this)); - /** - * Creates an object containing a single key:value pair. - * - * @func - * @memberOf R - * @since v0.18.0 - * @category Object - * @sig String -> a -> {String:a} - * @param {String} key - * @param {*} val - * @return {Object} - * @see R.pair - * @example - * - * var matchPhrases = R.compose( - * R.objOf('must'), - * R.map(R.objOf('match_phrase')) - * ); - * matchPhrases(['foo', 'bar', 'baz']); //=> {must: [{match_phrase: 'foo'}, {match_phrase: 'bar'}, {match_phrase: 'baz'}]} - */ - var objOf = _curry2(function objOf(key, val) { - var obj = {}; - obj[key] = val; - return obj; - }); + _this9.children = children; + return _this9; + } - /** - * Returns a singleton array containing the value provided. - * - * Note this `of` is different from the ES6 `of`; See - * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/of - * - * @func - * @memberOf R - * @since v0.3.0 - * @category Function - * @sig a -> [a] - * @param {*} x any value - * @return {Array} An array wrapping `x`. - * @example - * - * R.of(null); //=> [null] - * R.of([42]); //=> [[42]] - */ - var of = _curry1(_of); + _createClass(Seq, [{ + key: "emit", + value: function emit(ts, noIn) { + this.children.forEach(function (cr) { + return cr.emit(ts, noIn); + }); + } + }, { + key: "forEach", + value: function forEach(f) { + f(this); + this.children.forEach(function (x) { + return x.forEach(f); + }); + } + }]); - /** - * Accepts a function `fn` and returns a function that guards invocation of - * `fn` such that `fn` can only ever be called once, no matter how many times - * the returned function is invoked. The first value calculated is returned in - * subsequent invocations. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig (a... -> b) -> (a... -> b) - * @param {Function} fn The function to wrap in a call-only-once wrapper. - * @return {Function} The wrapped function. - * @example - * - * var addOneOnce = R.once(x => x + 1); - * addOneOnce(10); //=> 11 - * addOneOnce(addOneOnce(50)); //=> 11 - */ - var once = _curry1(function once(fn) { - var called = false; - var result; - return _arity(fn.length, function () { - if (called) { - return result; - } - called = true; - result = fn.apply(this, arguments); - return result; - }); - }); + return Seq; + }(CodeRep); - /** - * Returns `true` if one or both of its arguments are `true`. Returns `false` - * if both arguments are `false`. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Logic - * @sig * -> * -> * - * @param {Boolean} a A boolean value - * @param {Boolean} b A boolean value - * @return {Boolean} `true` if one or both arguments are `true`, `false` otherwise - * @see R.either - * @example - * - * R.or(true, true); //=> true - * R.or(true, false); //=> true - * R.or(false, true); //=> true - * R.or(false, false); //=> false - */ - var or = _curry2(function or(a, b) { - return a || b; - }); + var Semi = exports.Semi = function (_Token) { + _inherits(Semi, _Token); - /** - * Returns the result of "setting" the portion of the given data structure - * focused by the given lens to the result of applying the given function to - * the focused value. - * - * @func - * @memberOf R - * @since v0.16.0 - * @category Object - * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s - * @sig Lens s a -> (a -> a) -> s -> s - * @param {Lens} lens - * @param {*} v - * @param {*} x - * @return {*} - * @see R.prop, R.lensIndex, R.lensProp - * @example - * - * var headLens = R.lensIndex(0); - * - * R.over(headLens, R.toUpper, ['foo', 'bar', 'baz']); //=> ['FOO', 'bar', 'baz'] - */ - var over = function () { - var Identity = function (x) { - return { - value: x, - map: function (f) { - return Identity(f(x)); - } - }; - }; - return _curry3(function over(lens, f, x) { - return lens(function (y) { - return Identity(f(y)); - })(x).value; - }); - }(); + function Semi() { + _classCallCheck(this, Semi); - /** - * Takes two arguments, `fst` and `snd`, and returns `[fst, snd]`. - * - * @func - * @memberOf R - * @since v0.18.0 - * @category List - * @sig a -> b -> (a,b) - * @param {*} fst - * @param {*} snd - * @return {Array} - * @see R.createMapEntry, R.of - * @example - * - * R.pair('foo', 'bar'); //=> ['foo', 'bar'] - */ - var pair = _curry2(function pair(fst, snd) { - return [ - fst, - snd - ]; - }); + return _possibleConstructorReturn(this, Object.getPrototypeOf(Semi).call(this, ";")); + } - /** - * Retrieve the value at a given path. - * - * @func - * @memberOf R - * @since v0.2.0 - * @category Object - * @sig [String] -> {k: v} -> v | Undefined - * @param {Array} path The path to use. - * @param {Object} obj The object to retrieve the nested property from. - * @return {*} The data at `path`. - * @example - * - * R.path(['a', 'b'], {a: {b: 2}}); //=> 2 - * R.path(['a', 'b'], {c: {b: 2}}); //=> undefined - */ - var path = _curry2(function path(paths, obj) { - var val = obj; - var idx = 0; - while (idx < paths.length) { - if (val == null) { - return; - } - val = val[paths[idx]]; - idx += 1; - } - return val; - }); + return Semi; + }(Token); - /** - * If the given, non-null object has a value at the given path, returns the - * value at that path. Otherwise returns the provided default value. - * - * @func - * @memberOf R - * @since v0.18.0 - * @category Object - * @sig a -> [String] -> Object -> a - * @param {*} d The default value. - * @param {Array} p The path to use. - * @param {Object} obj The object to retrieve the nested property from. - * @return {*} The data at `path` of the supplied object or the default value. - * @example - * - * R.pathOr('N/A', ['a', 'b'], {a: {b: 2}}); //=> 2 - * R.pathOr('N/A', ['a', 'b'], {c: {b: 2}}); //=> "N/A" - */ - var pathOr = _curry3(function pathOr(d, p, obj) { - return defaultTo(d, path(p, obj)); - }); + var CommaSep = exports.CommaSep = function (_CodeRep10) { + _inherits(CommaSep, _CodeRep10); - /** - * Returns `true` if the specified object property at given path satisfies the - * given predicate; `false` otherwise. - * - * @func - * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category Logic - * @sig (a -> Boolean) -> [String] -> Object -> Boolean - * @param {Function} pred - * @param {Array} propPath - * @param {*} obj - * @return {Boolean} - * @see R.propSatisfies, R.path - * @example - * - * R.pathSatisfies(y => y > 0, ['x', 'y'], {x: {y: 2}}); //=> true - */ - var pathSatisfies = _curry3(function pathSatisfies(pred, propPath, obj) { - return propPath.length > 0 && pred(path(propPath, obj)); - }); + function CommaSep(children) { + _classCallCheck(this, CommaSep); - /** - * Returns a partial copy of an object containing only the keys specified. If - * the key does not exist, the property is ignored. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Object - * @sig [k] -> {k: v} -> {k: v} - * @param {Array} names an array of String property names to copy onto a new object - * @param {Object} obj The object to copy from - * @return {Object} A new object with only properties from `names` on it. - * @see R.omit, R.props - * @example - * - * R.pick(['a', 'd'], {a: 1, b: 2, c: 3, d: 4}); //=> {a: 1, d: 4} - * R.pick(['a', 'e', 'f'], {a: 1, b: 2, c: 3, d: 4}); //=> {a: 1} - */ - var pick = _curry2(function pick(names, obj) { - var result = {}; - var idx = 0; - while (idx < names.length) { - if (names[idx] in obj) { - result[names[idx]] = obj[names[idx]]; - } - idx += 1; - } - return result; - }); + var _this11 = _possibleConstructorReturn(this, Object.getPrototypeOf(CommaSep).call(this)); - /** - * Similar to `pick` except that this one includes a `key: undefined` pair for - * properties that don't exist. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Object - * @sig [k] -> {k: v} -> {k: v} - * @param {Array} names an array of String property names to copy onto a new object - * @param {Object} obj The object to copy from - * @return {Object} A new object with only properties from `names` on it. - * @see R.pick - * @example - * - * R.pickAll(['a', 'd'], {a: 1, b: 2, c: 3, d: 4}); //=> {a: 1, d: 4} - * R.pickAll(['a', 'e', 'f'], {a: 1, b: 2, c: 3, d: 4}); //=> {a: 1, e: undefined, f: undefined} - */ - var pickAll = _curry2(function pickAll(names, obj) { - var result = {}; - var idx = 0; - var len = names.length; - while (idx < len) { - var name = names[idx]; - result[name] = obj[name]; - idx += 1; - } - return result; - }); + _this11.children = children; + return _this11; + } - /** - * Returns a partial copy of an object containing only the keys that satisfy - * the supplied predicate. - * - * @func - * @memberOf R - * @since v0.8.0 - * @category Object - * @sig (v, k -> Boolean) -> {k: v} -> {k: v} - * @param {Function} pred A predicate to determine whether or not a key - * should be included on the output object. - * @param {Object} obj The object to copy from - * @return {Object} A new object with only properties that satisfy `pred` - * on it. - * @see R.pick, R.filter - * @example - * - * var isUpperCase = (val, key) => key.toUpperCase() === key; - * R.pickBy(isUpperCase, {a: 1, b: 2, A: 3, B: 4}); //=> {A: 3, B: 4} - */ - var pickBy = _curry2(function pickBy(test, obj) { - var result = {}; - for (var prop in obj) { - if (test(obj[prop], prop, obj)) { - result[prop] = obj[prop]; - } + _createClass(CommaSep, [{ + key: "emit", + value: function emit(ts, noIn) { + var first = true; + this.children.forEach(function (cr) { + if (first) { + first = false; + } else { + ts.put(","); } - return result; - }); + cr.emit(ts, noIn); + }); + } + }, { + key: "forEach", + value: function forEach(f) { + f(this); + this.children.forEach(function (x) { + return x.forEach(f); + }); + } + }]); - /** - * Returns a new list with the given element at the front, followed by the - * contents of the list. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig a -> [a] -> [a] - * @param {*} el The item to add to the head of the output list. - * @param {Array} list The array to add to the tail of the output list. - * @return {Array} A new array. - * @see R.append - * @example - * - * R.prepend('fee', ['fi', 'fo', 'fum']); //=> ['fee', 'fi', 'fo', 'fum'] - */ - var prepend = _curry2(function prepend(el, list) { - return _concat([el], list); - }); + return CommaSep; + }(CodeRep); - /** - * Returns a function that when supplied an object returns the indicated - * property of that object, if it exists. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Object - * @sig s -> {s: a} -> a | Undefined - * @param {String} p The property name - * @param {Object} obj The object to query - * @return {*} The value at `obj.p`. - * @example - * - * R.prop('x', {x: 100}); //=> 100 - * R.prop('x', {}); //=> undefined - */ - var prop = _curry2(function prop(p, obj) { - return obj[p]; - }); + var SemiOp = exports.SemiOp = function (_CodeRep11) { + _inherits(SemiOp, _CodeRep11); - /** - * If the given, non-null object has an own property with the specified name, - * returns the value of that property. Otherwise returns the provided default - * value. - * - * @func - * @memberOf R - * @since v0.6.0 - * @category Object - * @sig a -> String -> Object -> a - * @param {*} val The default value. - * @param {String} p The name of the property to return. - * @param {Object} obj The object to query. - * @return {*} The value of given property of the supplied object or the default value. - * @example - * - * var alice = { - * name: 'ALICE', - * age: 101 - * }; - * var favorite = R.prop('favoriteLibrary'); - * var favoriteWithDefault = R.propOr('Ramda', 'favoriteLibrary'); - * - * favorite(alice); //=> undefined - * favoriteWithDefault(alice); //=> 'Ramda' - */ - var propOr = _curry3(function propOr(val, p, obj) { - return obj != null && _has(p, obj) ? obj[p] : val; - }); + function SemiOp() { + _classCallCheck(this, SemiOp); - /** - * Returns `true` if the specified object property satisfies the given - * predicate; `false` otherwise. - * - * @func - * @memberOf R - * @since v0.16.0 - * @category Logic - * @sig (a -> Boolean) -> String -> {String: a} -> Boolean - * @param {Function} pred - * @param {String} name - * @param {*} obj - * @return {Boolean} - * @see R.propEq, R.propIs - * @example - * - * R.propSatisfies(x => x > 0, 'x', {x: 1, y: 2}); //=> true - */ - var propSatisfies = _curry3(function propSatisfies(pred, name, obj) { - return pred(obj[name]); - }); + return _possibleConstructorReturn(this, Object.getPrototypeOf(SemiOp).call(this)); + } - /** - * Acts as multiple `prop`: array of keys in, array of values out. Preserves - * order. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Object - * @sig [k] -> {k: v} -> [v] - * @param {Array} ps The property names to fetch - * @param {Object} obj The object to query - * @return {Array} The corresponding values or partially applied function. - * @example - * - * R.props(['x', 'y'], {x: 1, y: 2}); //=> [1, 2] - * R.props(['c', 'a', 'b'], {b: 2, a: 1}); //=> [undefined, 1, 2] - * - * var fullName = R.compose(R.join(' '), R.props(['first', 'last'])); - * fullName({last: 'Bullet-Tooth', age: 33, first: 'Tony'}); //=> 'Tony Bullet-Tooth' - */ - var props = _curry2(function props(ps, obj) { - var len = ps.length; - var out = []; - var idx = 0; - while (idx < len) { - out[idx] = obj[ps[idx]]; - idx += 1; - } - return out; - }); + _createClass(SemiOp, [{ + key: "emit", + value: function emit(ts) { + ts.putOptionalSemi(); + } + }]); - /** - * Returns a list of numbers from `from` (inclusive) to `to` (exclusive). - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig Number -> Number -> [Number] - * @param {Number} from The first number in the list. - * @param {Number} to One more than the last number in the list. - * @return {Array} The list of numbers in tthe set `[a, b)`. - * @example - * - * R.range(1, 5); //=> [1, 2, 3, 4] - * R.range(50, 53); //=> [50, 51, 52] - */ - var range = _curry2(function range(from, to) { - if (!(_isNumber(from) && _isNumber(to))) { - throw new TypeError('Both arguments to range must be numbers'); - } - var result = []; - var n = from; - while (n < to) { - result.push(n); - n += 1; - } - return result; - }); + return SemiOp; + }(CodeRep); - /** - * Returns a single item by iterating through the list, successively calling - * the iterator function and passing it an accumulator value and the current - * value from the array, and then passing the result to the next call. - * - * Similar to `reduce`, except moves through the input list from the right to - * the left. - * - * The iterator function receives two values: *(acc, value)* - * - * Note: `R.reduceRight` does not skip deleted or unassigned indices (sparse - * arrays), unlike the native `Array.prototype.reduce` method. For more details - * on this behavior, see: - * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduceRight#Description - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig (a,b -> a) -> a -> [b] -> a - * @param {Function} fn The iterator function. Receives two values, the accumulator and the - * current element from the array. - * @param {*} acc The accumulator value. - * @param {Array} list The list to iterate over. - * @return {*} The final, accumulated value. - * @see R.addIndex - * @example - * - * var pairs = [ ['a', 1], ['b', 2], ['c', 3] ]; - * var flattenPairs = (acc, pair) => acc.concat(pair); - * - * R.reduceRight(flattenPairs, [], pairs); //=> [ 'c', 3, 'b', 2, 'a', 1 ] - */ - var reduceRight = _curry3(function reduceRight(fn, acc, list) { - var idx = list.length - 1; - while (idx >= 0) { - acc = fn(acc, list[idx]); - idx -= 1; - } - return acc; - }); +/***/ }, +/* 20 */ +/***/ function(module, exports, __webpack_require__) { - /** - * Returns a value wrapped to indicate that it is the final value of the reduce - * and transduce functions. The returned value should be considered a black - * box: the internal structure is not guaranteed to be stable. - * - * Note: this optimization is unavailable to functions not explicitly listed - * above. For instance, it is not currently supported by reduceRight. - * - * @func - * @memberOf R - * @since v0.15.0 - * @category List - * @sig a -> * - * @param {*} x The final value of the reduce. - * @return {*} The wrapped value. - * @see R.reduce, R.transduce - * @example - * - * R.reduce( - * R.pipe(R.add, R.when(R.gte(R.__, 10), R.reduced)), - * 0, - * [1, 2, 3, 4, 5]) // 10 - */ - var reduced = _curry1(_reduced); + "use strict"; - /** - * Removes the sub-list of `list` starting at index `start` and containing - * `count` elements. _Note that this is not destructive_: it returns a copy of - * the list with the changes. - * No lists have been harmed in the application of this function. - * - * @func - * @memberOf R - * @since v0.2.2 - * @category List - * @sig Number -> Number -> [a] -> [a] - * @param {Number} start The position to start removing elements - * @param {Number} count The number of elements to remove - * @param {Array} list The list to remove from - * @return {Array} A new Array with `count` elements from `start` removed. - * @example - * - * R.remove(2, 3, [1,2,3,4,5,6,7,8]); //=> [1,2,6,7,8] - */ - var remove = _curry3(function remove(start, count, list) { - return _concat(_slice(list, 0, Math.min(start, list.length)), _slice(list, Math.min(list.length, start + count))); - }); + var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); - /** - * Replace a substring or regex match in a string with a replacement. - * - * @func - * @memberOf R - * @since v0.7.0 - * @category String - * @sig RegExp|String -> String -> String -> String - * @param {RegExp|String} pattern A regular expression or a substring to match. - * @param {String} replacement The string to replace the matches with. - * @param {String} str The String to do the search and replacement in. - * @return {String} The result. - * @example - * - * R.replace('foo', 'bar', 'foo foo foo'); //=> 'bar foo foo' - * R.replace(/foo/, 'bar', 'foo foo foo'); //=> 'bar foo foo' - * - * // Use the "g" (global) flag to replace all occurrences: - * R.replace(/foo/g, 'bar', 'foo foo foo'); //=> 'bar bar bar' - */ - var replace = _curry3(function replace(regex, replacement, str) { - return str.replace(regex, replacement); - }); + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.FormattedCodeGen = exports.ExtensibleCodeGen = exports.Sep = undefined; - /** - * Returns a new list or string with the elements or characters in reverse - * order. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig [a] -> [a] - * @sig String -> String - * @param {Array|String} list - * @return {Array|String} - * @example - * - * R.reverse([1, 2, 3]); //=> [3, 2, 1] - * R.reverse([1, 2]); //=> [2, 1] - * R.reverse([1]); //=> [1] - * R.reverse([]); //=> [] - * - * R.reverse('abc'); //=> 'cba' - * R.reverse('ab'); //=> 'ba' - * R.reverse('a'); //=> 'a' - * R.reverse(''); //=> '' - */ - var reverse = _curry1(function reverse(list) { - return _isString(list) ? list.split('').reverse().join('') : _slice(list).reverse(); - }); + var _objectAssign = __webpack_require__(14); - /** - * Scan is similar to reduce, but returns a list of successively reduced values - * from the left - * - * @func - * @memberOf R - * @since v0.10.0 - * @category List - * @sig (a,b -> a) -> a -> [b] -> [a] - * @param {Function} fn The iterator function. Receives two values, the accumulator and the - * current element from the array - * @param {*} acc The accumulator value. - * @param {Array} list The list to iterate over. - * @return {Array} A list of all intermediately reduced values. - * @example - * - * var numbers = [1, 2, 3, 4]; - * var factorials = R.scan(R.multiply, 1, numbers); //=> [1, 1, 2, 6, 24] - */ - var scan = _curry3(function scan(fn, acc, list) { - var idx = 0; - var len = list.length; - var result = [acc]; - while (idx < len) { - acc = fn(acc, list[idx]); - result[idx + 1] = acc; - idx += 1; - } - return result; - }); + var _objectAssign2 = _interopRequireDefault(_objectAssign); - /** - * Returns the result of "setting" the portion of the given data structure - * focused by the given lens to the given value. - * - * @func - * @memberOf R - * @since v0.16.0 - * @category Object - * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s - * @sig Lens s a -> a -> s -> s - * @param {Lens} lens - * @param {*} v - * @param {*} x - * @return {*} - * @see R.prop, R.lensIndex, R.lensProp - * @example - * - * var xLens = R.lensProp('x'); - * - * R.set(xLens, 4, {x: 1, y: 2}); //=> {x: 4, y: 2} - * R.set(xLens, 8, {x: 1, y: 2}); //=> {x: 8, y: 2} - */ - var set = _curry3(function set(lens, v, x) { - return over(lens, always(v), x); - }); + var _esutils = __webpack_require__(15); - /** - * Returns the elements of the given list or string (or object with a `slice` - * method) from `fromIndex` (inclusive) to `toIndex` (exclusive). - * - * Dispatches to the `slice` method of the third argument, if present. - * - * @func - * @memberOf R - * @since v0.1.4 - * @category List - * @sig Number -> Number -> [a] -> [a] - * @sig Number -> Number -> String -> String - * @param {Number} fromIndex The start index (inclusive). - * @param {Number} toIndex The end index (exclusive). - * @param {*} list - * @return {*} - * @example - * - * R.slice(1, 3, ['a', 'b', 'c', 'd']); //=> ['b', 'c'] - * R.slice(1, Infinity, ['a', 'b', 'c', 'd']); //=> ['b', 'c', 'd'] - * R.slice(0, -1, ['a', 'b', 'c', 'd']); //=> ['a', 'b', 'c'] - * R.slice(-3, -1, ['a', 'b', 'c', 'd']); //=> ['b', 'c'] - * R.slice(0, 3, 'ramda'); //=> 'ram' - */ - var slice = _curry3(_checkForMethod('slice', function slice(fromIndex, toIndex, list) { - return Array.prototype.slice.call(list, fromIndex, toIndex); - })); + var _coderep = __webpack_require__(19); - /** - * Returns a copy of the list, sorted according to the comparator function, - * which should accept two values at a time and return a negative number if the - * first value is smaller, a positive number if it's larger, and zero if they - * are equal. Please note that this is a **copy** of the list. It does not - * modify the original. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig (a,a -> Number) -> [a] -> [a] - * @param {Function} comparator A sorting function :: a -> b -> Int - * @param {Array} list The list to sort - * @return {Array} a new array with its elements sorted by the comparator function. - * @example - * - * var diff = function(a, b) { return a - b; }; - * R.sort(diff, [4,2,7,5]); //=> [2, 4, 5, 7] - */ - var sort = _curry2(function sort(comparator, list) { - return _slice(list).sort(comparator); - }); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - /** - * Sorts the list according to the supplied function. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig Ord b => (a -> b) -> [a] -> [a] - * @param {Function} fn - * @param {Array} list The list to sort. - * @return {Array} A new list sorted by the keys generated by `fn`. - * @example - * - * var sortByFirstItem = R.sortBy(R.prop(0)); - * var sortByNameCaseInsensitive = R.sortBy(R.compose(R.toLower, R.prop('name'))); - * var pairs = [[-1, 1], [-2, 2], [-3, 3]]; - * sortByFirstItem(pairs); //=> [[-3, 3], [-2, 2], [-1, 1]] - * var alice = { - * name: 'ALICE', - * age: 101 - * }; - * var bob = { - * name: 'Bob', - * age: -10 - * }; - * var clara = { - * name: 'clara', - * age: 314.159 - * }; - * var people = [clara, bob, alice]; - * sortByNameCaseInsensitive(people); //=> [alice, bob, clara] - */ - var sortBy = _curry2(function sortBy(fn, list) { - return _slice(list).sort(function (a, b) { - var aa = fn(a); - var bb = fn(b); - return aa < bb ? -1 : aa > bb ? 1 : 0; - }); - }); + function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } - /** - * Splits a given list or string at a given index. - * - * @func - * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category List - * @sig Number -> [a] -> [[a], [a]] - * @sig Number -> String -> [String, String] - * @param {Number} index The index where the array/string is split. - * @param {Array|String} array The array/string to be split. - * @return {Array} - * @example - * - * R.splitAt(1, [1, 2, 3]); //=> [[1], [2, 3]] - * R.splitAt(5, 'hello world'); //=> ['hello', ' world'] - * R.splitAt(-1, 'foobar'); //=> ['fooba', 'r'] - */ - var splitAt = _curry2(function splitAt(index, array) { - return [ - slice(0, index, array), - slice(index, length(array), array) - ]; - }); + function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } - /** - * Splits a collection into slices of the specified length. - * - * @func - * @memberOf R - * @since v0.16.0 - * @category List - * @sig Number -> [a] -> [[a]] - * @sig Number -> String -> [String] - * @param {Number} n - * @param {Array} list - * @return {Array} - * @example - * - * R.splitEvery(3, [1, 2, 3, 4, 5, 6, 7]); //=> [[1, 2, 3], [4, 5, 6], [7]] - * R.splitEvery(3, 'foobarbaz'); //=> ['foo', 'bar', 'baz'] - */ - var splitEvery = _curry2(function splitEvery(n, list) { - if (n <= 0) { - throw new Error('First argument to splitEvery must be a positive integer'); - } - var result = []; - var idx = 0; - while (idx < list.length) { - result.push(slice(idx, idx += n, list)); - } - return result; - }); + function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } - /** - * Takes a list and a predicate and returns a pair of lists with the following properties: - * - * - the result of concatenating the two output lists is equivalent to the input list; - * - none of the elements of the first output list satisfies the predicate; and - * - if the second output list is non-empty, its first element satisfies the predicate. - * - * @func - * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category List - * @sig (a -> Boolean) -> [a] -> [[a], [a]] - * @param {Function} pred The predicate that determines where the array is split. - * @param {Array} list The array to be split. - * @return {Array} - * @example - * - * R.splitWhen(R.equals(2), [1, 2, 3, 1, 2, 3]); //=> [[1], [2, 3, 1, 2, 3]] - */ - var splitWhen = _curry2(function splitWhen(pred, list) { - var idx = 0; - var len = list.length; - var prefix = []; - while (idx < len && !pred(list[idx])) { - prefix.push(list[idx]); - idx += 1; - } - return [ - prefix, - _slice(list, idx) - ]; - }); + function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - /** - * Subtracts two numbers. Equivalent to `a - b` but curried. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Math - * @sig Number -> Number -> Number - * @param {Number} a The first value. - * @param {Number} b The second value. - * @return {Number} The result of `a - b`. - * @see R.add - * @example - * - * R.subtract(10, 8); //=> 2 - * - * var minus5 = R.subtract(R.__, 5); - * minus5(17); //=> 12 - * - * var complementaryAngle = R.subtract(90); - * complementaryAngle(30); //=> 60 - * complementaryAngle(72); //=> 18 - */ - var subtract = _curry2(function subtract(a, b) { - return a - b; - }); + function empty() { + return new _coderep.Empty(); + } - /** - * Returns all but the first element of the given list or string (or object - * with a `tail` method). - * - * Dispatches to the `slice` method of the first argument, if present. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig [a] -> [a] - * @sig String -> String - * @param {*} list - * @return {*} - * @see R.head, R.init, R.last - * @example - * - * R.tail([1, 2, 3]); //=> [2, 3] - * R.tail([1, 2]); //=> [2] - * R.tail([1]); //=> [] - * R.tail([]); //=> [] - * - * R.tail('abc'); //=> 'bc' - * R.tail('ab'); //=> 'b' - * R.tail('a'); //=> '' - * R.tail(''); //=> '' - */ - var tail = _checkForMethod('tail', slice(1, Infinity)); + function noIn(rep) { + return new _coderep.NoIn(rep); + } - /** - * Returns the first `n` elements of the given list, string, or - * transducer/transformer (or object with a `take` method). - * - * Dispatches to the `take` method of the second argument, if present. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig Number -> [a] -> [a] - * @sig Number -> String -> String - * @param {Number} n - * @param {*} list - * @return {*} - * @see R.drop - * @example - * - * R.take(1, ['foo', 'bar', 'baz']); //=> ['foo'] - * R.take(2, ['foo', 'bar', 'baz']); //=> ['foo', 'bar'] - * R.take(3, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] - * R.take(4, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] - * R.take(3, 'ramda'); //=> 'ram' - * - * var personnel = [ - * 'Dave Brubeck', - * 'Paul Desmond', - * 'Eugene Wright', - * 'Joe Morello', - * 'Gerry Mulligan', - * 'Bob Bates', - * 'Joe Dodge', - * 'Ron Crotty' - * ]; - * - * var takeFive = R.take(5); - * takeFive(personnel); - * //=> ['Dave Brubeck', 'Paul Desmond', 'Eugene Wright', 'Joe Morello', 'Gerry Mulligan'] - */ - var take = _curry2(_dispatchable('take', _xtake, function take(n, xs) { - return slice(0, n < 0 ? Infinity : n, xs); - })); + function markContainsIn(state) { + return state.containsIn ? new _coderep.ContainsIn(state) : state; + } - /** - * Returns a new list containing the last `n` elements of a given list, passing - * each value to the supplied predicate function, and terminating when the - * predicate function returns `false`. Excludes the element that caused the - * predicate function to fail. The predicate function is passed one argument: - * *(value)*. - * - * @func - * @memberOf R - * @since v0.16.0 - * @category List - * @sig (a -> Boolean) -> [a] -> [a] - * @param {Function} fn The function called per iteration. - * @param {Array} list The collection to iterate over. - * @return {Array} A new array. - * @see R.dropLastWhile, R.addIndex - * @example - * - * var isNotOne = x => x !== 1; - * - * R.takeLastWhile(isNotOne, [1, 2, 3, 4]); //=> [2, 3, 4] - */ - var takeLastWhile = _curry2(function takeLastWhile(fn, list) { - var idx = list.length - 1; - while (idx >= 0 && fn(list[idx])) { - idx -= 1; - } - return _slice(list, idx + 1, Infinity); - }); + function seq() { + for (var _len = arguments.length, reps = Array(_len), _key = 0; _key < _len; _key++) { + reps[_key] = arguments[_key]; + } - /** - * Returns a new list containing the first `n` elements of a given list, - * passing each value to the supplied predicate function, and terminating when - * the predicate function returns `false`. Excludes the element that caused the - * predicate function to fail. The predicate function is passed one argument: - * *(value)*. - * - * Dispatches to the `takeWhile` method of the second argument, if present. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig (a -> Boolean) -> [a] -> [a] - * @param {Function} fn The function called per iteration. - * @param {Array} list The collection to iterate over. - * @return {Array} A new array. - * @see R.dropWhile, R.transduce, R.addIndex - * @example - * - * var isNotFour = x => x !== 4; - * - * R.takeWhile(isNotFour, [1, 2, 3, 4, 3, 2, 1]); //=> [1, 2, 3] - */ - var takeWhile = _curry2(_dispatchable('takeWhile', _xtakeWhile, function takeWhile(fn, list) { - var idx = 0; - var len = list.length; - while (idx < len && fn(list[idx])) { - idx += 1; - } - return _slice(list, 0, idx); - })); + return new _coderep.Seq(reps); + } - /** - * Runs the given function with the supplied object, then returns the object. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig (a -> *) -> a -> a - * @param {Function} fn The function to call with `x`. The return value of `fn` will be thrown away. - * @param {*} x - * @return {*} `x`. - * @example - * - * var sayX = x => console.log('x is ' + x); - * R.tap(sayX, 100); //=> 100 - * //-> 'x is 100' - */ - var tap = _curry2(function tap(fn, x) { - fn(x); - return x; - }); + function isEmpty(codeRep) { + return codeRep instanceof _coderep.Empty || codeRep instanceof Linebreak || codeRep instanceof _coderep.Seq && codeRep.children.every(isEmpty); + } - /** - * Calls an input function `n` times, returning an array containing the results - * of those function calls. - * - * `fn` is passed one argument: The current value of `n`, which begins at `0` - * and is gradually incremented to `n - 1`. - * - * @func - * @memberOf R - * @since v0.2.3 - * @category List - * @sig (Number -> a) -> Number -> [a] - * @param {Function} fn The function to invoke. Passed one argument, the current value of `n`. - * @param {Number} n A value between `0` and `n - 1`. Increments after each function call. - * @return {Array} An array containing the return values of all calls to `fn`. - * @example - * - * R.times(R.identity, 5); //=> [0, 1, 2, 3, 4] - */ - var times = _curry2(function times(fn, n) { - var len = Number(n); - var idx = 0; - var list; - if (len < 0 || isNaN(len)) { - throw new RangeError('n must be a non-negative number'); - } - list = new Array(len); - while (idx < len) { - list[idx] = fn(idx); - idx += 1; - } - return list; - }); + var Sep = {}; + var separatorNames = ["ARRAY_EMPTY", "ARRAY_BEFORE_COMMA", "ARRAY_AFTER_COMMA", "SPREAD", "BEFORE_DEFAULT_EQUALS", "AFTER_DEFAULT_EQUALS", "REST", "OBJECT_BEFORE_COMMA", "OBJECT_AFTER_COMMA", "BEFORE_PROP", "AFTER_PROP", "BEFORE_JUMP_LABEL", "ARGS_BEFORE_COMMA", "ARGS_AFTER_COMMA", "CALL", "BEFORE_CATCH_BINDING", "AFTER_CATCH_BINDING", "BEFORE_CLASS_NAME", "BEFORE_EXTENDS", "AFTER_EXTENDS", "BEFORE_CLASS_DECLARATION_ELEMENTS", "BEFORE_CLASS_EXPRESSION_ELEMENTS", "AFTER_STATIC", "BEFORE_CLASS_ELEMENT", "AFTER_CLASS_ELEMENT", "BEFORE_TERNARY_QUESTION", "AFTER_TERNARY_QUESTION", "BEFORE_TERNARY_COLON", "AFTER_TERNARY_COLON", "COMPUTED_MEMBER_EXPRESSION", "AFTER_DO", "BEFORE_DOWHILE_WHILE", "AFTER_DOWHILE_WHILE", "AFTER_FORIN_FOR", "BEFORE_FORIN_IN", "AFTER_FORIN_FOR", "BEFORE_FORIN_BODY", "AFTER_FOROF_FOR", "BEFORE_FOROF_OF", "AFTER_FOROF_FOR", "BEFORE_FOROF_BODY", "AFTER_FOR_FOR", "BEFORE_FOR_INIT", "AFTER_FOR_INIT", "EMPTY_FOR_INIT", "BEFORE_FOR_TEST", "AFTER_FOR_TEST", "EMPTY_FOR_TEST", "BEFORE_FOR_UPDATE", "AFTER_FOR_UPDATE", "EMPTY_FOR_UPDATE", "BEFORE_FOR_BODY", "BEFORE_GENERATOR_STAR", "AFTER_GENERATOR_STAR", "BEFORE_FUNCTION_PARAMS", "BEFORE_FUNCTION_DECLARATION_BODY", "BEFORE_FUNCTION_EXPRESSION_BODY", "AFTER_FUNCTION_DIRECTIVES", "BEFORE_ARROW", "AFTER_ARROW", "AFTER_GET", "BEFORE_GET_PARAMS", "BEFORE_GET_BODY", "AFTER_IF", "AFTER_IF_TEST", "BEFORE_ELSE", "AFTER_ELSE", "PARAMETER_BEFORE_COMMA", "PARAMETER_AFTER_COMMA", "NAMED_IMPORT_BEFORE_COMMA", "NAMED_IMPORT_AFTER_COMMA", "IMPORT_BEFORE_COMMA", "IMPORT_AFTER_COMMA", "BEFORE_IMPORT_BINDINGS", "BEFORE_IMPORT_MODULE", "AFTER_IMPORT_BINDINGS", "AFTER_FROM", "BEFORE_IMPORT_NAMESPACE", "BEFORE_IMPORT_STAR", "AFTER_IMPORT_STAR", "AFTER_IMPORT_AS", "AFTER_NAMESPACE_BINDING", "BEFORE_IMPORT_AS", "AFTER_IMPORT_AS", "EXPORTS_BEFORE_COMMA", "EXPORTS_AFTER_COMMA", "BEFORE_EXPORT_STAR", "AFTER_EXPORT_STAR", "BEFORE_EXPORT_BINDINGS", "AFTER_EXPORT_BINDINGS", "AFTER_EXPORT", "EXPORT_DEFAULT", "AFTER_EXPORT_DEFAULT", "BEFORE_EXPORT_AS", "AFTER_EXPORT_AS", "BEFORE_LABEL_COLON", "AFTER_LABEL_COLON", "AFTER_METHOD_GENERATOR_STAR", "AFTER_METHOD_NAME", "BEFORE_METHOD_BODY", "AFTER_MODULE_DIRECTIVES", "AFTER_NEW", "BEFORE_NEW_ARGS", "EMPTY_NEW_CALL", "NEW_TARGET_BEFORE_DOT", "NEW_TARGET_AFTER_DOT", "RETURN", "AFTER_SET", "BEFORE_SET_PARAMS", "BEFORE_SET_BODY", "AFTER_SCRIPT_DIRECTIVES", "BEFORE_STATIC_MEMBER_DOT", "AFTER_STATIC_MEMBER_DOT", "BEFORE_CASE_TEST", "AFTER_CASE_TEST", "BEFORE_CASE_BODY", "AFTER_CASE_BODY", "DEFAULT", "AFTER_DEFAULT_BODY", "BEFORE_SWITCH_DISCRIM", "BEFORE_SWITCH_BODY", "TEMPLATE_TAG", "BEFORE_TEMPLATE_EXPRESSION", "AFTER_TEMPLATE_EXPRESSION", "THROW", "AFTER_TRY", "BEFORE_CATCH", "BEFORE_FINALLY", "AFTER_FINALLY", "VARIABLE_DECLARATION", "YIELD", "BEFORE_YIELD_STAR", "AFTER_YIELD_STAR", "DECLARATORS_BEFORE_COMMA", "DECLARATORS_AFTER_COMMA", "BEFORE_INIT_EQUALS", "AFTER_INIT_EQUALS", "AFTER_WHILE", "BEFORE_WHILE_BODY", "AFTER_WITH", "BEFORE_WITH_BODY", "PAREN_AVOIDING_DIRECTIVE_BEFORE", "PAREN_AVOIDING_DIRECTIVE_AFTER", "PRECEDENCE_BEFORE", "PRECEDENCE_AFTER", "EXPRESSION_PAREN_BEFORE", "EXPRESSION_PAREN_AFTER", "CALL_PAREN_BEFORE", "CALL_PAREN_AFTER", "CALL_PAREN_EMPTY", "CATCH_PAREN_BEFORE", "CATCH_PAREN_AFTER", "DO_WHILE_TEST_PAREN_BEFORE", "DO_WHILE_TEST_PAREN_AFTER", "EXPRESSION_STATEMENT_PAREN_BEFORE", "EXPRESSION_STATEMENT_PAREN_AFTER", "FOR_IN_LET_PAREN_BEFORE", "FOR_IN_LET_PAREN_AFTER", "FOR_IN_PAREN_BEFORE", "FOR_IN_PAREN_AFTER", "FOR_OF_LET_PAREN_BEFORE", "FOR_OF_LET_PAREN_AFTER", "FOR_OF_PAREN_BEFORE", "FOR_OF_PAREN_AFTER", "PARAMETERS_PAREN_BEFORE", "PARAMETERS_PAREN_AFTER", "PARAMETERS_PAREN_EMPTY", "ARROW_PARAMETERS_PAREN_BEFORE", "ARROW_PARAMETERS_PAREN_AFTER", "ARROW_PARAMETERS_PAREN_EMPTY", "ARROW_BODY_PAREN_BEFORE", "ARROW_BODY_PAREN_AFTER", "GETTER_PARAMS", "IF_PAREN_BEFORE", "IF_PAREN_AFTER", "EXPORT_PAREN_BEFORE", "EXPORT_PAREN_AFTER", "NEW_CALLEE_PAREN_BEFORE", "NEW_CALLEE_PAREN_AFTER", "NEW_PAREN_BEFORE", "NEW_PAREN_AFTER", "NEW_PAREN_EMPTY", "SETTER_PARAM_BEFORE", "SETTER_PARAM_AFTER", "SWITCH_DISCRIM_PAREN_BEFORE", "SWITCH_DISCRIM_PAREN_AFTER", "WHILE_TEST_PAREN_BEFORE", "WHILE_TEST_PAREN_AFTER", "WITH_PAREN_BEFORE", "WITH_PAREN_AFTER", "OBJECT_BRACE_INITIAL", "OBJECT_BRACE_FINAL", "OBJECT_EMPTY", "BLOCK_BRACE_INITIAL", "BLOCK_BRACE_FINAL", "BLOCK_EMPTY", "CLASS_BRACE_INITIAL", "CLASS_BRACE_FINAL", "CLASS_EMPTY", "CLASS_EXPRESSION_BRACE_INITIAL", "CLASS_EXPRESSION_BRACE_FINAL", "CLASS_EXPRESSION_BRACE_EMPTY", "FUNCTION_BRACE_INITIAL", "FUNCTION_BRACE_FINAL", "FUNCTION_EMPTY", "FUNCTION_EXPRESSION_BRACE_INITIAL", "FUNCTION_EXPRESSION_BRACE_FINAL", "FUNCTION_EXPRESSION_EMPTY", "ARROW_BRACE_INITIAL", "ARROW_BRACE_FINAL", "ARROW_BRACE_EMPTY", "GET_BRACE_INTIAL", "GET_BRACE_FINAL", "GET_BRACE_EMPTY", "MISSING_ELSE_INTIIAL", "MISSING_ELSE_FINAL", "MISSING_ELSE_EMPTY", "IMPORT_BRACE_INTIAL", "IMPORT_BRACE_FINAL", "IMPORT_BRACE_EMPTY", "EXPORT_BRACE_INITIAL", "EXPORT_BRACE_FINAL", "EXPORT_BRACE_EMPTY", "METHOD_BRACE_INTIAL", "METHOD_BRACE_FINAL", "METHOD_BRACE_EMPTY", "SET_BRACE_INTIIAL", "SET_BRACE_FINAL", "SET_BRACE_EMPTY", "SWITCH_BRACE_INTIAL", "SWITCH_BRACE_FINAL", "SWITCH_BRACE_EMPTY", "ARRAY_INITIAL", "ARRAY_FINAL", "COMPUTED_MEMBER_BRACKET_INTIAL", "COMPUTED_MEMBER_BRACKET_FINAL", "COMPUTED_PROPERTY_BRACKET_INTIAL", "COMPUTED_PROPERTY_BRACKET_FINAL"]; + for (var i = 0; i < separatorNames.length; ++i) { + Sep[separatorNames[i]] = { type: separatorNames[i] }; + } - /** - * Converts an object into an array of key, value arrays. Only the object's - * own properties are used. - * Note that the order of the output array is not guaranteed to be consistent - * across different JS platforms. - * - * @func - * @memberOf R - * @since v0.4.0 - * @category Object - * @sig {String: *} -> [[String,*]] - * @param {Object} obj The object to extract from - * @return {Array} An array of key, value arrays from the object's own properties. - * @see R.fromPairs - * @example - * - * R.toPairs({a: 1, b: 2, c: 3}); //=> [['a', 1], ['b', 2], ['c', 3]] - */ - var toPairs = _curry1(function toPairs(obj) { - var pairs = []; - for (var prop in obj) { - if (_has(prop, obj)) { - pairs[pairs.length] = [ - prop, - obj[prop] - ]; - } - } - return pairs; - }); + Sep.BEFORE_ASSIGN_OP = function (op) { + return { + type: "BEFORE_ASSIGN_OP", + op: op + }; + }; - /** - * Converts an object into an array of key, value arrays. The object's own - * properties and prototype properties are used. Note that the order of the - * output array is not guaranteed to be consistent across different JS - * platforms. - * - * @func - * @memberOf R - * @since v0.4.0 - * @category Object - * @sig {String: *} -> [[String,*]] - * @param {Object} obj The object to extract from - * @return {Array} An array of key, value arrays from the object's own - * and prototype properties. - * @example - * - * var F = function() { this.x = 'X'; }; - * F.prototype.y = 'Y'; - * var f = new F(); - * R.toPairsIn(f); //=> [['x','X'], ['y','Y']] - */ - var toPairsIn = _curry1(function toPairsIn(obj) { - var pairs = []; - for (var prop in obj) { - pairs[pairs.length] = [ - prop, - obj[prop] - ]; - } - return pairs; - }); + Sep.AFTER_ASSIGN_OP = function (op) { + return { + type: "AFTER_ASSIGN_OP", + op: op + }; + }; - /** - * Transposes the rows and columns of a 2D list. - * When passed a list of `n` lists of length `x`, - * returns a list of `x` lists of length `n`. - * - * - * @func - * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category List - * @sig [[a]] -> [[a]] - * @param {Array} list A 2D list - * @return {Array} A 2D list - * @example - * - * R.transpose([[1, 'a'], [2, 'b'], [3, 'c']]) //=> [[1, 2, 3], ['a', 'b', 'c']] - * R.transpose([[1, 2, 3], ['a', 'b', 'c']]) //=> [[1, 'a'], [2, 'b'], [3, 'c']] - * - * If some of the rows are shorter than the following rows, their elements are skipped: - * - * R.transpose([[10, 11], [20], [], [30, 31, 32]]) //=> [[10, 20, 30], [11, 31], [32]] - */ - var transpose = _curry1(function transpose(outerlist) { - var i = 0; - var result = []; - while (i < outerlist.length) { - var innerlist = outerlist[i]; - var j = 0; - while (j < innerlist.length) { - if (typeof result[j] === 'undefined') { - result[j] = []; - } - result[j].push(innerlist[j]); - j += 1; - } - i += 1; - } - return result; - }); + Sep.BEFORE_BINOP = function (op) { + return { + type: "BEFORE_BINOP", + op: op + }; + }; - /** - * Removes (strips) whitespace from both ends of the string. - * - * @func - * @memberOf R - * @since v0.6.0 - * @category String - * @sig String -> String - * @param {String} str The string to trim. - * @return {String} Trimmed version of `str`. - * @example - * - * R.trim(' xyz '); //=> 'xyz' - * R.map(R.trim, R.split(',', 'x, y, z')); //=> ['x', 'y', 'z'] - */ - var trim = function () { - var ws = '\t\n\x0B\f\r \xA0\u1680\u180E\u2000\u2001\u2002\u2003' + '\u2004\u2005\u2006\u2007\u2008\u2009\u200A\u202F\u205F\u3000\u2028' + '\u2029\uFEFF'; - var zeroWidth = '\u200B'; - var hasProtoTrim = typeof String.prototype.trim === 'function'; - if (!hasProtoTrim || (ws.trim() || !zeroWidth.trim())) { - return _curry1(function trim(str) { - var beginRx = new RegExp('^[' + ws + '][' + ws + ']*'); - var endRx = new RegExp('[' + ws + '][' + ws + ']*$'); - return str.replace(beginRx, '').replace(endRx, ''); - }); - } else { - return _curry1(function trim(str) { - return str.trim(); - }); - } - }(); + Sep.AFTER_BINOP = function (op) { + return { + type: "AFTER_BINOP", + op: op + }; + }; - /** - * Gives a single-word string description of the (native) type of a value, - * returning such answers as 'Object', 'Number', 'Array', or 'Null'. Does not - * attempt to distinguish user Object types any further, reporting them all as - * 'Object'. - * - * @func - * @memberOf R - * @since v0.8.0 - * @category Type - * @sig (* -> {*}) -> String - * @param {*} val The value to test - * @return {String} - * @example - * - * R.type({}); //=> "Object" - * R.type(1); //=> "Number" - * R.type(false); //=> "Boolean" - * R.type('s'); //=> "String" - * R.type(null); //=> "Null" - * R.type([]); //=> "Array" - * R.type(/[A-z]/); //=> "RegExp" - */ - var type = _curry1(function type(val) { - return val === null ? 'Null' : val === undefined ? 'Undefined' : Object.prototype.toString.call(val).slice(8, -1); - }); + Sep.BEFORE_POSTFIX = function (op) { + return { + type: "BEFORE_POSTFIX", + op: op + }; + }; - /** - * Takes a function `fn`, which takes a single array argument, and returns a - * function which: - * - * - takes any number of positional arguments; - * - passes these arguments to `fn` as an array; and - * - returns the result. - * - * In other words, R.unapply derives a variadic function from a function which - * takes an array. R.unapply is the inverse of R.apply. - * - * @func - * @memberOf R - * @since v0.8.0 - * @category Function - * @sig ([*...] -> a) -> (*... -> a) - * @param {Function} fn - * @return {Function} - * @see R.apply - * @example - * - * R.unapply(JSON.stringify)(1, 2, 3); //=> '[1,2,3]' - */ - var unapply = _curry1(function unapply(fn) { - return function () { - return fn(_slice(arguments)); - }; - }); + Sep.UNARY = function (op) { + return { + type: "UNARY", + op: op + }; + }; - /** - * Wraps a function of any arity (including nullary) in a function that accepts - * exactly 1 parameter. Any extraneous parameters will not be passed to the - * supplied function. - * - * @func - * @memberOf R - * @since v0.2.0 - * @category Function - * @sig (* -> b) -> (a -> b) - * @param {Function} fn The function to wrap. - * @return {Function} A new function wrapping `fn`. The new function is guaranteed to be of - * arity 1. - * @example - * - * var takesTwoArgs = function(a, b) { - * return [a, b]; - * }; - * takesTwoArgs.length; //=> 2 - * takesTwoArgs(1, 2); //=> [1, 2] - * - * var takesOneArg = R.unary(takesTwoArgs); - * takesOneArg.length; //=> 1 - * // Only 1 argument is passed to the wrapped function - * takesOneArg(1, 2); //=> [1, undefined] - */ - var unary = _curry1(function unary(fn) { - return nAry(1, fn); - }); + Sep.AFTER_STATEMENT = function (node) { + return { + type: "AFTER_STATEMENT", + node: node + }; + }; - /** - * Returns a function of arity `n` from a (manually) curried function. - * - * @func - * @memberOf R - * @since v0.14.0 - * @category Function - * @sig Number -> (a -> b) -> (a -> c) - * @param {Number} length The arity for the returned function. - * @param {Function} fn The function to uncurry. - * @return {Function} A new function. - * @see R.curry - * @example - * - * var addFour = a => b => c => d => a + b + c + d; - * - * var uncurriedAddFour = R.uncurryN(4, addFour); - * uncurriedAddFour(1, 2, 3, 4); //=> 10 - */ - var uncurryN = _curry2(function uncurryN(depth, fn) { - return curryN(depth, function () { - var currentDepth = 1; - var value = fn; - var idx = 0; - var endIdx; - while (currentDepth <= depth && typeof value === 'function') { - endIdx = currentDepth === depth ? arguments.length : idx + value.length; - value = value.apply(this, _slice(arguments, idx, endIdx)); - currentDepth += 1; - idx = endIdx; - } - return value; - }); - }); + Sep.BEFORE_FUNCTION_NAME = function (node) { + return { + type: "BEFORE_FUNCTION_NAME", + node: node + }; + }; + exports.Sep = Sep; - /** - * Builds a list from a seed value. Accepts an iterator function, which returns - * either false to stop iteration or an array of length 2 containing the value - * to add to the resulting list and the seed to be used in the next call to the - * iterator function. - * - * The iterator function receives one argument: *(seed)*. - * - * @func - * @memberOf R - * @since v0.10.0 - * @category List - * @sig (a -> [b]) -> * -> [b] - * @param {Function} fn The iterator function. receives one argument, `seed`, and returns - * either false to quit iteration or an array of length two to proceed. The element - * at index 0 of this array will be added to the resulting array, and the element - * at index 1 will be passed to the next call to `fn`. - * @param {*} seed The seed value. - * @return {Array} The final list. - * @example - * - * var f = n => n > 50 ? false : [-n, n + 10]; - * R.unfold(f, 10); //=> [-10, -20, -30, -40, -50] - */ - var unfold = _curry2(function unfold(fn, seed) { - var pair = fn(seed); - var result = []; - while (pair && pair.length) { - result[result.length] = pair[0]; - pair = fn(pair[1]); - } - return result; - }); + var ExtensibleCodeGen = exports.ExtensibleCodeGen = function () { + function ExtensibleCodeGen() { + _classCallCheck(this, ExtensibleCodeGen); + } - /** - * Returns a new list containing only one copy of each element in the original - * list, based upon the value returned by applying the supplied predicate to - * two list elements. Prefers the first item if two items compare equal based - * on the predicate. - * - * @func - * @memberOf R - * @since v0.2.0 - * @category List - * @sig (a, a -> Boolean) -> [a] -> [a] - * @param {Function} pred A predicate used to test whether two items are equal. - * @param {Array} list The array to consider. - * @return {Array} The list of unique items. - * @example - * - * var strEq = R.eqBy(String); - * R.uniqWith(strEq)([1, '1', 2, 1]); //=> [1, 2] - * R.uniqWith(strEq)([{}, {}]); //=> [{}] - * R.uniqWith(strEq)([1, '1', 1]); //=> [1] - * R.uniqWith(strEq)(['1', 1, 1]); //=> ['1'] - */ - var uniqWith = _curry2(function uniqWith(pred, list) { - var idx = 0; - var len = list.length; - var result = []; - var item; - while (idx < len) { - item = list[idx]; - if (!_containsWith(pred, item, result)) { - result[result.length] = item; - } - idx += 1; + _createClass(ExtensibleCodeGen, [{ + key: "parenToAvoidBeingDirective", + value: function parenToAvoidBeingDirective(element, original) { + if (element && element.type === "ExpressionStatement" && element.expression.type === "LiteralStringExpression") { + return seq(this.paren(original.children[0], Sep.PAREN_AVOIDING_DIRECTIVE_BEFORE, Sep.PAREN_AVOIDING_DIRECTIVE_AFTER), this.semiOp()); + } + return original; + } + }, { + key: "t", + value: function t(token) { + return new _coderep.Token(token); + } + }, { + key: "p", + value: function p(node, precedence, a) { + return (0, _coderep.getPrecedence)(node) < precedence ? this.paren(a, Sep.PRECEDENCE_BEFORE, Sep.PRECEDENCE_AFTER) : a; + } + }, { + key: "getAssignmentExpr", + value: function getAssignmentExpr(state) { + return state ? state.containsGroup ? this.paren(state, Sep.EXPRESSION_PAREN_BEFORE, Sep.EXPRESSION_PAREN_AFTER) : state : empty(); + } + }, { + key: "paren", + value: function paren(rep, first, last, empty) { + if (isEmpty(rep)) { + return new _coderep.Paren(this.sep(empty)); + } + return new _coderep.Paren(seq(first ? this.sep(first) : new _coderep.Empty(), rep, last ? this.sep(last) : new _coderep.Empty())); + } + }, { + key: "brace", + value: function brace(rep, node, first, last, empty) { + if (isEmpty(rep)) { + return new _coderep.Brace(this.sep(empty)); + } + return new _coderep.Brace(seq(this.sep(first), rep, this.sep(last))); + } + }, { + key: "bracket", + value: function bracket(rep, first, last, empty) { + if (isEmpty(rep)) { + return new _coderep.Bracket(this.sep(empty)); + } + return new _coderep.Bracket(seq(this.sep(first), rep, this.sep(last))); + } + }, { + key: "commaSep", + value: function commaSep(pieces, before, after) { + var _this = this; + + var first = true; + pieces = pieces.map(function (p) { + if (first) { + first = false; + return p; + } else { + return seq(_this.sep(before), _this.t(","), _this.sep(after), p); } - return result; - }); + }); + return seq.apply(undefined, _toConsumableArray(pieces)); + } + }, { + key: "semiOp", + value: function semiOp() { + return new _coderep.SemiOp(); + } + }, { + key: "sep", + value: function sep(kind) { + return new _coderep.Empty(); + } + }, { + key: "reduceArrayExpression", + value: function reduceArrayExpression(node, _ref) { + var _this2 = this; - /** - * Tests the final argument by passing it to the given predicate function. If - * the predicate is not satisfied, the function will return the result of - * calling the `whenFalseFn` function with the same argument. If the predicate - * is satisfied, the argument is returned as is. - * - * @func - * @memberOf R - * @since v0.18.0 - * @category Logic - * @sig (a -> Boolean) -> (a -> a) -> a -> a - * @param {Function} pred A predicate function - * @param {Function} whenFalseFn A function to invoke when the `pred` evaluates - * to a falsy value. - * @param {*} x An object to test with the `pred` function and - * pass to `whenFalseFn` if necessary. - * @return {*} Either `x` or the result of applying `x` to `whenFalseFn`. - * @see R.ifElse, R.when - * @example - * - * // coerceArray :: (a|[a]) -> [a] - * var coerceArray = R.unless(R.isArrayLike, R.of); - * coerceArray([1, 2, 3]); //=> [1, 2, 3] - * coerceArray(1); //=> [1] - */ - var unless = _curry3(function unless(pred, whenFalseFn, x) { - return pred(x) ? x : whenFalseFn(x); - }); + var elements = _ref.elements; - /** - * Returns a new copy of the array with the element at the provided index - * replaced with the given value. - * - * @func - * @memberOf R - * @since v0.14.0 - * @category List - * @sig Number -> a -> [a] -> [a] - * @param {Number} idx The index to update. - * @param {*} x The value to exist at the given index of the returned array. - * @param {Array|Arguments} list The source array-like object to be updated. - * @return {Array} A copy of `list` with the value at index `idx` replaced with `x`. - * @see R.adjust - * @example - * - * R.update(1, 11, [0, 1, 2]); //=> [0, 11, 2] - * R.update(1)(11)([0, 1, 2]); //=> [0, 11, 2] - */ - var update = _curry3(function update(idx, x, list) { - return adjust(always(x), idx, list); - }); + if (elements.length === 0) { + return this.bracket(empty(), null, null, Sep.ARRAY_EMPTY); + } - /** - * Accepts a function `fn` and a list of transformer functions and returns a - * new curried function. When the new function is invoked, it calls the - * function `fn` with parameters consisting of the result of calling each - * supplied handler on successive arguments to the new function. - * - * If more arguments are passed to the returned function than transformer - * functions, those arguments are passed directly to `fn` as additional - * parameters. If you expect additional arguments that don't need to be - * transformed, although you can ignore them, it's best to pass an identity - * function so that the new function reports the correct arity. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig (x1 -> x2 -> ... -> z) -> [(a -> x1), (b -> x2), ...] -> (a -> b -> ... -> z) - * @param {Function} fn The function to wrap. - * @param {Array} transformers A list of transformer functions - * @return {Function} The wrapped function. - * @example - * - * R.useWith(Math.pow, [R.identity, R.identity])(3, 4); //=> 81 - * R.useWith(Math.pow, [R.identity, R.identity])(3)(4); //=> 81 - * R.useWith(Math.pow, [R.dec, R.inc])(3, 4); //=> 32 - * R.useWith(Math.pow, [R.dec, R.inc])(3)(4); //=> 32 - */ - var useWith = _curry2(function useWith(fn, transformers) { - return curryN(transformers.length, function () { - var args = []; - var idx = 0; - while (idx < transformers.length) { - args.push(transformers[idx].call(this, arguments[idx])); - idx += 1; - } - return fn.apply(this, args.concat(_slice(arguments, transformers.length))); - }); - }); + var content = this.commaSep(elements.map(function (e) { + return _this2.getAssignmentExpr(e); + }), Sep.ARRAY_BEFORE_COMMA, Sep.ARRAY_AFTER_COMMA); + if (elements.length > 0 && elements[elements.length - 1] == null) { + content = seq(content, this.sep(Sep.ARRAY_BEFORE_COMMA), this.t(","), this.sep(Sep.ARRAY_AFTER_COMMA)); + } + return this.bracket(content, Sep.ARRAY_INITIAL, Sep.ARRAY_FINAL); + } + }, { + key: "reduceSpreadElement", + value: function reduceSpreadElement(node, _ref2) { + var expression = _ref2.expression; - /** - * Returns a list of all the enumerable own properties of the supplied object. - * Note that the order of the output array is not guaranteed across different - * JS platforms. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Object - * @sig {k: v} -> [v] - * @param {Object} obj The object to extract values from - * @return {Array} An array of the values of the object's own properties. - * @example - * - * R.values({a: 1, b: 2, c: 3}); //=> [1, 2, 3] - */ - var values = _curry1(function values(obj) { - var props = keys(obj); - var len = props.length; - var vals = []; - var idx = 0; - while (idx < len) { - vals[idx] = obj[props[idx]]; - idx += 1; - } - return vals; - }); + return seq(this.t("..."), this.sep(Sep.SPREAD), this.p(node.expression, _coderep.Precedence.Assignment, expression)); + } + }, { + key: "reduceAssignmentExpression", + value: function reduceAssignmentExpression(node, _ref3) { + var binding = _ref3.binding; + var expression = _ref3.expression; - /** - * Returns a list of all the properties, including prototype properties, of the - * supplied object. - * Note that the order of the output array is not guaranteed to be consistent - * across different JS platforms. - * - * @func - * @memberOf R - * @since v0.2.0 - * @category Object - * @sig {k: v} -> [v] - * @param {Object} obj The object to extract values from - * @return {Array} An array of the values of the object's own and prototype properties. - * @example - * - * var F = function() { this.x = 'X'; }; - * F.prototype.y = 'Y'; - * var f = new F(); - * R.valuesIn(f); //=> ['X', 'Y'] - */ - var valuesIn = _curry1(function valuesIn(obj) { - var prop; - var vs = []; - for (prop in obj) { - vs[vs.length] = obj[prop]; - } - return vs; - }); + var leftCode = binding; + var rightCode = expression; + var containsIn = expression.containsIn; + var startsWithCurly = binding.startsWithCurly; + var startsWithLetSquareBracket = binding.startsWithLetSquareBracket; + var startsWithFunctionOrClass = binding.startsWithFunctionOrClass; + if ((0, _coderep.getPrecedence)(node.expression) < (0, _coderep.getPrecedence)(node)) { + rightCode = this.paren(rightCode, Sep.EXPRESSION_PAREN_BEFORE, Sep.EXPRESSION_PAREN_AFTER); + containsIn = false; + } + return (0, _objectAssign2.default)(seq(leftCode, this.sep(Sep.BEFORE_ASSIGN_OP("=")), this.t("="), this.sep(Sep.AFTER_ASSIGN_OP("=")), rightCode), { containsIn: containsIn, startsWithCurly: startsWithCurly, startsWithLetSquareBracket: startsWithLetSquareBracket, startsWithFunctionOrClass: startsWithFunctionOrClass }); + } + }, { + key: "reduceCompoundAssignmentExpression", + value: function reduceCompoundAssignmentExpression(node, _ref4) { + var binding = _ref4.binding; + var expression = _ref4.expression; - /** - * Returns a "view" of the given data structure, determined by the given lens. - * The lens's focus determines which portion of the data structure is visible. - * - * @func - * @memberOf R - * @since v0.16.0 - * @category Object - * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s - * @sig Lens s a -> s -> a - * @param {Lens} lens - * @param {*} x - * @return {*} - * @see R.prop, R.lensIndex, R.lensProp - * @example - * - * var xLens = R.lensProp('x'); - * - * R.view(xLens, {x: 1, y: 2}); //=> 1 - * R.view(xLens, {x: 4, y: 2}); //=> 4 - */ - var view = function () { - var Const = function (x) { - return { - value: x, - map: function () { - return this; - } - }; - }; - return _curry2(function view(lens, x) { - return lens(Const)(x).value; - }); - }(); + var leftCode = binding; + var rightCode = expression; + var containsIn = expression.containsIn; + var startsWithCurly = binding.startsWithCurly; + var startsWithLetSquareBracket = binding.startsWithLetSquareBracket; + var startsWithFunctionOrClass = binding.startsWithFunctionOrClass; + if ((0, _coderep.getPrecedence)(node.expression) < (0, _coderep.getPrecedence)(node)) { + rightCode = this.paren(rightCode, Sep.EXPRESSION_PAREN_BEFORE, Sep.EXPRESSION_PAREN_AFTER); + containsIn = false; + } + return (0, _objectAssign2.default)(seq(leftCode, this.sep(Sep.BEFORE_ASSIGN_OP(node.operator)), this.t(node.operator), this.sep(Sep.AFTER_ASSIGN_OP(node.operator)), rightCode), { containsIn: containsIn, startsWithCurly: startsWithCurly, startsWithLetSquareBracket: startsWithLetSquareBracket, startsWithFunctionOrClass: startsWithFunctionOrClass }); + } + }, { + key: "reduceBinaryExpression", + value: function reduceBinaryExpression(node, _ref5) { + var left = _ref5.left; + var right = _ref5.right; - /** - * Tests the final argument by passing it to the given predicate function. If - * the predicate is satisfied, the function will return the result of calling - * the `whenTrueFn` function with the same argument. If the predicate is not - * satisfied, the argument is returned as is. - * - * @func - * @memberOf R - * @since v0.18.0 - * @category Logic - * @sig (a -> Boolean) -> (a -> a) -> a -> a - * @param {Function} pred A predicate function - * @param {Function} whenTrueFn A function to invoke when the `condition` - * evaluates to a truthy value. - * @param {*} x An object to test with the `pred` function and - * pass to `whenTrueFn` if necessary. - * @return {*} Either `x` or the result of applying `x` to `whenTrueFn`. - * @see R.ifElse, R.unless - * @example - * - * // truncate :: String -> String - * var truncate = R.when( - * R.propSatisfies(R.gt(R.__, 10), 'length'), - * R.pipe(R.take(10), R.append('…'), R.join('')) - * ); - * truncate('12345'); //=> '12345' - * truncate('0123456789ABC'); //=> '0123456789…' - */ - var when = _curry3(function when(pred, whenTrueFn, x) { - return pred(x) ? whenTrueFn(x) : x; - }); + var leftCode = left; + var startsWithCurly = left.startsWithCurly; + var startsWithLetSquareBracket = left.startsWithLetSquareBracket; + var startsWithFunctionOrClass = left.startsWithFunctionOrClass; + var leftContainsIn = left.containsIn; + if ((0, _coderep.getPrecedence)(node.left) < (0, _coderep.getPrecedence)(node)) { + leftCode = this.paren(leftCode, Sep.EXPRESSION_PAREN_BEFORE, Sep.EXPRESSION_PAREN_AFTER); + startsWithCurly = false; + startsWithLetSquareBracket = false; + startsWithFunctionOrClass = false; + leftContainsIn = false; + } + var rightCode = right; + var rightContainsIn = right.containsIn; + if ((0, _coderep.getPrecedence)(node.right) <= (0, _coderep.getPrecedence)(node)) { + rightCode = this.paren(rightCode, Sep.EXPRESSION_PAREN_BEFORE, Sep.EXPRESSION_PAREN_AFTER); + rightContainsIn = false; + } + return (0, _objectAssign2.default)(seq(leftCode, this.sep(Sep.BEFORE_BINOP(node.operator)), this.t(node.operator), this.sep(Sep.AFTER_BINOP(node.operator)), rightCode), { + containsIn: leftContainsIn || rightContainsIn || node.operator === "in", + containsGroup: node.operator == ",", + startsWithCurly: startsWithCurly, + startsWithLetSquareBracket: startsWithLetSquareBracket, + startsWithFunctionOrClass: startsWithFunctionOrClass + }); + } + }, { + key: "reduceBindingWithDefault", + value: function reduceBindingWithDefault(node, _ref6) { + var binding = _ref6.binding; + var init = _ref6.init; - /** - * Takes a spec object and a test object; returns true if the test satisfies - * the spec. Each of the spec's own properties must be a predicate function. - * Each predicate is applied to the value of the corresponding property of the - * test object. `where` returns true if all the predicates return true, false - * otherwise. - * - * `where` is well suited to declaratively expressing constraints for other - * functions such as `filter` and `find`. - * - * @func - * @memberOf R - * @since v0.1.1 - * @category Object - * @sig {String: (* -> Boolean)} -> {String: *} -> Boolean - * @param {Object} spec - * @param {Object} testObj - * @return {Boolean} - * @example - * - * // pred :: Object -> Boolean - * var pred = R.where({ - * a: R.equals('foo'), - * b: R.complement(R.equals('bar')), - * x: R.gt(_, 10), - * y: R.lt(_, 20) - * }); - * - * pred({a: 'foo', b: 'xxx', x: 11, y: 19}); //=> true - * pred({a: 'xxx', b: 'xxx', x: 11, y: 19}); //=> false - * pred({a: 'foo', b: 'bar', x: 11, y: 19}); //=> false - * pred({a: 'foo', b: 'xxx', x: 10, y: 19}); //=> false - * pred({a: 'foo', b: 'xxx', x: 11, y: 20}); //=> false - */ - var where = _curry2(function where(spec, testObj) { - for (var prop in spec) { - if (_has(prop, spec) && !spec[prop](testObj[prop])) { - return false; - } - } - return true; - }); + return seq(binding, this.sep(Sep.BEFORE_DEFAULT_EQUALS), this.t("="), this.sep(Sep.AFTER_DEFAULT_EQUALS), init); + } + }, { + key: "reduceBindingIdentifier", + value: function reduceBindingIdentifier(node) { + var a = this.t(node.name); + if (node.name === "let") { + a.startsWithLet = true; + } + return a; + } + }, { + key: "reduceArrayBinding", + value: function reduceArrayBinding(node, _ref7) { + var _this3 = this; - /** - * Wrap a function inside another to allow you to make adjustments to the - * parameters, or do other processing either before the internal function is - * called or with its results. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig (a... -> b) -> ((a... -> b) -> a... -> c) -> (a... -> c) - * @param {Function} fn The function to wrap. - * @param {Function} wrapper The wrapper function. - * @return {Function} The wrapped function. - * @example - * - * var greet = name => 'Hello ' + name; - * - * var shoutedGreet = R.wrap(greet, (gr, name) => gr(name).toUpperCase()); - * - * shoutedGreet("Kathy"); //=> "HELLO KATHY" - * - * var shortenedGreet = R.wrap(greet, function(gr, name) { - * return gr(name.substring(0, 3)); - * }); - * shortenedGreet("Robert"); //=> "Hello Rob" - */ - var wrap = _curry2(function wrap(fn, wrapper) { - return curryN(fn.length, function () { - return wrapper.apply(this, _concat([fn], arguments)); - }); - }); + var elements = _ref7.elements; + var restElement = _ref7.restElement; - /** - * Creates a new list out of the two supplied by creating each possible pair - * from the lists. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig [a] -> [b] -> [[a,b]] - * @param {Array} as The first list. - * @param {Array} bs The second list. - * @return {Array} The list made by combining each possible pair from - * `as` and `bs` into pairs (`[a, b]`). - * @example - * - * R.xprod([1, 2], ['a', 'b']); //=> [[1, 'a'], [1, 'b'], [2, 'a'], [2, 'b']] - */ - // = xprodWith(prepend); (takes about 3 times as long...) - var xprod = _curry2(function xprod(a, b) { - // = xprodWith(prepend); (takes about 3 times as long...) - var idx = 0; - var ilen = a.length; - var j; - var jlen = b.length; - var result = []; - while (idx < ilen) { - j = 0; - while (j < jlen) { - result[result.length] = [ - a[idx], - b[j] - ]; - j += 1; - } - idx += 1; + var content = undefined; + if (elements.length === 0) { + content = restElement == null ? empty() : seq(this.t("..."), this.sep(Sep.REST), restElement); + } else { + elements = elements.concat(restElement == null ? [] : [seq(this.t("..."), this.sep(Sep.REST), restElement)]); + content = this.commaSep(elements.map(function (e) { + return _this3.getAssignmentExpr(e); + }), Sep.ARRAY_BEFORE_COMMA, Sep.ARRAY_AFTER_COMMA); + if (elements.length > 0 && elements[elements.length - 1] == null) { + content = seq(content, this.sep(Sep.ARRAY_BEFORE_COMMA), this.t(","), this.sep(Sep.ARRAY_AFTER_COMMA)); } - return result; - }); + } + return this.bracket(content, Sep.ARRAY_INITIAL, Sep.ARRAY_FINAL, Sep.ARRAY_EMPTY); + } + }, { + key: "reduceObjectBinding", + value: function reduceObjectBinding(node, _ref8) { + var properties = _ref8.properties; - /** - * Creates a new list out of the two supplied by pairing up equally-positioned - * items from both lists. The returned list is truncated to the length of the - * shorter of the two input lists. - * Note: `zip` is equivalent to `zipWith(function(a, b) { return [a, b] })`. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig [a] -> [b] -> [[a,b]] - * @param {Array} list1 The first array to consider. - * @param {Array} list2 The second array to consider. - * @return {Array} The list made by pairing up same-indexed elements of `list1` and `list2`. - * @example - * - * R.zip([1, 2, 3], ['a', 'b', 'c']); //=> [[1, 'a'], [2, 'b'], [3, 'c']] - */ - var zip = _curry2(function zip(a, b) { - var rv = []; - var idx = 0; - var len = Math.min(a.length, b.length); - while (idx < len) { - rv[idx] = [ - a[idx], - b[idx] - ]; - idx += 1; - } - return rv; - }); + var state = this.brace(this.commaSep(properties, Sep.OBJECT_BEFORE_COMMA, Sep.OBJECT_AFTER_COMMA), node, Sep.OBJECT_BRACE_INITIAL, Sep.OBJECT_BRACE_FINAL, Sep.OBJECT_EMPTY); + state.startsWithCurly = true; + return state; + } + }, { + key: "reduceBindingPropertyIdentifier", + value: function reduceBindingPropertyIdentifier(node, _ref9) { + var binding = _ref9.binding; + var init = _ref9.init; - /** - * Creates a new object out of a list of keys and a list of values. - * - * @func - * @memberOf R - * @since v0.3.0 - * @category List - * @sig [String] -> [*] -> {String: *} - * @param {Array} keys The array that will be properties on the output object. - * @param {Array} values The list of values on the output object. - * @return {Object} The object made by pairing up same-indexed elements of `keys` and `values`. - * @example - * - * R.zipObj(['a', 'b', 'c'], [1, 2, 3]); //=> {a: 1, b: 2, c: 3} - */ - var zipObj = _curry2(function zipObj(keys, values) { - var idx = 0; - var len = keys.length; - var out = {}; - while (idx < len) { - out[keys[idx]] = values[idx]; - idx += 1; - } - return out; - }); + if (node.init == null) return binding; + return seq(binding, this.sep(Sep.BEFORE_DEFAULT_EQUALS), this.t("="), this.sep(Sep.AFTER_DEFAULT_EQUALS), init); + } + }, { + key: "reduceBindingPropertyProperty", + value: function reduceBindingPropertyProperty(node, _ref10) { + var name = _ref10.name; + var binding = _ref10.binding; - /** - * Creates a new list out of the two supplied by applying the function to each - * equally-positioned pair in the lists. The returned list is truncated to the - * length of the shorter of the two input lists. - * - * @function - * @memberOf R - * @since v0.1.0 - * @category List - * @sig (a,b -> c) -> [a] -> [b] -> [c] - * @param {Function} fn The function used to combine the two elements into one value. - * @param {Array} list1 The first array to consider. - * @param {Array} list2 The second array to consider. - * @return {Array} The list made by combining same-indexed elements of `list1` and `list2` - * using `fn`. - * @example - * - * var f = (x, y) => { - * // ... - * }; - * R.zipWith(f, [1, 2, 3], ['a', 'b', 'c']); - * //=> [f(1, 'a'), f(2, 'b'), f(3, 'c')] - */ - var zipWith = _curry3(function zipWith(fn, a, b) { - var rv = []; - var idx = 0; - var len = Math.min(a.length, b.length); - while (idx < len) { - rv[idx] = fn(a[idx], b[idx]); - idx += 1; - } - return rv; - }); + return seq(name, this.sep(Sep.BEFORE_PROP), this.t(":"), this.sep(Sep.AFTER_PROP), binding); + } + }, { + key: "reduceBlock", + value: function reduceBlock(node, _ref11) { + var statements = _ref11.statements; - /** - * A function that always returns `false`. Any passed in parameters are ignored. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Function - * @sig * -> Boolean - * @param {*} - * @return {Boolean} - * @see R.always, R.T - * @example - * - * R.F(); //=> false - */ - var F = always(false); + return this.brace(seq.apply(undefined, _toConsumableArray(statements)), node, Sep.BLOCK_BRACE_INITIAL, Sep.BLOCK_BRACE_FINAL, Sep.BLOCK_EMPTY); + } + }, { + key: "reduceBlockStatement", + value: function reduceBlockStatement(node, _ref12) { + var block = _ref12.block; - /** - * A function that always returns `true`. Any passed in parameters are ignored. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Function - * @sig * -> Boolean - * @param {*} - * @return {Boolean} - * @see R.always, R.F - * @example - * - * R.T(); //=> true - */ - var T = always(true); + return seq(block, this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceBreakStatement", + value: function reduceBreakStatement(node, _ref13) { + var label = _ref13.label; - /** - * Copies an object. - * - * @private - * @param {*} value The value to be copied - * @param {Array} refFrom Array containing the source references - * @param {Array} refTo Array containing the copied source references - * @return {*} The copied value. - */ - var _clone = function _clone(value, refFrom, refTo) { - var copy = function copy(copiedValue) { - var len = refFrom.length; - var idx = 0; - while (idx < len) { - if (value === refFrom[idx]) { - return refTo[idx]; - } - idx += 1; - } - refFrom[idx + 1] = value; - refTo[idx + 1] = copiedValue; - for (var key in value) { - copiedValue[key] = _clone(value[key], refFrom, refTo); - } - return copiedValue; - }; - switch (type(value)) { - case 'Object': - return copy({}); - case 'Array': - return copy([]); - case 'Date': - return new Date(value.valueOf()); - case 'RegExp': - return _cloneRegExp(value); - default: - return value; - } - }; + return seq(this.t("break"), label ? seq(this.sep(Sep.BEFORE_JUMP_LABEL), this.t(label)) : empty(), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceCallExpression", + value: function reduceCallExpression(node, _ref14) { + var callee = _ref14.callee; + var args = _ref14.arguments; - var _createPartialApplicator = function _createPartialApplicator(concat) { - return _curry2(function (fn, args) { - return _arity(Math.max(0, fn.length - args.length), function () { - return fn.apply(this, concat(args, arguments)); - }); - }); - }; + return (0, _objectAssign2.default)(seq(this.p(node.callee, (0, _coderep.getPrecedence)(node), callee), this.sep(Sep.CALL), this.paren(this.commaSep(args, Sep.ARGS_BEFORE_COMMA, Sep.ARGS_AFTER_COMMA), Sep.CALL_PAREN_BEFORE, Sep.CALL_PAREN_AFTER, Sep.CALL_PAREN_EMPTY)), { + startsWithCurly: callee.startsWithCurly, + startsWithLetSquareBracket: callee.startsWithLetSquareBracket, + startsWithFunctionOrClass: callee.startsWithFunctionOrClass + }); + } + }, { + key: "reduceCatchClause", + value: function reduceCatchClause(node, _ref15) { + var binding = _ref15.binding; + var body = _ref15.body; - var _dropLast = function dropLast(n, xs) { - return take(n < xs.length ? xs.length - n : 0, xs); - }; + return seq(this.t("catch"), this.sep(Sep.BEFORE_CATCH_BINDING), this.paren(binding, Sep.CATCH_PAREN_BEFORE, Sep.CATCH_PAREN_AFTER), this.sep(Sep.AFTER_CATCH_BINDING), body); + } + }, { + key: "reduceClassDeclaration", + value: function reduceClassDeclaration(node, _ref16) { + var name = _ref16.name; + var _super = _ref16.super; + var elements = _ref16.elements; - // Values of other types are only equal if identical. - var _equals = function _equals(a, b, stackA, stackB) { - if (identical(a, b)) { - return true; - } - if (type(a) !== type(b)) { - return false; - } - if (a == null || b == null) { - return false; - } - if (typeof a.equals === 'function' || typeof b.equals === 'function') { - return typeof a.equals === 'function' && a.equals(b) && typeof b.equals === 'function' && b.equals(a); - } - switch (type(a)) { - case 'Arguments': - case 'Array': - case 'Object': - break; - case 'Boolean': - case 'Number': - case 'String': - if (!(typeof a === typeof b && identical(a.valueOf(), b.valueOf()))) { - return false; - } - break; - case 'Date': - if (!identical(a.valueOf(), b.valueOf())) { - return false; - } - break; - case 'Error': - return a.name === b.name && a.message === b.message; - case 'RegExp': - if (!(a.source === b.source && a.global === b.global && a.ignoreCase === b.ignoreCase && a.multiline === b.multiline && a.sticky === b.sticky && a.unicode === b.unicode)) { - return false; - } - break; - case 'Map': - case 'Set': - if (!_equals(_arrayFromIterator(a.entries()), _arrayFromIterator(b.entries()), stackA, stackB)) { - return false; - } - break; - case 'Int8Array': - case 'Uint8Array': - case 'Uint8ClampedArray': - case 'Int16Array': - case 'Uint16Array': - case 'Int32Array': - case 'Uint32Array': - case 'Float32Array': - case 'Float64Array': - break; - case 'ArrayBuffer': - break; - default: - // Values of other types are only equal if identical. - return false; - } - var keysA = keys(a); - if (keysA.length !== keys(b).length) { - return false; - } - var idx = stackA.length - 1; - while (idx >= 0) { - if (stackA[idx] === a) { - return stackB[idx] === b; - } - idx -= 1; - } - stackA.push(a); - stackB.push(b); - idx = keysA.length - 1; - while (idx >= 0) { - var key = keysA[idx]; - if (!(_has(key, b) && _equals(b[key], a[key], stackA, stackB))) { - return false; - } - idx -= 1; - } - stackA.pop(); - stackB.pop(); - return true; - }; + var state = seq(this.t("class"), this.sep(Sep.BEFORE_CLASS_NAME), name); + if (_super != null) { + state = seq(state, this.sep(Sep.BEFORE_EXTENDS), this.t("extends"), this.sep(Sep.AFTER_EXTENDS), _super); + } + state = seq(state, this.sep(Sep.BEFORE_CLASS_DECLARATION_ELEMENTS), this.brace(seq.apply(undefined, _toConsumableArray(elements)), node, Sep.CLASS_BRACE_INITIAL, Sep.CLASS_BRACE_FINAL, Sep.CLASS_EMPTY), this.sep(Sep.AFTER_STATEMENT(node))); + return state; + } + }, { + key: "reduceClassExpression", + value: function reduceClassExpression(node, _ref17) { + var name = _ref17.name; + var _super = _ref17.super; + var elements = _ref17.elements; - /** - * `_makeFlat` is a helper function that returns a one-level or fully recursive - * function based on the flag passed in. - * - * @private - */ - var _makeFlat = function _makeFlat(recursive) { - return function flatt(list) { - var value, jlen, j; - var result = []; - var idx = 0; - var ilen = list.length; - while (idx < ilen) { - if (isArrayLike(list[idx])) { - value = recursive ? flatt(list[idx]) : list[idx]; - j = 0; - jlen = value.length; - while (j < jlen) { - result[result.length] = value[j]; - j += 1; - } - } else { - result[result.length] = list[idx]; - } - idx += 1; - } - return result; - }; - }; + var state = this.t("class"); + if (name != null) { + state = seq(state, this.sep(Sep.BEFORE_CLASS_NAME), name); + } + if (_super != null) { + state = seq(state, this.sep(Sep.BEFORE_EXTENDS), this.t("extends"), this.sep(Sep.AFTER_EXTENDS), _super); + } + state = seq(state, this.sep(Sep.BEFORE_CLASS_EXPRESSION_ELEMENTS), this.brace(seq.apply(undefined, _toConsumableArray(elements)), node, Sep.CLASS_EXPRESSION_BRACE_INITIAL, Sep.CLASS_EXPRESSION_BRACE_FINAL, Sep.CLASS_EXPRESSION_BRACE_EMPTY)); + state.startsWithFunctionOrClass = true; + return state; + } + }, { + key: "reduceClassElement", + value: function reduceClassElement(node, _ref18) { + var method = _ref18.method; - var _reduce = function () { - function _arrayReduce(xf, acc, list) { - var idx = 0; - var len = list.length; - while (idx < len) { - acc = xf['@@transducer/step'](acc, list[idx]); - if (acc && acc['@@transducer/reduced']) { - acc = acc['@@transducer/value']; - break; - } - idx += 1; - } - return xf['@@transducer/result'](acc); - } - function _iterableReduce(xf, acc, iter) { - var step = iter.next(); - while (!step.done) { - acc = xf['@@transducer/step'](acc, step.value); - if (acc && acc['@@transducer/reduced']) { - acc = acc['@@transducer/value']; - break; - } - step = iter.next(); - } - return xf['@@transducer/result'](acc); - } - function _methodReduce(xf, acc, obj) { - return xf['@@transducer/result'](obj.reduce(bind(xf['@@transducer/step'], xf), acc)); - } - var symIterator = typeof Symbol !== 'undefined' ? Symbol.iterator : '@@iterator'; - return function _reduce(fn, acc, list) { - if (typeof fn === 'function') { - fn = _xwrap(fn); - } - if (isArrayLike(list)) { - return _arrayReduce(fn, acc, list); - } - if (typeof list.reduce === 'function') { - return _methodReduce(fn, acc, list); - } - if (list[symIterator] != null) { - return _iterableReduce(fn, acc, list[symIterator]()); - } - if (typeof list.next === 'function') { - return _iterableReduce(fn, acc, list); - } - throw new TypeError('reduce: list must be array or iterable'); - }; - }(); + method = seq(this.sep(Sep.BEFORE_CLASS_ELEMENT), method, this.sep(Sep.AFTER_CLASS_ELEMENT)); + if (!node.isStatic) return method; + return seq(this.t("static"), this.sep(Sep.AFTER_STATIC), method); + } + }, { + key: "reduceComputedMemberExpression", + value: function reduceComputedMemberExpression(node, _ref19) { + var object = _ref19.object; + var expression = _ref19.expression; - var _xdropLastWhile = function () { - function XDropLastWhile(fn, xf) { - this.f = fn; - this.retained = []; - this.xf = xf; - } - XDropLastWhile.prototype['@@transducer/init'] = _xfBase.init; - XDropLastWhile.prototype['@@transducer/result'] = function (result) { - this.retained = null; - return this.xf['@@transducer/result'](result); - }; - XDropLastWhile.prototype['@@transducer/step'] = function (result, input) { - return this.f(input) ? this.retain(result, input) : this.flush(result, input); - }; - XDropLastWhile.prototype.flush = function (result, input) { - result = _reduce(this.xf['@@transducer/step'], result, this.retained); - this.retained = []; - return this.xf['@@transducer/step'](result, input); - }; - XDropLastWhile.prototype.retain = function (result, input) { - this.retained.push(input); - return result; - }; - return _curry2(function _xdropLastWhile(fn, xf) { - return new XDropLastWhile(fn, xf); - }); - }(); + var startsWithLetSquareBracket = object.startsWithLetSquareBracket || node.object.type === "IdentifierExpression" && node.object.name === "let"; + return (0, _objectAssign2.default)(seq(this.p(node.object, (0, _coderep.getPrecedence)(node), object), this.sep(Sep.COMPUTED_MEMBER_EXPRESSION), this.bracket(expression, Sep.COMPUTED_MEMBER_BRACKET_INTIAL, Sep.COMPUTED_MEMBER_BRACKET_FINAL)), { + startsWithLet: object.startsWithLet, + startsWithLetSquareBracket: startsWithLetSquareBracket, + startsWithCurly: object.startsWithCurly, + startsWithFunctionOrClass: object.startsWithFunctionOrClass + }); + } + }, { + key: "reduceComputedPropertyName", + value: function reduceComputedPropertyName(node, _ref20) { + var expression = _ref20.expression; - var _xgroupBy = function () { - function XGroupBy(f, xf) { - this.xf = xf; - this.f = f; - this.inputs = {}; - } - XGroupBy.prototype['@@transducer/init'] = _xfBase.init; - XGroupBy.prototype['@@transducer/result'] = function (result) { - var key; - for (key in this.inputs) { - if (_has(key, this.inputs)) { - result = this.xf['@@transducer/step'](result, this.inputs[key]); - if (result['@@transducer/reduced']) { - result = result['@@transducer/value']; - break; - } - } - } - this.inputs = null; - return this.xf['@@transducer/result'](result); - }; - XGroupBy.prototype['@@transducer/step'] = function (result, input) { - var key = this.f(input); - this.inputs[key] = this.inputs[key] || [ - key, - [] - ]; - this.inputs[key][1] = append(input, this.inputs[key][1]); - return result; - }; - return _curry2(function _xgroupBy(f, xf) { - return new XGroupBy(f, xf); - }); - }(); + return this.bracket(expression, Sep.COMPUTED_PROPERTY_BRACKET_INTIAL, Sep.COMPUTED_PROPERTY_BRACKET_FINAL); + } + }, { + key: "reduceConditionalExpression", + value: function reduceConditionalExpression(node, _ref21) { + var test = _ref21.test; + var consequent = _ref21.consequent; + var alternate = _ref21.alternate; - /** - * Creates a new list iteration function from an existing one by adding two new - * parameters to its callback function: the current index, and the entire list. - * - * This would turn, for instance, Ramda's simple `map` function into one that - * more closely resembles `Array.prototype.map`. Note that this will only work - * for functions in which the iteration callback function is the first - * parameter, and where the list is the last parameter. (This latter might be - * unimportant if the list parameter is not used.) - * - * @func - * @memberOf R - * @since v0.15.0 - * @category Function - * @category List - * @sig ((a ... -> b) ... -> [a] -> *) -> (a ..., Int, [a] -> b) ... -> [a] -> *) - * @param {Function} fn A list iteration function that does not pass index or list to its callback - * @return {Function} An altered list iteration function that passes (item, index, list) to its callback - * @example - * - * var mapIndexed = R.addIndex(R.map); - * mapIndexed((val, idx) => idx + '-' + val, ['f', 'o', 'o', 'b', 'a', 'r']); - * //=> ['0-f', '1-o', '2-o', '3-b', '4-a', '5-r'] - */ - var addIndex = _curry1(function addIndex(fn) { - return curryN(fn.length, function () { - var idx = 0; - var origFn = arguments[0]; - var list = arguments[arguments.length - 1]; - var args = _slice(arguments); - args[0] = function () { - var result = origFn.apply(this, _concat(arguments, [ - idx, - list - ])); - idx += 1; - return result; - }; - return fn.apply(this, args); - }); - }); + var containsIn = test.containsIn || alternate.containsIn; + var startsWithCurly = test.startsWithCurly; + var startsWithLetSquareBracket = test.startsWithLetSquareBracket; + var startsWithFunctionOrClass = test.startsWithFunctionOrClass; + return (0, _objectAssign2.default)(seq(this.p(node.test, _coderep.Precedence.LogicalOR, test), this.sep(Sep.BEFORE_TERNARY_QUESTION), this.t("?"), this.sep(Sep.AFTER_TERNARY_QUESTION), this.p(node.consequent, _coderep.Precedence.Assignment, consequent), this.sep(Sep.BEFORE_TERNARY_COLON), this.t(":"), this.sep(Sep.AFTER_TERNARY_COLON), this.p(node.alternate, _coderep.Precedence.Assignment, alternate)), { + containsIn: containsIn, + startsWithCurly: startsWithCurly, + startsWithLetSquareBracket: startsWithLetSquareBracket, + startsWithFunctionOrClass: startsWithFunctionOrClass + }); + } + }, { + key: "reduceContinueStatement", + value: function reduceContinueStatement(node, _ref22) { + var label = _ref22.label; - /** - * Wraps a function of any arity (including nullary) in a function that accepts - * exactly 2 parameters. Any extraneous parameters will not be passed to the - * supplied function. - * - * @func - * @memberOf R - * @since v0.2.0 - * @category Function - * @sig (* -> c) -> (a, b -> c) - * @param {Function} fn The function to wrap. - * @return {Function} A new function wrapping `fn`. The new function is guaranteed to be of - * arity 2. - * @example - * - * var takesThreeArgs = function(a, b, c) { - * return [a, b, c]; - * }; - * takesThreeArgs.length; //=> 3 - * takesThreeArgs(1, 2, 3); //=> [1, 2, 3] - * - * var takesTwoArgs = R.binary(takesThreeArgs); - * takesTwoArgs.length; //=> 2 - * // Only 2 arguments are passed to the wrapped function - * takesTwoArgs(1, 2, 3); //=> [1, 2, undefined] - */ - var binary = _curry1(function binary(fn) { - return nAry(2, fn); - }); + return seq(this.t("continue"), label ? seq(this.sep(Sep.BEFORE_JUMP_LABEL), this.t(label)) : empty(), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceDataProperty", + value: function reduceDataProperty(node, _ref23) { + var name = _ref23.name; + var expression = _ref23.expression; - /** - * Creates a deep copy of the value which may contain (nested) `Array`s and - * `Object`s, `Number`s, `String`s, `Boolean`s and `Date`s. `Function`s are not - * copied, but assigned by their reference. - * - * Dispatches to a `clone` method if present. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Object - * @sig {*} -> {*} - * @param {*} value The object or array to clone - * @return {*} A new object or array. - * @example - * - * var objects = [{}, {}, {}]; - * var objectsClone = R.clone(objects); - * objects[0] === objectsClone[0]; //=> false - */ - var clone = _curry1(function clone(value) { - return value != null && typeof value.clone === 'function' ? value.clone() : _clone(value, [], []); - }); + return seq(name, this.sep(Sep.BEFORE_PROP), this.t(":"), this.sep(Sep.AFTER_PROP), this.getAssignmentExpr(expression)); + } + }, { + key: "reduceDebuggerStatement", + value: function reduceDebuggerStatement(node) { + return seq(this.t("debugger"), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceDoWhileStatement", + value: function reduceDoWhileStatement(node, _ref24) { + var body = _ref24.body; + var test = _ref24.test; - /** - * Returns a curried equivalent of the provided function. The curried function - * has two unusual capabilities. First, its arguments needn't be provided one - * at a time. If `f` is a ternary function and `g` is `R.curry(f)`, the - * following are equivalent: - * - * - `g(1)(2)(3)` - * - `g(1)(2, 3)` - * - `g(1, 2)(3)` - * - `g(1, 2, 3)` - * - * Secondly, the special placeholder value `R.__` may be used to specify - * "gaps", allowing partial application of any combination of arguments, - * regardless of their positions. If `g` is as above and `_` is `R.__`, the - * following are equivalent: - * - * - `g(1, 2, 3)` - * - `g(_, 2, 3)(1)` - * - `g(_, _, 3)(1)(2)` - * - `g(_, _, 3)(1, 2)` - * - `g(_, 2)(1)(3)` - * - `g(_, 2)(1, 3)` - * - `g(_, 2)(_, 3)(1)` - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig (* -> a) -> (* -> a) - * @param {Function} fn The function to curry. - * @return {Function} A new, curried function. - * @see R.curryN - * @example - * - * var addFourNumbers = (a, b, c, d) => a + b + c + d; - * - * var curriedAddFourNumbers = R.curry(addFourNumbers); - * var f = curriedAddFourNumbers(1, 2); - * var g = f(3); - * g(4); //=> 10 - */ - var curry = _curry1(function curry(fn) { - return curryN(fn.length, fn); - }); + return seq(this.t("do"), this.sep(Sep.AFTER_DO), body, this.sep(Sep.BEFORE_DOWHILE_WHILE), this.t("while"), this.sep(Sep.AFTER_DOWHILE_WHILE), this.paren(test, Sep.DO_WHILE_TEST_PAREN_BEFORE, Sep.DO_WHILE_TEST_PAREN_AFTER), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceEmptyStatement", + value: function reduceEmptyStatement(node) { + return seq(this.t(";"), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceExpressionStatement", + value: function reduceExpressionStatement(node, _ref25) { + var expression = _ref25.expression; - /** - * Returns all but the first `n` elements of the given list, string, or - * transducer/transformer (or object with a `drop` method). - * - * Dispatches to the `drop` method of the second argument, if present. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig Number -> [a] -> [a] - * @sig Number -> String -> String - * @param {Number} n - * @param {*} list - * @return {*} - * @see R.take, R.transduce - * @example - * - * R.drop(1, ['foo', 'bar', 'baz']); //=> ['bar', 'baz'] - * R.drop(2, ['foo', 'bar', 'baz']); //=> ['baz'] - * R.drop(3, ['foo', 'bar', 'baz']); //=> [] - * R.drop(4, ['foo', 'bar', 'baz']); //=> [] - * R.drop(3, 'ramda'); //=> 'da' - */ - var drop = _curry2(_dispatchable('drop', _xdrop, function drop(n, xs) { - return slice(Math.max(0, n), Infinity, xs); - })); + var needsParens = expression.startsWithCurly || expression.startsWithLetSquareBracket || expression.startsWithFunctionOrClass; + return seq(needsParens ? this.paren(expression, Sep.EXPRESSION_STATEMENT_PAREN_BEFORE, Sep.EXPRESSION_STATEMENT_PAREN_AFTER) : expression, this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceForInStatement", + value: function reduceForInStatement(node, _ref26) { + var left = _ref26.left; + var right = _ref26.right; + var body = _ref26.body; - /** - * Returns a list containing all but the last `n` elements of the given `list`. - * - * @func - * @memberOf R - * @since v0.16.0 - * @category List - * @sig Number -> [a] -> [a] - * @sig Number -> String -> String - * @param {Number} n The number of elements of `xs` to skip. - * @param {Array} xs The collection to consider. - * @return {Array} - * @see R.takeLast - * @example - * - * R.dropLast(1, ['foo', 'bar', 'baz']); //=> ['foo', 'bar'] - * R.dropLast(2, ['foo', 'bar', 'baz']); //=> ['foo'] - * R.dropLast(3, ['foo', 'bar', 'baz']); //=> [] - * R.dropLast(4, ['foo', 'bar', 'baz']); //=> [] - * R.dropLast(3, 'ramda'); //=> 'ra' - */ - var dropLast = _curry2(_dispatchable('dropLast', _xdropLast, _dropLast)); + var leftP = left; + switch (node.left.type) { + case "VariableDeclaration": + leftP = noIn(markContainsIn(left)); + break; + case "BindingIdentifier": + if (node.left.name === "let") { + leftP = this.paren(left, Sep.FOR_IN_LET_PAREN_BEFORE, Sep.FOR_IN_LET_PAREN_BEFORE); + } + break; + } + return (0, _objectAssign2.default)(seq(this.t("for"), this.sep(Sep.AFTER_FORIN_FOR), this.paren(seq(leftP, this.sep(Sep.BEFORE_FORIN_IN), this.t("in"), this.sep(Sep.AFTER_FORIN_FOR), right), Sep.FOR_IN_PAREN_BEFORE, Sep.FOR_IN_PAREN_AFTER), this.sep(Sep.BEFORE_FORIN_BODY), body, this.sep(Sep.AFTER_STATEMENT(node))), { endsWithMissingElse: body.endsWithMissingElse }); + } + }, { + key: "reduceForOfStatement", + value: function reduceForOfStatement(node, _ref27) { + var left = _ref27.left; + var right = _ref27.right; + var body = _ref27.body; - /** - * Returns a new list containing all but last the`n` elements of a given list, - * passing each value from the right to the supplied predicate function, - * skipping elements while the predicate function returns `true`. The predicate - * function is passed one argument: (value)*. - * - * @func - * @memberOf R - * @since v0.16.0 - * @category List - * @sig (a -> Boolean) -> [a] -> [a] - * @param {Function} fn The function called per iteration. - * @param {Array} list The collection to iterate over. - * @return {Array} A new array. - * @see R.takeLastWhile, R.addIndex - * @example - * - * var lteThree = x => x <= 3; - * - * R.dropLastWhile(lteThree, [1, 2, 3, 4, 3, 2, 1]); //=> [1, 2, 3, 4] - */ - var dropLastWhile = _curry2(_dispatchable('dropLastWhile', _xdropLastWhile, _dropLastWhile)); + left = node.left.type === "VariableDeclaration" ? noIn(markContainsIn(left)) : left; + return (0, _objectAssign2.default)(seq(this.t("for"), this.sep(Sep.AFTER_FOROF_FOR), this.paren(seq(left.startsWithLet ? this.paren(left, Sep.FOR_OF_LET_PAREN_BEFORE, Sep.FOR_OF_LET_PAREN_AFTER) : left, this.sep(Sep.BEFORE_FOROF_OF), this.t("of"), this.sep(Sep.AFTER_FOROF_FOR), right), Sep.FOR_OF_PAREN_BEFORE, Sep.FOR_OF_PAREN_AFTER), this.sep(Sep.BEFORE_FOROF_BODY), body, this.sep(Sep.AFTER_STATEMENT(node))), { endsWithMissingElse: body.endsWithMissingElse }); + } + }, { + key: "reduceForStatement", + value: function reduceForStatement(node, _ref28) { + var init = _ref28.init; + var test = _ref28.test; + var update = _ref28.update; + var body = _ref28.body; - /** - * Returns `true` if its arguments are equivalent, `false` otherwise. Handles - * cyclical data structures. - * - * Dispatches symmetrically to the `equals` methods of both arguments, if - * present. - * - * @func - * @memberOf R - * @since v0.15.0 - * @category Relation - * @sig a -> b -> Boolean - * @param {*} a - * @param {*} b - * @return {Boolean} - * @example - * - * R.equals(1, 1); //=> true - * R.equals(1, '1'); //=> false - * R.equals([1, 2, 3], [1, 2, 3]); //=> true - * - * var a = {}; a.v = a; - * var b = {}; b.v = b; - * R.equals(a, b); //=> true - */ - var equals = _curry2(function equals(a, b) { - return _equals(a, b, [], []); - }); + return (0, _objectAssign2.default)(seq(this.t("for"), this.sep(Sep.AFTER_FOR_FOR), this.paren(seq(init ? seq(this.sep(Sep.BEFORE_FOR_INIT), noIn(markContainsIn(init)), this.sep(Sep.AFTER_FOR_INIT)) : this.sep(Sep.EMPTY_FOR_INIT), this.t(";"), test ? seq(this.sep(Sep.BEFORE_FOR_TEST), test, this.sep(Sep.AFTER_FOR_TEST)) : this.sep(Sep.EMPTY_FOR_TEST), this.t(";"), update ? seq(this.sep(Sep.BEFORE_FOR_UPDATE), update, this.sep(Sep.AFTER_FOR_UPDATE)) : this.sep(Sep.EMPTY_FOR_UPDATE))), this.sep(Sep.BEFORE_FOR_BODY), body, this.sep(Sep.AFTER_STATEMENT(node))), { + endsWithMissingElse: body.endsWithMissingElse + }); + } + }, { + key: "reduceFunctionBody", + value: function reduceFunctionBody(node, _ref29) { + var directives = _ref29.directives; + var statements = _ref29.statements; - /** - * Takes a predicate and a "filterable", and returns a new filterable of the - * same type containing the members of the given filterable which satisfy the - * given predicate. - * - * Dispatches to the `filter` method of the second argument, if present. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig Filterable f => (a -> Boolean) -> f a -> f a - * @param {Function} pred - * @param {Array} filterable - * @return {Array} - * @see R.reject, R.transduce, R.addIndex - * @example - * - * var isEven = n => n % 2 === 0; - * - * R.filter(isEven, [1, 2, 3, 4]); //=> [2, 4] - * - * R.filter(isEven, {a: 1, b: 2, c: 3, d: 4}); //=> {b: 2, d: 4} - */ - // else - var filter = _curry2(_dispatchable('filter', _xfilter, function (pred, filterable) { - return _isObject(filterable) ? _reduce(function (acc, key) { - if (pred(filterable[key])) { - acc[key] = filterable[key]; - } - return acc; - }, {}, keys(filterable)) : // else - _filter(pred, filterable); - })); + if (statements.length) { + statements[0] = this.parenToAvoidBeingDirective(node.statements[0], statements[0]); + } + return seq.apply(undefined, _toConsumableArray(directives).concat([directives.length ? this.sep(Sep.AFTER_FUNCTION_DIRECTIVES) : empty()], _toConsumableArray(statements))); + } + }, { + key: "reduceFunctionDeclaration", + value: function reduceFunctionDeclaration(node, _ref30) { + var name = _ref30.name; + var params = _ref30.params; + var body = _ref30.body; - /** - * Returns a new list by pulling every item out of it (and all its sub-arrays) - * and putting them in a new array, depth-first. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig [a] -> [b] - * @param {Array} list The array to consider. - * @return {Array} The flattened list. - * @see R.unnest - * @example - * - * R.flatten([1, 2, [3, 4], 5, [6, [7, 8, [9, [10, 11], 12]]]]); - * //=> [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12] - */ - var flatten = _curry1(_makeFlat(true)); + return seq(this.t("function"), node.isGenerator ? seq(this.sep(Sep.BEFORE_GENERATOR_STAR), this.t("*"), this.sep(Sep.AFTER_GENERATOR_STAR)) : empty(), this.sep(Sep.BEFORE_FUNCTION_NAME(node)), node.name.name === "*default*" ? empty() : name, this.sep(Sep.BEFORE_FUNCTION_PARAMS), this.paren(params, Sep.PARAMETERS_PAREN_BEFORE, Sep.PARAMETERS_PAREN_AFTER, Sep.PARAMETERS_PAREN_EMPTY), this.sep(Sep.BEFORE_FUNCTION_DECLARATION_BODY), this.brace(body, node, Sep.FUNCTION_BRACE_INITIAL, Sep.FUNCTION_BRACE_FINAL, Sep.FUNCTION_EMPTY), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceFunctionExpression", + value: function reduceFunctionExpression(node, _ref31) { + var name = _ref31.name; + var params = _ref31.params; + var body = _ref31.body; - /** - * Returns a new function much like the supplied one, except that the first two - * arguments' order is reversed. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig (a -> b -> c -> ... -> z) -> (b -> a -> c -> ... -> z) - * @param {Function} fn The function to invoke with its first two parameters reversed. - * @return {*} The result of invoking `fn` with its first two parameters' order reversed. - * @example - * - * var mergeThree = (a, b, c) => [].concat(a, b, c); - * - * mergeThree(1, 2, 3); //=> [1, 2, 3] - * - * R.flip(mergeThree)(1, 2, 3); //=> [2, 1, 3] - */ - var flip = _curry1(function flip(fn) { - return curry(function (a, b) { - var args = _slice(arguments); - args[0] = b; - args[1] = a; - return fn.apply(this, args); - }); - }); + var state = seq(this.t("function"), node.isGenerator ? seq(this.sep(Sep.BEFORE_GENERATOR_STAR), this.t("*"), this.sep(Sep.AFTER_GENERATOR_STAR)) : empty(), this.sep(Sep.BEFORE_FUNCTION_NAME(node)), name ? name : empty(), this.sep(Sep.BEFORE_FUNCTION_PARAMS), this.paren(params, Sep.PARAMETERS_PAREN_BEFORE, Sep.PARAMETERS_PAREN_AFTER, Sep.PARAMETERS_PAREN_EMPTY), this.sep(Sep.BEFORE_FUNCTION_EXPRESSION_BODY), this.brace(body, node, Sep.FUNCTION_EXPRESSION_BRACE_INITIAL, Sep.FUNCTION_EXPRESSION_BRACE_FINAL, Sep.FUNCTION_EXPRESSION_EMPTY)); + state.startsWithFunctionOrClass = true; + return state; + } + }, { + key: "reduceFormalParameters", + value: function reduceFormalParameters(node, _ref32) { + var items = _ref32.items; + var rest = _ref32.rest; - /** - * Splits a list into sub-lists stored in an object, based on the result of - * calling a String-returning function on each element, and grouping the - * results according to values returned. - * - * Dispatches to the `groupBy` method of the second argument, if present. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig (a -> String) -> [a] -> {String: [a]} - * @param {Function} fn Function :: a -> String - * @param {Array} list The array to group - * @return {Object} An object with the output of `fn` for keys, mapped to arrays of elements - * that produced that key when passed to `fn`. - * @see R.transduce - * @example - * - * var byGrade = R.groupBy(function(student) { - * var score = student.score; - * return score < 65 ? 'F' : - * score < 70 ? 'D' : - * score < 80 ? 'C' : - * score < 90 ? 'B' : 'A'; - * }); - * var students = [{name: 'Abby', score: 84}, - * {name: 'Eddy', score: 58}, - * // ... - * {name: 'Jack', score: 69}]; - * byGrade(students); - * // { - * // 'A': [{name: 'Dianne', score: 99}], - * // 'B': [{name: 'Abby', score: 84}] - * // // ..., - * // 'F': [{name: 'Eddy', score: 58}] - * // } - */ - var groupBy = _curry2(_dispatchable('groupBy', _xgroupBy, function groupBy(fn, list) { - return _reduce(function (acc, elt) { - var key = fn(elt); - acc[key] = append(elt, acc[key] || (acc[key] = [])); - return acc; - }, {}, list); - })); + return this.commaSep(items.concat(rest == null ? [] : [seq(this.t("..."), this.sep(Sep.REST), rest)]), Sep.PARAMETER_BEFORE_COMMA, Sep.PARAMETER_AFTER_COMMA); + } + }, { + key: "reduceArrowExpression", + value: function reduceArrowExpression(node, _ref33) { + var params = _ref33.params; + var body = _ref33.body; - /** - * Returns the first element of the given list or string. In some libraries - * this function is named `first`. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig [a] -> a | Undefined - * @sig String -> String - * @param {Array|String} list - * @return {*} - * @see R.tail, R.init, R.last - * @example - * - * R.head(['fi', 'fo', 'fum']); //=> 'fi' - * R.head([]); //=> undefined - * - * R.head('abc'); //=> 'a' - * R.head(''); //=> '' - */ - var head = nth(0); + if (node.params.rest != null || node.params.items.length !== 1 || node.params.items[0].type !== "BindingIdentifier") { + params = this.paren(params, Sep.ARROW_PARAMETERS_PAREN_BEFORE, Sep.ARROW_PARAMETERS_PAREN_AFTER, Sep.ARROW_PARAMETERS_PAREN_EMPTY); + } + if (node.body.type === "FunctionBody") { + body = this.brace(body, node, Sep.ARROW_BRACE_INITIAL, Sep.ARROW_BRACE_FINAL, Sep.ARROW_BRACE_EMPTY); + } else if (body.startsWithCurly) { + body = this.paren(body, Sep.ARROW_BODY_PAREN_BEFORE, Sep.ARROW_BODY_PAREN_AFTER); + } + return seq(params, this.sep(Sep.BEFORE_ARROW), this.t("=>"), this.sep(Sep.AFTER_ARROW), this.p(node.body, _coderep.Precedence.Assignment, body)); + } + }, { + key: "reduceGetter", + value: function reduceGetter(node, _ref34) { + var name = _ref34.name; + var body = _ref34.body; - /** - * Given a function that generates a key, turns a list of objects into an - * object indexing the objects by the given key. Note that if multiple - * objects generate the same value for the indexing key only the last value - * will be included in the generated object. - * - * @func - * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category List - * @sig (a -> String) -> [{k: v}] -> {k: {k: v}} - * @param {Function} fn Function :: a -> String - * @param {Array} array The array of objects to index - * @return {Object} An object indexing each array element by the given property. - * @example - * - * var list = [{id: 'xyz', title: 'A'}, {id: 'abc', title: 'B'}]; - * R.indexBy(R.prop('id'), list); - * //=> {abc: {id: 'abc', title: 'B'}, xyz: {id: 'xyz', title: 'A'}} - */ - var indexBy = _curry2(function indexBy(fn, list) { - return _reduce(function (acc, elem) { - var key = fn(elem); - acc[key] = elem; - return acc; - }, {}, list); - }); + return seq(this.t("get"), this.sep(Sep.AFTER_GET), name, this.sep(Sep.BEFORE_GET_PARAMS), this.paren(empty(), null, null, Sep.GETTER_PARAMS), this.sep(Sep.BEFORE_GET_BODY), this.brace(body, node, Sep.GET_BRACE_INTIAL, Sep.GET_BRACE_FINAL, Sep.GET_BRACE_EMPTY)); + } + }, { + key: "reduceIdentifierExpression", + value: function reduceIdentifierExpression(node) { + var a = this.t(node.name); + if (node.name === "let") { + a.startsWithLet = true; + } + return a; + } + }, { + key: "reduceIfStatement", + value: function reduceIfStatement(node, _ref35) { + var test = _ref35.test; + var consequent = _ref35.consequent; + var alternate = _ref35.alternate; - /** - * Returns all but the last element of the given list or string. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category List - * @sig [a] -> [a] - * @sig String -> String - * @param {*} list - * @return {*} - * @see R.last, R.head, R.tail - * @example - * - * R.init([1, 2, 3]); //=> [1, 2] - * R.init([1, 2]); //=> [1] - * R.init([1]); //=> [] - * R.init([]); //=> [] - * - * R.init('abc'); //=> 'ab' - * R.init('ab'); //=> 'a' - * R.init('a'); //=> '' - * R.init(''); //=> '' - */ - var init = slice(0, -1); - - /** - * Combines two lists into a set (i.e. no duplicates) composed of those - * elements common to both lists. Duplication is determined according to the - * value returned by applying the supplied predicate to two list elements. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig (a -> a -> Boolean) -> [*] -> [*] -> [*] - * @param {Function} pred A predicate function that determines whether - * the two supplied elements are equal. - * @param {Array} list1 One list of items to compare - * @param {Array} list2 A second list of items to compare - * @return {Array} A new list containing those elements common to both lists. - * @see R.intersection - * @example - * - * var buffaloSpringfield = [ - * {id: 824, name: 'Richie Furay'}, - * {id: 956, name: 'Dewey Martin'}, - * {id: 313, name: 'Bruce Palmer'}, - * {id: 456, name: 'Stephen Stills'}, - * {id: 177, name: 'Neil Young'} - * ]; - * var csny = [ - * {id: 204, name: 'David Crosby'}, - * {id: 456, name: 'Stephen Stills'}, - * {id: 539, name: 'Graham Nash'}, - * {id: 177, name: 'Neil Young'} - * ]; - * - * R.intersectionWith(R.eqBy(R.prop('id')), buffaloSpringfield, csny); - * //=> [{id: 456, name: 'Stephen Stills'}, {id: 177, name: 'Neil Young'}] - */ - var intersectionWith = _curry3(function intersectionWith(pred, list1, list2) { - var results = []; - var idx = 0; - while (idx < list1.length) { - if (_containsWith(pred, list1[idx], list2)) { - results[results.length] = list1[idx]; - } - idx += 1; - } - return uniqWith(pred, results); - }); + if (alternate && consequent.endsWithMissingElse) { + consequent = this.brace(consequent, node, Sep.MISSING_ELSE_INTIIAL, Sep.MISSING_ELSE_FINAL, Sep.MISSING_ELSE_EMPTY); + } + return (0, _objectAssign2.default)(seq(this.t("if"), this.sep(Sep.AFTER_IF), this.paren(test, Sep.IF_PAREN_BEFORE, Sep.IF_PAREN_AFTER), this.sep(Sep.AFTER_IF_TEST), consequent, alternate ? seq(this.sep(Sep.BEFORE_ELSE), this.t("else"), this.sep(Sep.AFTER_ELSE), alternate) : empty(), this.sep(Sep.AFTER_STATEMENT(node))), { endsWithMissingElse: alternate ? alternate.endsWithMissingElse : true }); + } + }, { + key: "reduceImport", + value: function reduceImport(node, _ref36) { + var defaultBinding = _ref36.defaultBinding; + var namedImports = _ref36.namedImports; - /** - * Same as R.invertObj, however this accounts for objects with duplicate values - * by putting the values into an array. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Object - * @sig {s: x} -> {x: [ s, ... ]} - * @param {Object} obj The object or array to invert - * @return {Object} out A new object with keys - * in an array. - * @example - * - * var raceResultsByFirstName = { - * first: 'alice', - * second: 'jake', - * third: 'alice', - * }; - * R.invert(raceResultsByFirstName); - * //=> { 'alice': ['first', 'third'], 'jake':['second'] } - */ - var invert = _curry1(function invert(obj) { - var props = keys(obj); - var len = props.length; - var idx = 0; - var out = {}; - while (idx < len) { - var key = props[idx]; - var val = obj[key]; - var list = _has(val, out) ? out[val] : out[val] = []; - list[list.length] = key; - idx += 1; - } - return out; - }); + var bindings = []; + if (defaultBinding != null) { + bindings.push(defaultBinding); + } + if (namedImports.length > 0) { + bindings.push(this.brace(this.commaSep(namedImports, Sep.NAMED_IMPORT_BEFORE_COMMA, Sep.NAMED_IMPORT_AFTER_COMMA), node, Sep.IMPORT_BRACE_INTIAL, Sep.IMPORT_BRACE_FINAL, Sep.IMPORT_BRACE_EMPTY)); + } + if (bindings.length === 0) { + return seq(this.t("import"), this.sep(Sep.BEFORE_IMPORT_MODULE), this.t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + return seq(this.t("import"), this.sep(Sep.BEFORE_IMPORT_BINDINGS), this.commaSep(bindings, Sep.IMPORT_BEFORE_COMMA, Sep.IMPORT_AFTER_COMMA), this.sep(Sep.AFTER_IMPORT_BINDINGS), this.t("from"), this.sep(Sep.AFTER_FROM), this.t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceImportNamespace", + value: function reduceImportNamespace(node, _ref37) { + var defaultBinding = _ref37.defaultBinding; + var namespaceBinding = _ref37.namespaceBinding; - /** - * Returns a new object with the keys of the given object as values, and the - * values of the given object, which are coerced to strings, as keys. Note - * that the last key found is preferred when handling the same value. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Object - * @sig {s: x} -> {x: s} - * @param {Object} obj The object or array to invert - * @return {Object} out A new object - * @example - * - * var raceResults = { - * first: 'alice', - * second: 'jake' - * }; - * R.invertObj(raceResults); - * //=> { 'alice': 'first', 'jake':'second' } - * - * // Alternatively: - * var raceResults = ['alice', 'jake']; - * R.invertObj(raceResults); - * //=> { 'alice': '0', 'jake':'1' } - */ - var invertObj = _curry1(function invertObj(obj) { - var props = keys(obj); - var len = props.length; - var idx = 0; - var out = {}; - while (idx < len) { - var key = props[idx]; - out[obj[key]] = key; - idx += 1; - } - return out; - }); + return seq(this.t("import"), this.sep(Sep.BEFORE_IMPORT_NAMESPACE), defaultBinding == null ? empty() : seq(defaultBinding, this.sep(Sep.IMPORT_BEFORE_COMMA), this.t(","), this.sep(Sep.IMPORT_AFTER_COMMA)), this.sep(Sep.BEFORE_IMPORT_STAR), this.t("*"), this.sep(Sep.AFTER_IMPORT_STAR), this.t("as"), this.sep(Sep.AFTER_IMPORT_AS), namespaceBinding, this.sep(Sep.AFTER_NAMESPACE_BINDING), this.t("from"), this.sep(Sep.AFTER_FROM), this.t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceImportSpecifier", + value: function reduceImportSpecifier(node, _ref38) { + var binding = _ref38.binding; - /** - * Returns `true` if the given value is its type's empty value; `false` - * otherwise. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Logic - * @sig a -> Boolean - * @param {*} x - * @return {Boolean} - * @see R.empty - * @example - * - * R.isEmpty([1, 2, 3]); //=> false - * R.isEmpty([]); //=> true - * R.isEmpty(''); //=> true - * R.isEmpty(null); //=> false - * R.isEmpty({}); //=> true - * R.isEmpty({length: 0}); //=> false - */ - var isEmpty = _curry1(function isEmpty(x) { - return x != null && equals(x, empty(x)); - }); + if (node.name == null) return binding; + return seq(this.t(node.name), this.sep(Sep.BEFORE_IMPORT_AS), this.t("as"), this.sep(Sep.AFTER_IMPORT_AS), binding); + } + }, { + key: "reduceExportAllFrom", + value: function reduceExportAllFrom(node) { + return seq(this.t("export"), this.sep(Sep.BEFORE_EXPORT_STAR), this.t("*"), this.sep(Sep.AFTER_EXPORT_STAR), this.t("from"), this.sep(Sep.AFTER_FROM), this.t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceExportFrom", + value: function reduceExportFrom(node, _ref39) { + var namedExports = _ref39.namedExports; - /** - * Returns the last element of the given list or string. - * - * @func - * @memberOf R - * @since v0.1.4 - * @category List - * @sig [a] -> a | Undefined - * @sig String -> String - * @param {*} list - * @return {*} - * @see R.init, R.head, R.tail - * @example - * - * R.last(['fi', 'fo', 'fum']); //=> 'fum' - * R.last([]); //=> undefined - * - * R.last('abc'); //=> 'c' - * R.last(''); //=> '' - */ - var last = nth(-1); + return seq(this.t("export"), this.sep(Sep.BEFORE_EXPORT_BINDINGS), this.brace(this.commaSep(namedExports, Sep.EXPORTS_BEFORE_COMMA, Sep.EXPORTS_AFTER_COMMA), node, Sep.EXPORT_BRACE_INITIAL, Sep.EXPORT_BRACE_FINAL, Sep.EXPORT_BRACE_EMPTY), node.moduleSpecifier == null ? empty() : seq(this.sep(Sep.AFTER_EXPORT_BINDINGS), this.t("from"), this.sep(Sep.AFTER_FROM), this.t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node)))); + } + }, { + key: "reduceExport", + value: function reduceExport(node, _ref40) { + var declaration = _ref40.declaration; - /** - * Returns the position of the last occurrence of an item in an array, or -1 if - * the item is not included in the array. `R.equals` is used to determine - * equality. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig a -> [a] -> Number - * @param {*} target The item to find. - * @param {Array} xs The array to search in. - * @return {Number} the index of the target, or -1 if the target is not found. - * @see R.indexOf - * @example - * - * R.lastIndexOf(3, [-1,3,3,0,1,2,3,4]); //=> 6 - * R.lastIndexOf(10, [1,2,3,4]); //=> -1 - */ - var lastIndexOf = _curry2(function lastIndexOf(target, xs) { - if (typeof xs.lastIndexOf === 'function' && !_isArray(xs)) { - return xs.lastIndexOf(target); - } else { - var idx = xs.length - 1; - while (idx >= 0) { - if (equals(xs[idx], target)) { - return idx; - } - idx -= 1; - } - return -1; - } - }); + switch (node.declaration.type) { + case "FunctionDeclaration": + case "ClassDeclaration": + break; + default: + declaration = seq(declaration, this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + return seq(this.t("export"), this.sep(Sep.AFTER_EXPORT), declaration); + } + }, { + key: "reduceExportDefault", + value: function reduceExportDefault(node, _ref41) { + var body = _ref41.body; - /** - * Takes a function and - * a [functor](https://github.com/fantasyland/fantasy-land#functor), - * applies the function to each of the functor's values, and returns - * a functor of the same shape. - * - * Ramda provides suitable `map` implementations for `Array` and `Object`, - * so this function may be applied to `[1, 2, 3]` or `{x: 1, y: 2, z: 3}`. - * - * Dispatches to the `map` method of the second argument, if present. - * - * Acts as a transducer if a transformer is given in list position. - * - * Also treats functions as functors and will compose them together. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig Functor f => (a -> b) -> f a -> f b - * @param {Function} fn The function to be called on every element of the input `list`. - * @param {Array} list The list to be iterated over. - * @return {Array} The new list. - * @see R.transduce, R.addIndex - * @example - * - * var double = x => x * 2; - * - * R.map(double, [1, 2, 3]); //=> [2, 4, 6] - * - * R.map(double, {x: 1, y: 2, z: 3}); //=> {x: 2, y: 4, z: 6} - */ - var map = _curry2(_dispatchable('map', _xmap, function map(fn, functor) { - switch (Object.prototype.toString.call(functor)) { - case '[object Function]': - return curryN(functor.length, function () { - return fn.call(this, functor.apply(this, arguments)); - }); - case '[object Object]': - return _reduce(function (acc, key) { - acc[key] = fn(functor[key]); - return acc; - }, {}, keys(functor)); + body = body.startsWithFunctionOrClass ? this.paren(body, Sep.EXPORT_PAREN_BEFORE, Sep.EXPORT_PAREN_AFTER) : body; + switch (node.body.type) { + case "FunctionDeclaration": + case "ClassDeclaration": + break; default: - return _map(fn, functor); - } - })); + body = seq(body, this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + return seq(this.t("export"), this.sep(Sep.EXPORT_DEFAULT), this.t("default"), this.sep(Sep.AFTER_EXPORT_DEFAULT), body); + } + }, { + key: "reduceExportSpecifier", + value: function reduceExportSpecifier(node) { + if (node.name == null) return this.t(node.exportedName); + return seq(this.t(node.name), this.sep(Sep.BEFORE_EXPORT_AS), this.t("as"), this.sep(Sep.AFTER_EXPORT_AS), this.t(node.exportedName)); + } + }, { + key: "reduceLabeledStatement", + value: function reduceLabeledStatement(node, _ref42) { + var label = _ref42.label; + var body = _ref42.body; - /** - * An Object-specific version of `map`. The function is applied to three - * arguments: *(value, key, obj)*. If only the value is significant, use - * `map` instead. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Object - * @sig ((*, String, Object) -> *) -> Object -> Object - * @param {Function} fn - * @param {Object} obj - * @return {Object} - * @see R.map - * @example - * - * var values = { x: 1, y: 2, z: 3 }; - * var prependKeyAndDouble = (num, key, obj) => key + (num * 2); - * - * R.mapObjIndexed(prependKeyAndDouble, values); //=> { x: 'x2', y: 'y4', z: 'z6' } - */ - var mapObjIndexed = _curry2(function mapObjIndexed(fn, obj) { - return _reduce(function (acc, key) { - acc[key] = fn(obj[key], key, obj); - return acc; - }, {}, keys(obj)); - }); + return (0, _objectAssign2.default)(seq(this.t(label), this.sep(Sep.BEFORE_LABEL_COLON), this.t(":"), this.sep(Sep.AFTER_LABEL_COLON), body), { endsWithMissingElse: body.endsWithMissingElse }); + } + }, { + key: "reduceLiteralBooleanExpression", + value: function reduceLiteralBooleanExpression(node) { + return this.t(node.value.toString()); + } + }, { + key: "reduceLiteralNullExpression", + value: function reduceLiteralNullExpression(node) { + return this.t("null"); + } + }, { + key: "reduceLiteralInfinityExpression", + value: function reduceLiteralInfinityExpression(node) { + return this.t("2e308"); + } + }, { + key: "reduceLiteralNumericExpression", + value: function reduceLiteralNumericExpression(node) { + return new _coderep.NumberCodeRep(node.value); + } + }, { + key: "reduceLiteralRegExpExpression", + value: function reduceLiteralRegExpExpression(node) { + return this.t("/" + node.pattern + "/" + node.flags); + } + }, { + key: "reduceLiteralStringExpression", + value: function reduceLiteralStringExpression(node) { + return this.t((0, _coderep.escapeStringLiteral)(node.value)); + } + }, { + key: "reduceMethod", + value: function reduceMethod(node, _ref43) { + var name = _ref43.name; + var params = _ref43.params; + var body = _ref43.body; - /** - * Creates a new object with the own properties of the two provided objects. If - * a key exists in both objects, the provided function is applied to the values - * associated with the key in each object, with the result being used as the - * value associated with the key in the returned object. The key will be - * excluded from the returned object if the resulting value is `undefined`. - * - * @func - * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category Object - * @sig (a -> a -> a) -> {a} -> {a} -> {a} - * @param {Function} fn - * @param {Object} l - * @param {Object} r - * @return {Object} - * @see R.merge, R.mergeWithKey - * @example - * - * R.mergeWith(R.concat, - * { a: true, values: [10, 20] }, - * { b: true, values: [15, 35] }); - * //=> { a: true, b: true, values: [10, 20, 15, 35] } - */ - var mergeWith = _curry3(function mergeWith(fn, l, r) { - return mergeWithKey(function (_, _l, _r) { - return fn(_l, _r); - }, l, r); - }); + return seq(node.isGenerator ? seq(this.t("*"), this.sep(Sep.AFTER_METHOD_GENERATOR_STAR)) : empty(), name, this.sep(Sep.AFTER_METHOD_NAME), this.paren(params, Sep.PARAMETERS_PAREN_BEFORE, Sep.PARAMETERS_PAREN_AFTER, Sep.PARAMETERS_PAREN_EMPTY), this.sep(Sep.BEFORE_METHOD_BODY), this.brace(body, node, Sep.METHOD_BRACE_INTIAL, Sep.METHOD_BRACE_FINAL, Sep.METHOD_BRACE_EMPTY)); + } + }, { + key: "reduceModule", + value: function reduceModule(node, _ref44) { + var directives = _ref44.directives; + var items = _ref44.items; - /** - * Takes a function `f` and a list of arguments, and returns a function `g`. - * When applied, `g` returns the result of applying `f` to the arguments - * provided initially followed by the arguments provided to `g`. - * - * @func - * @memberOf R - * @since v0.10.0 - * @category Function - * @sig ((a, b, c, ..., n) -> x) -> [a, b, c, ...] -> ((d, e, f, ..., n) -> x) - * @param {Function} f - * @param {Array} args - * @return {Function} - * @see R.partialRight - * @example - * - * var multiply = (a, b) => a * b; - * var double = R.partial(multiply, [2]); - * double(2); //=> 4 - * - * var greet = (salutation, title, firstName, lastName) => - * salutation + ', ' + title + ' ' + firstName + ' ' + lastName + '!'; - * - * var sayHello = R.partial(greet, ['Hello']); - * var sayHelloToMs = R.partial(sayHello, ['Ms.']); - * sayHelloToMs('Jane', 'Jones'); //=> 'Hello, Ms. Jane Jones!' - */ - var partial = _createPartialApplicator(_concat); + if (items.length) { + items[0] = this.parenToAvoidBeingDirective(node.items[0], items[0]); + } + return seq.apply(undefined, _toConsumableArray(directives).concat([directives.length ? this.sep(Sep.AFTER_MODULE_DIRECTIVES) : empty()], _toConsumableArray(items))); + } + }, { + key: "reduceNewExpression", + value: function reduceNewExpression(node, _ref45) { + var callee = _ref45.callee; + var args = _ref45.arguments; - /** - * Takes a function `f` and a list of arguments, and returns a function `g`. - * When applied, `g` returns the result of applying `f` to the arguments - * provided to `g` followed by the arguments provided initially. - * - * @func - * @memberOf R - * @since v0.10.0 - * @category Function - * @sig ((a, b, c, ..., n) -> x) -> [d, e, f, ..., n] -> ((a, b, c, ...) -> x) - * @param {Function} f - * @param {Array} args - * @return {Function} - * @see R.partial - * @example - * - * var greet = (salutation, title, firstName, lastName) => - * salutation + ', ' + title + ' ' + firstName + ' ' + lastName + '!'; - * - * var greetMsJaneJones = R.partialRight(greet, ['Ms.', 'Jane', 'Jones']); - * - * greetMsJaneJones('Hello'); //=> 'Hello, Ms. Jane Jones!' - */ - var partialRight = _createPartialApplicator(flip(_concat)); + var calleeRep = (0, _coderep.getPrecedence)(node.callee) == _coderep.Precedence.Call ? this.paren(callee, Sep.NEW_CALLEE_PAREN_BEFORE, Sep.NEW_CALLEE_PAREN_AFTER) : this.p(node.callee, (0, _coderep.getPrecedence)(node), callee); + return seq(this.t("new"), this.sep(Sep.AFTER_NEW), calleeRep, args.length === 0 ? this.sep(Sep.EMPTY_NEW_CALL) : seq(this.sep(Sep.BEFORE_NEW_ARGS), this.paren(this.commaSep(args, Sep.ARGS_BEFORE_COMMA, Sep.ARGS_AFTER_COMMA), Sep.NEW_PAREN_BEFORE, Sep.NEW_PAREN_AFTER, Sep.NEW_PAREN_EMPTY))); + } + }, { + key: "reduceNewTargetExpression", + value: function reduceNewTargetExpression() { + return seq(this.t("new"), this.sep(Sep.NEW_TARGET_BEFORE_DOT), this.t("."), this.sep(Sep.NEW_TARGET_AFTER_DOT), this.t("target")); + } + }, { + key: "reduceObjectExpression", + value: function reduceObjectExpression(node, _ref46) { + var properties = _ref46.properties; - /** - * Takes a predicate and a list and returns the pair of lists of elements which - * do and do not satisfy the predicate, respectively. - * - * @func - * @memberOf R - * @since v0.1.4 - * @category List - * @sig (a -> Boolean) -> [a] -> [[a],[a]] - * @param {Function} pred A predicate to determine which array the element belongs to. - * @param {Array} list The array to partition. - * @return {Array} A nested array, containing first an array of elements that satisfied the predicate, - * and second an array of elements that did not satisfy. - * @see R.filter, R.reject - * @example - * - * R.partition(R.contains('s'), ['sss', 'ttt', 'foo', 'bars']); - * //=> [ [ 'sss', 'bars' ], [ 'ttt', 'foo' ] ] - */ - var partition = _curry2(function partition(pred, list) { - return _reduce(function (acc, elt) { - var xs = acc[pred(elt) ? 0 : 1]; - xs[xs.length] = elt; - return acc; - }, [ - [], - [] - ], list); - }); + var state = this.brace(this.commaSep(properties, Sep.OBJECT_BEFORE_COMMA, Sep.OBJECT_AFTER_COMMA), node, Sep.OBJECT_BRACE_INITIAL, Sep.OBJECT_BRACE_FINAL, Sep.OBJECT_EMPTY); + state.startsWithCurly = true; + return state; + } + }, { + key: "reduceUpdateExpression", + value: function reduceUpdateExpression(node, _ref47) { + var operand = _ref47.operand; - /** - * Determines whether a nested path on an object has a specific value, in - * `R.equals` terms. Most likely used to filter a list. - * - * @func - * @memberOf R - * @since v0.7.0 - * @category Relation - * @sig [String] -> * -> {String: *} -> Boolean - * @param {Array} path The path of the nested property to use - * @param {*} val The value to compare the nested property with - * @param {Object} obj The object to check the nested property in - * @return {Boolean} `true` if the value equals the nested object property, - * `false` otherwise. - * @example - * - * var user1 = { address: { zipCode: 90210 } }; - * var user2 = { address: { zipCode: 55555 } }; - * var user3 = { name: 'Bob' }; - * var users = [ user1, user2, user3 ]; - * var isFamous = R.pathEq(['address', 'zipCode'], 90210); - * R.filter(isFamous, users); //=> [ user1 ] - */ - var pathEq = _curry3(function pathEq(_path, val, obj) { - return equals(path(_path, obj), val); - }); + if (node.isPrefix) { + return this.reduceUnaryExpression.apply(this, arguments); + } else { + return (0, _objectAssign2.default)(seq(this.p(node.operand, _coderep.Precedence.New, operand), this.sep(Sep.BEFORE_POSTFIX(node.operator)), this.t(node.operator)), { + startsWithCurly: operand.startsWithCurly, + startsWithLetSquareBracket: operand.startsWithLetSquareBracket, + startsWithFunctionOrClass: operand.startsWithFunctionOrClass + }); + } + } + }, { + key: "reduceUnaryExpression", + value: function reduceUnaryExpression(node, _ref48) { + var operand = _ref48.operand; - /** - * Returns a new list by plucking the same named property off all objects in - * the list supplied. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig k -> [{k: v}] -> [v] - * @param {Number|String} key The key name to pluck off of each object. - * @param {Array} list The array to consider. - * @return {Array} The list of values for the given key. - * @see R.props - * @example - * - * R.pluck('a')([{a: 1}, {a: 2}]); //=> [1, 2] - * R.pluck(0)([[1, 2], [3, 4]]); //=> [1, 3] - */ - var pluck = _curry2(function pluck(p, list) { - return map(prop(p), list); - }); + return seq(this.t(node.operator), this.sep(Sep.UNARY(node.operator)), this.p(node.operand, (0, _coderep.getPrecedence)(node), operand)); + } + }, { + key: "reduceReturnStatement", + value: function reduceReturnStatement(node, _ref49) { + var expression = _ref49.expression; - /** - * Reasonable analog to SQL `select` statement. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Object - * @category Relation - * @sig [k] -> [{k: v}] -> [{k: v}] - * @param {Array} props The property names to project - * @param {Array} objs The objects to query - * @return {Array} An array of objects with just the `props` properties. - * @example - * - * var abby = {name: 'Abby', age: 7, hair: 'blond', grade: 2}; - * var fred = {name: 'Fred', age: 12, hair: 'brown', grade: 7}; - * var kids = [abby, fred]; - * R.project(['name', 'grade'], kids); //=> [{name: 'Abby', grade: 2}, {name: 'Fred', grade: 7}] - */ - // passing `identity` gives correct arity - var project = useWith(_map, [ - pickAll, - identity - ]); + return seq(this.t("return"), expression ? seq(this.sep(Sep.RETURN), expression) : empty(), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceScript", + value: function reduceScript(node, _ref50) { + var directives = _ref50.directives; + var statements = _ref50.statements; - /** - * Returns `true` if the specified object property is equal, in `R.equals` - * terms, to the given value; `false` otherwise. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig String -> a -> Object -> Boolean - * @param {String} name - * @param {*} val - * @param {*} obj - * @return {Boolean} - * @see R.equals, R.propSatisfies - * @example - * - * var abby = {name: 'Abby', age: 7, hair: 'blond'}; - * var fred = {name: 'Fred', age: 12, hair: 'brown'}; - * var rusty = {name: 'Rusty', age: 10, hair: 'brown'}; - * var alois = {name: 'Alois', age: 15, disposition: 'surly'}; - * var kids = [abby, fred, rusty, alois]; - * var hasBrownHair = R.propEq('hair', 'brown'); - * R.filter(hasBrownHair, kids); //=> [fred, rusty] - */ - var propEq = _curry3(function propEq(name, val, obj) { - return propSatisfies(equals(val), name, obj); - }); + if (statements.length) { + statements[0] = this.parenToAvoidBeingDirective(node.statements[0], statements[0]); + } + return seq.apply(undefined, _toConsumableArray(directives).concat([directives.length ? this.sep(Sep.AFTER_SCRIPT_DIRECTIVES) : empty()], _toConsumableArray(statements))); + } + }, { + key: "reduceSetter", + value: function reduceSetter(node, _ref51) { + var name = _ref51.name; + var param = _ref51.param; + var body = _ref51.body; - /** - * Returns `true` if the specified object property is of the given type; - * `false` otherwise. - * - * @func - * @memberOf R - * @since v0.16.0 - * @category Type - * @sig Type -> String -> Object -> Boolean - * @param {Function} type - * @param {String} name - * @param {*} obj - * @return {Boolean} - * @see R.is, R.propSatisfies - * @example - * - * R.propIs(Number, 'x', {x: 1, y: 2}); //=> true - * R.propIs(Number, 'x', {x: 'foo'}); //=> false - * R.propIs(Number, 'x', {}); //=> false - */ - var propIs = _curry3(function propIs(type, name, obj) { - return propSatisfies(is(type), name, obj); - }); + return seq(this.t("set"), this.sep(Sep.AFTER_SET), name, this.sep(Sep.BEFORE_SET_PARAMS), this.paren(param, Sep.SETTER_PARAM_BEFORE, Sep.SETTER_PARAM_AFTER), this.sep(Sep.BEFORE_SET_BODY), this.brace(body, node, Sep.SET_BRACE_INTIIAL, Sep.SET_BRACE_FINAL, Sep.SET_BRACE_EMPTY)); + } + }, { + key: "reduceShorthandProperty", + value: function reduceShorthandProperty(node) { + return this.t(node.name); + } + }, { + key: "reduceStaticMemberExpression", + value: function reduceStaticMemberExpression(node, _ref52) { + var object = _ref52.object; + var property = _ref52.property; - /** - * Returns a single item by iterating through the list, successively calling - * the iterator function and passing it an accumulator value and the current - * value from the array, and then passing the result to the next call. - * - * The iterator function receives two values: *(acc, value)*. It may use - * `R.reduced` to shortcut the iteration. - * - * Note: `R.reduce` does not skip deleted or unassigned indices (sparse - * arrays), unlike the native `Array.prototype.reduce` method. For more details - * on this behavior, see: - * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce#Description - * - * Dispatches to the `reduce` method of the third argument, if present. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig ((a, b) -> a) -> a -> [b] -> a - * @param {Function} fn The iterator function. Receives two values, the accumulator and the - * current element from the array. - * @param {*} acc The accumulator value. - * @param {Array} list The list to iterate over. - * @return {*} The final, accumulated value. - * @see R.reduced, R.addIndex - * @example - * - * var numbers = [1, 2, 3]; - * var add = (a, b) => a + b; - * - * R.reduce(add, 10, numbers); //=> 16 - */ - var reduce = _curry3(_reduce); + var state = seq(this.p(node.object, (0, _coderep.getPrecedence)(node), object), this.sep(Sep.BEFORE_STATIC_MEMBER_DOT), this.t("."), this.sep(Sep.AFTER_STATIC_MEMBER_DOT), this.t(property)); + state.startsWithLet = object.startsWithLet; + state.startsWithCurly = object.startsWithCurly; + state.startsWithLetSquareBracket = object.startsWithLetSquareBracket; + state.startsWithFunctionOrClass = object.startsWithFunctionOrClass; + return state; + } + }, { + key: "reduceStaticPropertyName", + value: function reduceStaticPropertyName(node) { + var n; + if (_esutils.keyword.isIdentifierNameES6(node.value)) { + return this.t(node.value); + } else if (n = parseFloat(node.value), n === n) { + return new _coderep.NumberCodeRep(n); + } + return this.t((0, _coderep.escapeStringLiteral)(node.value)); + } + }, { + key: "reduceSuper", + value: function reduceSuper() { + return this.t("super"); + } + }, { + key: "reduceSwitchCase", + value: function reduceSwitchCase(node, _ref53) { + var test = _ref53.test; + var consequent = _ref53.consequent; - /** - * The complement of `filter`. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig Filterable f => (a -> Boolean) -> f a -> f a - * @param {Function} pred - * @param {Array} filterable - * @return {Array} - * @see R.filter, R.transduce, R.addIndex - * @example - * - * var isOdd = (n) => n % 2 === 1; - * - * R.reject(isOdd, [1, 2, 3, 4]); //=> [2, 4] - * - * R.reject(isOdd, {a: 1, b: 2, c: 3, d: 4}); //=> {b: 2, d: 4} - */ - var reject = _curry2(function reject(pred, filterable) { - return filter(_complement(pred), filterable); - }); + return seq(this.t("case"), this.sep(Sep.BEFORE_CASE_TEST), test, this.sep(Sep.AFTER_CASE_TEST), this.t(":"), this.sep(Sep.BEFORE_CASE_BODY), seq.apply(undefined, _toConsumableArray(consequent)), this.sep(Sep.AFTER_CASE_BODY)); + } + }, { + key: "reduceSwitchDefault", + value: function reduceSwitchDefault(node, _ref54) { + var consequent = _ref54.consequent; - /** - * Returns a fixed list of size `n` containing a specified identical value. - * - * @func - * @memberOf R - * @since v0.1.1 - * @category List - * @sig a -> n -> [a] - * @param {*} value The value to repeat. - * @param {Number} n The desired size of the output list. - * @return {Array} A new array containing `n` `value`s. - * @example - * - * R.repeat('hi', 5); //=> ['hi', 'hi', 'hi', 'hi', 'hi'] - * - * var obj = {}; - * var repeatedObjs = R.repeat(obj, 5); //=> [{}, {}, {}, {}, {}] - * repeatedObjs[0] === repeatedObjs[1]; //=> true - */ - var repeat = _curry2(function repeat(value, n) { - return times(always(value), n); - }); + return seq(this.t("default"), this.sep(Sep.DEFAULT), this.t(":"), this.sep(Sep.BEFORE_CASE_BODY), seq.apply(undefined, _toConsumableArray(consequent)), this.sep(Sep.AFTER_DEFAULT_BODY)); + } + }, { + key: "reduceSwitchStatement", + value: function reduceSwitchStatement(node, _ref55) { + var discriminant = _ref55.discriminant; + var cases = _ref55.cases; - /** - * Adds together all the elements of a list. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Math - * @sig [Number] -> Number - * @param {Array} list An array of numbers - * @return {Number} The sum of all the numbers in the list. - * @see R.reduce - * @example - * - * R.sum([2,4,6,8,100,1]); //=> 121 - */ - var sum = reduce(add, 0); + return seq(this.t("switch"), this.sep(Sep.BEFORE_SWITCH_DISCRIM), this.paren(discriminant, Sep.SWITCH_DISCRIM_PAREN_BEFORE, Sep.SWITCH_DISCRIM_PAREN_AFTER), this.sep(Sep.BEFORE_SWITCH_BODY), this.brace(seq.apply(undefined, _toConsumableArray(cases)), node, Sep.SWITCH_BRACE_INTIAL, Sep.SWITCH_BRACE_FINAL, Sep.SWITCH_BRACE_EMPTY), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceSwitchStatementWithDefault", + value: function reduceSwitchStatementWithDefault(node, _ref56) { + var discriminant = _ref56.discriminant; + var preDefaultCases = _ref56.preDefaultCases; + var defaultCase = _ref56.defaultCase; + var postDefaultCases = _ref56.postDefaultCases; - /** - * Returns a new list containing the last `n` elements of the given list. - * If `n > list.length`, returns a list of `list.length` elements. - * - * @func - * @memberOf R - * @since v0.16.0 - * @category List - * @sig Number -> [a] -> [a] - * @sig Number -> String -> String - * @param {Number} n The number of elements to return. - * @param {Array} xs The collection to consider. - * @return {Array} - * @see R.dropLast - * @example - * - * R.takeLast(1, ['foo', 'bar', 'baz']); //=> ['baz'] - * R.takeLast(2, ['foo', 'bar', 'baz']); //=> ['bar', 'baz'] - * R.takeLast(3, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] - * R.takeLast(4, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] - * R.takeLast(3, 'ramda'); //=> 'mda' - */ - var takeLast = _curry2(function takeLast(n, xs) { - return drop(n >= 0 ? xs.length - n : 0, xs); - }); + return seq(this.t("switch"), this.sep(Sep.BEFORE_SWITCH_DISCRIM), this.paren(discriminant, Sep.SWITCH_DISCRIM_PAREN_BEFORE, Sep.SWITCH_DISCRIM_PAREN_AFTER), this.sep(Sep.BEFORE_SWITCH_BODY), this.brace(seq.apply(undefined, _toConsumableArray(preDefaultCases).concat([defaultCase], _toConsumableArray(postDefaultCases))), node, Sep.SWITCH_BRACE_INTIAL, Sep.SWITCH_BRACE_FINAL, Sep.SWITCH_BRACE_EMPTY), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceTemplateExpression", + value: function reduceTemplateExpression(node, _ref57) { + var tag = _ref57.tag; + var elements = _ref57.elements; - /** - * Initializes a transducer using supplied iterator function. Returns a single - * item by iterating through the list, successively calling the transformed - * iterator function and passing it an accumulator value and the current value - * from the array, and then passing the result to the next call. - * - * The iterator function receives two values: *(acc, value)*. It will be - * wrapped as a transformer to initialize the transducer. A transformer can be - * passed directly in place of an iterator function. In both cases, iteration - * may be stopped early with the `R.reduced` function. - * - * A transducer is a function that accepts a transformer and returns a - * transformer and can be composed directly. - * - * A transformer is an an object that provides a 2-arity reducing iterator - * function, step, 0-arity initial value function, init, and 1-arity result - * extraction function, result. The step function is used as the iterator - * function in reduce. The result function is used to convert the final - * accumulator into the return type and in most cases is R.identity. The init - * function can be used to provide an initial accumulator, but is ignored by - * transduce. - * - * The iteration is performed with R.reduce after initializing the transducer. - * - * @func - * @memberOf R - * @since v0.12.0 - * @category List - * @sig (c -> c) -> (a,b -> a) -> a -> [b] -> a - * @param {Function} xf The transducer function. Receives a transformer and returns a transformer. - * @param {Function} fn The iterator function. Receives two values, the accumulator and the - * current element from the array. Wrapped as transformer, if necessary, and used to - * initialize the transducer - * @param {*} acc The initial accumulator value. - * @param {Array} list The list to iterate over. - * @return {*} The final, accumulated value. - * @see R.reduce, R.reduced, R.into - * @example - * - * var numbers = [1, 2, 3, 4]; - * var transducer = R.compose(R.map(R.add(1)), R.take(2)); - * - * R.transduce(transducer, R.flip(R.append), [], numbers); //=> [2, 3] - */ - var transduce = curryN(4, function transduce(xf, fn, acc, list) { - return _reduce(xf(typeof fn === 'function' ? _xwrap(fn) : fn), acc, list); - }); + var state = node.tag == null ? empty() : seq(this.p(node.tag, (0, _coderep.getPrecedence)(node), tag), this.sep(Sep.TEMPLATE_TAG)); + var templateData = ""; + state = seq(state, this.t("`")); + for (var i = 0, l = node.elements.length; i < l; ++i) { + if (node.elements[i].type === "TemplateElement") { + var d = ""; + if (i > 0) d += "}"; + d += node.elements[i].rawValue; + if (i < l - 1) d += "${"; + state = seq(state, this.t(d)); + } else { + state = seq(state, this.sep(Sep.BEFORE_TEMPLATE_EXPRESSION), elements[i], this.sep(Sep.AFTER_TEMPLATE_EXPRESSION)); + } + } + state = seq(state, this.t("`")); + if (node.tag != null) { + state.startsWithCurly = tag.startsWithCurly; + state.startsWithLetSquareBracket = tag.startsWithLetSquareBracket; + state.startsWithFunctionOrClass = tag.startsWithFunctionOrClass; + } + return state; + } + }, { + key: "reduceTemplateElement", + value: function reduceTemplateElement(node) { + return this.t(node.rawValue); + } + }, { + key: "reduceThisExpression", + value: function reduceThisExpression(node) { + return this.t("this"); + } + }, { + key: "reduceThrowStatement", + value: function reduceThrowStatement(node, _ref58) { + var expression = _ref58.expression; - /** - * Combines two lists into a set (i.e. no duplicates) composed of the elements - * of each list. Duplication is determined according to the value returned by - * applying the supplied predicate to two list elements. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig (a -> a -> Boolean) -> [*] -> [*] -> [*] - * @param {Function} pred A predicate used to test whether two items are equal. - * @param {Array} list1 The first list. - * @param {Array} list2 The second list. - * @return {Array} The first and second lists concatenated, with - * duplicates removed. - * @see R.union - * @example - * - * var l1 = [{a: 1}, {a: 2}]; - * var l2 = [{a: 1}, {a: 4}]; - * R.unionWith(R.eqBy(R.prop('a')), l1, l2); //=> [{a: 1}, {a: 2}, {a: 4}] - */ - var unionWith = _curry3(function unionWith(pred, list1, list2) { - return uniqWith(pred, _concat(list1, list2)); - }); + return seq(this.t("throw"), this.sep(Sep.THROW), expression, this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceTryCatchStatement", + value: function reduceTryCatchStatement(node, _ref59) { + var body = _ref59.body; + var catchClause = _ref59.catchClause; - /** - * Takes a spec object and a test object; returns true if the test satisfies - * the spec, false otherwise. An object satisfies the spec if, for each of the - * spec's own properties, accessing that property of the object gives the same - * value (in `R.equals` terms) as accessing that property of the spec. - * - * `whereEq` is a specialization of [`where`](#where). - * - * @func - * @memberOf R - * @since v0.14.0 - * @category Object - * @sig {String: *} -> {String: *} -> Boolean - * @param {Object} spec - * @param {Object} testObj - * @return {Boolean} - * @see R.where - * @example - * - * // pred :: Object -> Boolean - * var pred = R.whereEq({a: 1, b: 2}); - * - * pred({a: 1}); //=> false - * pred({a: 1, b: 2}); //=> true - * pred({a: 1, b: 2, c: 3}); //=> true - * pred({a: 1, b: 1}); //=> false - */ - var whereEq = _curry2(function whereEq(spec, testObj) { - return where(map(equals, spec), testObj); - }); + return seq(this.t("try"), this.sep(Sep.AFTER_TRY), body, this.sep(Sep.BEFORE_CATCH), catchClause, this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceTryFinallyStatement", + value: function reduceTryFinallyStatement(node, _ref60) { + var body = _ref60.body; + var catchClause = _ref60.catchClause; + var finalizer = _ref60.finalizer; - var _flatCat = function () { - var preservingReduced = function (xf) { - return { - '@@transducer/init': _xfBase.init, - '@@transducer/result': function (result) { - return xf['@@transducer/result'](result); - }, - '@@transducer/step': function (result, input) { - var ret = xf['@@transducer/step'](result, input); - return ret['@@transducer/reduced'] ? _forceReduced(ret) : ret; - } - }; - }; - return function _xcat(xf) { - var rxf = preservingReduced(xf); - return { - '@@transducer/init': _xfBase.init, - '@@transducer/result': function (result) { - return rxf['@@transducer/result'](result); - }, - '@@transducer/step': function (result, input) { - return !isArrayLike(input) ? _reduce(rxf, result, [input]) : _reduce(rxf, result, input); - } - }; - }; - }(); + return seq(this.t("try"), this.sep(Sep.AFTER_TRY), body, catchClause ? seq(this.sep(Sep.BEFORE_CATCH), catchClause) : empty(), this.sep(Sep.BEFORE_FINALLY), this.t("finally"), this.sep(Sep.AFTER_FINALLY), finalizer, this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceYieldExpression", + value: function reduceYieldExpression(node, _ref61) { + var expression = _ref61.expression; - // Array.prototype.indexOf doesn't exist below IE9 - // manually crawl the list to distinguish between +0 and -0 - // NaN - // non-zero numbers can utilise Set - // all these types can utilise Set - // null can utilise Set - // anything else not covered above, defer to R.equals - var _indexOf = function _indexOf(list, a, idx) { - var inf, item; - // Array.prototype.indexOf doesn't exist below IE9 - if (typeof list.indexOf === 'function') { - switch (typeof a) { - case 'number': - if (a === 0) { - // manually crawl the list to distinguish between +0 and -0 - inf = 1 / a; - while (idx < list.length) { - item = list[idx]; - if (item === 0 && 1 / item === inf) { - return idx; - } - idx += 1; - } - return -1; - } else if (a !== a) { - // NaN - while (idx < list.length) { - item = list[idx]; - if (typeof item === 'number' && item !== item) { - return idx; - } - idx += 1; - } - return -1; - } - // non-zero numbers can utilise Set - return list.indexOf(a, idx); - // all these types can utilise Set - case 'string': - case 'boolean': - case 'function': - case 'undefined': - return list.indexOf(a, idx); - case 'object': - if (a === null) { - // null can utilise Set - return list.indexOf(a, idx); - } - } - } - // anything else not covered above, defer to R.equals - while (idx < list.length) { - if (equals(list[idx], a)) { - return idx; - } - idx += 1; - } - return -1; - }; + if (node.expression == null) return this.t("yield"); + return seq(this.t("yield"), this.sep(Sep.YIELD), this.p(node.expression, (0, _coderep.getPrecedence)(node), expression)); + } + }, { + key: "reduceYieldGeneratorExpression", + value: function reduceYieldGeneratorExpression(node, _ref62) { + var expression = _ref62.expression; - var _xchain = _curry2(function _xchain(f, xf) { - return map(f, _flatCat(xf)); - }); + return seq(this.t("yield"), this.sep(Sep.BEFORE_YIELD_STAR), this.t("*"), this.sep(Sep.AFTER_YIELD_STAR), this.p(node.expression, (0, _coderep.getPrecedence)(node), expression)); + } + }, { + key: "reduceDirective", + value: function reduceDirective(node) { + var delim = /^(?:[^"\\]|\\.)*$/.test(node.rawValue) ? "\"" : "'"; + return seq(this.t(delim + node.rawValue + delim), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceVariableDeclaration", + value: function reduceVariableDeclaration(node, _ref63) { + var declarators = _ref63.declarators; - /** - * Takes a list of predicates and returns a predicate that returns true for a - * given list of arguments if every one of the provided predicates is satisfied - * by those arguments. - * - * The function returned is a curried function whose arity matches that of the - * highest-arity predicate. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Logic - * @sig [(*... -> Boolean)] -> (*... -> Boolean) - * @param {Array} preds - * @return {Function} - * @see R.anyPass - * @example - * - * var isQueen = R.propEq('rank', 'Q'); - * var isSpade = R.propEq('suit', '♠︎'); - * var isQueenOfSpades = R.allPass([isQueen, isSpade]); - * - * isQueenOfSpades({rank: 'Q', suit: '♣︎'}); //=> false - * isQueenOfSpades({rank: 'Q', suit: '♠︎'}); //=> true - */ - var allPass = _curry1(function allPass(preds) { - return curryN(reduce(max, 0, pluck('length', preds)), function () { - var idx = 0; - var len = preds.length; - while (idx < len) { - if (!preds[idx].apply(this, arguments)) { - return false; - } - idx += 1; - } - return true; - }); - }); + return seq(this.t(node.kind), this.sep(Sep.VARIABLE_DECLARATION), this.commaSep(declarators, Sep.DECLARATORS_BEFORE_COMMA, Sep.DECLARATORS_AFTER_COMMA)); + } + }, { + key: "reduceVariableDeclarationStatement", + value: function reduceVariableDeclarationStatement(node, _ref64) { + var declaration = _ref64.declaration; - /** - * Returns `true` if all elements are unique, in `R.equals` terms, otherwise - * `false`. - * - * @func - * @memberOf R - * @since v0.18.0 - * @category List - * @sig [a] -> Boolean - * @param {Array} list The array to consider. - * @return {Boolean} `true` if all elements are unique, else `false`. - * @example - * - * R.allUniq(['1', 1]); //=> true - * R.allUniq([1, 1]); //=> false - * R.allUniq([[42], [42]]); //=> false - */ - var allUniq = _curry1(function allUniq(list) { - var len = list.length; - var idx = 0; - while (idx < len) { - if (_indexOf(list, list[idx], idx + 1) >= 0) { - return false; - } - idx += 1; + return seq(declaration, this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceVariableDeclarator", + value: function reduceVariableDeclarator(node, _ref65) { + var binding = _ref65.binding; + var init = _ref65.init; + + var containsIn = init && init.containsIn && !init.containsGroup; + if (init) { + if (init.containsGroup) { + init = this.paren(init, Sep.EXPRESSION_PAREN_BEFORE, Sep.EXPRESSION_PAREN_AFTER); + } else { + init = markContainsIn(init); } - return true; - }); + } + return (0, _objectAssign2.default)(init == null ? binding : seq(binding, this.sep(Sep.BEFORE_INIT_EQUALS), this.t("="), this.sep(Sep.AFTER_INIT_EQUALS), init), { containsIn: containsIn }); + } + }, { + key: "reduceWhileStatement", + value: function reduceWhileStatement(node, _ref66) { + var test = _ref66.test; + var body = _ref66.body; - /** - * Takes a list of predicates and returns a predicate that returns true for a - * given list of arguments if at least one of the provided predicates is - * satisfied by those arguments. - * - * The function returned is a curried function whose arity matches that of the - * highest-arity predicate. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Logic - * @sig [(*... -> Boolean)] -> (*... -> Boolean) - * @param {Array} preds - * @return {Function} - * @see R.allPass - * @example - * - * var gte = R.anyPass([R.gt, R.equals]); - * - * gte(3, 2); //=> true - * gte(2, 2); //=> true - * gte(2, 3); //=> false - */ - var anyPass = _curry1(function anyPass(preds) { - return curryN(reduce(max, 0, pluck('length', preds)), function () { - var idx = 0; - var len = preds.length; - while (idx < len) { - if (preds[idx].apply(this, arguments)) { - return true; - } - idx += 1; - } - return false; - }); - }); + return (0, _objectAssign2.default)(seq(this.t("while"), this.sep(Sep.AFTER_WHILE), this.paren(test, Sep.WHILE_TEST_PAREN_BEFORE, Sep.WHILE_TEST_PAREN_AFTER), this.sep(Sep.BEFORE_WHILE_BODY), body, this.sep(Sep.AFTER_STATEMENT(node))), { endsWithMissingElse: body.endsWithMissingElse }); + } + }, { + key: "reduceWithStatement", + value: function reduceWithStatement(node, _ref67) { + var object = _ref67.object; + var body = _ref67.body; - /** - * ap applies a list of functions to a list of values. - * - * Dispatches to the `ap` method of the second argument, if present. Also - * treats functions as applicatives. - * - * @func - * @memberOf R - * @since v0.3.0 - * @category Function - * @sig [f] -> [a] -> [f a] - * @param {Array} fns An array of functions - * @param {Array} vs An array of values - * @return {Array} An array of results of applying each of `fns` to all of `vs` in turn. - * @example - * - * R.ap([R.multiply(2), R.add(3)], [1,2,3]); //=> [2, 4, 6, 4, 5, 6] - */ - // else - var ap = _curry2(function ap(applicative, fn) { - return typeof applicative.ap === 'function' ? applicative.ap(fn) : typeof applicative === 'function' ? curryN(Math.max(applicative.length, fn.length), function () { - return applicative.apply(this, arguments)(fn.apply(this, arguments)); - }) : // else - _reduce(function (acc, f) { - return _concat(acc, map(f, fn)); - }, [], applicative); - }); + return (0, _objectAssign2.default)(seq(this.t("with"), this.sep(Sep.AFTER_WITH), this.paren(object, Sep.WITH_PAREN_BEFORE, Sep.WITH_PAREN_AFTER), this.sep(Sep.BEFORE_WITH_BODY), body, this.sep(Sep.AFTER_STATEMENT(node))), { endsWithMissingElse: body.endsWithMissingElse }); + } + }]); - /** - * Returns the result of calling its first argument with the remaining - * arguments. This is occasionally useful as a converging function for - * `R.converge`: the left branch can produce a function while the right branch - * produces a value to be passed to that function as an argument. - * - * @func - * @memberOf R - * @since v0.9.0 - * @category Function - * @sig (*... -> a),*... -> a - * @param {Function} fn The function to apply to the remaining arguments. - * @param {...*} args Any number of positional arguments. - * @return {*} - * @see R.apply - * @example - * - * var indentN = R.pipe(R.times(R.always(' ')), - * R.join(''), - * R.replace(/^(?!$)/gm)); - * - * var format = R.converge(R.call, [ - * R.pipe(R.prop('indent'), indentN), - * R.prop('value') - * ]); - * - * format({indent: 2, value: 'foo\nbar\nbaz\n'}); //=> ' foo\n bar\n baz\n' - */ - var call = curry(function call(fn) { - return fn.apply(this, _slice(arguments, 1)); - }); + return ExtensibleCodeGen; + }(); - /** - * `chain` maps a function over a list and concatenates the results. `chain` - * is also known as `flatMap` in some libraries - * - * Dispatches to the `chain` method of the second argument, if present. - * - * @func - * @memberOf R - * @since v0.3.0 - * @category List - * @sig (a -> [b]) -> [a] -> [b] - * @param {Function} fn - * @param {Array} list - * @return {Array} - * @example - * - * var duplicate = n => [n, n]; - * R.chain(duplicate, [1, 2, 3]); //=> [1, 1, 2, 2, 3, 3] - */ - var chain = _curry2(_dispatchable('chain', _xchain, function chain(fn, monad) { - if (typeof monad === 'function') { - return function () { - return monad.call(this, fn.apply(this, arguments)).apply(this, arguments); - }; - } - return _makeFlat(false)(map(fn, monad)); - })); + var INDENT = " "; - /** - * Turns a list of Functors into a Functor of a list, applying a mapping - * function to the elements of the list along the way. - * - * @func - * @memberOf R - * @since v0.8.0 - * @category List - * @sig Functor f => (a -> f b) -> (x -> f x) -> [a] -> f [b] - * @param {Function} fn The transformation function - * @param {Function} of A function that returns the data type to return - * @param {Array} list An array of functors of the same type - * @return {*} - * @see R.traverse - * @deprecated since v0.19.0 - * @example - * - * var add10 = R.map(R.add(10)); - * R.commuteMap(add10, R.of, [[1], [2, 3]]); //=> [[11, 12], [11, 13]] - * R.commuteMap(add10, R.of, [[1, 2], [3]]); //=> [[11, 13], [12, 13]] - * R.commuteMap(add10, R.of, [[1], [2], [3]]); //=> [[11, 12, 13]] - * R.commuteMap(add10, Maybe.of, [Just(1), Just(2), Just(3)]); //=> Just([11, 12, 13]) - * R.commuteMap(add10, Maybe.of, [Just(1), Just(2), Nothing()]); //=> Nothing() - * - * var fetch = url => Future((rej, res) => http.get(url, res).on('error', rej)); - * R.commuteMap(fetch, Future.of, [ - * 'http://ramdajs.com', - * 'http://github.com/ramda' - * ]); //=> Future([IncomingMessage, IncomingMessage]) - */ - var commuteMap = _curry3(function commuteMap(fn, of, list) { - function consF(acc, x) { - return ap(map(prepend, fn(x)), acc); - } - return reduceRight(consF, of([]), list); - }); + var Linebreak = function (_CodeRep) { + _inherits(Linebreak, _CodeRep); - /** - * Wraps a constructor function inside a curried function that can be called - * with the same arguments and returns the same type. The arity of the function - * returned is specified to allow using variadic constructor functions. - * - * @func - * @memberOf R - * @since v0.4.0 - * @category Function - * @sig Number -> (* -> {*}) -> (* -> {*}) - * @param {Number} n The arity of the constructor function. - * @param {Function} Fn The constructor function to wrap. - * @return {Function} A wrapped, curried constructor function. - * @example - * - * // Variadic constructor function - * var Widget = () => { - * this.children = Array.prototype.slice.call(arguments); - * // ... - * }; - * Widget.prototype = { - * // ... - * }; - * var allConfigs = [ - * // ... - * ]; - * R.map(R.constructN(1, Widget), allConfigs); // a list of Widgets - */ - var constructN = _curry2(function constructN(n, Fn) { - if (n > 10) { - throw new Error('Constructor with greater than ten arguments'); - } - if (n === 0) { - return function () { - return new Fn(); - }; - } - return curry(nAry(n, function ($0, $1, $2, $3, $4, $5, $6, $7, $8, $9) { - switch (arguments.length) { - case 1: - return new Fn($0); - case 2: - return new Fn($0, $1); - case 3: - return new Fn($0, $1, $2); - case 4: - return new Fn($0, $1, $2, $3); - case 5: - return new Fn($0, $1, $2, $3, $4); - case 6: - return new Fn($0, $1, $2, $3, $4, $5); - case 7: - return new Fn($0, $1, $2, $3, $4, $5, $6); - case 8: - return new Fn($0, $1, $2, $3, $4, $5, $6, $7); - case 9: - return new Fn($0, $1, $2, $3, $4, $5, $6, $7, $8); - case 10: - return new Fn($0, $1, $2, $3, $4, $5, $6, $7, $8, $9); - } - })); - }); + function Linebreak() { + _classCallCheck(this, Linebreak); - /** - * Accepts a converging function and a list of branching functions and returns - * a new function. When invoked, this new function is applied to some - * arguments, each branching function is applied to those same arguments. The - * results of each branching function are passed as arguments to the converging - * function to produce the return value. - * - * @func - * @memberOf R - * @since v0.4.2 - * @category Function - * @sig (x1 -> x2 -> ... -> z) -> [(a -> b -> ... -> x1), (a -> b -> ... -> x2), ...] -> (a -> b -> ... -> z) - * @param {Function} after A function. `after` will be invoked with the return values of - * `fn1` and `fn2` as its arguments. - * @param {Array} functions A list of functions. - * @return {Function} A new function. - * @example - * - * var add = (a, b) => a + b; - * var multiply = (a, b) => a * b; - * var subtract = (a, b) => a - b; - * - * //≅ multiply( add(1, 2), subtract(1, 2) ); - * R.converge(multiply, [add, subtract])(1, 2); //=> -3 - * - * var add3 = (a, b, c) => a + b + c; - * R.converge(add3, [multiply, add, subtract])(1, 2); //=> 4 - */ - var converge = _curry2(function converge(after, fns) { - return curryN(Math.max.apply(Math, pluck('length', fns)), function () { - var args = arguments; - var context = this; - return after.apply(context, _map(function (fn) { - return fn.apply(context, args); - }, fns)); - }); - }); + var _this4 = _possibleConstructorReturn(this, Object.getPrototypeOf(Linebreak).call(this)); - /** - * Returns a new list without any consecutively repeating elements. Equality is - * determined by applying the supplied predicate two consecutive elements. The - * first element in a series of equal element is the one being preserved. - * - * Dispatches to the `dropRepeatsWith` method of the second argument, if present. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since v0.14.0 - * @category List - * @sig (a, a -> Boolean) -> [a] -> [a] - * @param {Function} pred A predicate used to test whether two items are equal. - * @param {Array} list The array to consider. - * @return {Array} `list` without repeating elements. - * @see R.transduce - * @example - * - * var lengthEq = (x, y) => Math.abs(x) === Math.abs(y); - * var l = [1, -1, 1, 3, 4, -4, -4, -5, 5, 3, 3]; - * R.dropRepeatsWith(R.eqBy(Math.abs), l); //=> [1, 3, 4, -5, 3] - */ - var dropRepeatsWith = _curry2(_dispatchable('dropRepeatsWith', _xdropRepeatsWith, function dropRepeatsWith(pred, list) { - var result = []; - var idx = 1; - var len = list.length; - if (len !== 0) { - result[0] = list[0]; - while (idx < len) { - if (!pred(last(result), list[idx])) { - result[result.length] = list[idx]; - } - idx += 1; - } - } - return result; - })); - - /** - * Takes a function and two values in its domain and returns `true` if the - * values map to the same value in the codomain; `false` otherwise. - * - * @func - * @memberOf R - * @since v0.18.0 - * @category Relation - * @sig (a -> b) -> a -> a -> Boolean - * @param {Function} f - * @param {*} x - * @param {*} y - * @return {Boolean} - * @example - * - * R.eqBy(Math.abs, 5, -5); //=> true - */ - var eqBy = _curry3(function eqBy(f, x, y) { - return equals(f(x), f(y)); - }); - - /** - * Reports whether two objects have the same value, in `R.equals` terms, for - * the specified property. Useful as a curried predicate. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Object - * @sig k -> {k: v} -> {k: v} -> Boolean - * @param {String} prop The name of the property to compare - * @param {Object} obj1 - * @param {Object} obj2 - * @return {Boolean} - * - * @example - * - * var o1 = { a: 1, b: 2, c: 3, d: 4 }; - * var o2 = { a: 10, b: 20, c: 3, d: 40 }; - * R.eqProps('a', o1, o2); //=> false - * R.eqProps('c', o1, o2); //=> true - */ - var eqProps = _curry3(function eqProps(prop, obj1, obj2) { - return equals(obj1[prop], obj2[prop]); - }); - - /** - * Returns the position of the first occurrence of an item in an array, or -1 - * if the item is not included in the array. `R.equals` is used to determine - * equality. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig a -> [a] -> Number - * @param {*} target The item to find. - * @param {Array} xs The array to search in. - * @return {Number} the index of the target, or -1 if the target is not found. - * @see R.lastIndexOf - * @example - * - * R.indexOf(3, [1,2,3,4]); //=> 2 - * R.indexOf(10, [1,2,3,4]); //=> -1 - */ - var indexOf = _curry2(function indexOf(target, xs) { - return typeof xs.indexOf === 'function' && !_isArray(xs) ? xs.indexOf(target) : _indexOf(xs, target, 0); - }); + _this4.indentation = 0; + return _this4; + } - /** - * juxt applies a list of functions to a list of values. - * - * @func - * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category Function - * @sig [(a, b, ..., m) -> n] -> ((a, b, ..., m) -> [n]) - * @param {Array} fns An array of functions - * @return {Function} A function that returns a list of values after applying each of the original `fns` to its parameters. - * @example - * - * var range = R.juxt([Math.min, Math.max]); - * range(3, 4, 9, -3); //=> [-3, 9] - */ - var juxt = _curry1(function juxt(fns) { - return function () { - return map(apply(__, arguments), fns); - }; - }); + _createClass(Linebreak, [{ + key: "emit", + value: function emit(ts) { + ts.put("\n"); + for (var i = 0; i < this.indentation; ++i) { + ts.put(INDENT); + } + } + }]); - /** - * Returns a lens for the given getter and setter functions. The getter "gets" - * the value of the focus; the setter "sets" the value of the focus. The setter - * should not mutate the data structure. - * - * @func - * @memberOf R - * @since v0.8.0 - * @category Object - * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s - * @sig (s -> a) -> ((a, s) -> s) -> Lens s a - * @param {Function} getter - * @param {Function} setter - * @return {Lens} - * @see R.view, R.set, R.over, R.lensIndex, R.lensProp - * @example - * - * var xLens = R.lens(R.prop('x'), R.assoc('x')); - * - * R.view(xLens, {x: 1, y: 2}); //=> 1 - * R.set(xLens, 4, {x: 1, y: 2}); //=> {x: 4, y: 2} - * R.over(xLens, R.negate, {x: 1, y: 2}); //=> {x: -1, y: 2} - */ - var lens = _curry2(function lens(getter, setter) { - return function (f) { - return function (s) { - return map(function (v) { - return setter(v, s); - }, f(getter(s))); - }; - }; - }); + return Linebreak; + }(_coderep.CodeRep); - /** - * Returns a lens whose focus is the specified index. - * - * @func - * @memberOf R - * @since v0.14.0 - * @category Object - * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s - * @sig Number -> Lens s a - * @param {Number} n - * @return {Lens} - * @see R.view, R.set, R.over - * @example - * - * var headLens = R.lensIndex(0); - * - * R.view(headLens, ['a', 'b', 'c']); //=> 'a' - * R.set(headLens, 'x', ['a', 'b', 'c']); //=> ['x', 'b', 'c'] - * R.over(headLens, R.toUpper, ['a', 'b', 'c']); //=> ['A', 'b', 'c'] - */ - var lensIndex = _curry1(function lensIndex(n) { - return lens(nth(n), update(n)); - }); + function withoutTrailingLinebreak(state) { + if (state && state instanceof _coderep.Seq) { + var lastChild = state.children[state.children.length - 1]; + /* istanbul ignore next */ + while (lastChild instanceof _coderep.Empty) { + state.children.pop(); + lastChild = state.children[state.children.length - 1]; + } + /* istanbul ignore else */ + if (lastChild instanceof _coderep.Seq) { + withoutTrailingLinebreak(lastChild); + } else if (lastChild instanceof Linebreak) { + state.children.pop(); + } + } + return state; + } - /** - * Returns a lens whose focus is the specified path. - * - * @func - * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category Object - * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s - * @sig [String] -> Lens s a - * @param {Array} path The path to use. - * @return {Lens} - * @see R.view, R.set, R.over - * @example - * - * var xyLens = R.lensPath(['x', 'y']); - * - * R.view(xyLens, {x: {y: 2, z: 3}}); //=> 2 - * R.set(xyLens, 4, {x: {y: 2, z: 3}}); //=> {x: {y: 4, z: 3}} - * R.over(xyLens, R.negate, {x: {y: 2, z: 3}}); //=> {x: {y: -2, z: 3}} - */ - var lensPath = _curry1(function lensPath(p) { - return lens(path(p), assocPath(p)); - }); + function indent(rep, includingFinal) { + var finalLinebreak = undefined; + function indentNode(node) { + if (node instanceof Linebreak) { + finalLinebreak = node; + ++node.indentation; + } + } + rep.forEach(indentNode); + if (!includingFinal) { + --finalLinebreak.indentation; + } + return rep; + } - /** - * Returns a lens whose focus is the specified property. - * - * @func - * @memberOf R - * @since v0.14.0 - * @category Object - * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s - * @sig String -> Lens s a - * @param {String} k - * @return {Lens} - * @see R.view, R.set, R.over - * @example - * - * var xLens = R.lensProp('x'); - * - * R.view(xLens, {x: 1, y: 2}); //=> 1 - * R.set(xLens, 4, {x: 1, y: 2}); //=> {x: 4, y: 2} - * R.over(xLens, R.negate, {x: 1, y: 2}); //=> {x: -1, y: 2} - */ - var lensProp = _curry1(function lensProp(k) { - return lens(prop(k), assoc(k)); - }); + var FormattedCodeGen = exports.FormattedCodeGen = function (_ExtensibleCodeGen) { + _inherits(FormattedCodeGen, _ExtensibleCodeGen); - /** - * "lifts" a function to be the specified arity, so that it may "map over" that - * many lists (or other objects that satisfies the [FantasyLand Apply spec](https://github.com/fantasyland/fantasy-land#apply)). - * - * @func - * @memberOf R - * @since v0.7.0 - * @category Function - * @sig Number -> (*... -> *) -> ([*]... -> [*]) - * @param {Function} fn The function to lift into higher context - * @return {Function} The lifted function. - * @see R.lift - * @example - * - * var madd3 = R.liftN(3, R.curryN(3, (...args) => R.sum(args))); - * madd3([1,2,3], [1,2,3], [1]); //=> [3, 4, 5, 4, 5, 6, 5, 6, 7] - */ - var liftN = _curry2(function liftN(arity, fn) { - var lifted = curryN(arity, fn); - return curryN(arity, function () { - return _reduce(ap, map(lifted, arguments[0]), _slice(arguments, 1)); - }); - }); + function FormattedCodeGen() { + _classCallCheck(this, FormattedCodeGen); - /** - * Returns the mean of the given list of numbers. - * - * @func - * @memberOf R - * @since v0.14.0 - * @category Math - * @sig [Number] -> Number - * @param {Array} list - * @return {Number} - * @example - * - * R.mean([2, 7, 9]); //=> 6 - * R.mean([]); //=> NaN - */ - var mean = _curry1(function mean(list) { - return sum(list) / list.length; - }); + return _possibleConstructorReturn(this, Object.getPrototypeOf(FormattedCodeGen).apply(this, arguments)); + } - /** - * Returns the median of the given list of numbers. - * - * @func - * @memberOf R - * @since v0.14.0 - * @category Math - * @sig [Number] -> Number - * @param {Array} list - * @return {Number} - * @example - * - * R.median([2, 9, 7]); //=> 7 - * R.median([7, 2, 10, 9]); //=> 8 - * R.median([]); //=> NaN - */ - var median = _curry1(function median(list) { - var len = list.length; - if (len === 0) { - return NaN; - } - var width = 2 - len % 2; - var idx = (len - width) / 2; - return mean(_slice(list).sort(function (a, b) { - return a < b ? -1 : a > b ? 1 : 0; - }).slice(idx, idx + width)); - }); + _createClass(FormattedCodeGen, [{ + key: "parenToAvoidBeingDirective", + value: function parenToAvoidBeingDirective(element, original) { + if (element && element.type === "ExpressionStatement" && element.expression.type === "LiteralStringExpression") { + return seq(this.paren(original.children[0], Sep.PAREN_AVOIDING_DIRECTIVE_BEFORE, Sep.PAREN_AVOIDING_DIRECTIVE_AFTER), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(element))); + } + return original; + } + }, { + key: "brace", + value: function brace(rep, node) { + if (isEmpty(rep)) { + return this.t("{}"); + } - /** - * Create a new object with the own properties of the first object merged with - * the own properties of the second object. If a key exists in both objects, - * the value from the second object will be used. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Object - * @sig {k: v} -> {k: v} -> {k: v} - * @param {Object} l - * @param {Object} r - * @return {Object} - * @see R.mergeWith, R.mergeWithKey - * @example - * - * R.merge({ 'name': 'fred', 'age': 10 }, { 'age': 40 }); - * //=> { 'name': 'fred', 'age': 40 } - * - * var resetToDefault = R.merge(R.__, {x: 0}); - * resetToDefault({x: 5, y: 2}); //=> {x: 0, y: 2} - */ - var merge = mergeWith(function (l, r) { - return r; - }); + switch (node.type) { + case "ObjectBinding": + case "Import": + case "ExportFrom": + case "ObjectExpression": + return new _coderep.Brace(rep); + } - /** - * Merges a list of objects together into one object. - * - * @func - * @memberOf R - * @since v0.10.0 - * @category List - * @sig [{k: v}] -> {k: v} - * @param {Array} list An array of objects - * @return {Object} A merged object. - * @see R.reduce - * @example - * - * R.mergeAll([{foo:1},{bar:2},{baz:3}]); //=> {foo:1,bar:2,baz:3} - * R.mergeAll([{foo:1},{foo:2},{bar:2}]); //=> {foo:2,bar:2} - */ - var mergeAll = _curry1(function mergeAll(list) { - return reduce(merge, {}, list); - }); + rep = seq(new Linebreak(), rep); + indent(rep, false); + return new _coderep.Brace(rep); + } + }, { + key: "reduceDoWhileStatement", + value: function reduceDoWhileStatement(node, _ref68) { + var body = _ref68.body; + var test = _ref68.test; - /** - * Performs left-to-right function composition. The leftmost function may have - * any arity; the remaining functions must be unary. - * - * In some libraries this function is named `sequence`. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig (((a, b, ..., n) -> o), (o -> p), ..., (x -> y), (y -> z)) -> ((a, b, ..., n) -> z) - * @param {...Function} functions - * @return {Function} - * @see R.compose - * @example - * - * var f = R.pipe(Math.pow, R.negate, R.inc); - * - * f(3, 4); // -(3^4) + 1 - */ - var pipe = function pipe() { - if (arguments.length === 0) { - throw new Error('pipe requires at least one argument'); - } - return _arity(arguments[0].length, reduce(_pipe, arguments[0], tail(arguments))); - }; + return seq(this.t("do"), this.sep(Sep.AFTER_DO), withoutTrailingLinebreak(body), this.sep(Sep.BEFORE_DOWHILE_WHILE), this.t("while"), this.sep(Sep.AFTER_DOWHILE_WHILE), this.paren(test, Sep.DO_WHILE_TEST_PAREN_BEFORE, Sep.DO_WHILE_TEST_PAREN_AFTER), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + } + }, { + key: "reduceIfStatement", + value: function reduceIfStatement(node, _ref69) { + var test = _ref69.test; + var consequent = _ref69.consequent; + var alternate = _ref69.alternate; - /** - * Performs left-to-right composition of one or more Promise-returning - * functions. The leftmost function may have any arity; the remaining functions - * must be unary. - * - * @func - * @memberOf R - * @since v0.10.0 - * @category Function - * @sig ((a -> Promise b), (b -> Promise c), ..., (y -> Promise z)) -> (a -> Promise z) - * @param {...Function} functions - * @return {Function} - * @see R.composeP - * @example - * - * // followersForUser :: String -> Promise [User] - * var followersForUser = R.pipeP(db.getUserById, db.getFollowers); - */ - var pipeP = function pipeP() { - if (arguments.length === 0) { - throw new Error('pipeP requires at least one argument'); - } - return _arity(arguments[0].length, reduce(_pipeP, arguments[0], tail(arguments))); - }; + if (alternate && consequent.endsWithMissingElse) { + consequent = this.brace(consequent, node); + } + return (0, _objectAssign2.default)(seq(this.t("if"), this.sep(Sep.AFTER_IF), this.paren(test, Sep.IF_PAREN_BEFORE, Sep.IF_PAREN_AFTER), this.sep(Sep.AFTER_IF_TEST), withoutTrailingLinebreak(consequent), alternate ? seq(this.sep(Sep.BEFORE_ELSE), this.t("else"), this.sep(Sep.AFTER_ELSE), withoutTrailingLinebreak(alternate)) : empty(), this.sep(Sep.AFTER_STATEMENT(node))), { endsWithMissingElse: alternate ? alternate.endsWithMissingElse : true }); + } + }, { + key: "reduceSwitchCase", + value: function reduceSwitchCase(node, _ref70) { + var test = _ref70.test; + var consequent = _ref70.consequent; - /** - * Multiplies together all the elements of a list. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Math - * @sig [Number] -> Number - * @param {Array} list An array of numbers - * @return {Number} The product of all the numbers in the list. - * @see R.reduce - * @example - * - * R.product([2,4,6,8,100,1]); //=> 38400 - */ - var product = reduce(multiply, 1); + consequent = indent(withoutTrailingLinebreak(seq.apply(undefined, [this.sep(Sep.BEFORE_CASE_BODY)].concat(_toConsumableArray(consequent)))), true); + return seq(this.t("case"), this.sep(Sep.BEFORE_CASE_TEST), test, this.sep(Sep.AFTER_CASE_TEST), this.t(":"), consequent, this.sep(Sep.AFTER_CASE_BODY)); + } + }, { + key: "reduceSwitchDefault", + value: function reduceSwitchDefault(node, _ref71) { + var consequent = _ref71.consequent; - /** - * Transforms a [Traversable](https://github.com/fantasyland/fantasy-land#traversable) - * of [Applicative](https://github.com/fantasyland/fantasy-land#applicative) into an - * Applicative of Traversable. - * - * Dispatches to the `sequence` method of the second argument, if present. - * - * @func - * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category List - * @sig (Applicative f, Traversable t) => (a -> f a) -> t (f a) -> f (t a) - * @param {Function} of - * @param {*} traversable - * @return {*} - * @see R.traverse - * @example - * - * R.sequence(Maybe.of, [Just(1), Just(2), Just(3)]); //=> Just([1, 2, 3]) - * R.sequence(Maybe.of, [Just(1), Just(2), Nothing()]); //=> Nothing() - * - * R.sequence(R.of, Just([1, 2, 3])); //=> [Just(1), Just(2), Just(3)] - * R.sequence(R.of, Nothing()); //=> [Nothing()] - */ - var sequence = _curry2(function sequence(of, traversable) { - return typeof traversable.sequence === 'function' ? traversable.sequence(of) : reduceRight(function (acc, x) { - return ap(map(prepend, x), acc); - }, of([]), traversable); - }); - - /** - * Maps an [Applicative](https://github.com/fantasyland/fantasy-land#applicative)-returning - * function over a [Traversable](https://github.com/fantasyland/fantasy-land#traversable), - * then uses [`sequence`](#sequence) to transform the resulting Traversable of Applicative - * into an Applicative of Traversable. - * - * Dispatches to the `sequence` method of the third argument, if present. - * - * @func - * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category List - * @sig (Applicative f, Traversable t) => (a -> f a) -> (a -> f b) -> t a -> f (t b) - * @param {Function} of - * @param {Function} f - * @param {*} traversable - * @return {*} - * @see R.sequence - * @example - * - * R.traverse(Maybe.of, R.negate, [Just(1), Just(2), Just(3)]); //=> Just([-1, -2, -3]) - * R.traverse(Maybe.of, R.negate, [Just(1), Just(2), Nothing()]); //=> Nothing() - * - * R.traverse(R.of, R.negate, Just([1, 2, 3])); //=> [Just(-1), Just(-2), Just(-3)] - * R.traverse(R.of, R.negate, Nothing()); //=> [Nothing()] - */ - var traverse = _curry3(function traverse(of, f, traversable) { - return sequence(of, map(f, traversable)); - }); + consequent = indent(withoutTrailingLinebreak(seq.apply(undefined, [this.sep(Sep.BEFORE_CASE_BODY)].concat(_toConsumableArray(consequent)))), true); + return seq(this.t("default"), this.sep(Sep.DEFAULT), this.t(":"), consequent, this.sep(Sep.AFTER_DEFAULT_BODY)); + } + }, { + key: "sep", + value: function sep(separator) { + switch (separator.type) { + case "ARRAY_AFTER_COMMA": + case "OBJECT_AFTER_COMMA": + case "ARGS_AFTER_COMMA": + case "PARAMETER_AFTER_COMMA": + case "DECLARATORS_AFTER_COMMA": + case "NAMED_IMPORT_AFTER_COMMA": + case "IMPORT_AFTER_COMMA": + case "BEFORE_DEFAULT_EQUALS": + case "AFTER_DEFAULT_EQUALS": + case "AFTER_PROP": + case "BEFORE_JUMP_LABEL": + case "BEFORE_CATCH": + case "BEFORE_CATCH_BINDING": + case "AFTER_CATCH_BINDING": + case "BEFORE_CLASS_NAME": + case "BEFORE_EXTENDS": + case "AFTER_EXTENDS": + case "BEFORE_CLASS_DECLARATION_ELEMENTS": + case "BEFORE_CLASS_EXPRESSION_ELEMENTS": + case "AFTER_STATIC": + case "BEFORE_TERNARY_QUESTION": + case "AFTER_TERNARY_QUESTION": + case "BEFORE_TERNARY_COLON": + case "AFTER_TERNARY_COLON": + case "AFTER_DO": + case "BEFORE_DOWHILE_WHILE": + case "AFTER_DOWHILE_WHILE": + case "AFTER_FORIN_FOR": + case "BEFORE_FORIN_IN": + case "AFTER_FORIN_FOR": + case "BEFORE_FORIN_BODY": + case "AFTER_FOROF_FOR": + case "BEFORE_FOROF_OF": + case "AFTER_FOROF_FOR": + case "BEFORE_FOROF_BODY": + case "AFTER_FOR_FOR": + case "BEFORE_FOR_TEST": + case "BEFORE_FOR_UPDATE": + case "BEFORE_FOR_BODY": + case "BEFORE_FUNCTION_DECLARATION_BODY": + case "BEFORE_FUNCTION_EXPRESSION_BODY": + case "BEFORE_ARROW": + case "AFTER_ARROW": + case "AFTER_GET": + case "BEFORE_GET_BODY": + case "AFTER_IF": + case "AFTER_IF_TEST": + case "BEFORE_ELSE": + case "AFTER_ELSE": + case "BEFORE_IMPORT_BINDINGS": + case "BEFORE_IMPORT_MODULE": + case "AFTER_IMPORT_BINDINGS": + case "AFTER_FROM": + case "BEFORE_IMPORT_NAMESPACE": + case "BEFORE_IMPORT_STAR": + case "AFTER_IMPORT_STAR": + case "AFTER_IMPORT_AS": + case "AFTER_NAMESPACE_BINDING": + case "BEFORE_IMPORT_AS": + case "AFTER_IMPORT_AS": + case "EXPORTS_AFTER_COMMA": + case "BEFORE_EXPORT_STAR": + case "AFTER_EXPORT_STAR": + case "BEFORE_EXPORT_BINDINGS": + case "AFTER_EXPORT_BINDINGS": + case "AFTER_EXPORT": + case "AFTER_EXPORT_DEFAULT": + case "BEFORE_EXPORT_AS": + case "AFTER_EXPORT_AS": + case "AFTER_LABEL_COLON": + case "BEFORE_METHOD_BODY": + case "AFTER_NEW": + case "RETURN": + case "AFTER_SET": + case "BEFORE_SET_BODY": + case "BEFORE_SET_PARAMS": + case "BEFORE_CASE_TEST": + case "BEFORE_SWITCH_DISCRIM": + case "BEFORE_SWITCH_BODY": + case "THROW": + case "AFTER_TRY": + case "BEFORE_CATCH": + case "BEFORE_FINALLY": + case "AFTER_FINALLY": + case "VARIABLE_DECLARATION": + case "YIELD": + case "AFTER_YIELD_STAR": + case "DECLARATORS_AFTER_COMMA": + case "BEFORE_INIT_EQUALS": + case "AFTER_INIT_EQUALS": + case "AFTER_WHILE": + case "BEFORE_WHILE_BODY": + case "AFTER_WITH": + case "BEFORE_WITH_BODY": + case "BEFORE_FUNCTION_NAME": + case "AFTER_BINOP": + case "BEFORE_ASSIGN_OP": + case "AFTER_ASSIGN_OP": + return this.t(" "); + case "AFTER_STATEMENT": + switch (separator.node.type) { + case "ForInStatement": + case "ForOfStatement": + case "ForStatement": + case "WhileStatement": + case "WithStatement": + return empty(); // because those already end with an AFTER_STATEMENT + default: + return new Linebreak(); + } + case "AFTER_CLASS_ELEMENT": + case "BEFORE_CASE_BODY": + case "AFTER_CASE_BODY": + case "AFTER_DEFAULT_BODY": + return new Linebreak(); + case "BEFORE_BINOP": + return separator.op === "," ? empty() : this.t(" "); + case "UNARY": + return separator.op === "delete" || separator.op === "void" || separator.op === "typeof" ? this.t(" ") : empty(); + default: + return empty(); + } + } + }]); - /** - * Shorthand for `R.chain(R.identity)`, which removes one level of nesting from - * any [Chain](https://github.com/fantasyland/fantasy-land#chain). - * - * @func - * @memberOf R - * @since v0.3.0 - * @category List - * @sig Chain c => c (c a) -> c a - * @param {*} list - * @return {*} - * @see R.flatten, R.chain - * @example - * - * R.unnest([1, [2], [[3]]]); //=> [1, 2, [3]] - * R.unnest([[1, 2], [3, 4], [5, 6]]); //=> [1, 2, 3, 4, 5, 6] - */ - var unnest = chain(_identity); + return FormattedCodeGen; + }(ExtensibleCodeGen); - var _contains = function _contains(a, list) { - return _indexOf(list, a, 0) >= 0; - }; +/***/ }, +/* 21 */ +/***/ function(module, exports, __webpack_require__) { - var _stepCat = function () { - var _stepCatArray = { - '@@transducer/init': Array, - '@@transducer/step': function (xs, x) { - return _concat(xs, [x]); - }, - '@@transducer/result': _identity - }; - var _stepCatString = { - '@@transducer/init': String, - '@@transducer/step': function (a, b) { - return a + b; - }, - '@@transducer/result': _identity - }; - var _stepCatObject = { - '@@transducer/init': Object, - '@@transducer/step': function (result, input) { - return merge(result, isArrayLike(input) ? objOf(input[0], input[1]) : input); - }, - '@@transducer/result': _identity - }; - return function _stepCat(obj) { - if (_isTransformer(obj)) { - return obj; - } - if (isArrayLike(obj)) { - return _stepCatArray; - } - if (typeof obj === 'string') { - return _stepCatString; - } - if (typeof obj === 'object') { - return _stepCatObject; - } - throw new Error('Cannot create transformer for ' + obj); - }; - }(); + "use strict"; - // mapPairs :: (Object, [String]) -> [String] - var _toString = function _toString(x, seen) { - var recur = function recur(y) { - var xs = seen.concat([x]); - return _contains(y, xs) ? '' : _toString(y, xs); - }; - // mapPairs :: (Object, [String]) -> [String] - var mapPairs = function (obj, keys) { - return _map(function (k) { - return _quote(k) + ': ' + recur(obj[k]); - }, keys.slice().sort()); - }; - switch (Object.prototype.toString.call(x)) { - case '[object Arguments]': - return '(function() { return arguments; }(' + _map(recur, x).join(', ') + '))'; - case '[object Array]': - return '[' + _map(recur, x).concat(mapPairs(x, reject(function (k) { - return /^\d+$/.test(k); - }, keys(x)))).join(', ') + ']'; - case '[object Boolean]': - return typeof x === 'object' ? 'new Boolean(' + recur(x.valueOf()) + ')' : x.toString(); - case '[object Date]': - return 'new Date(' + (isNaN(x.valueOf()) ? recur(NaN) : _quote(_toISOString(x))) + ')'; - case '[object Null]': - return 'null'; - case '[object Number]': - return typeof x === 'object' ? 'new Number(' + recur(x.valueOf()) + ')' : 1 / x === -Infinity ? '-0' : x.toString(10); - case '[object String]': - return typeof x === 'object' ? 'new String(' + recur(x.valueOf()) + ')' : _quote(x); - case '[object Undefined]': - return 'undefined'; - default: - if (typeof x.toString === 'function') { - var repr = x.toString(); - if (repr !== '[object Object]') { - return repr; - } - } - return '{' + mapPairs(x, keys(x)).join(', ') + '}'; - } - }; + var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); /** + * Copyright 2014 Shape Security, Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License") + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ - /** - * Turns a list of Functors into a Functor of a list. - * - * @func - * @memberOf R - * @since v0.8.0 - * @category List - * @sig Functor f => (x -> f x) -> [f a] -> f [a] - * @param {Function} of A function that returns the data type to return - * @param {Array} list An array of functors of the same type - * @return {*} - * @see R.sequence - * @deprecated since v0.19.0 - * @example - * - * R.commute(R.of, [[1], [2, 3]]); //=> [[1, 2], [1, 3]] - * R.commute(R.of, [[1, 2], [3]]); //=> [[1, 3], [2, 3]] - * R.commute(R.of, [[1], [2], [3]]); //=> [[1, 2, 3]] - * R.commute(Maybe.of, [Just(1), Just(2), Just(3)]); //=> Just([1, 2, 3]) - * R.commute(Maybe.of, [Just(1), Just(2), Nothing()]); //=> Nothing() - */ - var commute = commuteMap(identity); + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.TokenStream = undefined; - /** - * Performs right-to-left function composition. The rightmost function may have - * any arity; the remaining functions must be unary. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig ((y -> z), (x -> y), ..., (o -> p), ((a, b, ..., n) -> o)) -> ((a, b, ..., n) -> z) - * @param {...Function} functions - * @return {Function} - * @see R.pipe - * @example - * - * var f = R.compose(R.inc, R.negate, Math.pow); - * - * f(3, 4); // -(3^4) + 1 - */ - var compose = function compose() { - if (arguments.length === 0) { - throw new Error('compose requires at least one argument'); - } - return pipe.apply(this, reverse(arguments)); - }; + var _esutils = __webpack_require__(15); - /** - * Returns the right-to-left Kleisli composition of the provided functions, - * each of which must return a value of a type supported by [`chain`](#chain). - * - * `R.composeK(h, g, f)` is equivalent to `R.compose(R.chain(h), R.chain(g), R.chain(f))`. - * - * @func - * @memberOf R - * @since v0.16.0 - * @category Function - * @sig Chain m => ((y -> m z), (x -> m y), ..., (a -> m b)) -> (m a -> m z) - * @param {...Function} - * @return {Function} - * @see R.pipeK - * @example - * - * // parseJson :: String -> Maybe * - * // get :: String -> Object -> Maybe * - * - * // getStateCode :: Maybe String -> Maybe String - * var getStateCode = R.composeK( - * R.compose(Maybe.of, R.toUpper), - * get('state'), - * get('address'), - * get('user'), - * parseJson - * ); - * - * getStateCode(Maybe.of('{"user":{"address":{"state":"ny"}}}')); - * //=> Just('NY') - * getStateCode(Maybe.of('[Invalid JSON]')); - * //=> Nothing() - */ - var composeK = function composeK() { - return compose.apply(this, prepend(identity, map(chain, arguments))); - }; + function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - /** - * Performs right-to-left composition of one or more Promise-returning - * functions. The rightmost function may have any arity; the remaining - * functions must be unary. - * - * @func - * @memberOf R - * @since v0.10.0 - * @category Function - * @sig ((y -> Promise z), (x -> Promise y), ..., (a -> Promise b)) -> (a -> Promise z) - * @param {...Function} functions - * @return {Function} - * @see R.pipeP - * @example - * - * // followersForUser :: String -> Promise [User] - * var followersForUser = R.composeP(db.getFollowers, db.getUserById); - */ - var composeP = function composeP() { - if (arguments.length === 0) { - throw new Error('composeP requires at least one argument'); - } - return pipeP.apply(this, reverse(arguments)); - }; + function numberDot(fragment) { + if (fragment.indexOf(".") < 0 && fragment.indexOf("e") < 0) { + return ".."; + } + return "."; + } - /** - * Wraps a constructor function inside a curried function that can be called - * with the same arguments and returns the same type. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig (* -> {*}) -> (* -> {*}) - * @param {Function} Fn The constructor function to wrap. - * @return {Function} A wrapped, curried constructor function. - * @example - * - * // Constructor function - * var Widget = config => { - * // ... - * }; - * Widget.prototype = { - * // ... - * }; - * var allConfigs = [ - * // ... - * ]; - * R.map(R.construct(Widget), allConfigs); // a list of Widgets - */ - var construct = _curry1(function construct(Fn) { - return constructN(Fn.length, Fn); + function renderNumber(n) { + var s; + if (n >= 1e3 && n % 10 === 0) { + s = n.toString(10); + if (/[eE]/.test(s)) { + return s.replace(/[eE]\+/, "e"); + } + return n.toString(10).replace(/0+$/, function (match) { + return "e" + match.length; }); + } else if (n % 1 === 0) { + if (n > 1e15 && n < 1e20) { + return "0x" + n.toString(16).toUpperCase(); + } + return n.toString(10).replace(/[eE]\+/, "e"); + } else { + return n.toString(10).replace(/^0\./, ".").replace(/[eE]\+/, "e"); + } + } - /** - * Returns `true` if the specified value is equal, in `R.equals` terms, to at - * least one element of the given list; `false` otherwise. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig a -> [a] -> Boolean - * @param {Object} a The item to compare against. - * @param {Array} list The array to consider. - * @return {Boolean} `true` if the item is in the list, `false` otherwise. - * @see R.any - * @example - * - * R.contains(3, [1, 2, 3]); //=> true - * R.contains(4, [1, 2, 3]); //=> false - * R.contains([42], [[42]]); //=> true - */ - var contains = _curry2(_contains); + var TokenStream = exports.TokenStream = function () { + function TokenStream() { + _classCallCheck(this, TokenStream); - /** - * Finds the set (i.e. no duplicates) of all elements in the first list not - * contained in the second list. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig [*] -> [*] -> [*] - * @param {Array} list1 The first list. - * @param {Array} list2 The second list. - * @return {Array} The elements in `list1` that are not in `list2`. - * @see R.differenceWith - * @example - * - * R.difference([1,2,3,4], [7,6,5,4,3]); //=> [1,2] - * R.difference([7,6,5,4,3], [1,2,3,4]); //=> [7,6,5] - */ - var difference = _curry2(function difference(first, second) { - var out = []; - var idx = 0; - var firstLen = first.length; - while (idx < firstLen) { - if (!_contains(first[idx], second) && !_contains(first[idx], out)) { - out[out.length] = first[idx]; - } - idx += 1; + this.result = ""; + this.lastNumber = null; + this.lastChar = null; + this.optionalSemi = false; + } + + _createClass(TokenStream, [{ + key: "putNumber", + value: function putNumber(number) { + var tokenStr = renderNumber(number); + this.put(tokenStr); + this.lastNumber = tokenStr; + } + }, { + key: "putOptionalSemi", + value: function putOptionalSemi() { + this.optionalSemi = true; + } + }, { + key: "put", + value: function put(tokenStr) { + if (this.optionalSemi) { + this.optionalSemi = false; + if (tokenStr !== "}") { + this.put(";"); } - return out; - }); + } + if (this.lastNumber !== null && tokenStr.length == 1) { + if (tokenStr === ".") { + this.result += numberDot(this.lastNumber); + this.lastNumber = null; + this.lastChar = "."; + return; + } + } + this.lastNumber = null; + var rightChar = tokenStr.charAt(0); + var lastChar = this.lastChar; + this.lastChar = tokenStr.charAt(tokenStr.length - 1); + if (lastChar && ((lastChar == "+" || lastChar == "-") && lastChar == rightChar || _esutils.code.isIdentifierPartES6(lastChar.charCodeAt(0)) && _esutils.code.isIdentifierPartES6(rightChar.charCodeAt(0)) || lastChar == "/" && rightChar == "i")) { + this.result += " "; + } - /** - * Returns a new list without any consecutively repeating elements. `R.equals` - * is used to determine equality. + this.result += tokenStr; + } + }]); + + return TokenStream; + }(); + +/***/ }, +/* 22 */ +/***/ function(module, exports, __webpack_require__) { + + "use strict"; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + + var _immutable = __webpack_require__(3); + + var _errors = __webpack_require__(23); + + var _ramdaFantasy = __webpack_require__(24); + + class BindingMap { + constructor() { + this._map = new Map(); + } + + // given a syntax object and a binding, + // add the binding to the map associating the binding with the syntax object's + // scope set + add(stx, _ref) { + let binding = _ref.binding; + let phase = _ref.phase; + var _ref$skipDup = _ref.skipDup; + let skipDup = _ref$skipDup === undefined ? false : _ref$skipDup; + + let stxName = stx.val(); + let allScopeset = stx.scopesets.all; + let scopeset = stx.scopesets.phase.has(phase) ? stx.scopesets.phase.get(phase) : (0, _immutable.List)(); + scopeset = allScopeset.concat(scopeset); + (0, _errors.assert)(phase != null, "must provide a phase for binding add"); + + if (this._map.has(stxName)) { + let scopesetBindingList = this._map.get(stxName); + if (skipDup && scopesetBindingList.some(s => s.scopes.equals(scopeset))) { + return; + } + this._map.set(stxName, scopesetBindingList.push({ + scopes: scopeset, + binding: binding, + alias: _ramdaFantasy.Maybe.Nothing() + })); + } else { + this._map.set(stxName, _immutable.List.of({ + scopes: scopeset, + binding: binding, + alias: _ramdaFantasy.Maybe.Nothing() + })); + } + } + + addForward(stx, forwardStx, binding, phase) { + let stxName = stx.token.value; + let allScopeset = stx.scopesets.all; + let scopeset = stx.scopesets.phase.has(phase) ? stx.scopesets.phase.get(phase) : (0, _immutable.List)(); + scopeset = allScopeset.concat(scopeset); + (0, _errors.assert)(phase != null, "must provide a phase for binding add"); + + if (this._map.has(stxName)) { + let scopesetBindingList = this._map.get(stxName); + this._map.set(stxName, scopesetBindingList.push({ + scopes: scopeset, + binding: binding, + alias: _ramdaFantasy.Maybe.of(forwardStx) + })); + } else { + this._map.set(stxName, _immutable.List.of({ + scopes: scopeset, + binding: binding, + alias: _ramdaFantasy.Maybe.of(forwardStx) + })); + } + } + + // Syntax -> ?List<{ scopes: ScopeSet, binding: Binding }> + get(stx) { + return this._map.get(stx.token.value); + } + + } + exports.default = BindingMap; + //# sourceMappingURL=data:application/json;base64,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VDtBQUhzQixPQUFSLENBQXZCO0FBS0Q7QUFFRjs7QUFFRDtBQUNBLE1BQUksR0FBSixFQUFTO0FBQ1AsV0FBTyxLQUFLLElBQUwsQ0FBVSxHQUFWLENBQWMsSUFBSSxLQUFKLENBQVUsS0FBeEIsQ0FBUDtBQUNEOztBQTdENkI7a0JBQVgsVSIsImZpbGUiOiJiaW5kaW5nLW1hcC5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExpc3QgfSBmcm9tIFwiaW1tdXRhYmxlXCI7XG5pbXBvcnQgeyBhc3NlcnQgfSBmcm9tIFwiLi9lcnJvcnNcIjtcbmltcG9ydCB7IE1heWJlIH0gZnJvbSAncmFtZGEtZmFudGFzeSc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEJpbmRpbmdNYXAge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLl9tYXAgPSBuZXcgTWFwKCk7XG4gIH1cblxuICAvLyBnaXZlbiBhIHN5bnRheCBvYmplY3QgYW5kIGEgYmluZGluZyxcbiAgLy8gYWRkIHRoZSBiaW5kaW5nIHRvIHRoZSBtYXAgYXNzb2NpYXRpbmcgdGhlIGJpbmRpbmcgd2l0aCB0aGUgc3ludGF4IG9iamVjdCdzXG4gIC8vIHNjb3BlIHNldFxuICBhZGQoc3R4LCB7IGJpbmRpbmcsIHBoYXNlLCBza2lwRHVwID0gZmFsc2UgfSkge1xuICAgIGxldCBzdHhOYW1lID0gc3R4LnZhbCgpO1xuICAgIGxldCBhbGxTY29wZXNldCA9IHN0eC5zY29wZXNldHMuYWxsO1xuICAgIGxldCBzY29wZXNldCA9IHN0eC5zY29wZXNldHMucGhhc2UuaGFzKHBoYXNlKSA/IHN0eC5zY29wZXNldHMucGhhc2UuZ2V0KHBoYXNlKSA6IExpc3QoKTtcbiAgICBzY29wZXNldCA9IGFsbFNjb3Blc2V0LmNvbmNhdChzY29wZXNldCk7XG4gICAgYXNzZXJ0KHBoYXNlICE9IG51bGwsIFwibXVzdCBwcm92aWRlIGEgcGhhc2UgZm9yIGJpbmRpbmcgYWRkXCIpO1xuXG4gICAgaWYgKHRoaXMuX21hcC5oYXMoc3R4TmFtZSkpIHtcbiAgICAgIGxldCBzY29wZXNldEJpbmRpbmdMaXN0ID0gdGhpcy5fbWFwLmdldChzdHhOYW1lKTtcbiAgICAgIGlmIChza2lwRHVwICYmIHNjb3Blc2V0QmluZGluZ0xpc3Quc29tZShzID0+IHMuc2NvcGVzLmVxdWFscyhzY29wZXNldCkpKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cbiAgICAgIHRoaXMuX21hcC5zZXQoc3R4TmFtZSwgc2NvcGVzZXRCaW5kaW5nTGlzdC5wdXNoKHtcbiAgICAgICAgc2NvcGVzOiBzY29wZXNldCxcbiAgICAgICAgYmluZGluZzogYmluZGluZyxcbiAgICAgICAgYWxpYXM6IE1heWJlLk5vdGhpbmcoKVxuICAgICAgfSkpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLl9tYXAuc2V0KHN0eE5hbWUsIExpc3Qub2Yoe1xuICAgICAgICBzY29wZXM6IHNjb3Blc2V0LFxuICAgICAgICBiaW5kaW5nOiBiaW5kaW5nLFxuICAgICAgICBhbGlhczogTWF5YmUuTm90aGluZygpXG4gICAgICB9KSk7XG4gICAgfVxuICB9XG5cbiAgYWRkRm9yd2FyZChzdHgsIGZvcndhcmRTdHgsIGJpbmRpbmcsIHBoYXNlKSB7XG4gICAgbGV0IHN0eE5hbWUgPSBzdHgudG9rZW4udmFsdWU7XG4gICAgbGV0IGFsbFNjb3Blc2V0ID0gc3R4LnNjb3Blc2V0cy5hbGw7XG4gICAgbGV0IHNjb3Blc2V0ID0gc3R4LnNjb3Blc2V0cy5waGFzZS5oYXMocGhhc2UpID8gc3R4LnNjb3Blc2V0cy5waGFzZS5nZXQocGhhc2UpIDogTGlzdCgpO1xuICAgIHNjb3Blc2V0ID0gYWxsU2NvcGVzZXQuY29uY2F0KHNjb3Blc2V0KTtcbiAgICBhc3NlcnQocGhhc2UgIT0gbnVsbCwgXCJtdXN0IHByb3ZpZGUgYSBwaGFzZSBmb3IgYmluZGluZyBhZGRcIik7XG5cbiAgICBpZiAodGhpcy5fbWFwLmhhcyhzdHhOYW1lKSkge1xuICAgICAgbGV0IHNjb3Blc2V0QmluZGluZ0xpc3QgPSB0aGlzLl9tYXAuZ2V0KHN0eE5hbWUpO1xuICAgICAgdGhpcy5fbWFwLnNldChzdHhOYW1lLCBzY29wZXNldEJpbmRpbmdMaXN0LnB1c2goe1xuICAgICAgICBzY29wZXM6IHNjb3Blc2V0LFxuICAgICAgICBiaW5kaW5nOiBiaW5kaW5nLFxuICAgICAgICBhbGlhczogTWF5YmUub2YoZm9yd2FyZFN0eClcbiAgICAgIH0pKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5fbWFwLnNldChzdHhOYW1lLCBMaXN0Lm9mKHtcbiAgICAgICAgc2NvcGVzOiBzY29wZXNldCxcbiAgICAgICAgYmluZGluZzogYmluZGluZyxcbiAgICAgICAgYWxpYXM6IE1heWJlLm9mKGZvcndhcmRTdHgpXG4gICAgICB9KSk7XG4gICAgfVxuXG4gIH1cblxuICAvLyBTeW50YXggLT4gP0xpc3Q8eyBzY29wZXM6IFNjb3BlU2V0LCBiaW5kaW5nOiBCaW5kaW5nIH0+XG4gIGdldChzdHgpIHtcbiAgICByZXR1cm4gdGhpcy5fbWFwLmdldChzdHgudG9rZW4udmFsdWUpO1xuICB9XG5cbn1cbiJdfQ== + +/***/ }, +/* 23 */ +/***/ function(module, exports) { + + "use strict"; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.expect = expect; + exports.assert = assert; + function expect(cond, message, offendingSyntax, rest) { + if (!cond) { + let ctx = ""; + if (rest) { + ctx = rest.slice(0, 20).map(s => { + let val = s.isDelimiter() ? "( ... )" : s.val(); + if (s === offendingSyntax) { + return "__" + val + "__"; + } + return val; + }).join(" "); + } + throw new Error("[error]: " + message + "\n" + ctx); + } + } + + function assert(cond, message) { + if (!cond) { + throw new Error("[assertion error]: " + message); + } + } + //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lcnJvcnMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7UUFBZ0IsTSxHQUFBLE07UUFnQkEsTSxHQUFBLE07QUFoQlQsU0FBUyxNQUFULENBQWdCLElBQWhCLEVBQXNCLE9BQXRCLEVBQStCLGVBQS9CLEVBQWdELElBQWhELEVBQXNEO0FBQzNELE1BQUksQ0FBQyxJQUFMLEVBQVc7QUFDVCxRQUFJLE1BQU0sRUFBVjtBQUNBLFFBQUksSUFBSixFQUFVO0FBQ1IsWUFBTSxLQUFLLEtBQUwsQ0FBVyxDQUFYLEVBQWMsRUFBZCxFQUFrQixHQUFsQixDQUFzQixLQUFLO0FBQy9CLFlBQUksTUFBTSxFQUFFLFdBQUYsS0FBa0IsU0FBbEIsR0FBOEIsRUFBRSxHQUFGLEVBQXhDO0FBQ0EsWUFBSSxNQUFNLGVBQVYsRUFBMkI7QUFDekIsaUJBQU8sT0FBTyxHQUFQLEdBQWEsSUFBcEI7QUFDRDtBQUNELGVBQU8sR0FBUDtBQUNELE9BTkssRUFNSCxJQU5HLENBTUUsR0FORixDQUFOO0FBT0Q7QUFDRCxVQUFNLElBQUksS0FBSixDQUFVLGNBQWMsT0FBZCxHQUF3QixJQUF4QixHQUErQixHQUF6QyxDQUFOO0FBQ0Q7QUFDRjs7QUFFTSxTQUFTLE1BQVQsQ0FBZ0IsSUFBaEIsRUFBc0IsT0FBdEIsRUFBK0I7QUFDcEMsTUFBSSxDQUFDLElBQUwsRUFBVztBQUNULFVBQU0sSUFBSSxLQUFKLENBQVUsd0JBQXdCLE9BQWxDLENBQU47QUFDRDtBQUNGIiwiZmlsZSI6ImVycm9ycy5qcyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBmdW5jdGlvbiBleHBlY3QoY29uZCwgbWVzc2FnZSwgb2ZmZW5kaW5nU3ludGF4LCByZXN0KSB7XG4gIGlmICghY29uZCkge1xuICAgIGxldCBjdHggPSBcIlwiO1xuICAgIGlmIChyZXN0KSB7XG4gICAgICBjdHggPSByZXN0LnNsaWNlKDAsIDIwKS5tYXAocyA9PiB7XG4gICAgICAgIGxldCB2YWwgPSBzLmlzRGVsaW1pdGVyKCkgPyBcIiggLi4uIClcIiA6IHMudmFsKCk7XG4gICAgICAgIGlmIChzID09PSBvZmZlbmRpbmdTeW50YXgpIHtcbiAgICAgICAgICByZXR1cm4gXCJfX1wiICsgdmFsICsgXCJfX1wiO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB2YWw7XG4gICAgICB9KS5qb2luKFwiIFwiKTtcbiAgICB9XG4gICAgdGhyb3cgbmV3IEVycm9yKFwiW2Vycm9yXTogXCIgKyBtZXNzYWdlICsgXCJcXG5cIiArIGN0eCk7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGFzc2VydChjb25kLCBtZXNzYWdlKSB7XG4gIGlmICghY29uZCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIlthc3NlcnRpb24gZXJyb3JdOiBcIiArIG1lc3NhZ2UpO1xuICB9XG59XG4iXX0= + +/***/ }, +/* 24 */ +/***/ function(module, exports, __webpack_require__) { + + module.exports = { + Either: __webpack_require__(25), + Future: __webpack_require__(28), + Identity: __webpack_require__(29), + IO: __webpack_require__(30), + lift2: __webpack_require__(31), + lift3: __webpack_require__(32), + Maybe: __webpack_require__(33), + Tuple: __webpack_require__(34), + Reader: __webpack_require__(35) + }; + + +/***/ }, +/* 25 */ +/***/ function(module, exports, __webpack_require__) { + + var R = __webpack_require__(26); + + var util = __webpack_require__(27); + + + function Either(left, right) { + switch (arguments.length) { + case 0: + throw new TypeError('no arguments to Either'); + case 1: + return function(right) { + return right == null ? Either.Left(left) : Either.Right(right); + }; + default: + return right == null ? Either.Left(left) : Either.Right(right); + } + } + + Either.prototype.map = util.returnThis; + + Either.of = Either.prototype.of = function(value) { + return Either.Right(value); + }; + + Either.prototype.chain = util.returnThis; // throw? + + Either.equals = Either.prototype.equals = util.getEquals(Either); + + + // Right + function _Right(x) { + this.value = x; + } + util.extend(_Right, Either); + + _Right.prototype.map = function(fn) { + return new _Right(fn(this.value)); + }; + + _Right.prototype.ap = function(that) { + return that.map(this.value); + }; + + _Right.prototype.chain = function(f) { + return f(this.value); + }; + + _Right.prototype.bimap = function(_, f) { + return new _Right(f(this.value)); + }; + + _Right.prototype.extend = function(f) { + return new _Right(f(this)); + }; + + _Right.prototype.toString = function() { + return 'Either.Right(' + R.toString(this.value) + ')'; + }; + + Either.Right = function(value) { + return new _Right(value); + }; + + + // Left + function _Left(x) { + this.value = x; + } + util.extend(_Left, Either); + + _Left.prototype.ap = function(that) { return that; }; + + _Left.prototype.bimap = function(f) { + return new _Left(f(this.value)); + }; + + _Left.prototype.extend = util.returnThis; + + _Left.prototype.toString = function() { + return 'Either.Left(' + R.toString(this.value) + ')'; + }; + + Either.Left = function(value) { + return new _Left(value); + }; + + + module.exports = Either; + + +/***/ }, +/* 26 */ +/***/ function(module, exports, __webpack_require__) { + + // Ramda v0.17.1 + // https://github.com/ramda/ramda + // (c) 2013-2015 Scott Sauyet, Michael Hurley, and David Chambers + // Ramda may be freely distributed under the MIT license. + + ;(function() { + + 'use strict'; + + /** + * A special placeholder value used to specify "gaps" within curried functions, + * allowing partial application of any combination of arguments, + * regardless of their positions. * - * Dispatches to the `dropRepeats` method of the first argument, if present. + * If `g` is a curried ternary function and `_` is `R.__`, the following are equivalent: * - * Acts as a transducer if a transformer is given in list position. + * - `g(1, 2, 3)` + * - `g(_, 2, 3)(1)` + * - `g(_, _, 3)(1)(2)` + * - `g(_, _, 3)(1, 2)` + * - `g(_, 2, _)(1, 3)` + * - `g(_, 2)(1)(3)` + * - `g(_, 2)(1, 3)` + * - `g(_, 2)(_, 3)(1)` * - * @func + * @constant * @memberOf R - * @since v0.14.0 - * @category List - * @sig [a] -> [a] - * @param {Array} list The array to consider. - * @return {Array} `list` without repeating elements. - * @see R.transduce + * @category Function * @example * - * R.dropRepeats([1, 1, 1, 2, 3, 4, 4, 2, 2]); //=> [1, 2, 3, 4, 2] + * var greet = R.replace('{name}', R.__, 'Hello, {name}!'); + * greet('Alice'); //=> 'Hello, Alice!' */ - var dropRepeats = _curry1(_dispatchable('dropRepeats', _xdropRepeatsWith(equals), dropRepeatsWith(equals))); + var __ = { '@@functional/placeholder': true }; + + // jshint unused:vars + var _arity = function _arity(n, fn) { + // jshint unused:vars + switch (n) { + case 0: + return function () { + return fn.apply(this, arguments); + }; + case 1: + return function (a0) { + return fn.apply(this, arguments); + }; + case 2: + return function (a0, a1) { + return fn.apply(this, arguments); + }; + case 3: + return function (a0, a1, a2) { + return fn.apply(this, arguments); + }; + case 4: + return function (a0, a1, a2, a3) { + return fn.apply(this, arguments); + }; + case 5: + return function (a0, a1, a2, a3, a4) { + return fn.apply(this, arguments); + }; + case 6: + return function (a0, a1, a2, a3, a4, a5) { + return fn.apply(this, arguments); + }; + case 7: + return function (a0, a1, a2, a3, a4, a5, a6) { + return fn.apply(this, arguments); + }; + case 8: + return function (a0, a1, a2, a3, a4, a5, a6, a7) { + return fn.apply(this, arguments); + }; + case 9: + return function (a0, a1, a2, a3, a4, a5, a6, a7, a8) { + return fn.apply(this, arguments); + }; + case 10: + return function (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9) { + return fn.apply(this, arguments); + }; + default: + throw new Error('First argument to _arity must be a non-negative integer no greater than ten'); + } + }; + + var _cloneRegExp = function _cloneRegExp(pattern) { + return new RegExp(pattern.source, (pattern.global ? 'g' : '') + (pattern.ignoreCase ? 'i' : '') + (pattern.multiline ? 'm' : '') + (pattern.sticky ? 'y' : '') + (pattern.unicode ? 'u' : '')); + }; + + var _complement = function _complement(f) { + return function () { + return !f.apply(this, arguments); + }; + }; /** - * Transforms the items of the list with the transducer and appends the - * transformed items to the accumulator using an appropriate iterator function - * based on the accumulator type. - * - * The accumulator can be an array, string, object or a transformer. Iterated - * items will be appended to arrays and concatenated to strings. Objects will - * be merged directly or 2-item arrays will be merged as key, value pairs. - * - * The accumulator can also be a transformer object that provides a 2-arity - * reducing iterator function, step, 0-arity initial value function, init, and - * 1-arity result extraction function result. The step function is used as the - * iterator function in reduce. The result function is used to convert the - * final accumulator into the return type and in most cases is R.identity. The - * init function is used to provide the initial accumulator. - * - * The iteration is performed with R.reduce after initializing the transducer. + * Private `concat` function to merge two array-like objects. * - * @func - * @memberOf R - * @since v0.12.0 - * @category List - * @sig a -> (b -> b) -> [c] -> a - * @param {*} acc The initial accumulator value. - * @param {Function} xf The transducer function. Receives a transformer and returns a transformer. - * @param {Array} list The list to iterate over. - * @return {*} The final, accumulated value. + * @private + * @param {Array|Arguments} [set1=[]] An array-like object. + * @param {Array|Arguments} [set2=[]] An array-like object. + * @return {Array} A new, merged array. * @example * - * var numbers = [1, 2, 3, 4]; - * var transducer = R.compose(R.map(R.add(1)), R.take(2)); - * - * R.into([], transducer, numbers); //=> [2, 3] - * - * var intoArray = R.into([]); - * intoArray(transducer, numbers); //=> [2, 3] + * _concat([4, 5, 6], [1, 2, 3]); //=> [4, 5, 6, 1, 2, 3] */ - var into = _curry3(function into(acc, xf, list) { - return _isTransformer(acc) ? _reduce(xf(acc), acc['@@transducer/init'](), list) : _reduce(xf(_stepCat(acc)), acc, list); - }); + var _concat = function _concat(set1, set2) { + set1 = set1 || []; + set2 = set2 || []; + var idx; + var len1 = set1.length; + var len2 = set2.length; + var result = []; + idx = 0; + while (idx < len1) { + result[result.length] = set1[idx]; + idx += 1; + } + idx = 0; + while (idx < len2) { + result[result.length] = set2[idx]; + idx += 1; + } + return result; + }; + + var _containsWith = function _containsWith(pred, x, list) { + var idx = 0, len = list.length; + while (idx < len) { + if (pred(x, list[idx])) { + return true; + } + idx += 1; + } + return false; + }; /** - * "lifts" a function of arity > 1 so that it may "map over" an Array or other - * object that satisfies the [FantasyLand Apply spec](https://github.com/fantasyland/fantasy-land#apply). + * Optimized internal two-arity curry function. * - * @func - * @memberOf R - * @since v0.7.0 + * @private * @category Function - * @sig (*... -> *) -> ([*]... -> [*]) - * @param {Function} fn The function to lift into higher context - * @return {Function} The lifted function. - * @see R.liftN - * @example - * - * var madd3 = R.lift(R.curry((a, b, c) => a + b + c)); - * - * madd3([1,2,3], [1,2,3], [1]); //=> [3, 4, 5, 4, 5, 6, 5, 6, 7] - * - * var madd5 = R.lift(R.curry((a, b, c, d, e) => a + b + c + d + e)); - * - * madd5([1,2], [3], [4, 5], [6], [7, 8]); //=> [21, 22, 22, 23, 22, 23, 23, 24] + * @param {Function} fn The function to curry. + * @return {Function} The curried function. */ - var lift = _curry1(function lift(fn) { - return liftN(fn.length, fn); - }); + var _curry1 = function _curry1(fn) { + return function f1(a) { + if (arguments.length === 0) { + return f1; + } else if (a != null && a['@@functional/placeholder'] === true) { + return f1; + } else { + return fn.apply(this, arguments); + } + }; + }; /** - * Returns a partial copy of an object omitting the keys specified. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Object - * @sig [String] -> {String: *} -> {String: *} - * @param {Array} names an array of String property names to omit from the new object - * @param {Object} obj The object to copy from - * @return {Object} A new object with properties from `names` not on it. - * @see R.pick - * @example + * Optimized internal two-arity curry function. * - * R.omit(['a', 'd'], {a: 1, b: 2, c: 3, d: 4}); //=> {b: 2, c: 3} + * @private + * @category Function + * @param {Function} fn The function to curry. + * @return {Function} The curried function. */ - var omit = _curry2(function omit(names, obj) { - var result = {}; - for (var prop in obj) { - if (!_contains(prop, names)) { - result[prop] = obj[prop]; + var _curry2 = function _curry2(fn) { + return function f2(a, b) { + var n = arguments.length; + if (n === 0) { + return f2; + } else if (n === 1 && a != null && a['@@functional/placeholder'] === true) { + return f2; + } else if (n === 1) { + return _curry1(function (b) { + return fn(a, b); + }); + } else if (n === 2 && a != null && a['@@functional/placeholder'] === true && b != null && b['@@functional/placeholder'] === true) { + return f2; + } else if (n === 2 && a != null && a['@@functional/placeholder'] === true) { + return _curry1(function (a) { + return fn(a, b); + }); + } else if (n === 2 && b != null && b['@@functional/placeholder'] === true) { + return _curry1(function (b) { + return fn(a, b); + }); + } else { + return fn(a, b); } - } - return result; - }); + }; + }; /** - * Returns the left-to-right Kleisli composition of the provided functions, - * each of which must return a value of a type supported by [`chain`](#chain). - * - * `R.pipeK(f, g, h)` is equivalent to `R.pipe(R.chain(f), R.chain(g), R.chain(h))`. + * Optimized internal three-arity curry function. * - * @func - * @memberOf R - * @since v0.16.0 + * @private * @category Function - * @sig Chain m => ((a -> m b), (b -> m c), ..., (y -> m z)) -> (m a -> m z) - * @param {...Function} - * @return {Function} - * @see R.composeK - * @example - * - * // parseJson :: String -> Maybe * - * // get :: String -> Object -> Maybe * - * - * // getStateCode :: Maybe String -> Maybe String - * var getStateCode = R.pipeK( - * parseJson, - * get('user'), - * get('address'), - * get('state'), - * R.compose(Maybe.of, R.toUpper) - * ); - * - * getStateCode(Maybe.of('{"user":{"address":{"state":"ny"}}}')); - * //=> Just('NY') - * getStateCode(Maybe.of('[Invalid JSON]')); - * //=> Nothing() + * @param {Function} fn The function to curry. + * @return {Function} The curried function. */ - var pipeK = function pipeK() { - return composeK.apply(this, reverse(arguments)); + var _curry3 = function _curry3(fn) { + return function f3(a, b, c) { + var n = arguments.length; + if (n === 0) { + return f3; + } else if (n === 1 && a != null && a['@@functional/placeholder'] === true) { + return f3; + } else if (n === 1) { + return _curry2(function (b, c) { + return fn(a, b, c); + }); + } else if (n === 2 && a != null && a['@@functional/placeholder'] === true && b != null && b['@@functional/placeholder'] === true) { + return f3; + } else if (n === 2 && a != null && a['@@functional/placeholder'] === true) { + return _curry2(function (a, c) { + return fn(a, b, c); + }); + } else if (n === 2 && b != null && b['@@functional/placeholder'] === true) { + return _curry2(function (b, c) { + return fn(a, b, c); + }); + } else if (n === 2) { + return _curry1(function (c) { + return fn(a, b, c); + }); + } else if (n === 3 && a != null && a['@@functional/placeholder'] === true && b != null && b['@@functional/placeholder'] === true && c != null && c['@@functional/placeholder'] === true) { + return f3; + } else if (n === 3 && a != null && a['@@functional/placeholder'] === true && b != null && b['@@functional/placeholder'] === true) { + return _curry2(function (a, b) { + return fn(a, b, c); + }); + } else if (n === 3 && a != null && a['@@functional/placeholder'] === true && c != null && c['@@functional/placeholder'] === true) { + return _curry2(function (a, c) { + return fn(a, b, c); + }); + } else if (n === 3 && b != null && b['@@functional/placeholder'] === true && c != null && c['@@functional/placeholder'] === true) { + return _curry2(function (b, c) { + return fn(a, b, c); + }); + } else if (n === 3 && a != null && a['@@functional/placeholder'] === true) { + return _curry1(function (a) { + return fn(a, b, c); + }); + } else if (n === 3 && b != null && b['@@functional/placeholder'] === true) { + return _curry1(function (b) { + return fn(a, b, c); + }); + } else if (n === 3 && c != null && c['@@functional/placeholder'] === true) { + return _curry1(function (c) { + return fn(a, b, c); + }); + } else { + return fn(a, b, c); + } + }; }; /** - * Returns the string representation of the given value. `eval`'ing the output - * should result in a value equivalent to the input value. Many of the built-in - * `toString` methods do not satisfy this requirement. - * - * If the given value is an `[object Object]` with a `toString` method other - * than `Object.prototype.toString`, this method is invoked with no arguments - * to produce the return value. This means user-defined constructor functions - * can provide a suitable `toString` method. For example: - * - * function Point(x, y) { - * this.x = x; - * this.y = y; - * } - * - * Point.prototype.toString = function() { - * return 'new Point(' + this.x + ', ' + this.y + ')'; - * }; - * - * R.toString(new Point(1, 2)); //=> 'new Point(1, 2)' - * - * @func - * @memberOf R - * @since v0.14.0 - * @category String - * @sig * -> String - * @param {*} val - * @return {String} - * @example - * - * R.toString(42); //=> '42' - * R.toString('abc'); //=> '"abc"' - * R.toString([1, 2, 3]); //=> '[1, 2, 3]' - * R.toString({foo: 1, bar: 2, baz: 3}); //=> '{"bar": 2, "baz": 3, "foo": 1}' - * R.toString(new Date('2001-02-03T04:05:06Z')); //=> 'new Date("2001-02-03T04:05:06.000Z")' - */ - var toString = _curry1(function toString(val) { - return _toString(val, []); - }); - - /** - * Returns a new list containing only one copy of each element in the original - * list, based upon the value returned by applying the supplied function to - * each list element. Prefers the first item if the supplied function produces - * the same value on two items. `R.equals` is used for comparison. - * - * @func - * @memberOf R - * @since v0.16.0 - * @category List - * @sig (a -> b) -> [a] -> [a] - * @param {Function} fn A function used to produce a value to use during comparisons. - * @param {Array} list The array to consider. - * @return {Array} The list of unique items. - * @example + * Internal curryN function. * - * R.uniqBy(Math.abs, [-1, -5, 2, 10, 1, 2]); //=> [-1, -5, 2, 10] + * @private + * @category Function + * @param {Number} length The arity of the curried function. + * @return {array} An array of arguments received thus far. + * @param {Function} fn The function to curry. */ - /* globals Set */ - // distinguishing between +0 and -0 is not supported by Set - /* falls through */ - // these types can all utilise Set - // prevent scan for null by tracking as a boolean - /* falls through */ - // scan through all previously applied items - var uniqBy = _curry2(/* globals Set */ - typeof Set === 'undefined' ? function uniqBy(fn, list) { - var idx = 0; - var applied = []; - var result = []; - var appliedItem, item; - while (idx < list.length) { - item = list[idx]; - appliedItem = fn(item); - if (!_contains(appliedItem, applied)) { - result.push(item); - applied.push(appliedItem); - } - idx += 1; - } - return result; - } : function uniqBySet(fn, list) { - var set = new Set(); - var applied = []; - var prevSetSize = 0; - var result = []; - var nullExists = false; - var negZeroExists = false; - var idx = 0; - var appliedItem, item, newSetSize; - while (idx < list.length) { - item = list[idx]; - appliedItem = fn(item); - switch (typeof appliedItem) { - case 'number': - // distinguishing between +0 and -0 is not supported by Set - if (appliedItem === 0 && !negZeroExists && 1 / appliedItem === -Infinity) { - negZeroExists = true; - result.push(item); - break; - } - /* falls through */ - case 'string': - case 'boolean': - case 'function': - case 'undefined': - // these types can all utilise Set - set.add(appliedItem); - newSetSize = set.size; - if (newSetSize > prevSetSize) { - result.push(item); - prevSetSize = newSetSize; - } - break; - case 'object': - if (appliedItem === null) { - if (!nullExists) { - // prevent scan for null by tracking as a boolean - nullExists = true; - result.push(null); - } - break; + var _curryN = function _curryN(length, received, fn) { + return function () { + var combined = []; + var argsIdx = 0; + var left = length; + var combinedIdx = 0; + while (combinedIdx < received.length || argsIdx < arguments.length) { + var result; + if (combinedIdx < received.length && (received[combinedIdx] == null || received[combinedIdx]['@@functional/placeholder'] !== true || argsIdx >= arguments.length)) { + result = received[combinedIdx]; + } else { + result = arguments[argsIdx]; + argsIdx += 1; } - /* falls through */ - default: - // scan through all previously applied items - if (!_contains(appliedItem, applied)) { - applied.push(appliedItem); - result.push(item); + combined[combinedIdx] = result; + if (result == null || result['@@functional/placeholder'] !== true) { + left -= 1; } + combinedIdx += 1; + } + return left <= 0 ? fn.apply(this, combined) : _arity(left, _curryN(length, combined, fn)); + }; + }; + + var _filter = function _filter(fn, list) { + var idx = 0, len = list.length, result = []; + while (idx < len) { + if (fn(list[idx])) { + result[result.length] = list[idx]; } idx += 1; } return result; - }); + }; - /** - * Returns a new list without values in the first argument. - * `R.equals` is used to determine equality. - * - * Acts as a transducer if a transformer is given in list position. - * - * @func - * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category List - * @sig [a] -> [a] -> [a] - * @param {Array} list1 The values to be removed from `list2`. - * @param {Array} list2 The array to remove values from. - * @return {Array} The new array without values in `list1`. - * @see R.transduce - * @example - * - * R.without([1, 2], [1, 2, 1, 3, 4]); //=> [3, 4] - */ - var without = _curry2(function (xs, list) { - return reject(flip(_contains)(xs), list); - }); + var _forceReduced = function _forceReduced(x) { + return { + '@@transducer/value': x, + '@@transducer/reduced': true + }; + }; /** - * Takes a function `f` and returns a function `g` such that: - * - * - applying `g` to zero or more arguments will give __true__ if applying - * the same arguments to `f` gives a logical __false__ value; and - * - * - applying `g` to zero or more arguments will give __false__ if applying - * the same arguments to `f` gives a logical __true__ value. - * - * `R.complement` will work on all other functors as well. - * - * @func - * @memberOf R - * @since v0.12.0 - * @category Logic - * @sig (*... -> *) -> (*... -> Boolean) - * @param {Function} f - * @return {Function} - * @see R.not - * @example - * - * var isEven = n => n % 2 === 0; - * var isOdd = R.complement(isEven); - * isOdd(21); //=> true - * isOdd(42); //=> false + * @private + * @param {Function} fn The strategy for extracting function names from an object + * @return {Function} A function that takes an object and returns an array of function names. */ - var complement = lift(not); + var _functionsWith = function _functionsWith(fn) { + return function (obj) { + return _filter(function (key) { + return typeof obj[key] === 'function'; + }, fn(obj)); + }; + }; - /** - * Turns a named method with a specified arity into a function that can be - * called directly supplied with arguments and a target object. - * - * The returned function is curried and accepts `arity + 1` parameters where - * the final parameter is the target object. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig Number -> String -> (a -> b -> ... -> n -> Object -> *) - * @param {Number} arity Number of arguments the returned function should take - * before the target object. - * @param {String} method Name of the method to call. - * @return {Function} A new curried function. - * @example - * - * var sliceFrom = R.invoker(1, 'slice'); - * sliceFrom(6, 'abcdefghijklm'); //=> 'ghijklm' - * var sliceFrom6 = R.invoker(2, 'slice')(6); - * sliceFrom6(8, 'abcdefghijklm'); //=> 'gh' - */ - var invoker = _curry2(function invoker(arity, method) { - return curryN(arity + 1, function () { - var target = arguments[arity]; - if (target != null && is(Function, target[method])) { - return target[method].apply(target, _slice(arguments, 0, arity)); - } - throw new TypeError(toString(target) + ' does not have a method named "' + method + '"'); - }); - }); + var _has = function _has(prop, obj) { + return Object.prototype.hasOwnProperty.call(obj, prop); + }; - /** - * Returns a string made by inserting the `separator` between each element and - * concatenating all the elements into a single string. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category List - * @sig String -> [a] -> String - * @param {Number|String} separator The string used to separate the elements. - * @param {Array} xs The elements to join into a string. - * @return {String} str The string made by concatenating `xs` with `separator`. - * @see R.split - * @example - * - * var spacer = R.join(' '); - * spacer(['a', 2, 3.4]); //=> 'a 2 3.4' - * R.join('|', [1, 2, 3]); //=> '1|2|3' - */ - var join = invoker(1, 'join'); + var _identity = function _identity(x) { + return x; + }; /** - * Creates a new function that, when invoked, caches the result of calling `fn` - * for a given argument set and returns the result. Subsequent calls to the - * memoized `fn` with the same argument set will not result in an additional - * call to `fn`; instead, the cached result for that set of arguments will be - * returned. + * Tests whether or not an object is an array. * - * @func - * @memberOf R - * @since v0.1.0 - * @category Function - * @sig (*... -> a) -> (*... -> a) - * @param {Function} fn The function to memoize. - * @return {Function} Memoized version of `fn`. + * @private + * @param {*} val The object to test. + * @return {Boolean} `true` if `val` is an array, `false` otherwise. * @example * - * var count = 0; - * var factorial = R.memoize(n => { - * count += 1; - * return R.product(R.range(1, n + 1)); - * }); - * factorial(5); //=> 120 - * factorial(5); //=> 120 - * factorial(5); //=> 120 - * count; //=> 1 + * _isArray([]); //=> true + * _isArray(null); //=> false + * _isArray({}); //=> false */ - var memoize = _curry1(function memoize(fn) { - var cache = {}; - return _arity(fn.length, function () { - var key = toString(arguments); - if (!_has(key, cache)) { - cache[key] = fn.apply(this, arguments); - } - return cache[key]; - }); - }); + var _isArray = Array.isArray || function _isArray(val) { + return val != null && val.length >= 0 && Object.prototype.toString.call(val) === '[object Array]'; + }; /** - * Splits a string into an array of strings based on the given - * separator. - * - * @func - * @memberOf R - * @since v0.1.0 - * @category String - * @sig (String | RegExp) -> String -> [String] - * @param {String|RegExp} sep The pattern. - * @param {String} str The string to separate into an array. - * @return {Array} The array of strings from `str` separated by `str`. - * @see R.join - * @example - * - * var pathComponents = R.split('/'); - * R.tail(pathComponents('/usr/local/bin/node')); //=> ['usr', 'local', 'bin', 'node'] + * Determine if the passed argument is an integer. * - * R.split('.', 'a.b.c.xyz.d'); //=> ['a', 'b', 'c', 'xyz', 'd'] + * @private + * @param {*} n + * @category Type + * @return {Boolean} */ - var split = invoker(1, 'split'); + var _isInteger = Number.isInteger || function _isInteger(n) { + return n << 0 === n; + }; + + var _isNumber = function _isNumber(x) { + return Object.prototype.toString.call(x) === '[object Number]'; + }; + + var _isString = function _isString(x) { + return Object.prototype.toString.call(x) === '[object String]'; + }; + + var _isTransformer = function _isTransformer(obj) { + return typeof obj['@@transducer/step'] === 'function'; + }; + + var _map = function _map(fn, list) { + var idx = 0, len = list.length, result = Array(len); + while (idx < len) { + result[idx] = fn(list[idx]); + idx += 1; + } + return result; + }; + + var _pipe = function _pipe(f, g) { + return function () { + return g.call(this, f.apply(this, arguments)); + }; + }; + + var _pipeP = function _pipeP(f, g) { + return function () { + var ctx = this; + return f.apply(ctx, arguments).then(function (x) { + return g.call(ctx, x); + }); + }; + }; + + var _quote = function _quote(s) { + return '"' + s.replace(/"/g, '\\"') + '"'; + }; + + var _reduced = function _reduced(x) { + return x && x['@@transducer/reduced'] ? x : { + '@@transducer/value': x, + '@@transducer/reduced': true + }; + }; /** - * Determines whether a given string matches a given regular expression. + * An optimized, private array `slice` implementation. * - * @func - * @memberOf R - * @since v0.12.0 - * @category String - * @sig RegExp -> String -> Boolean - * @param {RegExp} pattern - * @param {String} str - * @return {Boolean} - * @see R.match + * @private + * @param {Arguments|Array} args The array or arguments object to consider. + * @param {Number} [from=0] The array index to slice from, inclusive. + * @param {Number} [to=args.length] The array index to slice to, exclusive. + * @return {Array} A new, sliced array. * @example * - * R.test(/^x/, 'xyz'); //=> true - * R.test(/^y/, 'xyz'); //=> false + * _slice([1, 2, 3, 4, 5], 1, 3); //=> [2, 3] + * + * var firstThreeArgs = function(a, b, c, d) { + * return _slice(arguments, 0, 3); + * }; + * firstThreeArgs(1, 2, 3, 4); //=> [1, 2, 3] */ - var test = _curry2(function test(pattern, str) { - if (!_isRegExp(pattern)) { - throw new TypeError('\u2018test\u2019 requires a value of type RegExp as its first argument; received ' + toString(pattern)); + var _slice = function _slice(args, from, to) { + switch (arguments.length) { + case 1: + return _slice(args, 0, args.length); + case 2: + return _slice(args, from, args.length); + default: + var list = []; + var idx = 0; + var len = Math.max(0, Math.min(args.length, to) - from); + while (idx < len) { + list[idx] = args[from + idx]; + idx += 1; + } + return list; } - return _cloneRegExp(pattern).test(str); - }); + }; /** - * The lower case version of a string. - * + * Polyfill from . + */ + var _toISOString = function () { + var pad = function pad(n) { + return (n < 10 ? '0' : '') + n; + }; + return typeof Date.prototype.toISOString === 'function' ? function _toISOString(d) { + return d.toISOString(); + } : function _toISOString(d) { + return d.getUTCFullYear() + '-' + pad(d.getUTCMonth() + 1) + '-' + pad(d.getUTCDate()) + 'T' + pad(d.getUTCHours()) + ':' + pad(d.getUTCMinutes()) + ':' + pad(d.getUTCSeconds()) + '.' + (d.getUTCMilliseconds() / 1000).toFixed(3).slice(2, 5) + 'Z'; + }; + }(); + + var _xdropRepeatsWith = function () { + function XDropRepeatsWith(pred, xf) { + this.xf = xf; + this.pred = pred; + this.lastValue = undefined; + this.seenFirstValue = false; + } + XDropRepeatsWith.prototype['@@transducer/init'] = function () { + return this.xf['@@transducer/init'](); + }; + XDropRepeatsWith.prototype['@@transducer/result'] = function (result) { + return this.xf['@@transducer/result'](result); + }; + XDropRepeatsWith.prototype['@@transducer/step'] = function (result, input) { + var sameAsLast = false; + if (!this.seenFirstValue) { + this.seenFirstValue = true; + } else if (this.pred(this.lastValue, input)) { + sameAsLast = true; + } + this.lastValue = input; + return sameAsLast ? result : this.xf['@@transducer/step'](result, input); + }; + return _curry2(function _xdropRepeatsWith(pred, xf) { + return new XDropRepeatsWith(pred, xf); + }); + }(); + + var _xfBase = { + init: function () { + return this.xf['@@transducer/init'](); + }, + result: function (result) { + return this.xf['@@transducer/result'](result); + } + }; + + var _xfilter = function () { + function XFilter(f, xf) { + this.xf = xf; + this.f = f; + } + XFilter.prototype['@@transducer/init'] = _xfBase.init; + XFilter.prototype['@@transducer/result'] = _xfBase.result; + XFilter.prototype['@@transducer/step'] = function (result, input) { + return this.f(input) ? this.xf['@@transducer/step'](result, input) : result; + }; + return _curry2(function _xfilter(f, xf) { + return new XFilter(f, xf); + }); + }(); + + var _xfind = function () { + function XFind(f, xf) { + this.xf = xf; + this.f = f; + this.found = false; + } + XFind.prototype['@@transducer/init'] = _xfBase.init; + XFind.prototype['@@transducer/result'] = function (result) { + if (!this.found) { + result = this.xf['@@transducer/step'](result, void 0); + } + return this.xf['@@transducer/result'](result); + }; + XFind.prototype['@@transducer/step'] = function (result, input) { + if (this.f(input)) { + this.found = true; + result = _reduced(this.xf['@@transducer/step'](result, input)); + } + return result; + }; + return _curry2(function _xfind(f, xf) { + return new XFind(f, xf); + }); + }(); + + var _xfindIndex = function () { + function XFindIndex(f, xf) { + this.xf = xf; + this.f = f; + this.idx = -1; + this.found = false; + } + XFindIndex.prototype['@@transducer/init'] = _xfBase.init; + XFindIndex.prototype['@@transducer/result'] = function (result) { + if (!this.found) { + result = this.xf['@@transducer/step'](result, -1); + } + return this.xf['@@transducer/result'](result); + }; + XFindIndex.prototype['@@transducer/step'] = function (result, input) { + this.idx += 1; + if (this.f(input)) { + this.found = true; + result = _reduced(this.xf['@@transducer/step'](result, this.idx)); + } + return result; + }; + return _curry2(function _xfindIndex(f, xf) { + return new XFindIndex(f, xf); + }); + }(); + + var _xfindLast = function () { + function XFindLast(f, xf) { + this.xf = xf; + this.f = f; + } + XFindLast.prototype['@@transducer/init'] = _xfBase.init; + XFindLast.prototype['@@transducer/result'] = function (result) { + return this.xf['@@transducer/result'](this.xf['@@transducer/step'](result, this.last)); + }; + XFindLast.prototype['@@transducer/step'] = function (result, input) { + if (this.f(input)) { + this.last = input; + } + return result; + }; + return _curry2(function _xfindLast(f, xf) { + return new XFindLast(f, xf); + }); + }(); + + var _xfindLastIndex = function () { + function XFindLastIndex(f, xf) { + this.xf = xf; + this.f = f; + this.idx = -1; + this.lastIdx = -1; + } + XFindLastIndex.prototype['@@transducer/init'] = _xfBase.init; + XFindLastIndex.prototype['@@transducer/result'] = function (result) { + return this.xf['@@transducer/result'](this.xf['@@transducer/step'](result, this.lastIdx)); + }; + XFindLastIndex.prototype['@@transducer/step'] = function (result, input) { + this.idx += 1; + if (this.f(input)) { + this.lastIdx = this.idx; + } + return result; + }; + return _curry2(function _xfindLastIndex(f, xf) { + return new XFindLastIndex(f, xf); + }); + }(); + + var _xmap = function () { + function XMap(f, xf) { + this.xf = xf; + this.f = f; + } + XMap.prototype['@@transducer/init'] = _xfBase.init; + XMap.prototype['@@transducer/result'] = _xfBase.result; + XMap.prototype['@@transducer/step'] = function (result, input) { + return this.xf['@@transducer/step'](result, this.f(input)); + }; + return _curry2(function _xmap(f, xf) { + return new XMap(f, xf); + }); + }(); + + var _xtake = function () { + function XTake(n, xf) { + this.xf = xf; + this.n = n; + } + XTake.prototype['@@transducer/init'] = _xfBase.init; + XTake.prototype['@@transducer/result'] = _xfBase.result; + XTake.prototype['@@transducer/step'] = function (result, input) { + if (this.n === 0) { + return _reduced(result); + } else { + this.n -= 1; + return this.xf['@@transducer/step'](result, input); + } + }; + return _curry2(function _xtake(n, xf) { + return new XTake(n, xf); + }); + }(); + + var _xtakeWhile = function () { + function XTakeWhile(f, xf) { + this.xf = xf; + this.f = f; + } + XTakeWhile.prototype['@@transducer/init'] = _xfBase.init; + XTakeWhile.prototype['@@transducer/result'] = _xfBase.result; + XTakeWhile.prototype['@@transducer/step'] = function (result, input) { + return this.f(input) ? this.xf['@@transducer/step'](result, input) : _reduced(result); + }; + return _curry2(function _xtakeWhile(f, xf) { + return new XTakeWhile(f, xf); + }); + }(); + + var _xwrap = function () { + function XWrap(fn) { + this.f = fn; + } + XWrap.prototype['@@transducer/init'] = function () { + throw new Error('init not implemented on XWrap'); + }; + XWrap.prototype['@@transducer/result'] = function (acc) { + return acc; + }; + XWrap.prototype['@@transducer/step'] = function (acc, x) { + return this.f(acc, x); + }; + return function _xwrap(fn) { + return new XWrap(fn); + }; + }(); + + /** + * Adds two numbers. Equivalent to `a + b` but curried. + * * @func * @memberOf R - * @since v0.9.0 - * @category String - * @sig String -> String - * @param {String} str The string to lower case. - * @return {String} The lower case version of `str`. - * @see R.toUpper + * @category Math + * @sig Number -> Number -> Number + * @param {Number} a + * @param {Number} b + * @return {Number} + * @see R.subtract * @example * - * R.toLower('XYZ'); //=> 'xyz' + * R.add(2, 3); //=> 5 + * R.add(7)(10); //=> 17 */ - var toLower = invoker(0, 'toLowerCase'); + var add = _curry2(function add(a, b) { + return a + b; + }); /** - * The upper case version of a string. + * Applies a function to the value at the given index of an array, + * returning a new copy of the array with the element at the given + * index replaced with the result of the function application. + * @see R.update * * @func * @memberOf R - * @since v0.9.0 - * @category String - * @sig String -> String - * @param {String} str The string to upper case. - * @return {String} The upper case version of `str`. - * @see R.toLower + * @category List + * @sig (a -> a) -> Number -> [a] -> [a] + * @param {Function} fn The function to apply. + * @param {Number} idx The index. + * @param {Array|Arguments} list An array-like object whose value + * at the supplied index will be replaced. + * @return {Array} A copy of the supplied array-like object with + * the element at index `idx` replaced with the value + * returned by applying `fn` to the existing element. * @example * - * R.toUpper('abc'); //=> 'ABC' + * R.adjust(R.add(10), 1, [0, 1, 2]); //=> [0, 11, 2] + * R.adjust(R.add(10))(1)([0, 1, 2]); //=> [0, 11, 2] */ - var toUpper = invoker(0, 'toUpperCase'); + var adjust = _curry3(function adjust(fn, idx, list) { + if (idx >= list.length || idx < -list.length) { + return list; + } + var start = idx < 0 ? list.length : 0; + var _idx = start + idx; + var _list = _concat(list); + _list[_idx] = fn(list[_idx]); + return _list; + }); /** - * Returns a new list containing only one copy of each element in the original - * list. `R.equals` is used to determine equality. + * Returns a function that always returns the given value. Note that for + * non-primitives the value returned is a reference to the original value. + * + * This function is known as `const`, `constant`, or `K` (for K combinator) + * in other languages and libraries. * * @func * @memberOf R - * @since v0.1.0 - * @category List - * @sig [a] -> [a] - * @param {Array} list The array to consider. - * @return {Array} The list of unique items. + * @category Function + * @sig a -> (* -> a) + * @param {*} val The value to wrap in a function + * @return {Function} A Function :: * -> val. * @example * - * R.uniq([1, 1, 2, 1]); //=> [1, 2] - * R.uniq([1, '1']); //=> [1, '1'] - * R.uniq([[42], [42]]); //=> [[42]] + * var t = R.always('Tee'); + * t(); //=> 'Tee' */ - var uniq = uniqBy(identity); + var always = _curry1(function always(val) { + return function () { + return val; + }; + }); /** - * Returns the result of concatenating the given lists or strings. - * - * Dispatches to the `concat` method of the second argument, if present. + * Returns a new list, composed of n-tuples of consecutive elements + * If `n` is greater than the length of the list, an empty list is returned. * * @func * @memberOf R - * @since v0.1.0 * @category List - * @sig [a] -> [a] -> [a] - * @sig String -> String -> String - * @param {Array|String} a - * @param {Array|String} b - * @return {Array|String} - * + * @sig Number -> [a] -> [[a]] + * @param {Number} n The size of the tuples to create + * @param {Array} list The list to split into `n`-tuples + * @return {Array} The new list. * @example * - * R.concat([], []); //=> [] - * R.concat([4, 5, 6], [1, 2, 3]); //=> [4, 5, 6, 1, 2, 3] - * R.concat('ABC', 'DEF'); // 'ABCDEF' + * R.aperture(2, [1, 2, 3, 4, 5]); //=> [[1, 2], [2, 3], [3, 4], [4, 5]] + * R.aperture(3, [1, 2, 3, 4, 5]); //=> [[1, 2, 3], [2, 3, 4], [3, 4, 5]] + * R.aperture(7, [1, 2, 3, 4, 5]); //=> [] */ - var concat = flip(invoker(1, 'concat')); + var aperture = _curry2(function aperture(n, list) { + var idx = 0; + var limit = list.length - (n - 1); + var acc = new Array(limit >= 0 ? limit : 0); + while (idx < limit) { + acc[idx] = _slice(list, idx, idx + n); + idx += 1; + } + return acc; + }); /** - * Combines two lists into a set (i.e. no duplicates) composed of those - * elements common to both lists. + * Returns a new list containing the contents of the given list, followed by the given + * element. * * @func * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig [*] -> [*] -> [*] - * @param {Array} list1 The first list. - * @param {Array} list2 The second list. - * @return {Array} The list of elements found in both `list1` and `list2`. - * @see R.intersectionWith + * @category List + * @sig a -> [a] -> [a] + * @param {*} el The element to add to the end of the new list. + * @param {Array} list The list whose contents will be added to the beginning of the output + * list. + * @return {Array} A new list containing the contents of the old list followed by `el`. + * @see R.prepend * @example * - * R.intersection([1,2,3,4], [7,6,5,4,3]); //=> [4, 3] + * R.append('tests', ['write', 'more']); //=> ['write', 'more', 'tests'] + * R.append('tests', []); //=> ['tests'] + * R.append(['tests'], ['write', 'more']); //=> ['write', 'more', ['tests']] */ - var intersection = _curry2(function intersection(list1, list2) { - return uniq(_filter(flip(_contains)(list1), list2)); + var append = _curry2(function append(el, list) { + return _concat(list, [el]); }); /** - * Finds the set (i.e. no duplicates) of all elements contained in the first or - * second list, but not both. + * Applies function `fn` to the argument list `args`. This is useful for + * creating a fixed-arity function from a variadic function. `fn` should + * be a bound function if context is significant. * * @func * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category Relation - * @sig [*] -> [*] -> [*] - * @param {Array} list1 The first list. - * @param {Array} list2 The second list. - * @return {Array} The elements in `list1` or `list2`, but not both. - * @see R.symmetricDifferenceWith + * @category Function + * @sig (*... -> a) -> [*] -> a + * @param {Function} fn + * @param {Array} args + * @return {*} + * @see R.call, R.unapply * @example * - * R.symmetricDifference([1,2,3,4], [7,6,5,4,3]); //=> [1,2,7,6,5] - * R.symmetricDifference([7,6,5,4,3], [1,2,3,4]); //=> [7,6,5,1,2] + * var nums = [1, 2, 3, -99, 42, 6, 7]; + * R.apply(Math.max, nums); //=> 42 */ - var symmetricDifference = _curry2(function symmetricDifference(list1, list2) { - return concat(difference(list1, list2), difference(list2, list1)); + var apply = _curry2(function apply(fn, args) { + return fn.apply(this, args); }); /** - * Finds the set (i.e. no duplicates) of all elements contained in the first or - * second list, but not both. Duplication is determined according to the value - * returned by applying the supplied predicate to two list elements. + * Makes a shallow clone of an object, setting or overriding the specified + * property with the given value. Note that this copies and flattens + * prototype properties onto the new object as well. All non-primitive + * properties are copied by reference. * * @func * @memberOf R - * @since 0.19.1 - * @since 0.19.0 - * @category Relation - * @sig (a -> a -> Boolean) -> [a] -> [a] -> [a] - * @param {Function} pred A predicate used to test whether two items are equal. - * @param {Array} list1 The first list. - * @param {Array} list2 The second list. - * @return {Array} The elements in `list1` or `list2`, but not both. - * @see R.symmetricDifference + * @category Object + * @sig String -> a -> {k: v} -> {k: v} + * @param {String} prop the property name to set + * @param {*} val the new value + * @param {Object} obj the object to clone + * @return {Object} a new object similar to the original except for the specified property. + * @see R.dissoc * @example * - * var eqA = R.eqBy(R.prop('a')); - * var l1 = [{a: 1}, {a: 2}, {a: 3}, {a: 4}]; - * var l2 = [{a: 3}, {a: 4}, {a: 5}, {a: 6}]; - * R.symmetricDifferenceWith(eqA, l1, l2); //=> [{a: 1}, {a: 2}, {a: 5}, {a: 6}] + * R.assoc('c', 3, {a: 1, b: 2}); //=> {a: 1, b: 2, c: 3} */ - var symmetricDifferenceWith = _curry3(function symmetricDifferenceWith(pred, list1, list2) { - return concat(differenceWith(pred, list1, list2), differenceWith(pred, list2, list1)); + var assoc = _curry3(function assoc(prop, val, obj) { + var result = {}; + for (var p in obj) { + result[p] = obj[p]; + } + result[prop] = val; + return result; }); /** - * Combines two lists into a set (i.e. no duplicates) composed of the elements - * of each list. + * Makes a shallow clone of an object, setting or overriding the nodes + * required to create the given path, and placing the specific value at the + * tail end of that path. Note that this copies and flattens prototype + * properties onto the new object as well. All non-primitive properties + * are copied by reference. * * @func * @memberOf R - * @since v0.1.0 - * @category Relation - * @sig [*] -> [*] -> [*] - * @param {Array} as The first list. - * @param {Array} bs The second list. - * @return {Array} The first and second lists concatenated, with - * duplicates removed. + * @category Object + * @sig [String] -> a -> {k: v} -> {k: v} + * @param {Array} path the path to set + * @param {*} val the new value + * @param {Object} obj the object to clone + * @return {Object} a new object similar to the original except along the specified path. + * @see R.dissocPath * @example * - * R.union([1, 2, 3], [2, 3, 4]); //=> [1, 2, 3, 4] + * R.assocPath(['a', 'b', 'c'], 42, {a: {b: {c: 0}}}); //=> {a: {b: {c: 42}}} */ - var union = _curry2(compose(uniq, _concat)); + var assocPath = _curry3(function assocPath(path, val, obj) { + switch (path.length) { + case 0: + return obj; + case 1: + return assoc(path[0], val, obj); + default: + return assoc(path[0], assocPath(_slice(path, 1), val, Object(obj[path[0]])), obj); + } + }); - var R = { - F: F, - T: T, - __: __, - add: add, - addIndex: addIndex, - adjust: adjust, - all: all, - allPass: allPass, - allUniq: allUniq, - always: always, - and: and, - any: any, - anyPass: anyPass, - ap: ap, - aperture: aperture, - append: append, - apply: apply, - assoc: assoc, - assocPath: assocPath, - binary: binary, - bind: bind, - both: both, - call: call, - chain: chain, - clone: clone, - commute: commute, - commuteMap: commuteMap, - comparator: comparator, - complement: complement, - compose: compose, - composeK: composeK, - composeP: composeP, - concat: concat, - cond: cond, - construct: construct, - constructN: constructN, - contains: contains, - converge: converge, - countBy: countBy, - curry: curry, - curryN: curryN, - dec: dec, - defaultTo: defaultTo, - difference: difference, - differenceWith: differenceWith, - dissoc: dissoc, - dissocPath: dissocPath, - divide: divide, - drop: drop, - dropLast: dropLast, - dropLastWhile: dropLastWhile, - dropRepeats: dropRepeats, - dropRepeatsWith: dropRepeatsWith, - dropWhile: dropWhile, - either: either, - empty: empty, - eqBy: eqBy, - eqProps: eqProps, - equals: equals, - evolve: evolve, - filter: filter, - find: find, - findIndex: findIndex, - findLast: findLast, - findLastIndex: findLastIndex, - flatten: flatten, - flip: flip, - forEach: forEach, - fromPairs: fromPairs, - groupBy: groupBy, - gt: gt, - gte: gte, - has: has, - hasIn: hasIn, - head: head, - identical: identical, - identity: identity, - ifElse: ifElse, - inc: inc, - indexBy: indexBy, - indexOf: indexOf, - init: init, - insert: insert, - insertAll: insertAll, - intersection: intersection, - intersectionWith: intersectionWith, - intersperse: intersperse, - into: into, - invert: invert, - invertObj: invertObj, - invoker: invoker, - is: is, - isArrayLike: isArrayLike, - isEmpty: isEmpty, - isNil: isNil, - join: join, - juxt: juxt, - keys: keys, - keysIn: keysIn, - last: last, - lastIndexOf: lastIndexOf, - length: length, - lens: lens, - lensIndex: lensIndex, - lensPath: lensPath, - lensProp: lensProp, - lift: lift, - liftN: liftN, - lt: lt, - lte: lte, - map: map, - mapAccum: mapAccum, - mapAccumRight: mapAccumRight, - mapObjIndexed: mapObjIndexed, - match: match, - mathMod: mathMod, - max: max, - maxBy: maxBy, - mean: mean, - median: median, - memoize: memoize, - merge: merge, - mergeAll: mergeAll, - mergeWith: mergeWith, - mergeWithKey: mergeWithKey, - min: min, - minBy: minBy, - modulo: modulo, - multiply: multiply, - nAry: nAry, - negate: negate, - none: none, - not: not, - nth: nth, - nthArg: nthArg, - objOf: objOf, - of: of, - omit: omit, - once: once, - or: or, - over: over, - pair: pair, - partial: partial, - partialRight: partialRight, - partition: partition, - path: path, - pathEq: pathEq, - pathOr: pathOr, - pathSatisfies: pathSatisfies, - pick: pick, - pickAll: pickAll, - pickBy: pickBy, - pipe: pipe, - pipeK: pipeK, - pipeP: pipeP, - pluck: pluck, - prepend: prepend, - product: product, - project: project, - prop: prop, - propEq: propEq, - propIs: propIs, - propOr: propOr, - propSatisfies: propSatisfies, - props: props, - range: range, - reduce: reduce, - reduceRight: reduceRight, - reduced: reduced, - reject: reject, - remove: remove, - repeat: repeat, - replace: replace, - reverse: reverse, - scan: scan, - sequence: sequence, - set: set, - slice: slice, - sort: sort, - sortBy: sortBy, - split: split, - splitAt: splitAt, - splitEvery: splitEvery, - splitWhen: splitWhen, - subtract: subtract, - sum: sum, - symmetricDifference: symmetricDifference, - symmetricDifferenceWith: symmetricDifferenceWith, - tail: tail, - take: take, - takeLast: takeLast, - takeLastWhile: takeLastWhile, - takeWhile: takeWhile, - tap: tap, - test: test, - times: times, - toLower: toLower, - toPairs: toPairs, - toPairsIn: toPairsIn, - toString: toString, - toUpper: toUpper, - transduce: transduce, - transpose: transpose, - traverse: traverse, - trim: trim, - type: type, - unapply: unapply, - unary: unary, - uncurryN: uncurryN, - unfold: unfold, - union: union, - unionWith: unionWith, - uniq: uniq, - uniqBy: uniqBy, - uniqWith: uniqWith, - unless: unless, - unnest: unnest, - update: update, - useWith: useWith, - values: values, - valuesIn: valuesIn, - view: view, - when: when, - where: where, - whereEq: whereEq, - without: without, - wrap: wrap, - xprod: xprod, - zip: zip, - zipObj: zipObj, - zipWith: zipWith - }; - /* eslint-env amd */ - - /* TEST_ENTRY_POINT */ - - if (true) { - module.exports = R; - } else if (typeof define === 'function' && define.amd) { - define(function() { return R; }); - } else { - this.R = R; - } - - }.call(this)); - - -/***/ }, -/* 28 */ -/***/ function(module, exports, __webpack_require__) { - - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.isImportDeclaration = exports.isCompiletimeStatement = exports.isCompiletimeDeclaration = exports.isSyntaxDeclarationStatement = exports.isExportSyntax = exports.isParenthesizedExpression = exports.isFunctionWithName = exports.isFunctionTerm = exports.isSyntaxrecDeclaration = exports.isSyntaxDeclaration = exports.isEOF = exports.isVariableDeclarator = exports.isVariableDeclaration = exports.isSyntaxTemplate = exports.isTemplateElement = exports.isSwitchDefault = exports.isSwitchCase = exports.isSuper = exports.isSpreadElement = exports.isScript = exports.isFunctionDeclaration = exports.isFunctionBody = exports.isFormalParameters = exports.isDirective = exports.isCatchClause = exports.isBlock = exports.isPragma = exports.isWithStatement = exports.isWhileStatement = exports.isVariableDeclarationStatement = exports.isTryFinallyStatement = exports.isTryCatchStatement = exports.isThrowStatement = exports.isSwitchStatementWithDefault = exports.isSwitchStatement = exports.isReturnStatement = exports.isLabeledStatement = exports.isIfStatement = exports.isForStatement = exports.isForOfStatement = exports.isForInStatement = exports.isExpressionStatement = exports.isEmptyStatement = exports.isDoWhileStatement = exports.isDebuggerStatement = exports.isCompoundAssignmentExpression = exports.isContinueStatement = exports.isBreakStatement = exports.isBlockStatement = exports.isYieldGeneratorExpression = exports.isYieldExpression = exports.isUpdateExpression = exports.isThisExpression = exports.isTemplateExpression = exports.isStaticMemberExpression = exports.isUnaryExpression = exports.isObjectExpression = exports.isNewTargetExpression = exports.isNewExpression = exports.isIdentifierExpression = exports.isFunctionExpression = exports.isConditionalExpression = exports.isComputedMemberExpression = exports.isComputedAssignmentExpression = exports.isCallExpression = exports.isBinaryExpression = exports.isAssignmentExpression = exports.isArrowExpression = exports.isArrayExpression = exports.isLiteralStringExpression = exports.isLiteralRegExpExpression = exports.isLiteralNumericExpression = exports.isLiteralNullExpression = exports.isLiteralInfinityExpression = exports.isLiteralBooleanExpression = exports.isStaticPropertyName = exports.isComputedPropertyName = exports.isShorthandProperty = exports.isDataProperty = exports.isSetter = exports.isGetter = exports.isMethod = exports.isExportSpecifier = exports.isExportDefault = exports.isExport = exports.isExportFrom = exports.isExportAllFrom = exports.isImportSpecifier = exports.isImportNamespace = exports.isImport = exports.isModule = exports.isClassElement = exports.isClassDeclaration = exports.isClassExpression = exports.isBindingPropertyProperty = exports.isBindingPropertyIdentifier = exports.isObjectBinding = exports.isArrayBinding = exports.isBindingIdentifier = exports.isBindingWithDefault = undefined; - - var _immutable = __webpack_require__(11); + /** + * Creates a function that is bound to a context. + * Note: `R.bind` does not provide the additional argument-binding capabilities of + * [Function.prototype.bind](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/bind). + * + * @func + * @memberOf R + * @category Function + * @category Object + * @see R.partial + * @sig (* -> *) -> {*} -> (* -> *) + * @param {Function} fn The function to bind to context + * @param {Object} thisObj The context to bind `fn` to + * @return {Function} A function that will execute in the context of `thisObj`. + */ + var bind = _curry2(function bind(fn, thisObj) { + return _arity(fn.length, function () { + return fn.apply(thisObj, arguments); + }); + }); - var _errors = __webpack_require__(13); + /** + * A function wrapping calls to the two functions in an `&&` operation, returning the result of the first + * function if it is false-y and the result of the second function otherwise. Note that this is + * short-circuited, meaning that the second function will not be invoked if the first returns a false-y + * value. + * + * @func + * @memberOf R + * @category Logic + * @sig (*... -> Boolean) -> (*... -> Boolean) -> (*... -> Boolean) + * @param {Function} f a predicate + * @param {Function} g another predicate + * @return {Function} a function that applies its arguments to `f` and `g` and `&&`s their outputs together. + * @see R.and + * @example + * + * var gt10 = function(x) { return x > 10; }; + * var even = function(x) { return x % 2 === 0 }; + * var f = R.both(gt10, even); + * f(100); //=> true + * f(101); //=> false + */ + var both = _curry2(function both(f, g) { + return function _both() { + return f.apply(this, arguments) && g.apply(this, arguments); + }; + }); - var _utils = __webpack_require__(29); + /** + * Makes a comparator function out of a function that reports whether the first element is less than the second. + * + * @func + * @memberOf R + * @category Function + * @sig (a, b -> Boolean) -> (a, b -> Number) + * @param {Function} pred A predicate function of arity two. + * @return {Function} A Function :: a -> b -> Int that returns `-1` if a < b, `1` if b < a, otherwise `0`. + * @example + * + * var cmp = R.comparator(function(a, b) { + * return a.age < b.age; + * }); + * var people = [ + * // ... + * ]; + * R.sort(cmp, people); + */ + var comparator = _curry1(function comparator(pred) { + return function (a, b) { + return pred(a, b) ? -1 : pred(b, a) ? 1 : 0; + }; + }); - var _syntax = __webpack_require__(12); + /** + * Takes a function `f` and returns a function `g` such that: + * + * - applying `g` to zero or more arguments will give __true__ if applying + * the same arguments to `f` gives a logical __false__ value; and + * + * - applying `g` to zero or more arguments will give __false__ if applying + * the same arguments to `f` gives a logical __true__ value. + * + * @func + * @memberOf R + * @category Logic + * @sig (*... -> *) -> (*... -> Boolean) + * @param {Function} f + * @return {Function} + * @see R.not + * @example + * + * var isEven = function(n) { return n % 2 === 0; }; + * var isOdd = R.complement(isEven); + * isOdd(21); //=> true + * isOdd(42); //=> false + */ + var complement = _curry1(_complement); - var _syntax2 = _interopRequireDefault(_syntax); + /** + * Returns a function, `fn`, which encapsulates if/else-if/else logic. + * `R.cond` takes a list of [predicate, transform] pairs. All of the + * arguments to `fn` are applied to each of the predicates in turn + * until one returns a "truthy" value, at which point `fn` returns the + * result of applying its arguments to the corresponding transformer. + * If none of the predicates matches, `fn` returns undefined. + * + * @func + * @memberOf R + * @category Logic + * @sig [[(*... -> Boolean),(*... -> *)]] -> (*... -> *) + * @param {Array} pairs + * @return {Function} + * @example + * + * var fn = R.cond([ + * [R.equals(0), R.always('water freezes at 0°C')], + * [R.equals(100), R.always('water boils at 100°C')], + * [R.T, function(temp) { return 'nothing special happens at ' + temp + '°C'; }] + * ]); + * fn(0); //=> 'water freezes at 0°C' + * fn(50); //=> 'nothing special happens at 50°C' + * fn(100); //=> 'water boils at 100°C' + */ + var cond = _curry1(function cond(pairs) { + return function () { + var idx = 0; + while (idx < pairs.length) { + if (pairs[idx][0].apply(this, arguments)) { + return pairs[idx][1].apply(this, arguments); + } + idx += 1; + } + }; + }); - var _termSpec = __webpack_require__(30); + /** + * Returns `true` if the `x` is found in the `list`, using `pred` as an + * equality predicate for `x`. + * + * @func + * @memberOf R + * @category List + * @sig (a, a -> Boolean) -> a -> [a] -> Boolean + * @param {Function} pred A predicate used to test whether two items are equal. + * @param {*} x The item to find + * @param {Array} list The list to iterate over + * @return {Boolean} `true` if `x` is in `list`, else `false`. + * @example + * + * var xs = [{x: 12}, {x: 11}, {x: 10}]; + * R.containsWith(function(a, b) { return a.x === b.x; }, {x: 10}, xs); //=> true + * R.containsWith(function(a, b) { return a.x === b.x; }, {x: 1}, xs); //=> false + */ + var containsWith = _curry3(_containsWith); - var _termSpec2 = _interopRequireDefault(_termSpec); + /** + * Counts the elements of a list according to how many match each value + * of a key generated by the supplied function. Returns an object + * mapping the keys produced by `fn` to the number of occurrences in + * the list. Note that all keys are coerced to strings because of how + * JavaScript objects work. + * + * @func + * @memberOf R + * @category Relation + * @sig (a -> String) -> [a] -> {*} + * @param {Function} fn The function used to map values to keys. + * @param {Array} list The list to count elements from. + * @return {Object} An object mapping keys to number of occurrences in the list. + * @example + * + * var numbers = [1.0, 1.1, 1.2, 2.0, 3.0, 2.2]; + * var letters = R.split('', 'abcABCaaaBBc'); + * R.countBy(Math.floor)(numbers); //=> {'1': 3, '2': 2, '3': 1} + * R.countBy(R.toLower)(letters); //=> {'a': 5, 'b': 4, 'c': 3} + */ + var countBy = _curry2(function countBy(fn, list) { + var counts = {}; + var len = list.length; + var idx = 0; + while (idx < len) { + var key = fn(list[idx]); + counts[key] = (_has(key, counts) ? counts[key] : 0) + 1; + idx += 1; + } + return counts; + }); - var _ramda = __webpack_require__(27); + /** + * Creates an object containing a single key:value pair. + * + * @func + * @memberOf R + * @category Object + * @sig String -> a -> {String:a} + * @param {String} key + * @param {*} val + * @return {Object} + * @example + * + * var matchPhrases = R.compose( + * R.createMapEntry('must'), + * R.map(R.createMapEntry('match_phrase')) + * ); + * matchPhrases(['foo', 'bar', 'baz']); //=> {must: [{match_phrase: 'foo'}, {match_phrase: 'bar'}, {match_phrase: 'baz'}]} + */ + var createMapEntry = _curry2(function createMapEntry(key, val) { + var obj = {}; + obj[key] = val; + return obj; + }); - var R = _interopRequireWildcard(_ramda); + /** + * Returns a curried equivalent of the provided function, with the + * specified arity. The curried function has two unusual capabilities. + * First, its arguments needn't be provided one at a time. If `g` is + * `R.curryN(3, f)`, the following are equivalent: + * + * - `g(1)(2)(3)` + * - `g(1)(2, 3)` + * - `g(1, 2)(3)` + * - `g(1, 2, 3)` + * + * Secondly, the special placeholder value `R.__` may be used to specify + * "gaps", allowing partial application of any combination of arguments, + * regardless of their positions. If `g` is as above and `_` is `R.__`, + * the following are equivalent: + * + * - `g(1, 2, 3)` + * - `g(_, 2, 3)(1)` + * - `g(_, _, 3)(1)(2)` + * - `g(_, _, 3)(1, 2)` + * - `g(_, 2)(1)(3)` + * - `g(_, 2)(1, 3)` + * - `g(_, 2)(_, 3)(1)` + * + * @func + * @memberOf R + * @category Function + * @sig Number -> (* -> a) -> (* -> a) + * @param {Number} length The arity for the returned function. + * @param {Function} fn The function to curry. + * @return {Function} A new, curried function. + * @see R.curry + * @example + * + * var addFourNumbers = function() { + * return R.sum([].slice.call(arguments, 0, 4)); + * }; + * + * var curriedAddFourNumbers = R.curryN(4, addFourNumbers); + * var f = curriedAddFourNumbers(1, 2); + * var g = f(3); + * g(4); //=> 10 + */ + var curryN = _curry2(function curryN(length, fn) { + if (length === 1) { + return _curry1(fn); + } + return _arity(length, _curryN(length, [], fn)); + }); - function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + /** + * Decrements its argument. + * + * @func + * @memberOf R + * @category Math + * @sig Number -> Number + * @param {Number} n + * @return {Number} + * @see R.inc + * @example + * + * R.dec(42); //=> 41 + */ + var dec = add(-1); - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + /** + * Returns the second argument if it is not null or undefined. If it is null + * or undefined, the first (default) argument is returned. + * + * @func + * @memberOf R + * @category Logic + * @sig a -> b -> a | b + * @param {a} val The default value. + * @param {b} val The value to return if it is not null or undefined + * @return {*} The the second value or the default value + * @example + * + * var defaultTo42 = defaultTo(42); + * + * defaultTo42(null); //=> 42 + * defaultTo42(undefined); //=> 42 + * defaultTo42('Ramda'); //=> 'Ramda' + */ + var defaultTo = _curry2(function defaultTo(d, v) { + return v == null ? d : v; + }); - class Term { - constructor(type_1349, props_1350) { - this.type = type_1349; - this.loc = null; - for (let prop of Object.keys(props_1350)) { - this[prop] = props_1350[prop]; - } - } - extend(props_1351) { - let newProps_1352 = {}; - for (let field of _termSpec2.default.spec[this.type].fields) { - if (props_1351.hasOwnProperty(field)) { - newProps_1352[field] = props_1351[field]; - } else { - newProps_1352[field] = this[field]; - } - } - return new Term(this.type, newProps_1352); - } - gen() { - var _ref = arguments.length <= 0 || arguments[0] === undefined ? { includeImports: true } : arguments[0]; - - let includeImports = _ref.includeImports; - - let next_1353 = {}; - for (let field of _termSpec2.default.spec[this.type].fields) { - if (this[field] == null) { - next_1353[field] = null; - } else if (this[field] instanceof Term) { - next_1353[field] = this[field].gen(includeImports); - } else if (_immutable.List.isList(this[field])) { - let pred = includeImports ? R.complement(isCompiletimeStatement_1347) : R.both(R.complement(isImportDeclaration_1348), R.complement(isCompiletimeStatement_1347)); - next_1353[field] = this[field].filter(pred).map(term_1354 => term_1354 instanceof Term ? term_1354.gen(includeImports) : term_1354); - } else { - next_1353[field] = this[field]; - } - } - return new Term(this.type, next_1353); - } - visit(f_1355) { - let next_1356 = {}; - for (let field of _termSpec2.default.spec[this.type].fields) { - if (this[field] == null) { - next_1356[field] = null; - } else if (_immutable.List.isList(this[field])) { - next_1356[field] = this[field].map(field_1357 => field_1357 != null ? f_1355(field_1357) : null); - } else { - next_1356[field] = f_1355(this[field]); - } - } - return this.extend(next_1356); - } - addScope(scope_1358, bindings_1359, phase_1360, options_1361) { - return this.visit(term_1362 => { - if (typeof term_1362.addScope === "function") { - return term_1362.addScope(scope_1358, bindings_1359, phase_1360, options_1361); - } - return term_1362; - }); - } - removeScope(scope_1363, phase_1364) { - return this.visit(term_1365 => { - if (typeof term_1365.removeScope === "function") { - return term_1365.removeScope(scope_1363, phase_1364); - } - return term_1365; + /** + * Finds the set (i.e. no duplicates) of all elements in the first list not contained in the second list. + * Duplication is determined according to the value returned by applying the supplied predicate to two list + * elements. + * + * @func + * @memberOf R + * @category Relation + * @sig (a,a -> Boolean) -> [a] -> [a] -> [a] + * @param {Function} pred A predicate used to test whether two items are equal. + * @param {Array} list1 The first list. + * @param {Array} list2 The second list. + * @see R.difference + * @return {Array} The elements in `list1` that are not in `list2`. + * @example + * + * function cmp(x, y) { return x.a === y.a; } + * var l1 = [{a: 1}, {a: 2}, {a: 3}]; + * var l2 = [{a: 3}, {a: 4}]; + * R.differenceWith(cmp, l1, l2); //=> [{a: 1}, {a: 2}] + */ + var differenceWith = _curry3(function differenceWith(pred, first, second) { + var out = []; + var idx = 0; + var firstLen = first.length; + var containsPred = containsWith(pred); + while (idx < firstLen) { + if (!containsPred(first[idx], second) && !containsPred(first[idx], out)) { + out[out.length] = first[idx]; + } + idx += 1; + } + return out; }); - } - lineNumber() { - for (let field of _termSpec2.default.spec[this.type].fields) { - if (typeof this[field] && this[field].lineNumber === "function") { - return this[field].lineNumber(); - } - } - } - setLineNumber(line_1366) { - let next_1367 = {}; - for (let field of _termSpec2.default.spec[this.type].fields) { - if (this[field] == null) { - next_1367[field] = null; - } else if (typeof this[field].setLineNumber === "function") { - next_1367[field] = this[field].setLineNumber(line_1366); - } else if (_immutable.List.isList(this[field])) { - next_1367[field] = this[field].map(f_1368 => f_1368.setLineNumber(line_1366)); - } else { - next_1367[field] = this[field]; - } - } - return new Term(this.type, next_1367); - } - } - exports.default = Term; - const isBindingWithDefault_1249 = R.whereEq({ type: "BindingWithDefault" }); - ; - const isBindingIdentifier_1250 = R.whereEq({ type: "BindingIdentifier" }); - ; - const isArrayBinding_1251 = R.whereEq({ type: "ArrayBinding" }); - ; - const isObjectBinding_1252 = R.whereEq({ type: "ObjectBinding" }); - ; - const isBindingPropertyIdentifier_1253 = R.whereEq({ type: "BindingPropertyIdentifier" }); - ; - const isBindingPropertyProperty_1254 = R.whereEq({ type: "BindingPropertyIdentifier" }); - ; - const isClassExpression_1255 = R.whereEq({ type: "ClassExpression" }); - ; - const isClassDeclaration_1256 = R.whereEq({ type: "ClassDeclaration" }); - ; - const isClassElement_1257 = R.whereEq({ type: "ClassElement" }); - ; - const isModule_1258 = R.whereEq({ type: "Module" }); - ; - const isImport_1259 = R.whereEq({ type: "Import" }); - ; - const isImportNamespace_1260 = R.whereEq({ type: "ImportNamespace" }); - ; - const isImportSpecifier_1261 = R.whereEq({ type: "ImportSpecifier" }); - ; - const isExportAllFrom_1262 = R.whereEq({ type: "ExportAllFrom" }); - ; - const isExportFrom_1263 = R.whereEq({ type: "ExportFrom" }); - ; - const isExport_1264 = R.whereEq({ type: "Export" }); - ; - const isExportDefault_1265 = R.whereEq({ type: "ExportDefault" }); - ; - const isExportSpecifier_1266 = R.whereEq({ type: "ExportSpecifier" }); - ; - const isMethod_1267 = R.whereEq({ type: "Method" }); - ; - const isGetter_1268 = R.whereEq({ type: "Getter" }); - ; - const isSetter_1269 = R.whereEq({ type: "Setter" }); - ; - const isDataProperty_1270 = R.whereEq({ type: "DataProperty" }); - ; - const isShorthandProperty_1271 = R.whereEq({ type: "ShorthandProperty" }); - ; - const isComputedPropertyName_1272 = R.whereEq({ type: "ComputedPropertyName" }); - ; - const isStaticPropertyName_1273 = R.whereEq({ type: "StaticPropertyName" }); - ; - const isLiteralBooleanExpression_1274 = R.whereEq({ type: "LiteralBooleanExpression" }); - ; - const isLiteralInfinityExpression_1275 = R.whereEq({ type: "LiteralInfinityExpression" }); - ; - const isLiteralNullExpression_1276 = R.whereEq({ type: "LiteralNullExpression" }); - ; - const isLiteralNumericExpression_1277 = R.whereEq({ type: "LiteralNumericExpression" }); - ; - const isLiteralRegExpExpression_1278 = R.whereEq({ type: "LiteralRegExpExpression" }); - ; - const isLiteralStringExpression_1279 = R.whereEq({ type: "LiteralStringExpression" }); - ; - const isArrayExpression_1280 = R.whereEq({ type: "ArrayExpression" }); - ; - const isArrowExpression_1281 = R.whereEq({ type: "ArrowExpression" }); - ; - const isAssignmentExpression_1282 = R.whereEq({ type: "AssignmentExpression" }); - ; - const isBinaryExpression_1283 = R.whereEq({ type: "BinaryExpression" }); - ; - const isCallExpression_1284 = R.whereEq({ type: "CallExpression" }); - ; - const isComputedAssignmentExpression_1285 = R.whereEq({ type: "ComputedAssignmentExpression" }); - ; - const isComputedMemberExpression_1286 = R.whereEq({ type: "ComputedMemberExpression" }); - ; - const isConditionalExpression_1287 = R.whereEq({ type: "ConditionalExpression" }); - ; - const isFunctionExpression_1288 = R.whereEq({ type: "FunctionExpression" }); - ; - const isIdentifierExpression_1289 = R.whereEq({ type: "IdentifierExpression" }); - ; - const isNewExpression_1290 = R.whereEq({ type: "NewExpression" }); - ; - const isNewTargetExpression_1291 = R.whereEq({ type: "NewTargetExpression" }); - ; - const isObjectExpression_1292 = R.whereEq({ type: "ObjectExpression" }); - ; - const isUnaryExpression_1293 = R.whereEq({ type: "UnaryExpression" }); - ; - const isStaticMemberExpression_1294 = R.whereEq({ type: "StaticMemberExpression" }); - ; - const isTemplateExpression_1295 = R.whereEq({ type: "TemplateExpression" }); - ; - const isThisExpression_1296 = R.whereEq({ type: "ThisExpression" }); - ; - const isUpdateExpression_1297 = R.whereEq({ type: "UpdateExpression" }); - ; - const isYieldExpression_1298 = R.whereEq({ type: "YieldExpression" }); - ; - const isYieldGeneratorExpression_1299 = R.whereEq({ type: "YieldGeneratorExpression" }); - ; - const isBlockStatement_1300 = R.whereEq({ type: "BlockStatement" }); - ; - const isBreakStatement_1301 = R.whereEq({ type: "BreakStatement" }); - ; - const isContinueStatement_1302 = R.whereEq({ type: "ContinueStatement" }); - ; - const isCompoundAssignmentExpression_1303 = R.whereEq({ type: "CompoundAssignmentExpression" }); - ; - const isDebuggerStatement_1304 = R.whereEq({ type: "DebuggerStatement" }); - ; - const isDoWhileStatement_1305 = R.whereEq({ type: "DoWhileStatement" }); - ; - const isEmptyStatement_1306 = R.whereEq({ type: "EmptyStatement" }); - ; - const isExpressionStatement_1307 = R.whereEq({ type: "ExpressionStatement" }); - ; - const isForInStatement_1308 = R.whereEq({ type: "ForInStatement" }); - ; - const isForOfStatement_1309 = R.whereEq({ type: "ForOfStatement" }); - ; - const isForStatement_1310 = R.whereEq({ type: "ForStatement" }); - ; - const isIfStatement_1311 = R.whereEq({ type: "IfStatement" }); - ; - const isLabeledStatement_1312 = R.whereEq({ type: "LabeledStatement" }); - ; - const isReturnStatement_1313 = R.whereEq({ type: "ReturnStatement" }); - ; - const isSwitchStatement_1314 = R.whereEq({ type: "SwitchStatement" }); - ; - const isSwitchStatementWithDefault_1315 = R.whereEq({ type: "SwitchStatementWithDefault" }); - ; - const isThrowStatement_1316 = R.whereEq({ type: "ThrowStatement" }); - ; - const isTryCatchStatement_1317 = R.whereEq({ type: "TryCatchStatement" }); - ; - const isTryFinallyStatement_1318 = R.whereEq({ type: "TryFinallyStatement" }); - ; - const isVariableDeclarationStatement_1319 = R.whereEq({ type: "VariableDeclarationStatement" }); - ; - const isWhileStatement_1320 = R.whereEq({ type: "WhileStatement" }); - ; - const isWithStatement_1321 = R.whereEq({ type: "WithStatement" }); - ; - const isPragma_1322 = R.whereEq({ type: "Pragma" }); - ; - const isBlock_1323 = R.whereEq({ type: "Block" }); - ; - const isCatchClause_1324 = R.whereEq({ type: "CatchClause" }); - ; - const isDirective_1325 = R.whereEq({ type: "Directive" }); - ; - const isFormalParameters_1326 = R.whereEq({ type: "FormalParameters" }); - ; - const isFunctionBody_1327 = R.whereEq({ type: "FunctionBody" }); - ; - const isFunctionDeclaration_1328 = R.whereEq({ type: "FunctionDeclaration" }); - ; - const isScript_1329 = R.whereEq({ type: "Script" }); - ; - const isSpreadElement_1330 = R.whereEq({ type: "SpreadElement" }); - ; - const isSuper_1331 = R.whereEq({ type: "Super" }); - ; - const isSwitchCase_1332 = R.whereEq({ type: "SwitchCase" }); - ; - const isSwitchDefault_1333 = R.whereEq({ type: "SwitchDefault" }); - ; - const isTemplateElement_1334 = R.whereEq({ type: "TemplateElement" }); - ; - const isSyntaxTemplate_1335 = R.whereEq({ type: "SyntaxTemplate" }); - ; - const isVariableDeclaration_1336 = R.whereEq({ type: "VariableDeclaration" }); - ; - const isVariableDeclarator_1337 = R.whereEq({ type: "VariableDeclarator" }); - ; - const isEOF_1338 = R.whereEq({ type: "EOF" }); - ; - const isSyntaxDeclaration_1339 = R.both(isVariableDeclaration_1336, R.whereEq({ kind: "syntax" })); - ; - const isSyntaxrecDeclaration_1340 = R.both(isVariableDeclaration_1336, R.whereEq({ kind: "syntaxrec" })); - ; - const isFunctionTerm_1341 = R.either(isFunctionDeclaration_1328, isFunctionExpression_1288); - ; - const isFunctionWithName_1342 = R.and(isFunctionTerm_1341, R.complement(R.where({ name: R.isNil }))); - ; - const isParenthesizedExpression_1343 = R.whereEq({ type: "ParenthesizedExpression" }); - ; - const isExportSyntax_1344 = R.both(isExport_1264, exp_1369 => R.or(isSyntaxDeclaration_1339(exp_1369.declaration), isSyntaxrecDeclaration_1340(exp_1369.declaration))); - ; - const isSyntaxDeclarationStatement_1345 = R.both(isVariableDeclarationStatement_1319, decl_1370 => isCompiletimeDeclaration_1346(decl_1370.declaration)); - ; - const isCompiletimeDeclaration_1346 = R.either(isSyntaxDeclaration_1339, isSyntaxrecDeclaration_1340); - ; - const isCompiletimeStatement_1347 = term_1371 => { - return term_1371 instanceof Term && isVariableDeclarationStatement_1319(term_1371) && isCompiletimeDeclaration_1346(term_1371.declaration); - }; - ; - const isImportDeclaration_1348 = R.either(isImport_1259, isImportNamespace_1260); - ; - exports.isBindingWithDefault = isBindingWithDefault_1249; - exports.isBindingIdentifier = isBindingIdentifier_1250; - exports.isArrayBinding = isArrayBinding_1251; - exports.isObjectBinding = isObjectBinding_1252; - exports.isBindingPropertyIdentifier = isBindingPropertyIdentifier_1253; - exports.isBindingPropertyProperty = isBindingPropertyProperty_1254; - exports.isClassExpression = isClassExpression_1255; - exports.isClassDeclaration = isClassDeclaration_1256; - exports.isClassElement = isClassElement_1257; - exports.isModule = isModule_1258; - exports.isImport = isImport_1259; - exports.isImportNamespace = isImportNamespace_1260; - exports.isImportSpecifier = isImportSpecifier_1261; - exports.isExportAllFrom = isExportAllFrom_1262; - exports.isExportFrom = isExportFrom_1263; - exports.isExport = isExport_1264; - exports.isExportDefault = isExportDefault_1265; - exports.isExportSpecifier = isExportSpecifier_1266; - exports.isMethod = isMethod_1267; - exports.isGetter = isGetter_1268; - exports.isSetter = isSetter_1269; - exports.isDataProperty = isDataProperty_1270; - exports.isShorthandProperty = isShorthandProperty_1271; - exports.isComputedPropertyName = isComputedPropertyName_1272; - exports.isStaticPropertyName = isStaticPropertyName_1273; - exports.isLiteralBooleanExpression = isLiteralBooleanExpression_1274; - exports.isLiteralInfinityExpression = isLiteralInfinityExpression_1275; - exports.isLiteralNullExpression = isLiteralNullExpression_1276; - exports.isLiteralNumericExpression = isLiteralNumericExpression_1277; - exports.isLiteralRegExpExpression = isLiteralRegExpExpression_1278; - exports.isLiteralStringExpression = isLiteralStringExpression_1279; - exports.isArrayExpression = isArrayExpression_1280; - exports.isArrowExpression = isArrowExpression_1281; - exports.isAssignmentExpression = isAssignmentExpression_1282; - exports.isBinaryExpression = isBinaryExpression_1283; - exports.isCallExpression = isCallExpression_1284; - exports.isComputedAssignmentExpression = isComputedAssignmentExpression_1285; - exports.isComputedMemberExpression = isComputedMemberExpression_1286; - exports.isConditionalExpression = isConditionalExpression_1287; - exports.isFunctionExpression = isFunctionExpression_1288; - exports.isIdentifierExpression = isIdentifierExpression_1289; - exports.isNewExpression = isNewExpression_1290; - exports.isNewTargetExpression = isNewTargetExpression_1291; - exports.isObjectExpression = isObjectExpression_1292; - exports.isUnaryExpression = isUnaryExpression_1293; - exports.isStaticMemberExpression = isStaticMemberExpression_1294; - exports.isTemplateExpression = isTemplateExpression_1295; - exports.isThisExpression = isThisExpression_1296; - exports.isUpdateExpression = isUpdateExpression_1297; - exports.isYieldExpression = isYieldExpression_1298; - exports.isYieldGeneratorExpression = isYieldGeneratorExpression_1299; - exports.isBlockStatement = isBlockStatement_1300; - exports.isBreakStatement = isBreakStatement_1301; - exports.isContinueStatement = isContinueStatement_1302; - exports.isCompoundAssignmentExpression = isCompoundAssignmentExpression_1303; - exports.isDebuggerStatement = isDebuggerStatement_1304; - exports.isDoWhileStatement = isDoWhileStatement_1305; - exports.isEmptyStatement = isEmptyStatement_1306; - exports.isExpressionStatement = isExpressionStatement_1307; - exports.isForInStatement = isForInStatement_1308; - exports.isForOfStatement = isForOfStatement_1309; - exports.isForStatement = isForStatement_1310; - exports.isIfStatement = isIfStatement_1311; - exports.isLabeledStatement = isLabeledStatement_1312; - exports.isReturnStatement = isReturnStatement_1313; - exports.isSwitchStatement = isSwitchStatement_1314; - exports.isSwitchStatementWithDefault = isSwitchStatementWithDefault_1315; - exports.isThrowStatement = isThrowStatement_1316; - exports.isTryCatchStatement = isTryCatchStatement_1317; - exports.isTryFinallyStatement = isTryFinallyStatement_1318; - exports.isVariableDeclarationStatement = isVariableDeclarationStatement_1319; - exports.isWhileStatement = isWhileStatement_1320; - exports.isWithStatement = isWithStatement_1321; - exports.isPragma = isPragma_1322; - exports.isBlock = isBlock_1323; - exports.isCatchClause = isCatchClause_1324; - exports.isDirective = isDirective_1325; - exports.isFormalParameters = isFormalParameters_1326; - exports.isFunctionBody = isFunctionBody_1327; - exports.isFunctionDeclaration = isFunctionDeclaration_1328; - exports.isScript = isScript_1329; - exports.isSpreadElement = isSpreadElement_1330; - exports.isSuper = isSuper_1331; - exports.isSwitchCase = isSwitchCase_1332; - exports.isSwitchDefault = isSwitchDefault_1333; - exports.isTemplateElement = isTemplateElement_1334; - exports.isSyntaxTemplate = isSyntaxTemplate_1335; - exports.isVariableDeclaration = isVariableDeclaration_1336; - exports.isVariableDeclarator = isVariableDeclarator_1337; - exports.isEOF = isEOF_1338; - exports.isSyntaxDeclaration = isSyntaxDeclaration_1339; - exports.isSyntaxrecDeclaration = isSyntaxrecDeclaration_1340; - exports.isFunctionTerm = isFunctionTerm_1341; - exports.isFunctionWithName = isFunctionWithName_1342; - exports.isParenthesizedExpression = isParenthesizedExpression_1343; - exports.isExportSyntax = isExportSyntax_1344; - exports.isSyntaxDeclarationStatement = isSyntaxDeclarationStatement_1345; - exports.isCompiletimeDeclaration = isCompiletimeDeclaration_1346; - exports.isCompiletimeStatement = isCompiletimeStatement_1347; - exports.isImportDeclaration = isImportDeclaration_1348; - //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/terms.js"],"names":[],"mappings":"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B,c,GAAvB,mB;QACsB,a,GAAtB,kB;QAC2B,kB,GAA3B,uB;QAC0B,iB,GAA1B,sB;QAC0B,iB,GAA1B,sB;QACqC,4B,GAArC,iC;QACyB,gB,GAAzB,qB;QAC4B,mB,GAA5B,wB;QAC8B,qB,GAA9B,0B;QACuC,8B,GAAvC,mC;QACyB,gB,GAAzB,qB;QACwB,e,GAAxB,oB;QACiB,Q,GAAjB,a;QACgB,O,GAAhB,Y;QACsB,a,GAAtB,kB;QACoB,W,GAApB,gB;QAC2B,kB,GAA3B,uB;QACuB,c,GAAvB,mB;QAC8B,qB,GAA9B,0B;QACiB,Q,GAAjB,a;QACwB,e,GAAxB,oB;QACgB,O,GAAhB,Y;QACqB,Y,GAArB,iB;QACwB,e,GAAxB,oB;QAC0B,iB,GAA1B,sB;QACyB,gB,GAAzB,qB;QAC8B,qB,GAA9B,0B;QAC6B,oB,GAA7B,yB;QACc,K,GAAd,U;QAC4B,mB,GAA5B,wB;QAC+B,sB,GAA/B,2B;QACuB,c,GAAvB,mB;QAC2B,kB,GAA3B,uB;QACkC,yB,GAAlC,8B;QACuB,c,GAAvB,mB;QACqC,4B,GAArC,iC;QACiC,wB,GAAjC,6B;QAC+B,sB,GAA/B,2B;QAC4B,mB,GAA5B,wB","file":"terms.js","sourcesContent":["import {List} from \"immutable\";\nimport {assert, expect} from \"./errors\";\nimport {mixin} from \"./utils\";\nimport Syntax from \"./syntax\";\nimport TermSpec from \"./term-spec\";\nimport  * as R from \"ramda\";\nexport default class Term {\n  constructor(type_1349, props_1350) {\n    this.type = type_1349;\n    this.loc = null;\n    for (let prop of Object.keys(props_1350)) {\n      this[prop] = props_1350[prop];\n    }\n  }\n  extend(props_1351) {\n    let newProps_1352 = {};\n    for (let field of TermSpec.spec[this.type].fields) {\n      if (props_1351.hasOwnProperty(field)) {\n        newProps_1352[field] = props_1351[field];\n      } else {\n        newProps_1352[field] = this[field];\n      }\n    }\n    return new Term(this.type, newProps_1352);\n  }\n  gen({includeImports} = {includeImports: true}) {\n    let next_1353 = {};\n    for (let field of TermSpec.spec[this.type].fields) {\n      if (this[field] == null) {\n        next_1353[field] = null;\n      } else if (this[field] instanceof Term) {\n        next_1353[field] = this[field].gen(includeImports);\n      } else if (List.isList(this[field])) {\n        let pred = includeImports ? R.complement(isCompiletimeStatement_1347) : R.both(R.complement(isImportDeclaration_1348), R.complement(isCompiletimeStatement_1347));\n        next_1353[field] = this[field].filter(pred).map(term_1354 => term_1354 instanceof Term ? term_1354.gen(includeImports) : term_1354);\n      } else {\n        next_1353[field] = this[field];\n      }\n    }\n    return new Term(this.type, next_1353);\n  }\n  visit(f_1355) {\n    let next_1356 = {};\n    for (let field of TermSpec.spec[this.type].fields) {\n      if (this[field] == null) {\n        next_1356[field] = null;\n      } else if (List.isList(this[field])) {\n        next_1356[field] = this[field].map(field_1357 => field_1357 != null ? f_1355(field_1357) : null);\n      } else {\n        next_1356[field] = f_1355(this[field]);\n      }\n    }\n    return this.extend(next_1356);\n  }\n  addScope(scope_1358, bindings_1359, phase_1360, options_1361) {\n    return this.visit(term_1362 => {\n      if (typeof term_1362.addScope === \"function\") {\n        return term_1362.addScope(scope_1358, bindings_1359, phase_1360, options_1361);\n      }\n      return term_1362;\n    });\n  }\n  removeScope(scope_1363, phase_1364) {\n    return this.visit(term_1365 => {\n      if (typeof term_1365.removeScope === \"function\") {\n        return term_1365.removeScope(scope_1363, phase_1364);\n      }\n      return term_1365;\n    });\n  }\n  lineNumber() {\n    for (let field of TermSpec.spec[this.type].fields) {\n      if (typeof this[field] && this[field].lineNumber === \"function\") {\n        return this[field].lineNumber();\n      }\n    }\n  }\n  setLineNumber(line_1366) {\n    let next_1367 = {};\n    for (let field of TermSpec.spec[this.type].fields) {\n      if (this[field] == null) {\n        next_1367[field] = null;\n      } else if (typeof this[field].setLineNumber === \"function\") {\n        next_1367[field] = this[field].setLineNumber(line_1366);\n      } else if (List.isList(this[field])) {\n        next_1367[field] = this[field].map(f_1368 => f_1368.setLineNumber(line_1366));\n      } else {\n        next_1367[field] = this[field];\n      }\n    }\n    return new Term(this.type, next_1367);\n  }\n}\nconst isBindingWithDefault_1249 = R.whereEq({type: \"BindingWithDefault\"});\n;\nconst isBindingIdentifier_1250 = R.whereEq({type: \"BindingIdentifier\"});\n;\nconst isArrayBinding_1251 = R.whereEq({type: \"ArrayBinding\"});\n;\nconst isObjectBinding_1252 = R.whereEq({type: \"ObjectBinding\"});\n;\nconst isBindingPropertyIdentifier_1253 = R.whereEq({type: \"BindingPropertyIdentifier\"});\n;\nconst isBindingPropertyProperty_1254 = R.whereEq({type: \"BindingPropertyIdentifier\"});\n;\nconst isClassExpression_1255 = R.whereEq({type: \"ClassExpression\"});\n;\nconst isClassDeclaration_1256 = R.whereEq({type: \"ClassDeclaration\"});\n;\nconst isClassElement_1257 = R.whereEq({type: \"ClassElement\"});\n;\nconst isModule_1258 = R.whereEq({type: \"Module\"});\n;\nconst isImport_1259 = R.whereEq({type: \"Import\"});\n;\nconst isImportNamespace_1260 = R.whereEq({type: \"ImportNamespace\"});\n;\nconst isImportSpecifier_1261 = R.whereEq({type: \"ImportSpecifier\"});\n;\nconst isExportAllFrom_1262 = R.whereEq({type: \"ExportAllFrom\"});\n;\nconst isExportFrom_1263 = R.whereEq({type: \"ExportFrom\"});\n;\nconst isExport_1264 = R.whereEq({type: \"Export\"});\n;\nconst isExportDefault_1265 = R.whereEq({type: \"ExportDefault\"});\n;\nconst isExportSpecifier_1266 = R.whereEq({type: \"ExportSpecifier\"});\n;\nconst isMethod_1267 = R.whereEq({type: \"Method\"});\n;\nconst isGetter_1268 = R.whereEq({type: \"Getter\"});\n;\nconst isSetter_1269 = R.whereEq({type: \"Setter\"});\n;\nconst isDataProperty_1270 = R.whereEq({type: \"DataProperty\"});\n;\nconst isShorthandProperty_1271 = R.whereEq({type: \"ShorthandProperty\"});\n;\nconst isComputedPropertyName_1272 = R.whereEq({type: \"ComputedPropertyName\"});\n;\nconst isStaticPropertyName_1273 = R.whereEq({type: \"StaticPropertyName\"});\n;\nconst isLiteralBooleanExpression_1274 = R.whereEq({type: \"LiteralBooleanExpression\"});\n;\nconst isLiteralInfinityExpression_1275 = R.whereEq({type: \"LiteralInfinityExpression\"});\n;\nconst isLiteralNullExpression_1276 = R.whereEq({type: \"LiteralNullExpression\"});\n;\nconst isLiteralNumericExpression_1277 = R.whereEq({type: \"LiteralNumericExpression\"});\n;\nconst isLiteralRegExpExpression_1278 = R.whereEq({type: \"LiteralRegExpExpression\"});\n;\nconst isLiteralStringExpression_1279 = R.whereEq({type: \"LiteralStringExpression\"});\n;\nconst isArrayExpression_1280 = R.whereEq({type: \"ArrayExpression\"});\n;\nconst isArrowExpression_1281 = R.whereEq({type: \"ArrowExpression\"});\n;\nconst isAssignmentExpression_1282 = R.whereEq({type: \"AssignmentExpression\"});\n;\nconst isBinaryExpression_1283 = R.whereEq({type: \"BinaryExpression\"});\n;\nconst isCallExpression_1284 = R.whereEq({type: \"CallExpression\"});\n;\nconst isComputedAssignmentExpression_1285 = R.whereEq({type: \"ComputedAssignmentExpression\"});\n;\nconst isComputedMemberExpression_1286 = R.whereEq({type: \"ComputedMemberExpression\"});\n;\nconst isConditionalExpression_1287 = R.whereEq({type: \"ConditionalExpression\"});\n;\nconst isFunctionExpression_1288 = R.whereEq({type: \"FunctionExpression\"});\n;\nconst isIdentifierExpression_1289 = R.whereEq({type: \"IdentifierExpression\"});\n;\nconst isNewExpression_1290 = R.whereEq({type: \"NewExpression\"});\n;\nconst isNewTargetExpression_1291 = R.whereEq({type: \"NewTargetExpression\"});\n;\nconst isObjectExpression_1292 = R.whereEq({type: \"ObjectExpression\"});\n;\nconst isUnaryExpression_1293 = R.whereEq({type: \"UnaryExpression\"});\n;\nconst isStaticMemberExpression_1294 = R.whereEq({type: \"StaticMemberExpression\"});\n;\nconst isTemplateExpression_1295 = R.whereEq({type: \"TemplateExpression\"});\n;\nconst isThisExpression_1296 = R.whereEq({type: \"ThisExpression\"});\n;\nconst isUpdateExpression_1297 = R.whereEq({type: \"UpdateExpression\"});\n;\nconst isYieldExpression_1298 = R.whereEq({type: \"YieldExpression\"});\n;\nconst isYieldGeneratorExpression_1299 = R.whereEq({type: \"YieldGeneratorExpression\"});\n;\nconst isBlockStatement_1300 = R.whereEq({type: \"BlockStatement\"});\n;\nconst isBreakStatement_1301 = R.whereEq({type: \"BreakStatement\"});\n;\nconst isContinueStatement_1302 = R.whereEq({type: \"ContinueStatement\"});\n;\nconst isCompoundAssignmentExpression_1303 = R.whereEq({type: \"CompoundAssignmentExpression\"});\n;\nconst isDebuggerStatement_1304 = R.whereEq({type: \"DebuggerStatement\"});\n;\nconst isDoWhileStatement_1305 = R.whereEq({type: \"DoWhileStatement\"});\n;\nconst isEmptyStatement_1306 = R.whereEq({type: \"EmptyStatement\"});\n;\nconst isExpressionStatement_1307 = R.whereEq({type: \"ExpressionStatement\"});\n;\nconst isForInStatement_1308 = R.whereEq({type: \"ForInStatement\"});\n;\nconst isForOfStatement_1309 = R.whereEq({type: \"ForOfStatement\"});\n;\nconst isForStatement_1310 = R.whereEq({type: \"ForStatement\"});\n;\nconst isIfStatement_1311 = R.whereEq({type: \"IfStatement\"});\n;\nconst isLabeledStatement_1312 = R.whereEq({type: \"LabeledStatement\"});\n;\nconst isReturnStatement_1313 = R.whereEq({type: \"ReturnStatement\"});\n;\nconst isSwitchStatement_1314 = R.whereEq({type: \"SwitchStatement\"});\n;\nconst isSwitchStatementWithDefault_1315 = R.whereEq({type: \"SwitchStatementWithDefault\"});\n;\nconst isThrowStatement_1316 = R.whereEq({type: \"ThrowStatement\"});\n;\nconst isTryCatchStatement_1317 = R.whereEq({type: \"TryCatchStatement\"});\n;\nconst isTryFinallyStatement_1318 = R.whereEq({type: \"TryFinallyStatement\"});\n;\nconst isVariableDeclarationStatement_1319 = R.whereEq({type: \"VariableDeclarationStatement\"});\n;\nconst isWhileStatement_1320 = R.whereEq({type: \"WhileStatement\"});\n;\nconst isWithStatement_1321 = R.whereEq({type: \"WithStatement\"});\n;\nconst isPragma_1322 = R.whereEq({type: \"Pragma\"});\n;\nconst isBlock_1323 = R.whereEq({type: \"Block\"});\n;\nconst isCatchClause_1324 = R.whereEq({type: \"CatchClause\"});\n;\nconst isDirective_1325 = R.whereEq({type: \"Directive\"});\n;\nconst isFormalParameters_1326 = R.whereEq({type: \"FormalParameters\"});\n;\nconst isFunctionBody_1327 = R.whereEq({type: \"FunctionBody\"});\n;\nconst isFunctionDeclaration_1328 = R.whereEq({type: \"FunctionDeclaration\"});\n;\nconst isScript_1329 = R.whereEq({type: \"Script\"});\n;\nconst isSpreadElement_1330 = R.whereEq({type: \"SpreadElement\"});\n;\nconst isSuper_1331 = R.whereEq({type: \"Super\"});\n;\nconst isSwitchCase_1332 = R.whereEq({type: \"SwitchCase\"});\n;\nconst isSwitchDefault_1333 = R.whereEq({type: \"SwitchDefault\"});\n;\nconst isTemplateElement_1334 = R.whereEq({type: \"TemplateElement\"});\n;\nconst isSyntaxTemplate_1335 = R.whereEq({type: \"SyntaxTemplate\"});\n;\nconst isVariableDeclaration_1336 = R.whereEq({type: \"VariableDeclaration\"});\n;\nconst isVariableDeclarator_1337 = R.whereEq({type: \"VariableDeclarator\"});\n;\nconst isEOF_1338 = R.whereEq({type: \"EOF\"});\n;\nconst isSyntaxDeclaration_1339 = R.both(isVariableDeclaration_1336, R.whereEq({kind: \"syntax\"}));\n;\nconst isSyntaxrecDeclaration_1340 = R.both(isVariableDeclaration_1336, R.whereEq({kind: \"syntaxrec\"}));\n;\nconst isFunctionTerm_1341 = R.either(isFunctionDeclaration_1328, isFunctionExpression_1288);\n;\nconst isFunctionWithName_1342 = R.and(isFunctionTerm_1341, R.complement(R.where({name: R.isNil})));\n;\nconst isParenthesizedExpression_1343 = R.whereEq({type: \"ParenthesizedExpression\"});\n;\nconst isExportSyntax_1344 = R.both(isExport_1264, exp_1369 => R.or(isSyntaxDeclaration_1339(exp_1369.declaration), isSyntaxrecDeclaration_1340(exp_1369.declaration)));\n;\nconst isSyntaxDeclarationStatement_1345 = R.both(isVariableDeclarationStatement_1319, decl_1370 => isCompiletimeDeclaration_1346(decl_1370.declaration));\n;\nconst isCompiletimeDeclaration_1346 = R.either(isSyntaxDeclaration_1339, isSyntaxrecDeclaration_1340);\n;\nconst isCompiletimeStatement_1347 = term_1371 => {\n  return term_1371 instanceof Term && isVariableDeclarationStatement_1319(term_1371) && isCompiletimeDeclaration_1346(term_1371.declaration);\n};\n;\nconst isImportDeclaration_1348 = R.either(isImport_1259, isImportNamespace_1260);\n;\nexport {isBindingWithDefault_1249 as isBindingWithDefault};\nexport {isBindingIdentifier_1250 as isBindingIdentifier};\nexport {isArrayBinding_1251 as isArrayBinding};\nexport {isObjectBinding_1252 as isObjectBinding};\nexport {isBindingPropertyIdentifier_1253 as isBindingPropertyIdentifier};\nexport {isBindingPropertyProperty_1254 as isBindingPropertyProperty};\nexport {isClassExpression_1255 as isClassExpression};\nexport {isClassDeclaration_1256 as isClassDeclaration};\nexport {isClassElement_1257 as isClassElement};\nexport {isModule_1258 as isModule};\nexport {isImport_1259 as isImport};\nexport {isImportNamespace_1260 as isImportNamespace};\nexport {isImportSpecifier_1261 as isImportSpecifier};\nexport {isExportAllFrom_1262 as isExportAllFrom};\nexport {isExportFrom_1263 as isExportFrom};\nexport {isExport_1264 as isExport};\nexport {isExportDefault_1265 as isExportDefault};\nexport {isExportSpecifier_1266 as isExportSpecifier};\nexport {isMethod_1267 as isMethod};\nexport {isGetter_1268 as isGetter};\nexport {isSetter_1269 as isSetter};\nexport {isDataProperty_1270 as isDataProperty};\nexport {isShorthandProperty_1271 as isShorthandProperty};\nexport {isComputedPropertyName_1272 as isComputedPropertyName};\nexport {isStaticPropertyName_1273 as isStaticPropertyName};\nexport {isLiteralBooleanExpression_1274 as isLiteralBooleanExpression};\nexport {isLiteralInfinityExpression_1275 as isLiteralInfinityExpression};\nexport {isLiteralNullExpression_1276 as isLiteralNullExpression};\nexport {isLiteralNumericExpression_1277 as isLiteralNumericExpression};\nexport {isLiteralRegExpExpression_1278 as isLiteralRegExpExpression};\nexport {isLiteralStringExpression_1279 as isLiteralStringExpression};\nexport {isArrayExpression_1280 as isArrayExpression};\nexport {isArrowExpression_1281 as isArrowExpression};\nexport {isAssignmentExpression_1282 as isAssignmentExpression};\nexport {isBinaryExpression_1283 as isBinaryExpression};\nexport {isCallExpression_1284 as isCallExpression};\nexport {isComputedAssignmentExpression_1285 as isComputedAssignmentExpression};\nexport {isComputedMemberExpression_1286 as isComputedMemberExpression};\nexport {isConditionalExpression_1287 as isConditionalExpression};\nexport {isFunctionExpression_1288 as isFunctionExpression};\nexport {isIdentifierExpression_1289 as isIdentifierExpression};\nexport {isNewExpression_1290 as isNewExpression};\nexport {isNewTargetExpression_1291 as isNewTargetExpression};\nexport {isObjectExpression_1292 as isObjectExpression};\nexport {isUnaryExpression_1293 as isUnaryExpression};\nexport {isStaticMemberExpression_1294 as isStaticMemberExpression};\nexport {isTemplateExpression_1295 as isTemplateExpression};\nexport {isThisExpression_1296 as isThisExpression};\nexport {isUpdateExpression_1297 as isUpdateExpression};\nexport {isYieldExpression_1298 as isYieldExpression};\nexport {isYieldGeneratorExpression_1299 as isYieldGeneratorExpression};\nexport {isBlockStatement_1300 as isBlockStatement};\nexport {isBreakStatement_1301 as isBreakStatement};\nexport {isContinueStatement_1302 as isContinueStatement};\nexport {isCompoundAssignmentExpression_1303 as isCompoundAssignmentExpression};\nexport {isDebuggerStatement_1304 as isDebuggerStatement};\nexport {isDoWhileStatement_1305 as isDoWhileStatement};\nexport {isEmptyStatement_1306 as isEmptyStatement};\nexport {isExpressionStatement_1307 as isExpressionStatement};\nexport {isForInStatement_1308 as isForInStatement};\nexport {isForOfStatement_1309 as isForOfStatement};\nexport {isForStatement_1310 as isForStatement};\nexport {isIfStatement_1311 as isIfStatement};\nexport {isLabeledStatement_1312 as isLabeledStatement};\nexport {isReturnStatement_1313 as isReturnStatement};\nexport {isSwitchStatement_1314 as isSwitchStatement};\nexport {isSwitchStatementWithDefault_1315 as isSwitchStatementWithDefault};\nexport {isThrowStatement_1316 as isThrowStatement};\nexport {isTryCatchStatement_1317 as isTryCatchStatement};\nexport {isTryFinallyStatement_1318 as isTryFinallyStatement};\nexport {isVariableDeclarationStatement_1319 as isVariableDeclarationStatement};\nexport {isWhileStatement_1320 as isWhileStatement};\nexport {isWithStatement_1321 as isWithStatement};\nexport {isPragma_1322 as isPragma};\nexport {isBlock_1323 as isBlock};\nexport {isCatchClause_1324 as isCatchClause};\nexport {isDirective_1325 as isDirective};\nexport {isFormalParameters_1326 as isFormalParameters};\nexport {isFunctionBody_1327 as isFunctionBody};\nexport {isFunctionDeclaration_1328 as isFunctionDeclaration};\nexport {isScript_1329 as isScript};\nexport {isSpreadElement_1330 as isSpreadElement};\nexport {isSuper_1331 as isSuper};\nexport {isSwitchCase_1332 as isSwitchCase};\nexport {isSwitchDefault_1333 as isSwitchDefault};\nexport {isTemplateElement_1334 as isTemplateElement};\nexport {isSyntaxTemplate_1335 as isSyntaxTemplate};\nexport {isVariableDeclaration_1336 as isVariableDeclaration};\nexport {isVariableDeclarator_1337 as isVariableDeclarator};\nexport {isEOF_1338 as isEOF};\nexport {isSyntaxDeclaration_1339 as isSyntaxDeclaration};\nexport {isSyntaxrecDeclaration_1340 as isSyntaxrecDeclaration};\nexport {isFunctionTerm_1341 as isFunctionTerm};\nexport {isFunctionWithName_1342 as isFunctionWithName};\nexport {isParenthesizedExpression_1343 as isParenthesizedExpression};\nexport {isExportSyntax_1344 as isExportSyntax};\nexport {isSyntaxDeclarationStatement_1345 as isSyntaxDeclarationStatement};\nexport {isCompiletimeDeclaration_1346 as isCompiletimeDeclaration};\nexport {isCompiletimeStatement_1347 as isCompiletimeStatement};\nexport {isImportDeclaration_1348 as isImportDeclaration}"]} - -/***/ }, -/* 29 */ -/***/ function(module, exports) { - - "use strict"; - Object.defineProperty(exports, "__esModule", { - value: true - }); - function mixin_1457(target_1458, source_1459) { - class F extends target_1458 {} - Object.getOwnPropertyNames(source_1459.prototype).forEach(name_1460 => { - if (name_1460 !== "constructor") { - let newProp = Object.getOwnPropertyDescriptor(source_1459.prototype, name_1460); - Object.defineProperty(F.prototype, name_1460, newProp); - } - }); - return F; - } - exports.mixin = mixin_1457; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L3V0aWxzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsU0FBUyxVQUFULENBQW9CLFdBQXBCLEVBQWlDLFdBQWpDLEVBQThDO0FBQzVDLFFBQU0sQ0FBTixTQUFnQixXQUFoQixDQUE0QjtBQUM1QixTQUFPLG1CQUFQLENBQTJCLFlBQVksU0FBdkMsRUFBa0QsT0FBbEQsQ0FBMEQsYUFBYTtBQUNyRSxRQUFJLGNBQWMsYUFBbEIsRUFBaUM7QUFDL0IsVUFBSSxVQUFVLE9BQU8sd0JBQVAsQ0FBZ0MsWUFBWSxTQUE1QyxFQUF1RCxTQUF2RCxDQUFkO0FBQ0EsYUFBTyxjQUFQLENBQXNCLEVBQUUsU0FBeEIsRUFBbUMsU0FBbkMsRUFBOEMsT0FBOUM7QUFDRDtBQUNGLEdBTEQ7QUFNQSxTQUFPLENBQVA7QUFDRDtRQUNxQixLLEdBQWQsVSIsImZpbGUiOiJ1dGlscy5qcyIsInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIG1peGluXzE0NTcodGFyZ2V0XzE0NTgsIHNvdXJjZV8xNDU5KSB7XG4gIGNsYXNzIEYgZXh0ZW5kcyB0YXJnZXRfMTQ1OCB7fVxuICBPYmplY3QuZ2V0T3duUHJvcGVydHlOYW1lcyhzb3VyY2VfMTQ1OS5wcm90b3R5cGUpLmZvckVhY2gobmFtZV8xNDYwID0+IHtcbiAgICBpZiAobmFtZV8xNDYwICE9PSBcImNvbnN0cnVjdG9yXCIpIHtcbiAgICAgIGxldCBuZXdQcm9wID0gT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcihzb3VyY2VfMTQ1OS5wcm90b3R5cGUsIG5hbWVfMTQ2MCk7XG4gICAgICBPYmplY3QuZGVmaW5lUHJvcGVydHkoRi5wcm90b3R5cGUsIG5hbWVfMTQ2MCwgbmV3UHJvcCk7XG4gICAgfVxuICB9KTtcbiAgcmV0dXJuIEY7XG59XG5leHBvcnQge21peGluXzE0NTcgYXMgbWl4aW59Il19 + /** + * Returns a new object that does not contain a `prop` property. + * + * @func + * @memberOf R + * @category Object + * @sig String -> {k: v} -> {k: v} + * @param {String} prop the name of the property to dissociate + * @param {Object} obj the object to clone + * @return {Object} a new object similar to the original but without the specified property + * @see R.assoc + * @example + * + * R.dissoc('b', {a: 1, b: 2, c: 3}); //=> {a: 1, c: 3} + */ + var dissoc = _curry2(function dissoc(prop, obj) { + var result = {}; + for (var p in obj) { + if (p !== prop) { + result[p] = obj[p]; + } + } + return result; + }); -/***/ }, -/* 30 */ -/***/ function(module, exports) { + /** + * Makes a shallow clone of an object, omitting the property at the + * given path. Note that this copies and flattens prototype properties + * onto the new object as well. All non-primitive properties are copied + * by reference. + * + * @func + * @memberOf R + * @category Object + * @sig [String] -> {k: v} -> {k: v} + * @param {Array} path the path to set + * @param {Object} obj the object to clone + * @return {Object} a new object without the property at path + * @see R.assocPath + * @example + * + * R.dissocPath(['a', 'b', 'c'], {a: {b: {c: 42}}}); //=> {a: {b: {}}} + */ + var dissocPath = _curry2(function dissocPath(path, obj) { + switch (path.length) { + case 0: + return obj; + case 1: + return dissoc(path[0], obj); + default: + var head = path[0]; + var tail = _slice(path, 1); + return obj[head] == null ? obj : assoc(head, dissocPath(tail, obj[head]), obj); + } + }); - "use strict"; + /** + * Divides two numbers. Equivalent to `a / b`. + * + * @func + * @memberOf R + * @category Math + * @sig Number -> Number -> Number + * @param {Number} a The first value. + * @param {Number} b The second value. + * @return {Number} The result of `a / b`. + * @see R.multiply + * @example + * + * R.divide(71, 100); //=> 0.71 + * + * var half = R.divide(R.__, 2); + * half(42); //=> 21 + * + * var reciprocal = R.divide(1); + * reciprocal(4); //=> 0.25 + */ + var divide = _curry2(function divide(a, b) { + return a / b; + }); - Object.defineProperty(exports, "__esModule", { - value: true - }); - const Term_1157 = Object.create(Object.prototype, { spec: { value: {}, writable: true, configurable: false, enumerable: true }, fields: { value: [], writable: false, configurable: false, enumerable: true } }); - const BindingWithDefault_1158 = Object.create(Term_1157, { fields: { value: ["binding", "init"], writable: false, configurable: false, enumerable: true } }); - BindingWithDefault_1158.spec.BindingWithDefault = BindingWithDefault_1158; - const BindingIdentifier_1159 = Object.create(Term_1157, { fields: { value: ["name"], writable: false, configurable: false, enumerable: true } }); - BindingIdentifier_1159.spec.BindingIdentifier = BindingIdentifier_1159; - const ArrayBinding_1160 = Object.create(Term_1157, { fields: { value: ["elements", "restElement"], writable: false, configurable: false, enumerable: true } }); - ArrayBinding_1160.spec.ArrayBinding = ArrayBinding_1160; - const ObjectBinding_1161 = Object.create(Term_1157, { fields: { value: ["properties"], writable: false, configurable: false, enumerable: true } }); - ObjectBinding_1161.spec.ObjectBinding = ObjectBinding_1161; - const BindingPropertyIdentifier_1162 = Object.create(Term_1157, { fields: { value: ["binding", "init"], writable: false, configurable: false, enumerable: true } }); - BindingPropertyIdentifier_1162.spec.BindingPropertyIdentifier = BindingPropertyIdentifier_1162; - const BindingPropertyProperty_1163 = Object.create(Term_1157, { fields: { value: ["name", "binding"], writable: false, configurable: false, enumerable: true } }); - BindingPropertyProperty_1163.spec.BindingPropertyProperty = BindingPropertyProperty_1163; - const Statement_1164 = Object.create(Term_1157, { fields: { value: [], writable: false, configurable: false, enumerable: true } }); - Statement_1164.spec.Statement = Statement_1164; - const Expression_1165 = Object.create(Term_1157, { fields: { value: [], writable: false, configurable: false, enumerable: true } }); - Expression_1165.spec.Expression = Expression_1165; - const ClassExpression_1166 = Object.create(Expression_1165, { fields: { value: ["name", "super", "elements"], writable: false, configurable: false, enumerable: true } }); - ClassExpression_1166.spec.ClassExpression = ClassExpression_1166; - const ClassDeclaration_1167 = Object.create(Statement_1164, { fields: { value: ["name", "super", "elements"], writable: false, configurable: false, enumerable: true } }); - ClassDeclaration_1167.spec.ClassDeclaration = ClassDeclaration_1167; - const ClassElement_1168 = Object.create(Term_1157, { fields: { value: ["isStatic", "method"], writable: false, configurable: false, enumerable: true } }); - ClassElement_1168.spec.ClassElement = ClassElement_1168; - const Module_1169 = Object.create(Term_1157, { fields: { value: ["directives", "items"], writable: false, configurable: false, enumerable: true } }); - Module_1169.spec.Module = Module_1169; - const Import_1170 = Object.create(Term_1157, { fields: { value: ["moduleSpecifier", "defaultBinding", "namedImports", "forSyntax"], writable: false, configurable: false, enumerable: true } }); - Import_1170.spec.Import = Import_1170; - const ImportNamespace_1171 = Object.create(Term_1157, { fields: { value: ["moduleSpecifier", "defaultBinding", "namespaceBinding"], writable: false, configurable: false, enumerable: true } }); - ImportNamespace_1171.spec.ImportNamespace = ImportNamespace_1171; - const ImportSpecifier_1172 = Object.create(Term_1157, { fields: { value: ["name", "binding"], writable: false, configurable: false, enumerable: true } }); - ImportSpecifier_1172.spec.ImportSpecifier = ImportSpecifier_1172; - const ExportAllFrom_1173 = Object.create(Term_1157, { fields: { value: ["moduleSpecifier"], writable: false, configurable: false, enumerable: true } }); - ExportAllFrom_1173.spec.ExportAllFrom = ExportAllFrom_1173; - const ExportFrom_1174 = Object.create(Term_1157, { fields: { value: ["namedExports", "moduleSpecifier"], writable: false, configurable: false, enumerable: true } }); - ExportFrom_1174.spec.ExportFrom = ExportFrom_1174; - const Export_1175 = Object.create(Term_1157, { fields: { value: ["declaration"], writable: false, configurable: false, enumerable: true } }); - Export_1175.spec.Export = Export_1175; - const ExportDefault_1176 = Object.create(Term_1157, { fields: { value: ["body"], writable: false, configurable: false, enumerable: true } }); - ExportDefault_1176.spec.ExportDefault = ExportDefault_1176; - const ExportSpecifier_1177 = Object.create(Term_1157, { fields: { value: ["name", "exportedName"], writable: false, configurable: false, enumerable: true } }); - ExportSpecifier_1177.spec.ExportSpecifier = ExportSpecifier_1177; - const Method_1178 = Object.create(Term_1157, { fields: { value: ["name", "body", "isGenerator", "params"], writable: false, configurable: false, enumerable: true } }); - Method_1178.spec.Method = Method_1178; - const Getter_1179 = Object.create(Term_1157, { fields: { value: ["name", "body"], writable: false, configurable: false, enumerable: true } }); - Getter_1179.spec.Getter = Getter_1179; - const Setter_1180 = Object.create(Term_1157, { fields: { value: ["name", "body", "param"], writable: false, configurable: false, enumerable: true } }); - Setter_1180.spec.Setter = Setter_1180; - const DataProperty_1181 = Object.create(Term_1157, { fields: { value: ["name", "expression"], writable: false, configurable: false, enumerable: true } }); - DataProperty_1181.spec.DataProperty = DataProperty_1181; - const ShorthandProperty_1182 = Object.create(Term_1157, { fields: { value: ["expression"], writable: false, configurable: false, enumerable: true } }); - ShorthandProperty_1182.spec.ShorthandProperty = ShorthandProperty_1182; - const StaticPropertyName_1183 = Object.create(Term_1157, { fields: { value: ["value"], writable: false, configurable: false, enumerable: true } }); - StaticPropertyName_1183.spec.StaticPropertyName = StaticPropertyName_1183; - const LiteralBooleanExpression_1184 = Object.create(Expression_1165, { fields: { value: ["value"], writable: false, configurable: false, enumerable: true } }); - LiteralBooleanExpression_1184.spec.LiteralBooleanExpression = LiteralBooleanExpression_1184; - const LiteralInfinityExpression_1185 = Object.create(Expression_1165, { fields: { value: [], writable: false, configurable: false, enumerable: true } }); - LiteralInfinityExpression_1185.spec.LiteralInfinityExpression = LiteralInfinityExpression_1185; - const LiteralNullExpression_1186 = Object.create(Expression_1165, { fields: { value: [], writable: false, configurable: false, enumerable: true } }); - LiteralNullExpression_1186.spec.LiteralNullExpression = LiteralNullExpression_1186; - const LiteralNumericExpression_1187 = Object.create(Expression_1165, { fields: { value: ["value"], writable: false, configurable: false, enumerable: true } }); - LiteralNumericExpression_1187.spec.LiteralNumericExpression = LiteralNumericExpression_1187; - const LiteralRegExpExpression_1188 = Object.create(Expression_1165, { fields: { value: ["pattern", "flags"], writable: false, configurable: false, enumerable: true } }); - LiteralRegExpExpression_1188.spec.LiteralRegExpExpression = LiteralRegExpExpression_1188; - const LiteralStringExpression_1189 = Object.create(Expression_1165, { fields: { value: ["value"], writable: false, configurable: false, enumerable: true } }); - LiteralStringExpression_1189.spec.LiteralStringExpression = LiteralStringExpression_1189; - const ArrayExpression_1190 = Object.create(Expression_1165, { fields: { value: ["elements"], writable: false, configurable: false, enumerable: true } }); - ArrayExpression_1190.spec.ArrayExpression = ArrayExpression_1190; - const ArrowExpression_1191 = Object.create(Expression_1165, { fields: { value: ["params", "body"], writable: false, configurable: false, enumerable: true } }); - ArrowExpression_1191.spec.ArrowExpression = ArrowExpression_1191; - const AssignmentExpression_1192 = Object.create(Expression_1165, { fields: { value: ["binding", "expression"], writable: false, configurable: false, enumerable: true } }); - AssignmentExpression_1192.spec.AssignmentExpression = AssignmentExpression_1192; - const BinaryExpression_1193 = Object.create(Expression_1165, { fields: { value: ["operator", "left", "right"], writable: false, configurable: false, enumerable: true } }); - BinaryExpression_1193.spec.BinaryExpression = BinaryExpression_1193; - const CallExpression_1194 = Object.create(Expression_1165, { fields: { value: ["callee", "arguments"], writable: false, configurable: false, enumerable: true } }); - CallExpression_1194.spec.CallExpression = CallExpression_1194; - const ComputedAssignmentExpression_1195 = Object.create(Expression_1165, { fields: { value: ["operator", "binding", "expression"], writable: false, configurable: false, enumerable: true } }); - ComputedAssignmentExpression_1195.spec.ComputedAssignmentExpression = ComputedAssignmentExpression_1195; - const ComputedMemberExpression_1196 = Object.create(Expression_1165, { fields: { value: ["object", "expression"], writable: false, configurable: false, enumerable: true } }); - ComputedMemberExpression_1196.spec.ComputedMemberExpression = ComputedMemberExpression_1196; - const ConditionalExpression_1197 = Object.create(Expression_1165, { fields: { value: ["test", "consequent", "alternate"], writable: false, configurable: false, enumerable: true } }); - ConditionalExpression_1197.spec.ConditionalExpression = ConditionalExpression_1197; - const FunctionExpression_1198 = Object.create(Expression_1165, { fields: { value: ["name", "isGenerator", "params", "body"], writable: false, configurable: false, enumerable: true } }); - FunctionExpression_1198.spec.FunctionExpression = FunctionExpression_1198; - const IdentifierExpression_1199 = Object.create(Expression_1165, { fields: { value: ["name"], writable: false, configurable: false, enumerable: true } }); - IdentifierExpression_1199.spec.IdentifierExpression = IdentifierExpression_1199; - const NewExpression_1200 = Object.create(Expression_1165, { fields: { value: ["callee", "arguments"], writable: false, configurable: false, enumerable: true } }); - NewExpression_1200.spec.NewExpression = NewExpression_1200; - const NewTargetExpression_1201 = Object.create(Expression_1165, { fields: { value: [], writable: false, configurable: false, enumerable: true } }); - NewTargetExpression_1201.spec.NewTargetExpression = NewTargetExpression_1201; - const ObjectExpression_1202 = Object.create(Expression_1165, { fields: { value: ["properties"], writable: false, configurable: false, enumerable: true } }); - ObjectExpression_1202.spec.ObjectExpression = ObjectExpression_1202; - const UnaryExpression_1203 = Object.create(Expression_1165, { fields: { value: ["operator", "operand"], writable: false, configurable: false, enumerable: true } }); - UnaryExpression_1203.spec.UnaryExpression = UnaryExpression_1203; - const StaticMemberExpression_1204 = Object.create(Expression_1165, { fields: { value: ["object", "property"], writable: false, configurable: false, enumerable: true } }); - StaticMemberExpression_1204.spec.StaticMemberExpression = StaticMemberExpression_1204; - const TemplateExpression_1205 = Object.create(Expression_1165, { fields: { value: ["tag", "elements"], writable: false, configurable: false, enumerable: true } }); - TemplateExpression_1205.spec.TemplateExpression = TemplateExpression_1205; - const ThisExpression_1206 = Object.create(Expression_1165, { fields: { value: [], writable: false, configurable: false, enumerable: true } }); - ThisExpression_1206.spec.ThisExpression = ThisExpression_1206; - const UpdateExpression_1207 = Object.create(Expression_1165, { fields: { value: ["isPrefix", "operator", "operand"], writable: false, configurable: false, enumerable: true } }); - UpdateExpression_1207.spec.UpdateExpression = UpdateExpression_1207; - const YieldExpression_1208 = Object.create(Expression_1165, { fields: { value: ["expression"], writable: false, configurable: false, enumerable: true } }); - YieldExpression_1208.spec.YieldExpression = YieldExpression_1208; - const YieldGeneratorExpression_1209 = Object.create(Expression_1165, { fields: { value: ["expression"], writable: false, configurable: false, enumerable: true } }); - YieldGeneratorExpression_1209.spec.YieldGeneratorExpression = YieldGeneratorExpression_1209; - const ParenthesizedExpression_1210 = Object.create(Expression_1165, { fields: { value: ["inner"], writable: false, configurable: false, enumerable: true } }); - ParenthesizedExpression_1210.spec.ParenthesizedExpression = ParenthesizedExpression_1210; - const BlockStatement_1211 = Object.create(Statement_1164, { fields: { value: ["block"], writable: false, configurable: false, enumerable: true } }); - BlockStatement_1211.spec.BlockStatement = BlockStatement_1211; - const BreakStatement_1212 = Object.create(Statement_1164, { fields: { value: ["label"], writable: false, configurable: false, enumerable: true } }); - BreakStatement_1212.spec.BreakStatement = BreakStatement_1212; - const ContinueStatement_1213 = Object.create(Statement_1164, { fields: { value: ["label"], writable: false, configurable: false, enumerable: true } }); - ContinueStatement_1213.spec.ContinueStatement = ContinueStatement_1213; - const CompoundAssignmentExpression_1214 = Object.create(Statement_1164, { fields: { value: ["binding", "operator", "expression"], writable: false, configurable: false, enumerable: true } }); - CompoundAssignmentExpression_1214.spec.CompoundAssignmentExpression = CompoundAssignmentExpression_1214; - const DebuggerStatement_1215 = Object.create(Statement_1164, { fields: { value: [], writable: false, configurable: false, enumerable: true } }); - DebuggerStatement_1215.spec.DebuggerStatement = DebuggerStatement_1215; - const DoWhileStatement_1216 = Object.create(Statement_1164, { fields: { value: ["test", "body"], writable: false, configurable: false, enumerable: true } }); - DoWhileStatement_1216.spec.DoWhileStatement = DoWhileStatement_1216; - const EmptyStatement_1217 = Object.create(Statement_1164, { fields: { value: [], writable: false, configurable: false, enumerable: true } }); - EmptyStatement_1217.spec.EmptyStatement = EmptyStatement_1217; - const ExpressionStatement_1218 = Object.create(Statement_1164, { fields: { value: ["expression"], writable: false, configurable: false, enumerable: true } }); - ExpressionStatement_1218.spec.ExpressionStatement = ExpressionStatement_1218; - const ForInStatement_1219 = Object.create(Statement_1164, { fields: { value: ["left", "right", "body"], writable: false, configurable: false, enumerable: true } }); - ForInStatement_1219.spec.ForInStatement = ForInStatement_1219; - const ForOfStatement_1220 = Object.create(Statement_1164, { fields: { value: ["left", "right", "body"], writable: false, configurable: false, enumerable: true } }); - ForOfStatement_1220.spec.ForOfStatement = ForOfStatement_1220; - const ForStatement_1221 = Object.create(Statement_1164, { fields: { value: ["init", "test", "update", "body"], writable: false, configurable: false, enumerable: true } }); - ForStatement_1221.spec.ForStatement = ForStatement_1221; - const IfStatement_1222 = Object.create(Statement_1164, { fields: { value: ["test", "consequent", "alternate"], writable: false, configurable: false, enumerable: true } }); - IfStatement_1222.spec.IfStatement = IfStatement_1222; - const LabeledStatement_1223 = Object.create(Statement_1164, { fields: { value: ["label", "body"], writable: false, configurable: false, enumerable: true } }); - LabeledStatement_1223.spec.LabeledStatement = LabeledStatement_1223; - const ReturnStatement_1224 = Object.create(Statement_1164, { fields: { value: ["expression"], writable: false, configurable: false, enumerable: true } }); - ReturnStatement_1224.spec.ReturnStatement = ReturnStatement_1224; - const SwitchStatement_1225 = Object.create(Statement_1164, { fields: { value: ["discriminant", "cases"], writable: false, configurable: false, enumerable: true } }); - SwitchStatement_1225.spec.SwitchStatement = SwitchStatement_1225; - const SwitchStatementWithDefault_1226 = Object.create(Statement_1164, { fields: { value: ["discriminant", "preDefaultCases", "defaultCase", "postDefaultCases"], writable: false, configurable: false, enumerable: true } }); - SwitchStatementWithDefault_1226.spec.SwitchStatementWithDefault = SwitchStatementWithDefault_1226; - const ThrowStatement_1227 = Object.create(Statement_1164, { fields: { value: ["expression"], writable: false, configurable: false, enumerable: true } }); - ThrowStatement_1227.spec.ThrowStatement = ThrowStatement_1227; - const TryCatchStatement_1228 = Object.create(Statement_1164, { fields: { value: ["body", "catchClause"], writable: false, configurable: false, enumerable: true } }); - TryCatchStatement_1228.spec.TryCatchStatement = TryCatchStatement_1228; - const TryFinallyStatement_1229 = Object.create(Statement_1164, { fields: { value: ["body", "catchClause", "finalizer"], writable: false, configurable: false, enumerable: true } }); - TryFinallyStatement_1229.spec.TryFinallyStatement = TryFinallyStatement_1229; - const VariableDeclarationStatement_1230 = Object.create(Statement_1164, { fields: { value: ["declaration"], writable: false, configurable: false, enumerable: true } }); - VariableDeclarationStatement_1230.spec.VariableDeclarationStatement = VariableDeclarationStatement_1230; - const WithStatement_1231 = Object.create(Statement_1164, { fields: { value: ["object", "body"], writable: false, configurable: false, enumerable: true } }); - WithStatement_1231.spec.WithStatement = WithStatement_1231; - const WhileStatement_1232 = Object.create(Statement_1164, { fields: { value: ["test", "body"], writable: false, configurable: false, enumerable: true } }); - WhileStatement_1232.spec.WhileStatement = WhileStatement_1232; - const Pragma_1233 = Object.create(Term_1157, { fields: { value: ["kind", "items"], writable: false, configurable: false, enumerable: true } }); - Pragma_1233.spec.Pragma = Pragma_1233; - const Block_1234 = Object.create(Term_1157, { fields: { value: ["statements"], writable: false, configurable: false, enumerable: true } }); - Block_1234.spec.Block = Block_1234; - const CatchClause_1235 = Object.create(Term_1157, { fields: { value: ["binding", "body"], writable: false, configurable: false, enumerable: true } }); - CatchClause_1235.spec.CatchClause = CatchClause_1235; - const Directive_1236 = Object.create(Term_1157, { fields: { value: ["rawValue"], writable: false, configurable: false, enumerable: true } }); - Directive_1236.spec.Directive = Directive_1236; - const FormalParameters_1237 = Object.create(Term_1157, { fields: { value: ["items", "rest"], writable: false, configurable: false, enumerable: true } }); - FormalParameters_1237.spec.FormalParameters = FormalParameters_1237; - const FunctionBody_1238 = Object.create(Term_1157, { fields: { value: ["directives", "statements"], writable: false, configurable: false, enumerable: true } }); - FunctionBody_1238.spec.FunctionBody = FunctionBody_1238; - const FunctionDeclaration_1239 = Object.create(Statement_1164, { fields: { value: ["name", "isGenerator", "params", "body"], writable: false, configurable: false, enumerable: true } }); - FunctionDeclaration_1239.spec.FunctionDeclaration = FunctionDeclaration_1239; - const Script_1240 = Object.create(Term_1157, { fields: { value: ["directives", "statements"], writable: false, configurable: false, enumerable: true } }); - Script_1240.spec.Script = Script_1240; - const SpreadElement_1241 = Object.create(Term_1157, { fields: { value: ["expression"], writable: false, configurable: false, enumerable: true } }); - SpreadElement_1241.spec.SpreadElement = SpreadElement_1241; - const Super_1242 = Object.create(Term_1157, { fields: { value: [], writable: false, configurable: false, enumerable: true } }); - Super_1242.spec.Super = Super_1242; - const SwitchCase_1243 = Object.create(Term_1157, { fields: { value: ["test", "consequent"], writable: false, configurable: false, enumerable: true } }); - SwitchCase_1243.spec.SwitchCase = SwitchCase_1243; - const SwitchDefault_1244 = Object.create(Term_1157, { fields: { value: ["consequent"], writable: false, configurable: false, enumerable: true } }); - SwitchDefault_1244.spec.SwitchDefault = SwitchDefault_1244; - const TemplateElement_1245 = Object.create(Term_1157, { fields: { value: ["rawValue"], writable: false, configurable: false, enumerable: true } }); - TemplateElement_1245.spec.TemplateElement = TemplateElement_1245; - const SyntaxTemplate_1246 = Object.create(Term_1157, { fields: { value: ["template"], writable: false, configurable: false, enumerable: true } }); - SyntaxTemplate_1246.spec.SyntaxTemplate = SyntaxTemplate_1246; - const VariableDeclaration_1247 = Object.create(Term_1157, { fields: { value: ["kind", "declarators"], writable: false, configurable: false, enumerable: true } }); - VariableDeclaration_1247.spec.VariableDeclaration = VariableDeclaration_1247; - const VariableDeclarator_1248 = Object.create(Term_1157, { fields: { value: ["binding", "init"], writable: false, configurable: false, enumerable: true } }); - VariableDeclarator_1248.spec.VariableDeclarator = VariableDeclarator_1248; - exports.default = Term_1157; - //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/term-spec.js"],"names":[],"mappings":"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","file":"term-spec.js","sourcesContent":["const Term_1157 = Object.create(Object.prototype, {spec: {value: {}, writable: true, configurable: false, enumerable: true}, fields: {value: [], writable: false, configurable: false, enumerable: true}});\nconst BindingWithDefault_1158 = Object.create(Term_1157, {fields: {value: [\"binding\", \"init\"], writable: false, configurable: false, enumerable: true}});\nBindingWithDefault_1158.spec.BindingWithDefault = BindingWithDefault_1158;\nconst BindingIdentifier_1159 = Object.create(Term_1157, {fields: {value: [\"name\"], writable: false, configurable: false, enumerable: true}});\nBindingIdentifier_1159.spec.BindingIdentifier = BindingIdentifier_1159;\nconst ArrayBinding_1160 = Object.create(Term_1157, {fields: {value: [\"elements\", \"restElement\"], writable: false, configurable: false, enumerable: true}});\nArrayBinding_1160.spec.ArrayBinding = ArrayBinding_1160;\nconst ObjectBinding_1161 = Object.create(Term_1157, {fields: {value: [\"properties\"], writable: false, configurable: false, enumerable: true}});\nObjectBinding_1161.spec.ObjectBinding = ObjectBinding_1161;\nconst BindingPropertyIdentifier_1162 = Object.create(Term_1157, {fields: {value: [\"binding\", \"init\"], writable: false, configurable: false, enumerable: true}});\nBindingPropertyIdentifier_1162.spec.BindingPropertyIdentifier = BindingPropertyIdentifier_1162;\nconst BindingPropertyProperty_1163 = Object.create(Term_1157, {fields: {value: [\"name\", \"binding\"], writable: false, configurable: false, enumerable: true}});\nBindingPropertyProperty_1163.spec.BindingPropertyProperty = BindingPropertyProperty_1163;\nconst Statement_1164 = Object.create(Term_1157, {fields: {value: [], writable: false, configurable: false, enumerable: true}});\nStatement_1164.spec.Statement = Statement_1164;\nconst Expression_1165 = Object.create(Term_1157, {fields: {value: [], writable: false, configurable: false, enumerable: true}});\nExpression_1165.spec.Expression = Expression_1165;\nconst ClassExpression_1166 = Object.create(Expression_1165, {fields: {value: [\"name\", \"super\", \"elements\"], writable: false, configurable: false, enumerable: true}});\nClassExpression_1166.spec.ClassExpression = ClassExpression_1166;\nconst ClassDeclaration_1167 = Object.create(Statement_1164, {fields: {value: [\"name\", \"super\", \"elements\"], writable: false, configurable: false, enumerable: true}});\nClassDeclaration_1167.spec.ClassDeclaration = ClassDeclaration_1167;\nconst ClassElement_1168 = Object.create(Term_1157, {fields: {value: [\"isStatic\", \"method\"], writable: false, configurable: false, enumerable: true}});\nClassElement_1168.spec.ClassElement = ClassElement_1168;\nconst Module_1169 = Object.create(Term_1157, {fields: {value: [\"directives\", \"items\"], writable: false, configurable: false, enumerable: true}});\nModule_1169.spec.Module = Module_1169;\nconst Import_1170 = Object.create(Term_1157, {fields: {value: [\"moduleSpecifier\", \"defaultBinding\", \"namedImports\", \"forSyntax\"], writable: false, configurable: false, enumerable: true}});\nImport_1170.spec.Import = Import_1170;\nconst ImportNamespace_1171 = Object.create(Term_1157, {fields: {value: [\"moduleSpecifier\", \"defaultBinding\", \"namespaceBinding\"], writable: false, configurable: false, enumerable: true}});\nImportNamespace_1171.spec.ImportNamespace = ImportNamespace_1171;\nconst ImportSpecifier_1172 = Object.create(Term_1157, {fields: {value: [\"name\", \"binding\"], writable: false, configurable: false, enumerable: true}});\nImportSpecifier_1172.spec.ImportSpecifier = ImportSpecifier_1172;\nconst ExportAllFrom_1173 = Object.create(Term_1157, {fields: {value: [\"moduleSpecifier\"], writable: false, configurable: false, enumerable: true}});\nExportAllFrom_1173.spec.ExportAllFrom = ExportAllFrom_1173;\nconst ExportFrom_1174 = Object.create(Term_1157, {fields: {value: [\"namedExports\", \"moduleSpecifier\"], writable: false, configurable: false, enumerable: true}});\nExportFrom_1174.spec.ExportFrom = ExportFrom_1174;\nconst Export_1175 = Object.create(Term_1157, {fields: {value: [\"declaration\"], writable: false, configurable: false, enumerable: true}});\nExport_1175.spec.Export = Export_1175;\nconst ExportDefault_1176 = Object.create(Term_1157, {fields: {value: [\"body\"], writable: false, configurable: false, enumerable: true}});\nExportDefault_1176.spec.ExportDefault = ExportDefault_1176;\nconst ExportSpecifier_1177 = Object.create(Term_1157, {fields: {value: [\"name\", \"exportedName\"], writable: false, configurable: false, enumerable: true}});\nExportSpecifier_1177.spec.ExportSpecifier = ExportSpecifier_1177;\nconst Method_1178 = Object.create(Term_1157, {fields: {value: [\"name\", \"body\", \"isGenerator\", \"params\"], writable: false, configurable: false, enumerable: true}});\nMethod_1178.spec.Method = Method_1178;\nconst Getter_1179 = Object.create(Term_1157, {fields: {value: [\"name\", \"body\"], writable: false, configurable: false, enumerable: true}});\nGetter_1179.spec.Getter = Getter_1179;\nconst Setter_1180 = Object.create(Term_1157, {fields: {value: [\"name\", \"body\", \"param\"], writable: false, configurable: false, enumerable: true}});\nSetter_1180.spec.Setter = Setter_1180;\nconst DataProperty_1181 = Object.create(Term_1157, {fields: {value: [\"name\", \"expression\"], writable: false, configurable: false, enumerable: true}});\nDataProperty_1181.spec.DataProperty = DataProperty_1181;\nconst ShorthandProperty_1182 = Object.create(Term_1157, {fields: {value: [\"expression\"], writable: false, configurable: false, enumerable: true}});\nShorthandProperty_1182.spec.ShorthandProperty = ShorthandProperty_1182;\nconst StaticPropertyName_1183 = Object.create(Term_1157, {fields: {value: [\"value\"], writable: false, configurable: false, enumerable: true}});\nStaticPropertyName_1183.spec.StaticPropertyName = StaticPropertyName_1183;\nconst LiteralBooleanExpression_1184 = Object.create(Expression_1165, {fields: {value: [\"value\"], writable: false, configurable: false, enumerable: true}});\nLiteralBooleanExpression_1184.spec.LiteralBooleanExpression = LiteralBooleanExpression_1184;\nconst LiteralInfinityExpression_1185 = Object.create(Expression_1165, {fields: {value: [], writable: false, configurable: false, enumerable: true}});\nLiteralInfinityExpression_1185.spec.LiteralInfinityExpression = LiteralInfinityExpression_1185;\nconst LiteralNullExpression_1186 = Object.create(Expression_1165, {fields: {value: [], writable: false, configurable: false, enumerable: true}});\nLiteralNullExpression_1186.spec.LiteralNullExpression = LiteralNullExpression_1186;\nconst LiteralNumericExpression_1187 = Object.create(Expression_1165, {fields: {value: [\"value\"], writable: false, configurable: false, enumerable: true}});\nLiteralNumericExpression_1187.spec.LiteralNumericExpression = LiteralNumericExpression_1187;\nconst LiteralRegExpExpression_1188 = Object.create(Expression_1165, {fields: {value: [\"pattern\", \"flags\"], writable: false, configurable: false, enumerable: true}});\nLiteralRegExpExpression_1188.spec.LiteralRegExpExpression = LiteralRegExpExpression_1188;\nconst LiteralStringExpression_1189 = Object.create(Expression_1165, {fields: {value: [\"value\"], writable: false, configurable: false, enumerable: true}});\nLiteralStringExpression_1189.spec.LiteralStringExpression = LiteralStringExpression_1189;\nconst ArrayExpression_1190 = Object.create(Expression_1165, {fields: {value: [\"elements\"], writable: false, configurable: false, enumerable: true}});\nArrayExpression_1190.spec.ArrayExpression = ArrayExpression_1190;\nconst ArrowExpression_1191 = Object.create(Expression_1165, {fields: {value: [\"params\", \"body\"], writable: false, configurable: false, enumerable: true}});\nArrowExpression_1191.spec.ArrowExpression = ArrowExpression_1191;\nconst AssignmentExpression_1192 = Object.create(Expression_1165, {fields: {value: [\"binding\", \"expression\"], writable: false, configurable: false, enumerable: true}});\nAssignmentExpression_1192.spec.AssignmentExpression = AssignmentExpression_1192;\nconst BinaryExpression_1193 = Object.create(Expression_1165, {fields: {value: [\"operator\", \"left\", \"right\"], writable: false, configurable: false, enumerable: true}});\nBinaryExpression_1193.spec.BinaryExpression = BinaryExpression_1193;\nconst CallExpression_1194 = Object.create(Expression_1165, {fields: {value: [\"callee\", \"arguments\"], writable: false, configurable: false, enumerable: true}});\nCallExpression_1194.spec.CallExpression = CallExpression_1194;\nconst ComputedAssignmentExpression_1195 = Object.create(Expression_1165, {fields: {value: [\"operator\", \"binding\", \"expression\"], writable: false, configurable: false, enumerable: true}});\nComputedAssignmentExpression_1195.spec.ComputedAssignmentExpression = ComputedAssignmentExpression_1195;\nconst ComputedMemberExpression_1196 = Object.create(Expression_1165, {fields: {value: [\"object\", \"expression\"], writable: false, configurable: false, enumerable: true}});\nComputedMemberExpression_1196.spec.ComputedMemberExpression = ComputedMemberExpression_1196;\nconst ConditionalExpression_1197 = Object.create(Expression_1165, {fields: {value: [\"test\", \"consequent\", \"alternate\"], writable: false, configurable: false, enumerable: true}});\nConditionalExpression_1197.spec.ConditionalExpression = ConditionalExpression_1197;\nconst FunctionExpression_1198 = Object.create(Expression_1165, {fields: {value: [\"name\", \"isGenerator\", \"params\", \"body\"], writable: false, configurable: false, enumerable: true}});\nFunctionExpression_1198.spec.FunctionExpression = FunctionExpression_1198;\nconst IdentifierExpression_1199 = Object.create(Expression_1165, {fields: {value: [\"name\"], writable: false, configurable: false, enumerable: true}});\nIdentifierExpression_1199.spec.IdentifierExpression = IdentifierExpression_1199;\nconst NewExpression_1200 = Object.create(Expression_1165, {fields: {value: [\"callee\", \"arguments\"], writable: false, configurable: false, enumerable: true}});\nNewExpression_1200.spec.NewExpression = NewExpression_1200;\nconst NewTargetExpression_1201 = Object.create(Expression_1165, {fields: {value: [], writable: false, configurable: false, enumerable: true}});\nNewTargetExpression_1201.spec.NewTargetExpression = NewTargetExpression_1201;\nconst ObjectExpression_1202 = Object.create(Expression_1165, {fields: {value: [\"properties\"], writable: false, configurable: false, enumerable: true}});\nObjectExpression_1202.spec.ObjectExpression = ObjectExpression_1202;\nconst UnaryExpression_1203 = Object.create(Expression_1165, {fields: {value: [\"operator\", \"operand\"], writable: false, configurable: false, enumerable: true}});\nUnaryExpression_1203.spec.UnaryExpression = UnaryExpression_1203;\nconst StaticMemberExpression_1204 = Object.create(Expression_1165, {fields: {value: [\"object\", \"property\"], writable: false, configurable: false, enumerable: true}});\nStaticMemberExpression_1204.spec.StaticMemberExpression = StaticMemberExpression_1204;\nconst TemplateExpression_1205 = Object.create(Expression_1165, {fields: {value: [\"tag\", \"elements\"], writable: false, configurable: false, enumerable: true}});\nTemplateExpression_1205.spec.TemplateExpression = TemplateExpression_1205;\nconst ThisExpression_1206 = Object.create(Expression_1165, {fields: {value: [], writable: false, configurable: false, enumerable: true}});\nThisExpression_1206.spec.ThisExpression = ThisExpression_1206;\nconst UpdateExpression_1207 = Object.create(Expression_1165, {fields: {value: [\"isPrefix\", \"operator\", \"operand\"], writable: false, configurable: false, enumerable: true}});\nUpdateExpression_1207.spec.UpdateExpression = UpdateExpression_1207;\nconst YieldExpression_1208 = Object.create(Expression_1165, {fields: {value: [\"expression\"], writable: false, configurable: false, enumerable: true}});\nYieldExpression_1208.spec.YieldExpression = YieldExpression_1208;\nconst YieldGeneratorExpression_1209 = Object.create(Expression_1165, {fields: {value: [\"expression\"], writable: false, configurable: false, enumerable: true}});\nYieldGeneratorExpression_1209.spec.YieldGeneratorExpression = YieldGeneratorExpression_1209;\nconst ParenthesizedExpression_1210 = Object.create(Expression_1165, {fields: {value: [\"inner\"], writable: false, configurable: false, enumerable: true}});\nParenthesizedExpression_1210.spec.ParenthesizedExpression = ParenthesizedExpression_1210;\nconst BlockStatement_1211 = Object.create(Statement_1164, {fields: {value: [\"block\"], writable: false, configurable: false, enumerable: true}});\nBlockStatement_1211.spec.BlockStatement = BlockStatement_1211;\nconst BreakStatement_1212 = Object.create(Statement_1164, {fields: {value: [\"label\"], writable: false, configurable: false, enumerable: true}});\nBreakStatement_1212.spec.BreakStatement = BreakStatement_1212;\nconst ContinueStatement_1213 = Object.create(Statement_1164, {fields: {value: [\"label\"], writable: false, configurable: false, enumerable: true}});\nContinueStatement_1213.spec.ContinueStatement = ContinueStatement_1213;\nconst CompoundAssignmentExpression_1214 = Object.create(Statement_1164, {fields: {value: [\"binding\", \"operator\", \"expression\"], writable: false, configurable: false, enumerable: true}});\nCompoundAssignmentExpression_1214.spec.CompoundAssignmentExpression = CompoundAssignmentExpression_1214;\nconst DebuggerStatement_1215 = Object.create(Statement_1164, {fields: {value: [], writable: false, configurable: false, enumerable: true}});\nDebuggerStatement_1215.spec.DebuggerStatement = DebuggerStatement_1215;\nconst DoWhileStatement_1216 = Object.create(Statement_1164, {fields: {value: [\"test\", \"body\"], writable: false, configurable: false, enumerable: true}});\nDoWhileStatement_1216.spec.DoWhileStatement = DoWhileStatement_1216;\nconst EmptyStatement_1217 = Object.create(Statement_1164, {fields: {value: [], writable: false, configurable: false, enumerable: true}});\nEmptyStatement_1217.spec.EmptyStatement = EmptyStatement_1217;\nconst ExpressionStatement_1218 = Object.create(Statement_1164, {fields: {value: [\"expression\"], writable: false, configurable: false, enumerable: true}});\nExpressionStatement_1218.spec.ExpressionStatement = ExpressionStatement_1218;\nconst ForInStatement_1219 = Object.create(Statement_1164, {fields: {value: [\"left\", \"right\", \"body\"], writable: false, configurable: false, enumerable: true}});\nForInStatement_1219.spec.ForInStatement = ForInStatement_1219;\nconst ForOfStatement_1220 = Object.create(Statement_1164, {fields: {value: [\"left\", \"right\", \"body\"], writable: false, configurable: false, enumerable: true}});\nForOfStatement_1220.spec.ForOfStatement = ForOfStatement_1220;\nconst ForStatement_1221 = Object.create(Statement_1164, {fields: {value: [\"init\", \"test\", \"update\", \"body\"], writable: false, configurable: false, enumerable: true}});\nForStatement_1221.spec.ForStatement = ForStatement_1221;\nconst IfStatement_1222 = Object.create(Statement_1164, {fields: {value: [\"test\", \"consequent\", \"alternate\"], writable: false, configurable: false, enumerable: true}});\nIfStatement_1222.spec.IfStatement = IfStatement_1222;\nconst LabeledStatement_1223 = Object.create(Statement_1164, {fields: {value: [\"label\", \"body\"], writable: false, configurable: false, enumerable: true}});\nLabeledStatement_1223.spec.LabeledStatement = LabeledStatement_1223;\nconst ReturnStatement_1224 = Object.create(Statement_1164, {fields: {value: [\"expression\"], writable: false, configurable: false, enumerable: true}});\nReturnStatement_1224.spec.ReturnStatement = ReturnStatement_1224;\nconst SwitchStatement_1225 = Object.create(Statement_1164, {fields: {value: [\"discriminant\", \"cases\"], writable: false, configurable: false, enumerable: true}});\nSwitchStatement_1225.spec.SwitchStatement = SwitchStatement_1225;\nconst SwitchStatementWithDefault_1226 = Object.create(Statement_1164, {fields: {value: [\"discriminant\", \"preDefaultCases\", \"defaultCase\", \"postDefaultCases\"], writable: false, configurable: false, enumerable: true}});\nSwitchStatementWithDefault_1226.spec.SwitchStatementWithDefault = SwitchStatementWithDefault_1226;\nconst ThrowStatement_1227 = Object.create(Statement_1164, {fields: {value: [\"expression\"], writable: false, configurable: false, enumerable: true}});\nThrowStatement_1227.spec.ThrowStatement = ThrowStatement_1227;\nconst TryCatchStatement_1228 = Object.create(Statement_1164, {fields: {value: [\"body\", \"catchClause\"], writable: false, configurable: false, enumerable: true}});\nTryCatchStatement_1228.spec.TryCatchStatement = TryCatchStatement_1228;\nconst TryFinallyStatement_1229 = Object.create(Statement_1164, {fields: {value: [\"body\", \"catchClause\", \"finalizer\"], writable: false, configurable: false, enumerable: true}});\nTryFinallyStatement_1229.spec.TryFinallyStatement = TryFinallyStatement_1229;\nconst VariableDeclarationStatement_1230 = Object.create(Statement_1164, {fields: {value: [\"declaration\"], writable: false, configurable: false, enumerable: true}});\nVariableDeclarationStatement_1230.spec.VariableDeclarationStatement = VariableDeclarationStatement_1230;\nconst WithStatement_1231 = Object.create(Statement_1164, {fields: {value: [\"object\", \"body\"], writable: false, configurable: false, enumerable: true}});\nWithStatement_1231.spec.WithStatement = WithStatement_1231;\nconst WhileStatement_1232 = Object.create(Statement_1164, {fields: {value: [\"test\", \"body\"], writable: false, configurable: false, enumerable: true}});\nWhileStatement_1232.spec.WhileStatement = WhileStatement_1232;\nconst Pragma_1233 = Object.create(Term_1157, {fields: {value: [\"kind\", \"items\"], writable: false, configurable: false, enumerable: true}});\nPragma_1233.spec.Pragma = Pragma_1233;\nconst Block_1234 = Object.create(Term_1157, {fields: {value: [\"statements\"], writable: false, configurable: false, enumerable: true}});\nBlock_1234.spec.Block = Block_1234;\nconst CatchClause_1235 = Object.create(Term_1157, {fields: {value: [\"binding\", \"body\"], writable: false, configurable: false, enumerable: true}});\nCatchClause_1235.spec.CatchClause = CatchClause_1235;\nconst Directive_1236 = Object.create(Term_1157, {fields: {value: [\"rawValue\"], writable: false, configurable: false, enumerable: true}});\nDirective_1236.spec.Directive = Directive_1236;\nconst FormalParameters_1237 = Object.create(Term_1157, {fields: {value: [\"items\", \"rest\"], writable: false, configurable: false, enumerable: true}});\nFormalParameters_1237.spec.FormalParameters = FormalParameters_1237;\nconst FunctionBody_1238 = Object.create(Term_1157, {fields: {value: [\"directives\", \"statements\"], writable: false, configurable: false, enumerable: true}});\nFunctionBody_1238.spec.FunctionBody = FunctionBody_1238;\nconst FunctionDeclaration_1239 = Object.create(Statement_1164, {fields: {value: [\"name\", \"isGenerator\", \"params\", \"body\"], writable: false, configurable: false, enumerable: true}});\nFunctionDeclaration_1239.spec.FunctionDeclaration = FunctionDeclaration_1239;\nconst Script_1240 = Object.create(Term_1157, {fields: {value: [\"directives\", \"statements\"], writable: false, configurable: false, enumerable: true}});\nScript_1240.spec.Script = Script_1240;\nconst SpreadElement_1241 = Object.create(Term_1157, {fields: {value: [\"expression\"], writable: false, configurable: false, enumerable: true}});\nSpreadElement_1241.spec.SpreadElement = SpreadElement_1241;\nconst Super_1242 = Object.create(Term_1157, {fields: {value: [], writable: false, configurable: false, enumerable: true}});\nSuper_1242.spec.Super = Super_1242;\nconst SwitchCase_1243 = Object.create(Term_1157, {fields: {value: [\"test\", \"consequent\"], writable: false, configurable: false, enumerable: true}});\nSwitchCase_1243.spec.SwitchCase = SwitchCase_1243;\nconst SwitchDefault_1244 = Object.create(Term_1157, {fields: {value: [\"consequent\"], writable: false, configurable: false, enumerable: true}});\nSwitchDefault_1244.spec.SwitchDefault = SwitchDefault_1244;\nconst TemplateElement_1245 = Object.create(Term_1157, {fields: {value: [\"rawValue\"], writable: false, configurable: false, enumerable: true}});\nTemplateElement_1245.spec.TemplateElement = TemplateElement_1245;\nconst SyntaxTemplate_1246 = Object.create(Term_1157, {fields: {value: [\"template\"], writable: false, configurable: false, enumerable: true}});\nSyntaxTemplate_1246.spec.SyntaxTemplate = SyntaxTemplate_1246;\nconst VariableDeclaration_1247 = Object.create(Term_1157, {fields: {value: [\"kind\", \"declarators\"], writable: false, configurable: false, enumerable: true}});\nVariableDeclaration_1247.spec.VariableDeclaration = VariableDeclaration_1247;\nconst VariableDeclarator_1248 = Object.create(Term_1157, {fields: {value: [\"binding\", \"init\"], writable: false, configurable: false, enumerable: true}});\nVariableDeclarator_1248.spec.VariableDeclarator = VariableDeclarator_1248;\nexport default Term_1157;\n"]} + /** + * Returns a new list containing all but last the`n` elements of a given list, + * passing each value from the right to the supplied predicate function, skipping + * elements while the predicate function returns `true`. The predicate function + * is passed one argument: (value)*. + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> [a] + * @param {Function} fn The function called per iteration. + * @param {Array} list The collection to iterate over. + * @return {Array} A new array. + * @see R.takeLastWhile + * @example + * + * var lteThree = function(x) { + * return x <= 3; + * }; + * + * R.dropLastWhile(lteThree, [1, 2, 3, 4, 3, 2, 1]); //=> [1, 2] + */ + var dropLastWhile = _curry2(function dropLastWhile(pred, list) { + var idx = list.length - 1; + while (idx >= 0 && pred(list[idx])) { + idx -= 1; + } + return _slice(list, 0, idx + 1); + }); -/***/ }, -/* 31 */ -/***/ function(module, exports, __webpack_require__) { + /** + * A function wrapping calls to the two functions in an `||` operation, returning the result of the first + * function if it is truth-y and the result of the second function otherwise. Note that this is + * short-circuited, meaning that the second function will not be invoked if the first returns a truth-y + * value. + * + * @func + * @memberOf R + * @category Logic + * @sig (*... -> Boolean) -> (*... -> Boolean) -> (*... -> Boolean) + * @param {Function} f a predicate + * @param {Function} g another predicate + * @return {Function} a function that applies its arguments to `f` and `g` and `||`s their outputs together. + * @see R.or + * @example + * + * var gt10 = function(x) { return x > 10; }; + * var even = function(x) { return x % 2 === 0 }; + * var f = R.either(gt10, even); + * f(101); //=> true + * f(8); //=> true + */ + var either = _curry2(function either(f, g) { + return function _either() { + return f.apply(this, arguments) || g.apply(this, arguments); + }; + }); - "use strict"; + /** + * Returns the empty value of its argument's type. Ramda defines the empty + * value of Array (`[]`), Object (`{}`), and String (`''`). Other types are + * supported if they define `.empty` and/or `.prototype.empty`. + * + * @func + * @memberOf R + * @category Function + * @sig a -> a + * @param {*} x + * @return {*} + * @example + * + * R.empty(Just(42)); //=> Nothing() + * R.empty([1, 2, 3]); //=> [] + * R.empty('unicorns'); //=> '' + * R.empty({x: 1, y: 2}); //=> {} + */ + var empty = _curry1(function empty(x) { + if (x != null && typeof x.empty === 'function') { + return x.empty(); + } else if (x != null && typeof x.constructor != null && typeof x.constructor.empty === 'function') { + return x.constructor.empty(); + } else { + switch (Object.prototype.toString.call(x)) { + case '[object Array]': + return []; + case '[object Object]': + return {}; + case '[object String]': + return ''; + } + } + }); - Object.defineProperty(exports, "__esModule", { - value: true - }); + /** + * Creates a new object by recursively evolving a shallow copy of `object`, according to the + * `transformation` functions. All non-primitive properties are copied by reference. + * + * A `tranformation` function will not be invoked if its corresponding key does not exist in + * the evolved object. + * + * @func + * @memberOf R + * @category Object + * @sig {k: (v -> v)} -> {k: v} -> {k: v} + * @param {Object} transformations The object specifying transformation functions to apply + * to the object. + * @param {Object} object The object to be transformed. + * @return {Object} The transformed object. + * @example + * + * var tomato = {firstName: ' Tomato ', data: {elapsed: 100, remaining: 1400}, id:123}; + * var transformations = { + * firstName: R.trim, + * lastName: R.trim, // Will not get invoked. + * data: {elapsed: R.add(1), remaining: R.add(-1)} + * }; + * R.evolve(transformations, tomato); //=> {firstName: 'Tomato', data: {elapsed: 101, remaining: 1399}, id:123} + */ + var evolve = _curry2(function evolve(transformations, object) { + var transformation, key, type, result = {}; + for (key in object) { + transformation = transformations[key]; + type = typeof transformation; + result[key] = type === 'function' ? transformation(object[key]) : type === 'object' ? evolve(transformations[key], object[key]) : object[key]; + } + return result; + }); - var _transforms = __webpack_require__(32); + /** + * Creates a new object out of a list key-value pairs. + * + * @func + * @memberOf R + * @category List + * @sig [[k,v]] -> {k: v} + * @param {Array} pairs An array of two-element arrays that will be the keys and values of the output object. + * @return {Object} The object made by pairing up `keys` and `values`. + * @see R.toPairs + * @example + * + * R.fromPairs([['a', 1], ['b', 2], ['c', 3]]); //=> {a: 1, b: 2, c: 3} + */ + var fromPairs = _curry1(function fromPairs(pairs) { + var idx = 0, len = pairs.length, out = {}; + while (idx < len) { + if (_isArray(pairs[idx]) && pairs[idx].length) { + out[pairs[idx][0]] = pairs[idx][1]; + } + idx += 1; + } + return out; + }); - class Env { - constructor() { - this.map = new Map(); - this.map.set("function", _transforms.FunctionDeclTransform); - this.map.set("var", _transforms.VariableDeclTransform); - this.map.set("let", _transforms.LetDeclTransform); - this.map.set("const", _transforms.ConstDeclTransform); - this.map.set("syntaxQuote", _transforms.SyntaxQuoteTransform); - this.map.set("syntaxrec", _transforms.SyntaxrecDeclTransform); - this.map.set("syntax", _transforms.SyntaxDeclTransform); - this.map.set("return", _transforms.ReturnStatementTransform); - this.map.set("while", _transforms.WhileTransform); - this.map.set("if", _transforms.IfTransform); - this.map.set("for", _transforms.ForTransform); - this.map.set("switch", _transforms.SwitchTransform); - this.map.set("break", _transforms.BreakTransform); - this.map.set("continue", _transforms.ContinueTransform); - this.map.set("do", _transforms.DoTransform); - this.map.set("debugger", _transforms.DebuggerTransform); - this.map.set("with", _transforms.WithTransform); - this.map.set("try", _transforms.TryTransform); - this.map.set("throw", _transforms.ThrowTransform); - this.map.set("new", _transforms.NewTransform); - } - has(key_332) { - return this.map.has(key_332); - } - get(key_333) { - return this.map.get(key_333); - } - set(key_334, val_335) { - return this.map.set(key_334, val_335); - } - } - exports.default = Env; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2Vudi5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7QUFDZSxNQUFNLEdBQU4sQ0FBVTtBQUN2QixnQkFBYztBQUNaLFNBQUssR0FBTCxHQUFXLElBQUksR0FBSixFQUFYO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLFVBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsS0FBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxLQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLE9BQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsYUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxXQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLFFBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsUUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxPQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLElBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsS0FBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxRQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLE9BQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsVUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxJQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLFVBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsTUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxLQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLE9BQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsS0FBYjtBQUNEO0FBQ0QsTUFBSSxPQUFKLEVBQWE7QUFDWCxXQUFPLEtBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxPQUFiLENBQVA7QUFDRDtBQUNELE1BQUksT0FBSixFQUFhO0FBQ1gsV0FBTyxLQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsT0FBYixDQUFQO0FBQ0Q7QUFDRCxNQUFJLE9BQUosRUFBYSxPQUFiLEVBQXNCO0FBQ3BCLFdBQU8sS0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLE9BQWIsRUFBc0IsT0FBdEIsQ0FBUDtBQUNEO0FBaENzQjtrQkFBSixHIiwiZmlsZSI6ImVudi5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RnVuY3Rpb25EZWNsVHJhbnNmb3JtLCBWYXJpYWJsZURlY2xUcmFuc2Zvcm0sIExldERlY2xUcmFuc2Zvcm0sIENvbnN0RGVjbFRyYW5zZm9ybSwgU3ludGF4RGVjbFRyYW5zZm9ybSwgU3ludGF4cmVjRGVjbFRyYW5zZm9ybSwgU3ludGF4UXVvdGVUcmFuc2Zvcm0sIFJldHVyblN0YXRlbWVudFRyYW5zZm9ybSwgSWZUcmFuc2Zvcm0sIEZvclRyYW5zZm9ybSwgU3dpdGNoVHJhbnNmb3JtLCBCcmVha1RyYW5zZm9ybSwgQ29udGludWVUcmFuc2Zvcm0sIERvVHJhbnNmb3JtLCBEZWJ1Z2dlclRyYW5zZm9ybSwgV2l0aFRyYW5zZm9ybSwgVHJ5VHJhbnNmb3JtLCBUaHJvd1RyYW5zZm9ybSwgTmV3VHJhbnNmb3JtLCBXaGlsZVRyYW5zZm9ybX0gZnJvbSBcIi4vdHJhbnNmb3Jtc1wiO1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgRW52IHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5tYXAgPSBuZXcgTWFwO1xuICAgIHRoaXMubWFwLnNldChcImZ1bmN0aW9uXCIsIEZ1bmN0aW9uRGVjbFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwidmFyXCIsIFZhcmlhYmxlRGVjbFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwibGV0XCIsIExldERlY2xUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcImNvbnN0XCIsIENvbnN0RGVjbFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwic3ludGF4UXVvdGVcIiwgU3ludGF4UXVvdGVUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcInN5bnRheHJlY1wiLCBTeW50YXhyZWNEZWNsVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJzeW50YXhcIiwgU3ludGF4RGVjbFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwicmV0dXJuXCIsIFJldHVyblN0YXRlbWVudFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwid2hpbGVcIiwgV2hpbGVUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcImlmXCIsIElmVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJmb3JcIiwgRm9yVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJzd2l0Y2hcIiwgU3dpdGNoVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJicmVha1wiLCBCcmVha1RyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwiY29udGludWVcIiwgQ29udGludWVUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcImRvXCIsIERvVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJkZWJ1Z2dlclwiLCBEZWJ1Z2dlclRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwid2l0aFwiLCBXaXRoVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJ0cnlcIiwgVHJ5VHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJ0aHJvd1wiLCBUaHJvd1RyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwibmV3XCIsIE5ld1RyYW5zZm9ybSk7XG4gIH1cbiAgaGFzKGtleV8zMzIpIHtcbiAgICByZXR1cm4gdGhpcy5tYXAuaGFzKGtleV8zMzIpO1xuICB9XG4gIGdldChrZXlfMzMzKSB7XG4gICAgcmV0dXJuIHRoaXMubWFwLmdldChrZXlfMzMzKTtcbiAgfVxuICBzZXQoa2V5XzMzNCwgdmFsXzMzNSkge1xuICAgIHJldHVybiB0aGlzLm1hcC5zZXQoa2V5XzMzNCwgdmFsXzMzNSk7XG4gIH1cbn1cbiJdfQ== + /** + * Returns `true` if the first argument is greater than the second; + * `false` otherwise. + * + * @func + * @memberOf R + * @category Relation + * @sig Ord a => a -> a -> Boolean + * @param {*} a + * @param {*} b + * @return {Boolean} + * @see R.lt + * @example + * + * R.gt(2, 1); //=> true + * R.gt(2, 2); //=> false + * R.gt(2, 3); //=> false + * R.gt('a', 'z'); //=> false + * R.gt('z', 'a'); //=> true + */ + var gt = _curry2(function gt(a, b) { + return a > b; + }); -/***/ }, -/* 32 */ -/***/ function(module, exports) { + /** + * Returns `true` if the first argument is greater than or equal to the second; + * `false` otherwise. + * + * @func + * @memberOf R + * @category Relation + * @sig Ord a => a -> a -> Boolean + * @param {Number} a + * @param {Number} b + * @return {Boolean} + * @see R.lte + * @example + * + * R.gte(2, 1); //=> true + * R.gte(2, 2); //=> true + * R.gte(2, 3); //=> false + * R.gte('a', 'z'); //=> false + * R.gte('z', 'a'); //=> true + */ + var gte = _curry2(function gte(a, b) { + return a >= b; + }); - "use strict"; + /** + * Returns whether or not an object has an own property with + * the specified name + * + * @func + * @memberOf R + * @category Object + * @sig s -> {s: x} -> Boolean + * @param {String} prop The name of the property to check for. + * @param {Object} obj The object to query. + * @return {Boolean} Whether the property exists. + * @example + * + * var hasName = R.has('name'); + * hasName({name: 'alice'}); //=> true + * hasName({name: 'bob'}); //=> true + * hasName({}); //=> false + * + * var point = {x: 0, y: 0}; + * var pointHas = R.has(R.__, point); + * pointHas('x'); //=> true + * pointHas('y'); //=> true + * pointHas('z'); //=> false + */ + var has = _curry2(_has); - Object.defineProperty(exports, "__esModule", { - value: true - }); - class FunctionDeclTransform_1433 {} - class VariableDeclTransform_1434 {} - class NewTransform_1435 {} - class ThrowTransform_1436 {} - class LetDeclTransform_1437 {} - class ConstDeclTransform_1438 {} - class TryTransform_1439 {} - class WhileTransform_1440 {} - class IfTransform_1441 {} - class ForTransform_1442 {} - class SwitchTransform_1443 {} - class BreakTransform_1444 {} - class ContinueTransform_1445 {} - class DoTransform_1446 {} - class WithTransform_1447 {} - class DebuggerTransform_1448 {} - class SyntaxrecDeclTransform_1449 {} - class SyntaxDeclTransform_1450 {} - class SyntaxQuoteTransform_1451 {} - class ReturnStatementTransform_1452 {} - class VarBindingTransform_1453 { - constructor(id_1455) { - this.id = id_1455; - } - } - class CompiletimeTransform_1454 { - constructor(value_1456) { - this.value = value_1456; - } - } - exports.FunctionDeclTransform = FunctionDeclTransform_1433; - exports.VariableDeclTransform = VariableDeclTransform_1434; - exports.NewTransform = NewTransform_1435; - exports.ThrowTransform = ThrowTransform_1436; - exports.LetDeclTransform = LetDeclTransform_1437; - exports.ConstDeclTransform = ConstDeclTransform_1438; - exports.TryTransform = TryTransform_1439; - exports.WhileTransform = WhileTransform_1440; - exports.IfTransform = IfTransform_1441; - exports.ForTransform = ForTransform_1442; - exports.SwitchTransform = SwitchTransform_1443; - exports.BreakTransform = BreakTransform_1444; - exports.ContinueTransform = ContinueTransform_1445; - exports.DoTransform = DoTransform_1446; - exports.WithTransform = WithTransform_1447; - exports.DebuggerTransform = DebuggerTransform_1448; - exports.SyntaxrecDeclTransform = SyntaxrecDeclTransform_1449; - exports.SyntaxDeclTransform = SyntaxDeclTransform_1450; - exports.SyntaxQuoteTransform = SyntaxQuoteTransform_1451; - exports.ReturnStatementTransform = ReturnStatementTransform_1452; - exports.VarBindingTransform = VarBindingTransform_1453; - exports.CompiletimeTransform = CompiletimeTransform_1454; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L3RyYW5zZm9ybXMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxNQUFNLDBCQUFOLENBQWlDO0FBQ2pDLE1BQU0sMEJBQU4sQ0FBaUM7QUFDakMsTUFBTSxpQkFBTixDQUF3QjtBQUN4QixNQUFNLG1CQUFOLENBQTBCO0FBQzFCLE1BQU0scUJBQU4sQ0FBNEI7QUFDNUIsTUFBTSx1QkFBTixDQUE4QjtBQUM5QixNQUFNLGlCQUFOLENBQXdCO0FBQ3hCLE1BQU0sbUJBQU4sQ0FBMEI7QUFDMUIsTUFBTSxnQkFBTixDQUF1QjtBQUN2QixNQUFNLGlCQUFOLENBQXdCO0FBQ3hCLE1BQU0sb0JBQU4sQ0FBMkI7QUFDM0IsTUFBTSxtQkFBTixDQUEwQjtBQUMxQixNQUFNLHNCQUFOLENBQTZCO0FBQzdCLE1BQU0sZ0JBQU4sQ0FBdUI7QUFDdkIsTUFBTSxrQkFBTixDQUF5QjtBQUN6QixNQUFNLHNCQUFOLENBQTZCO0FBQzdCLE1BQU0sMkJBQU4sQ0FBa0M7QUFDbEMsTUFBTSx3QkFBTixDQUErQjtBQUMvQixNQUFNLHlCQUFOLENBQWdDO0FBQ2hDLE1BQU0sNkJBQU4sQ0FBb0M7QUFDcEMsTUFBTSx3QkFBTixDQUErQjtBQUM3QixjQUFZLE9BQVosRUFBcUI7QUFDbkIsU0FBSyxFQUFMLEdBQVUsT0FBVjtBQUNEO0FBSDRCO0FBSy9CLE1BQU0seUJBQU4sQ0FBZ0M7QUFDOUIsY0FBWSxVQUFaLEVBQXdCO0FBQ3RCLFNBQUssS0FBTCxHQUFhLFVBQWI7QUFDRDtBQUg2QjtRQUtNLHFCLEdBQTlCLDBCO1FBQzhCLHFCLEdBQTlCLDBCO1FBQ3FCLFksR0FBckIsaUI7UUFDdUIsYyxHQUF2QixtQjtRQUN5QixnQixHQUF6QixxQjtRQUMyQixrQixHQUEzQix1QjtRQUNxQixZLEdBQXJCLGlCO1FBQ3VCLGMsR0FBdkIsbUI7UUFDb0IsVyxHQUFwQixnQjtRQUNxQixZLEdBQXJCLGlCO1FBQ3dCLGUsR0FBeEIsb0I7UUFDdUIsYyxHQUF2QixtQjtRQUMwQixpQixHQUExQixzQjtRQUNvQixXLEdBQXBCLGdCO1FBQ3NCLGEsR0FBdEIsa0I7UUFDMEIsaUIsR0FBMUIsc0I7UUFDK0Isc0IsR0FBL0IsMkI7UUFDNEIsbUIsR0FBNUIsd0I7UUFDNkIsb0IsR0FBN0IseUI7UUFDaUMsd0IsR0FBakMsNkI7UUFDNEIsbUIsR0FBNUIsd0I7UUFDNkIsb0IsR0FBN0IseUIiLCJmaWxlIjoidHJhbnNmb3Jtcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImNsYXNzIEZ1bmN0aW9uRGVjbFRyYW5zZm9ybV8xNDMzIHt9XG5jbGFzcyBWYXJpYWJsZURlY2xUcmFuc2Zvcm1fMTQzNCB7fVxuY2xhc3MgTmV3VHJhbnNmb3JtXzE0MzUge31cbmNsYXNzIFRocm93VHJhbnNmb3JtXzE0MzYge31cbmNsYXNzIExldERlY2xUcmFuc2Zvcm1fMTQzNyB7fVxuY2xhc3MgQ29uc3REZWNsVHJhbnNmb3JtXzE0Mzgge31cbmNsYXNzIFRyeVRyYW5zZm9ybV8xNDM5IHt9XG5jbGFzcyBXaGlsZVRyYW5zZm9ybV8xNDQwIHt9XG5jbGFzcyBJZlRyYW5zZm9ybV8xNDQxIHt9XG5jbGFzcyBGb3JUcmFuc2Zvcm1fMTQ0MiB7fVxuY2xhc3MgU3dpdGNoVHJhbnNmb3JtXzE0NDMge31cbmNsYXNzIEJyZWFrVHJhbnNmb3JtXzE0NDQge31cbmNsYXNzIENvbnRpbnVlVHJhbnNmb3JtXzE0NDUge31cbmNsYXNzIERvVHJhbnNmb3JtXzE0NDYge31cbmNsYXNzIFdpdGhUcmFuc2Zvcm1fMTQ0NyB7fVxuY2xhc3MgRGVidWdnZXJUcmFuc2Zvcm1fMTQ0OCB7fVxuY2xhc3MgU3ludGF4cmVjRGVjbFRyYW5zZm9ybV8xNDQ5IHt9XG5jbGFzcyBTeW50YXhEZWNsVHJhbnNmb3JtXzE0NTAge31cbmNsYXNzIFN5bnRheFF1b3RlVHJhbnNmb3JtXzE0NTEge31cbmNsYXNzIFJldHVyblN0YXRlbWVudFRyYW5zZm9ybV8xNDUyIHt9XG5jbGFzcyBWYXJCaW5kaW5nVHJhbnNmb3JtXzE0NTMge1xuICBjb25zdHJ1Y3RvcihpZF8xNDU1KSB7XG4gICAgdGhpcy5pZCA9IGlkXzE0NTU7XG4gIH1cbn1cbmNsYXNzIENvbXBpbGV0aW1lVHJhbnNmb3JtXzE0NTQge1xuICBjb25zdHJ1Y3Rvcih2YWx1ZV8xNDU2KSB7XG4gICAgdGhpcy52YWx1ZSA9IHZhbHVlXzE0NTY7XG4gIH1cbn1cbmV4cG9ydCB7RnVuY3Rpb25EZWNsVHJhbnNmb3JtXzE0MzMgYXMgRnVuY3Rpb25EZWNsVHJhbnNmb3JtfTtcbmV4cG9ydCB7VmFyaWFibGVEZWNsVHJhbnNmb3JtXzE0MzQgYXMgVmFyaWFibGVEZWNsVHJhbnNmb3JtfTtcbmV4cG9ydCB7TmV3VHJhbnNmb3JtXzE0MzUgYXMgTmV3VHJhbnNmb3JtfTtcbmV4cG9ydCB7VGhyb3dUcmFuc2Zvcm1fMTQzNiBhcyBUaHJvd1RyYW5zZm9ybX07XG5leHBvcnQge0xldERlY2xUcmFuc2Zvcm1fMTQzNyBhcyBMZXREZWNsVHJhbnNmb3JtfTtcbmV4cG9ydCB7Q29uc3REZWNsVHJhbnNmb3JtXzE0MzggYXMgQ29uc3REZWNsVHJhbnNmb3JtfTtcbmV4cG9ydCB7VHJ5VHJhbnNmb3JtXzE0MzkgYXMgVHJ5VHJhbnNmb3JtfTtcbmV4cG9ydCB7V2hpbGVUcmFuc2Zvcm1fMTQ0MCBhcyBXaGlsZVRyYW5zZm9ybX07XG5leHBvcnQge0lmVHJhbnNmb3JtXzE0NDEgYXMgSWZUcmFuc2Zvcm19O1xuZXhwb3J0IHtGb3JUcmFuc2Zvcm1fMTQ0MiBhcyBGb3JUcmFuc2Zvcm19O1xuZXhwb3J0IHtTd2l0Y2hUcmFuc2Zvcm1fMTQ0MyBhcyBTd2l0Y2hUcmFuc2Zvcm19O1xuZXhwb3J0IHtCcmVha1RyYW5zZm9ybV8xNDQ0IGFzIEJyZWFrVHJhbnNmb3JtfTtcbmV4cG9ydCB7Q29udGludWVUcmFuc2Zvcm1fMTQ0NSBhcyBDb250aW51ZVRyYW5zZm9ybX07XG5leHBvcnQge0RvVHJhbnNmb3JtXzE0NDYgYXMgRG9UcmFuc2Zvcm19O1xuZXhwb3J0IHtXaXRoVHJhbnNmb3JtXzE0NDcgYXMgV2l0aFRyYW5zZm9ybX07XG5leHBvcnQge0RlYnVnZ2VyVHJhbnNmb3JtXzE0NDggYXMgRGVidWdnZXJUcmFuc2Zvcm19O1xuZXhwb3J0IHtTeW50YXhyZWNEZWNsVHJhbnNmb3JtXzE0NDkgYXMgU3ludGF4cmVjRGVjbFRyYW5zZm9ybX07XG5leHBvcnQge1N5bnRheERlY2xUcmFuc2Zvcm1fMTQ1MCBhcyBTeW50YXhEZWNsVHJhbnNmb3JtfTtcbmV4cG9ydCB7U3ludGF4UXVvdGVUcmFuc2Zvcm1fMTQ1MSBhcyBTeW50YXhRdW90ZVRyYW5zZm9ybX07XG5leHBvcnQge1JldHVyblN0YXRlbWVudFRyYW5zZm9ybV8xNDUyIGFzIFJldHVyblN0YXRlbWVudFRyYW5zZm9ybX07XG5leHBvcnQge1ZhckJpbmRpbmdUcmFuc2Zvcm1fMTQ1MyBhcyBWYXJCaW5kaW5nVHJhbnNmb3JtfTtcbmV4cG9ydCB7Q29tcGlsZXRpbWVUcmFuc2Zvcm1fMTQ1NCBhcyBDb21waWxldGltZVRyYW5zZm9ybX0iXX0= + /** + * Returns whether or not an object or its prototype chain has + * a property with the specified name + * + * @func + * @memberOf R + * @category Object + * @sig s -> {s: x} -> Boolean + * @param {String} prop The name of the property to check for. + * @param {Object} obj The object to query. + * @return {Boolean} Whether the property exists. + * @example + * + * function Rectangle(width, height) { + * this.width = width; + * this.height = height; + * } + * Rectangle.prototype.area = function() { + * return this.width * this.height; + * }; + * + * var square = new Rectangle(2, 2); + * R.hasIn('width', square); //=> true + * R.hasIn('area', square); //=> true + */ + var hasIn = _curry2(function hasIn(prop, obj) { + return prop in obj; + }); -/***/ }, -/* 33 */ -/***/ function(module, exports, __webpack_require__) { + /** + * Returns true if its arguments are identical, false otherwise. Values are + * identical if they reference the same memory. `NaN` is identical to `NaN`; + * `0` and `-0` are not identical. + * + * @func + * @memberOf R + * @category Relation + * @sig a -> a -> Boolean + * @param {*} a + * @param {*} b + * @return {Boolean} + * @example + * + * var o = {}; + * R.identical(o, o); //=> true + * R.identical(1, 1); //=> true + * R.identical(1, '1'); //=> false + * R.identical([], []); //=> false + * R.identical(0, -0); //=> false + * R.identical(NaN, NaN); //=> true + */ + // SameValue algorithm + // Steps 1-5, 7-10 + // Steps 6.b-6.e: +0 != -0 + // Step 6.a: NaN == NaN + var identical = _curry2(function identical(a, b) { + // SameValue algorithm + if (a === b) { + // Steps 1-5, 7-10 + // Steps 6.b-6.e: +0 != -0 + return a !== 0 || 1 / a === 1 / b; + } else { + // Step 6.a: NaN == NaN + return a !== a && b !== b; + } + }); - "use strict"; + /** + * A function that does nothing but return the parameter supplied to it. Good as a default + * or placeholder function. + * + * @func + * @memberOf R + * @category Function + * @sig a -> a + * @param {*} x The value to return. + * @return {*} The input value, `x`. + * @example + * + * R.identity(1); //=> 1 + * + * var obj = {}; + * R.identity(obj) === obj; //=> true + */ + var identity = _curry1(_identity); - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.MonoidalReducer = exports.CloneReducer = undefined; - exports.default = reduce; - - var _cloneReducer = __webpack_require__(34); + /** + * Creates a function that will process either the `onTrue` or the `onFalse` function depending + * upon the result of the `condition` predicate. + * + * @func + * @memberOf R + * @category Logic + * @sig (*... -> Boolean) -> (*... -> *) -> (*... -> *) -> (*... -> *) + * @param {Function} condition A predicate function + * @param {Function} onTrue A function to invoke when the `condition` evaluates to a truthy value. + * @param {Function} onFalse A function to invoke when the `condition` evaluates to a falsy value. + * @return {Function} A new unary function that will process either the `onTrue` or the `onFalse` + * function depending upon the result of the `condition` predicate. + * @example + * + * // Flatten all arrays in the list but leave other values alone. + * var flattenArrays = R.map(R.ifElse(Array.isArray, R.flatten, R.identity)); + * + * flattenArrays([[0], [[10], [8]], 1234, {}]); //=> [[0], [10, 8], 1234, {}] + * flattenArrays([[[10], 123], [8, [10]], "hello"]); //=> [[10, 123], [8, 10], "hello"] + */ + var ifElse = _curry3(function ifElse(condition, onTrue, onFalse) { + return curryN(Math.max(condition.length, onTrue.length, onFalse.length), function _ifElse() { + return condition.apply(this, arguments) ? onTrue.apply(this, arguments) : onFalse.apply(this, arguments); + }); + }); - Object.defineProperty(exports, "CloneReducer", { - enumerable: true, - get: function get() { - return _cloneReducer.default; - } - }); + /** + * Increments its argument. + * + * @func + * @memberOf R + * @category Math + * @sig Number -> Number + * @param {Number} n + * @return {Number} + * @see R.dec + * @example + * + * R.inc(42); //=> 43 + */ + var inc = add(1); - var _monoidalReducer = __webpack_require__(36); + /** + * Inserts the supplied element into the list, at index `index`. _Note + * that this is not destructive_: it returns a copy of the list with the changes. + * No lists have been harmed in the application of this function. + * + * @func + * @memberOf R + * @category List + * @sig Number -> a -> [a] -> [a] + * @param {Number} index The position to insert the element + * @param {*} elt The element to insert into the Array + * @param {Array} list The list to insert into + * @return {Array} A new Array with `elt` inserted at `index`. + * @example + * + * R.insert(2, 'x', [1,2,3,4]); //=> [1,2,'x',3,4] + */ + var insert = _curry3(function insert(idx, elt, list) { + idx = idx < list.length && idx >= 0 ? idx : list.length; + var result = _slice(list); + result.splice(idx, 0, elt); + return result; + }); - Object.defineProperty(exports, "MonoidalReducer", { - enumerable: true, - get: function get() { - return _monoidalReducer.default; - } - }); + /** + * Inserts the sub-list into the list, at index `index`. _Note that this + * is not destructive_: it returns a copy of the list with the changes. + * No lists have been harmed in the application of this function. + * + * @func + * @memberOf R + * @category List + * @sig Number -> [a] -> [a] -> [a] + * @param {Number} index The position to insert the sub-list + * @param {Array} elts The sub-list to insert into the Array + * @param {Array} list The list to insert the sub-list into + * @return {Array} A new Array with `elts` inserted starting at `index`. + * @example + * + * R.insertAll(2, ['x','y','z'], [1,2,3,4]); //=> [1,2,'x','y','z',3,4] + */ + var insertAll = _curry3(function insertAll(idx, elts, list) { + idx = idx < list.length && idx >= 0 ? idx : list.length; + return _concat(_concat(_slice(list, 0, idx), elts), _slice(list, idx)); + }); - var _shiftSpec = __webpack_require__(35); + /** + * See if an object (`val`) is an instance of the supplied constructor. + * This function will check up the inheritance chain, if any. + * + * @func + * @memberOf R + * @category Type + * @sig (* -> {*}) -> a -> Boolean + * @param {Object} ctor A constructor + * @param {*} val The value to test + * @return {Boolean} + * @example + * + * R.is(Object, {}); //=> true + * R.is(Number, 1); //=> true + * R.is(Object, 1); //=> false + * R.is(String, 's'); //=> true + * R.is(String, new String('')); //=> true + * R.is(Object, new String('')); //=> true + * R.is(Object, 's'); //=> false + * R.is(Number, {}); //=> false + */ + var is = _curry2(function is(Ctor, val) { + return val != null && val.constructor === Ctor || val instanceof Ctor; + }); - var _shiftSpec2 = _interopRequireDefault(_shiftSpec); + /** + * Tests whether or not an object is similar to an array. + * + * @func + * @memberOf R + * @category Type + * @category List + * @sig * -> Boolean + * @param {*} x The object to test. + * @return {Boolean} `true` if `x` has a numeric length property and extreme indices defined; `false` otherwise. + * @example + * + * R.isArrayLike([]); //=> true + * R.isArrayLike(true); //=> false + * R.isArrayLike({}); //=> false + * R.isArrayLike({length: 10}); //=> false + * R.isArrayLike({0: 'zero', 9: 'nine', length: 10}); //=> true + */ + var isArrayLike = _curry1(function isArrayLike(x) { + if (_isArray(x)) { + return true; + } + if (!x) { + return false; + } + if (typeof x !== 'object') { + return false; + } + if (x instanceof String) { + return false; + } + if (x.nodeType === 1) { + return !!x.length; + } + if (x.length === 0) { + return true; + } + if (x.length > 0) { + return x.hasOwnProperty(0) && x.hasOwnProperty(x.length - 1); + } + return false; + }); - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + /** + * Reports whether the list has zero elements. + * + * @func + * @memberOf R + * @category Logic + * @sig [a] -> Boolean + * @param {Array} list + * @return {Boolean} + * @example + * + * R.isEmpty([1, 2, 3]); //=> false + * R.isEmpty([]); //=> true + * R.isEmpty(''); //=> true + * R.isEmpty(null); //=> false + * R.isEmpty(R.keys({})); //=> true + * R.isEmpty({}); //=> false ({} does not have a length property) + * R.isEmpty({length: 0}); //=> true + */ + var isEmpty = _curry1(function isEmpty(list) { + return Object(list).length === 0; + }); - function transformWithSpec(transformer, node, spec) { - switch (spec.typeName) { - case "Enum": - case "String": - case "Number": - case "Boolean": - case "SourceSpan": - return node; - case "Const": - // TODO: checked version - return transformWithSpec(transformer, node, spec.argument); - case "Maybe": - return node && transformWithSpec(transformer, node, spec.argument); - case "List": - return node.map(function (e) { - return transformWithSpec(transformer, e, spec.argument); - }); - case "Union": - // TODO: checked version - return transformWithSpec(transformer, node, _shiftSpec2.default[node.type]); - default: - var state = {}; - spec.fields.forEach(function (field) { - var v = transformWithSpec(transformer, node[field.name], field.type); - state[field.name] = v == null ? null : v; - }); - if (typeof transformer["reduce" + node.type] !== "function") { - throw new Error("Encountered " + node.type + ", which the provided reducer does not handle."); - } - return transformer["reduce" + node.type](node, state); - } - } /** - * Copyright 2014 Shape Security, Inc. - * - * Licensed under the Apache License, Version 2.0 (the "License") - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ + /** + * Checks if the input value is `null` or `undefined`. + * + * @func + * @memberOf R + * @category Type + * @sig * -> Boolean + * @param {*} x The value to test. + * @return {Boolean} `true` if `x` is `undefined` or `null`, otherwise `false`. + * @example + * + * R.isNil(null); //=> true + * R.isNil(undefined); //=> true + * R.isNil(0); //=> false + * R.isNil([]); //=> false + */ + var isNil = _curry1(function isNil(x) { + return x == null; + }); - function reduce(reducer, reducible) { - return transformWithSpec(reducer, reducible, _shiftSpec2.default[reducible.type]); - } + /** + * Returns a list containing the names of all the enumerable own + * properties of the supplied object. + * Note that the order of the output array is not guaranteed to be + * consistent across different JS platforms. + * + * @func + * @memberOf R + * @category Object + * @sig {k: v} -> [k] + * @param {Object} obj The object to extract properties from + * @return {Array} An array of the object's own properties. + * @example + * + * R.keys({a: 1, b: 2, c: 3}); //=> ['a', 'b', 'c'] + */ + // cover IE < 9 keys issues + var keys = function () { + // cover IE < 9 keys issues + var hasEnumBug = !{ toString: null }.propertyIsEnumerable('toString'); + var nonEnumerableProps = [ + 'constructor', + 'valueOf', + 'isPrototypeOf', + 'toString', + 'propertyIsEnumerable', + 'hasOwnProperty', + 'toLocaleString' + ]; + var contains = function contains(list, item) { + var idx = 0; + while (idx < list.length) { + if (list[idx] === item) { + return true; + } + idx += 1; + } + return false; + }; + return typeof Object.keys === 'function' ? _curry1(function keys(obj) { + return Object(obj) !== obj ? [] : Object.keys(obj); + }) : _curry1(function keys(obj) { + if (Object(obj) !== obj) { + return []; + } + var prop, ks = [], nIdx; + for (prop in obj) { + if (_has(prop, obj)) { + ks[ks.length] = prop; + } + } + if (hasEnumBug) { + nIdx = nonEnumerableProps.length - 1; + while (nIdx >= 0) { + prop = nonEnumerableProps[nIdx]; + if (_has(prop, obj) && !contains(ks, prop)) { + ks[ks.length] = prop; + } + nIdx -= 1; + } + } + return ks; + }); + }(); -/***/ }, -/* 34 */ -/***/ function(module, exports, __webpack_require__) { + /** + * Returns a list containing the names of all the + * properties of the supplied object, including prototype properties. + * Note that the order of the output array is not guaranteed to be + * consistent across different JS platforms. + * + * @func + * @memberOf R + * @category Object + * @sig {k: v} -> [k] + * @param {Object} obj The object to extract properties from + * @return {Array} An array of the object's own and prototype properties. + * @example + * + * var F = function() { this.x = 'X'; }; + * F.prototype.y = 'Y'; + * var f = new F(); + * R.keysIn(f); //=> ['x', 'y'] + */ + var keysIn = _curry1(function keysIn(obj) { + var prop, ks = []; + for (prop in obj) { + ks[ks.length] = prop; + } + return ks; + }); - "use strict"; + /** + * Returns the number of elements in the array by returning `list.length`. + * + * @func + * @memberOf R + * @category List + * @sig [a] -> Number + * @param {Array} list The array to inspect. + * @return {Number} The length of the array. + * @example + * + * R.length([]); //=> 0 + * R.length([1, 2, 3]); //=> 3 + */ + var length = _curry1(function length(list) { + return list != null && is(Number, list.length) ? list.length : NaN; + }); - Object.defineProperty(exports, "__esModule", { - value: true - }); + /** + * Returns `true` if the first argument is less than the second; + * `false` otherwise. + * + * @func + * @memberOf R + * @category Relation + * @sig Ord a => a -> a -> Boolean + * @param {*} a + * @param {*} b + * @return {Boolean} + * @see R.gt + * @example + * + * R.lt(2, 1); //=> false + * R.lt(2, 2); //=> false + * R.lt(2, 3); //=> true + * R.lt('a', 'z'); //=> true + * R.lt('z', 'a'); //=> false + */ + var lt = _curry2(function lt(a, b) { + return a < b; + }); - var _shiftSpec = __webpack_require__(35); + /** + * Returns `true` if the first argument is less than or equal to the second; + * `false` otherwise. + * + * @func + * @memberOf R + * @category Relation + * @sig Ord a => a -> a -> Boolean + * @param {Number} a + * @param {Number} b + * @return {Boolean} + * @see R.gte + * @example + * + * R.lte(2, 1); //=> false + * R.lte(2, 2); //=> true + * R.lte(2, 3); //=> true + * R.lte('a', 'z'); //=> true + * R.lte('z', 'a'); //=> false + */ + var lte = _curry2(function lte(a, b) { + return a <= b; + }); - var _shiftSpec2 = _interopRequireDefault(_shiftSpec); + /** + * The mapAccum function behaves like a combination of map and reduce; it applies a + * function to each element of a list, passing an accumulating parameter from left to + * right, and returning a final value of this accumulator together with the new list. + * + * The iterator function receives two arguments, *acc* and *value*, and should return + * a tuple *[acc, value]*. + * + * @func + * @memberOf R + * @category List + * @sig (acc -> x -> (acc, y)) -> acc -> [x] -> (acc, [y]) + * @param {Function} fn The function to be called on every element of the input `list`. + * @param {*} acc The accumulator value. + * @param {Array} list The list to iterate over. + * @return {*} The final, accumulated value. + * @example + * + * var digits = ['1', '2', '3', '4']; + * var append = function(a, b) { + * return [a + b, a + b]; + * } + * + * R.mapAccum(append, 0, digits); //=> ['01234', ['01', '012', '0123', '01234']] + */ + var mapAccum = _curry3(function mapAccum(fn, acc, list) { + var idx = 0, len = list.length, result = [], tuple = [acc]; + while (idx < len) { + tuple = fn(tuple[0], list[idx]); + result[idx] = tuple[1]; + idx += 1; + } + return [ + tuple[0], + result + ]; + }); - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + /** + * The mapAccumRight function behaves like a combination of map and reduce; it applies a + * function to each element of a list, passing an accumulating parameter from right + * to left, and returning a final value of this accumulator together with the new list. + * + * Similar to `mapAccum`, except moves through the input list from the right to the + * left. + * + * The iterator function receives two arguments, *acc* and *value*, and should return + * a tuple *[acc, value]*. + * + * @func + * @memberOf R + * @category List + * @sig (acc -> x -> (acc, y)) -> acc -> [x] -> (acc, [y]) + * @param {Function} fn The function to be called on every element of the input `list`. + * @param {*} acc The accumulator value. + * @param {Array} list The list to iterate over. + * @return {*} The final, accumulated value. + * @example + * + * var digits = ['1', '2', '3', '4']; + * var append = function(a, b) { + * return [a + b, a + b]; + * } + * + * R.mapAccumRight(append, 0, digits); //=> ['04321', ['04321', '0432', '043', '04']] + */ + var mapAccumRight = _curry3(function mapAccumRight(fn, acc, list) { + var idx = list.length - 1, result = [], tuple = [acc]; + while (idx >= 0) { + tuple = fn(tuple[0], list[idx]); + result[idx] = tuple[1]; + idx -= 1; + } + return [ + tuple[0], + result + ]; + }); - function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } /** - * Copyright 2014 Shape Security, Inc. - * - * Licensed under the Apache License, Version 2.0 (the "License") - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ + /** + * Tests a regular expression against a String. Note that this function + * will return an empty array when there are no matches. This differs + * from [`String.prototype.match`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/match) + * which returns `null` when there are no matches. + * + * @func + * @memberOf R + * @see R.test + * @category String + * @sig RegExp -> String -> [String | Undefined] + * @param {RegExp} rx A regular expression. + * @param {String} str The string to match against + * @return {Array} The list of matches or empty array. + * @example + * + * R.match(/([a-z]a)/g, 'bananas'); //=> ['ba', 'na', 'na'] + * R.match(/a/, 'b'); //=> [] + * R.match(/a/, null); //=> TypeError: null does not have a method named "match" + */ + var match = _curry2(function match(rx, str) { + return str.match(rx) || []; + }); - var CloneReducer = function CloneReducer() { - _classCallCheck(this, CloneReducer); - }; + /** + * mathMod behaves like the modulo operator should mathematically, unlike the `%` + * operator (and by extension, R.modulo). So while "-17 % 5" is -2, + * mathMod(-17, 5) is 3. mathMod requires Integer arguments, and returns NaN + * when the modulus is zero or negative. + * + * @func + * @memberOf R + * @category Math + * @sig Number -> Number -> Number + * @param {Number} m The dividend. + * @param {Number} p the modulus. + * @return {Number} The result of `b mod a`. + * @example + * + * R.mathMod(-17, 5); //=> 3 + * R.mathMod(17, 5); //=> 2 + * R.mathMod(17, -5); //=> NaN + * R.mathMod(17, 0); //=> NaN + * R.mathMod(17.2, 5); //=> NaN + * R.mathMod(17, 5.3); //=> NaN + * + * var clock = R.mathMod(R.__, 12); + * clock(15); //=> 3 + * clock(24); //=> 0 + * + * var seventeenMod = R.mathMod(17); + * seventeenMod(3); //=> 2 + * seventeenMod(4); //=> 1 + * seventeenMod(10); //=> 7 + */ + var mathMod = _curry2(function mathMod(m, p) { + if (!_isInteger(m)) { + return NaN; + } + if (!_isInteger(p) || p < 1) { + return NaN; + } + return (m % p + p) % p; + }); - exports.default = CloneReducer; + /** + * Returns the larger of its two arguments. + * + * @func + * @memberOf R + * @category Relation + * @sig Ord a => a -> a -> a + * @param {*} a + * @param {*} b + * @return {*} + * @see R.maxBy, R.min + * @example + * + * R.max(789, 123); //=> 789 + * R.max('a', 'b'); //=> 'b' + */ + var max = _curry2(function max(a, b) { + return b > a ? b : a; + }); - for (var typeName in _shiftSpec2.default) { - var type = _shiftSpec2.default[typeName]; - Object.defineProperty(CloneReducer.prototype, "reduce" + typeName, { - value: function value(node, state) { - return state; - } - }); - } + /** + * Takes a function and two values, and returns whichever value produces + * the larger result when passed to the provided function. + * + * @func + * @memberOf R + * @category Relation + * @sig Ord b => (a -> b) -> a -> a -> a + * @param {Function} f + * @param {*} a + * @param {*} b + * @return {*} + * @see R.max, R.minBy + * @example + * + * R.maxBy(function(n) { return n * n; }, -3, 2); //=> -3 + */ + var maxBy = _curry3(function maxBy(f, a, b) { + return f(b) > f(a) ? b : a; + }); -/***/ }, -/* 35 */ -/***/ function(module, exports) { + /** + * Create a new object with the own properties of `a` + * merged with the own properties of object `b`. + * + * @func + * @memberOf R + * @category Object + * @sig {k: v} -> {k: v} -> {k: v} + * @param {Object} a + * @param {Object} b + * @return {Object} + * @example + * + * R.merge({ 'name': 'fred', 'age': 10 }, { 'age': 40 }); + * //=> { 'name': 'fred', 'age': 40 } + * + * var resetToDefault = R.merge(R.__, {x: 0}); + * resetToDefault({x: 5, y: 2}); //=> {x: 0, y: 2} + */ + var merge = _curry2(function merge(a, b) { + var result = {}; + var ks = keys(a); + var idx = 0; + while (idx < ks.length) { + result[ks[idx]] = a[ks[idx]]; + idx += 1; + } + ks = keys(b); + idx = 0; + while (idx < ks.length) { + result[ks[idx]] = b[ks[idx]]; + idx += 1; + } + return result; + }); - // Generated by src/generate-spec.js. + /** + * Returns the smaller of its two arguments. + * + * @func + * @memberOf R + * @category Relation + * @sig Ord a => a -> a -> a + * @param {*} a + * @param {*} b + * @return {*} + * @see R.minBy, R.max + * @example + * + * R.min(789, 123); //=> 123 + * R.min('a', 'b'); //=> 'a' + */ + var min = _curry2(function min(a, b) { + return b < a ? b : a; + }); - /** - * Copyright 2015 Shape Security, Inc. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ + /** + * Takes a function and two values, and returns whichever value produces + * the smaller result when passed to the provided function. + * + * @func + * @memberOf R + * @category Relation + * @sig Ord b => (a -> b) -> a -> a -> a + * @param {Function} f + * @param {*} a + * @param {*} b + * @return {*} + * @see R.min, R.maxBy + * @example + * + * R.minBy(function(n) { return n * n; }, -3, 2); //=> 2 + */ + var minBy = _curry3(function minBy(f, a, b) { + return f(b) < f(a) ? b : a; + }); - // Hack to make Babel6 import this as a module. - Object.defineProperty(exports, "__esModule", { - value: true - }); + /** + * Divides the second parameter by the first and returns the remainder. + * Note that this functions preserves the JavaScript-style behavior for + * modulo. For mathematical modulo see `mathMod` + * + * @func + * @memberOf R + * @category Math + * @sig Number -> Number -> Number + * @param {Number} a The value to the divide. + * @param {Number} b The pseudo-modulus + * @return {Number} The result of `b % a`. + * @see R.mathMod + * @example + * + * R.modulo(17, 3); //=> 2 + * // JS behavior: + * R.modulo(-17, 3); //=> -2 + * R.modulo(17, -3); //=> 2 + * + * var isOdd = R.modulo(R.__, 2); + * isOdd(42); //=> 0 + * isOdd(21); //=> 1 + */ + var modulo = _curry2(function modulo(a, b) { + return a % b; + }); - // Meta data generated from spec.idl. - exports.default = (function() { - var SPEC = {}; + /** + * Multiplies two numbers. Equivalent to `a * b` but curried. + * + * @func + * @memberOf R + * @category Math + * @sig Number -> Number -> Number + * @param {Number} a The first value. + * @param {Number} b The second value. + * @return {Number} The result of `a * b`. + * @see R.divide + * @example + * + * var double = R.multiply(2); + * var triple = R.multiply(3); + * double(3); //=> 6 + * triple(4); //=> 12 + * R.multiply(2, 5); //=> 10 + */ + var multiply = _curry2(function multiply(a, b) { + return a * b; + }); - var BOOLEAN = { typeName: "Boolean" }; - var DOUBLE = { typeName: "Number" }; - var STRING = { typeName: "String" }; - function Maybe(arg) { return { typeName: "Maybe", argument: arg }; } - function List(arg) { return { typeName: "List", argument: arg }; } - function Const(arg) { return { typeName: "Const", argument: arg }; } - function Union() { return { typeName: "Union", arguments: [].slice.call(arguments, 0) }; } + /** + * Wraps a function of any arity (including nullary) in a function that accepts exactly `n` + * parameters. Any extraneous parameters will not be passed to the supplied function. + * + * @func + * @memberOf R + * @category Function + * @sig Number -> (* -> a) -> (* -> a) + * @param {Number} n The desired arity of the new function. + * @param {Function} fn The function to wrap. + * @return {Function} A new function wrapping `fn`. The new function is guaranteed to be of + * arity `n`. + * @example + * + * var takesTwoArgs = function(a, b) { + * return [a, b]; + * }; + * takesTwoArgs.length; //=> 2 + * takesTwoArgs(1, 2); //=> [1, 2] + * + * var takesOneArg = R.nAry(1, takesTwoArgs); + * takesOneArg.length; //=> 1 + * // Only `n` arguments are passed to the wrapped function + * takesOneArg(1, 2); //=> [1, undefined] + */ + var nAry = _curry2(function nAry(n, fn) { + switch (n) { + case 0: + return function () { + return fn.call(this); + }; + case 1: + return function (a0) { + return fn.call(this, a0); + }; + case 2: + return function (a0, a1) { + return fn.call(this, a0, a1); + }; + case 3: + return function (a0, a1, a2) { + return fn.call(this, a0, a1, a2); + }; + case 4: + return function (a0, a1, a2, a3) { + return fn.call(this, a0, a1, a2, a3); + }; + case 5: + return function (a0, a1, a2, a3, a4) { + return fn.call(this, a0, a1, a2, a3, a4); + }; + case 6: + return function (a0, a1, a2, a3, a4, a5) { + return fn.call(this, a0, a1, a2, a3, a4, a5); + }; + case 7: + return function (a0, a1, a2, a3, a4, a5, a6) { + return fn.call(this, a0, a1, a2, a3, a4, a5, a6); + }; + case 8: + return function (a0, a1, a2, a3, a4, a5, a6, a7) { + return fn.call(this, a0, a1, a2, a3, a4, a5, a6, a7); + }; + case 9: + return function (a0, a1, a2, a3, a4, a5, a6, a7, a8) { + return fn.call(this, a0, a1, a2, a3, a4, a5, a6, a7, a8); + }; + case 10: + return function (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9) { + return fn.call(this, a0, a1, a2, a3, a4, a5, a6, a7, a8, a9); + }; + default: + throw new Error('First argument to nAry must be a non-negative integer no greater than ten'); + } + }); - var TYPE_INDICATOR = { - typeName: "Enum", - values: ["ArrayBinding", "ArrayExpression", "ArrowExpression", "AssignmentExpression", "BinaryExpression", "BindingIdentifier", "BindingProperty", "BindingPropertyIdentifier", "BindingPropertyProperty", "BindingWithDefault", "Block", "BlockStatement", "BreakStatement", "CallExpression", "CatchClause", "Class", "ClassDeclaration", "ClassElement", "ClassExpression", "CompoundAssignmentExpression", "ComputedMemberExpression", "ComputedPropertyName", "ConditionalExpression", "ContinueStatement", "DataProperty", "DebuggerStatement", "Directive", "DoWhileStatement", "EmptyStatement", "Export", "ExportAllFrom", "ExportDeclaration", "ExportDefault", "ExportFrom", "ExportSpecifier", "Expression", "ExpressionStatement", "ForInStatement", "ForOfStatement", "ForStatement", "FormalParameters", "Function", "FunctionBody", "FunctionDeclaration", "FunctionExpression", "Getter", "IdentifierExpression", "IfStatement", "Import", "ImportDeclaration", "ImportNamespace", "ImportSpecifier", "IterationStatement", "LabeledStatement", "LiteralBooleanExpression", "LiteralInfinityExpression", "LiteralNullExpression", "LiteralNumericExpression", "LiteralRegExpExpression", "LiteralStringExpression", "MemberExpression", "Method", "MethodDefinition", "Module", "NamedObjectProperty", "NewExpression", "NewTargetExpression", "Node", "ObjectBinding", "ObjectExpression", "ObjectProperty", "PropertyName", "ReturnStatement", "Script", "Setter", "ShorthandProperty", "SourceLocation", "SourceSpan", "SpreadElement", "Statement", "StaticMemberExpression", "StaticPropertyName", "Super", "SwitchCase", "SwitchDefault", "SwitchStatement", "SwitchStatementWithDefault", "TemplateElement", "TemplateExpression", "ThisExpression", "ThrowStatement", "TryCatchStatement", "TryFinallyStatement", "UnaryExpression", "UpdateExpression", "VariableDeclaration", "VariableDeclarationStatement", "VariableDeclarator", "WhileStatement", "WithStatement", "YieldExpression", "YieldGeneratorExpression"] - }; + /** + * Negates its argument. + * + * @func + * @memberOf R + * @category Math + * @sig Number -> Number + * @param {Number} n + * @return {Number} + * @example + * + * R.negate(42); //=> -42 + */ + var negate = _curry1(function negate(n) { + return -n; + }); - var VariableDeclarationKind = { - typeName: "Enum", - values: ["var", "let", "const"] - }; + /** + * A function that returns the `!` of its argument. It will return `true` when + * passed false-y value, and `false` when passed a truth-y one. + * + * @func + * @memberOf R + * @category Logic + * @sig * -> Boolean + * @param {*} a any value + * @return {Boolean} the logical inverse of passed argument. + * @see R.complement + * @example + * + * R.not(true); //=> false + * R.not(false); //=> true + * R.not(0); => true + * R.not(1); => false + */ + var not = _curry1(function not(a) { + return !a; + }); - var CompoundAssignmentOperator = { - typeName: "Enum", - values: ["+=", "-=", "*=", "/=", "%=", "<<=", ">>=", ">>>=", "|=", "^=", "&="] - }; + /** + * Returns the nth element of the given list or string. + * If n is negative the element at index length + n is returned. + * + * @func + * @memberOf R + * @category List + * @sig Number -> [a] -> a | Undefined + * @sig Number -> String -> String + * @param {Number} offset + * @param {*} list + * @return {*} + * @example + * + * var list = ['foo', 'bar', 'baz', 'quux']; + * R.nth(1, list); //=> 'bar' + * R.nth(-1, list); //=> 'quux' + * R.nth(-99, list); //=> undefined + * + * R.nth('abc', 2); //=> 'c' + * R.nth('abc', 3); //=> '' + */ + var nth = _curry2(function nth(offset, list) { + var idx = offset < 0 ? list.length + offset : offset; + return _isString(list) ? list.charAt(idx) : list[idx]; + }); - var BinaryOperator = { - typeName: "Enum", - values: ["==", "!=", "===", "!==", "<", "<=", ">", ">=", "in", "instanceof", "<<", ">>", ">>>", "+", "-", "*", "/", "%", ",", "||", "&&", "|", "^", "&"] - }; + /** + * Returns a function which returns its nth argument. + * + * @func + * @memberOf R + * @category Function + * @sig Number -> *... -> * + * @param {Number} n + * @return {Function} + * @example + * + * R.nthArg(1)('a', 'b', 'c'); //=> 'b' + * R.nthArg(-1)('a', 'b', 'c'); //=> 'c' + */ + var nthArg = _curry1(function nthArg(n) { + return function () { + return nth(n, arguments); + }; + }); - var UnaryOperator = { - typeName: "Enum", - values: ["+", "-", "!", "~", "typeof", "void", "delete"] - }; + /** + * Returns the nth character of the given string. + * + * @func + * @memberOf R + * @category String + * @sig Number -> String -> String + * @param {Number} n + * @param {String} str + * @return {String} + * @deprecated since v0.16.0 + * @example + * + * R.nthChar(2, 'Ramda'); //=> 'm' + * R.nthChar(-2, 'Ramda'); //=> 'd' + */ + var nthChar = _curry2(function nthChar(n, str) { + return str.charAt(n < 0 ? str.length + n : n); + }); - var UpdateOperator = { - typeName: "Enum", - values: ["++", "--"] - }; + /** + * Returns the character code of the nth character of the given string. + * + * @func + * @memberOf R + * @category String + * @sig Number -> String -> Number + * @param {Number} n + * @param {String} str + * @return {Number} + * @deprecated since v0.16.0 + * @example + * + * R.nthCharCode(2, 'Ramda'); //=> 'm'.charCodeAt(0) + * R.nthCharCode(-2, 'Ramda'); //=> 'd'.charCodeAt(0) + */ + var nthCharCode = _curry2(function nthCharCode(n, str) { + return str.charCodeAt(n < 0 ? str.length + n : n); + }); - var SourceLocation = SPEC.SourceLocation = {}; - var SourceSpan = SPEC.SourceSpan = {}; - var BindingWithDefault = SPEC.BindingWithDefault = {}; - var BindingIdentifier = SPEC.BindingIdentifier = {}; - var ArrayBinding = SPEC.ArrayBinding = {}; - var ObjectBinding = SPEC.ObjectBinding = {}; - var BindingPropertyIdentifier = SPEC.BindingPropertyIdentifier = {}; - var BindingPropertyProperty = SPEC.BindingPropertyProperty = {}; - var ClassExpression = SPEC.ClassExpression = {}; - var ClassDeclaration = SPEC.ClassDeclaration = {}; - var ClassElement = SPEC.ClassElement = {}; - var Module = SPEC.Module = {}; - var Import = SPEC.Import = {}; - var ImportNamespace = SPEC.ImportNamespace = {}; - var ImportSpecifier = SPEC.ImportSpecifier = {}; - var ExportAllFrom = SPEC.ExportAllFrom = {}; - var ExportFrom = SPEC.ExportFrom = {}; - var Export = SPEC.Export = {}; - var ExportDefault = SPEC.ExportDefault = {}; - var ExportSpecifier = SPEC.ExportSpecifier = {}; - var Method = SPEC.Method = {}; - var Getter = SPEC.Getter = {}; - var Setter = SPEC.Setter = {}; - var DataProperty = SPEC.DataProperty = {}; - var ShorthandProperty = SPEC.ShorthandProperty = {}; - var ComputedPropertyName = SPEC.ComputedPropertyName = {}; - var StaticPropertyName = SPEC.StaticPropertyName = {}; - var LiteralBooleanExpression = SPEC.LiteralBooleanExpression = {}; - var LiteralInfinityExpression = SPEC.LiteralInfinityExpression = {}; - var LiteralNullExpression = SPEC.LiteralNullExpression = {}; - var LiteralNumericExpression = SPEC.LiteralNumericExpression = {}; - var LiteralRegExpExpression = SPEC.LiteralRegExpExpression = {}; - var LiteralStringExpression = SPEC.LiteralStringExpression = {}; - var ArrayExpression = SPEC.ArrayExpression = {}; - var ArrowExpression = SPEC.ArrowExpression = {}; - var AssignmentExpression = SPEC.AssignmentExpression = {}; - var BinaryExpression = SPEC.BinaryExpression = {}; - var CallExpression = SPEC.CallExpression = {}; - var CompoundAssignmentExpression = SPEC.CompoundAssignmentExpression = {}; - var ComputedMemberExpression = SPEC.ComputedMemberExpression = {}; - var ConditionalExpression = SPEC.ConditionalExpression = {}; - var FunctionExpression = SPEC.FunctionExpression = {}; - var IdentifierExpression = SPEC.IdentifierExpression = {}; - var NewExpression = SPEC.NewExpression = {}; - var NewTargetExpression = SPEC.NewTargetExpression = {}; - var ObjectExpression = SPEC.ObjectExpression = {}; - var UnaryExpression = SPEC.UnaryExpression = {}; - var StaticMemberExpression = SPEC.StaticMemberExpression = {}; - var TemplateExpression = SPEC.TemplateExpression = {}; - var ThisExpression = SPEC.ThisExpression = {}; - var UpdateExpression = SPEC.UpdateExpression = {}; - var YieldExpression = SPEC.YieldExpression = {}; - var YieldGeneratorExpression = SPEC.YieldGeneratorExpression = {}; - var BlockStatement = SPEC.BlockStatement = {}; - var BreakStatement = SPEC.BreakStatement = {}; - var ContinueStatement = SPEC.ContinueStatement = {}; - var DebuggerStatement = SPEC.DebuggerStatement = {}; - var DoWhileStatement = SPEC.DoWhileStatement = {}; - var EmptyStatement = SPEC.EmptyStatement = {}; - var ExpressionStatement = SPEC.ExpressionStatement = {}; - var ForInStatement = SPEC.ForInStatement = {}; - var ForOfStatement = SPEC.ForOfStatement = {}; - var ForStatement = SPEC.ForStatement = {}; - var IfStatement = SPEC.IfStatement = {}; - var LabeledStatement = SPEC.LabeledStatement = {}; - var ReturnStatement = SPEC.ReturnStatement = {}; - var SwitchStatement = SPEC.SwitchStatement = {}; - var SwitchStatementWithDefault = SPEC.SwitchStatementWithDefault = {}; - var ThrowStatement = SPEC.ThrowStatement = {}; - var TryCatchStatement = SPEC.TryCatchStatement = {}; - var TryFinallyStatement = SPEC.TryFinallyStatement = {}; - var VariableDeclarationStatement = SPEC.VariableDeclarationStatement = {}; - var WhileStatement = SPEC.WhileStatement = {}; - var WithStatement = SPEC.WithStatement = {}; - var Block = SPEC.Block = {}; - var CatchClause = SPEC.CatchClause = {}; - var Directive = SPEC.Directive = {}; - var FormalParameters = SPEC.FormalParameters = {}; - var FunctionBody = SPEC.FunctionBody = {}; - var FunctionDeclaration = SPEC.FunctionDeclaration = {}; - var Script = SPEC.Script = {}; - var SpreadElement = SPEC.SpreadElement = {}; - var Super = SPEC.Super = {}; - var SwitchCase = SPEC.SwitchCase = {}; - var SwitchDefault = SPEC.SwitchDefault = {}; - var TemplateElement = SPEC.TemplateElement = {}; - var VariableDeclaration = SPEC.VariableDeclaration = {}; - var VariableDeclarator = SPEC.VariableDeclarator = {}; - - var Class = Union(ClassExpression, ClassDeclaration); - var BindingProperty = Union(BindingPropertyIdentifier, BindingPropertyProperty); - var ExportDeclaration = Union(ExportAllFrom, ExportFrom, Export, ExportDefault); - var ImportDeclaration = Union(Import, ImportNamespace); - var MethodDefinition = Union(Method, Getter, Setter); - var NamedObjectProperty = Union(MethodDefinition, DataProperty); - var ObjectProperty = Union(NamedObjectProperty, ShorthandProperty); - var PropertyName = Union(ComputedPropertyName, StaticPropertyName); - var MemberExpression = Union(ComputedMemberExpression, StaticMemberExpression); - var Expression = Union(MemberExpression, ClassExpression, LiteralBooleanExpression, LiteralInfinityExpression, LiteralNullExpression, LiteralNumericExpression, LiteralRegExpExpression, LiteralStringExpression, ArrayExpression, ArrowExpression, AssignmentExpression, BinaryExpression, CallExpression, CompoundAssignmentExpression, ConditionalExpression, FunctionExpression, IdentifierExpression, NewExpression, NewTargetExpression, ObjectExpression, UnaryExpression, TemplateExpression, ThisExpression, UpdateExpression, YieldExpression, YieldGeneratorExpression); - var IterationStatement = Union(DoWhileStatement, ForInStatement, ForOfStatement, ForStatement, WhileStatement); - var Statement = Union(IterationStatement, ClassDeclaration, BlockStatement, BreakStatement, ContinueStatement, DebuggerStatement, EmptyStatement, ExpressionStatement, IfStatement, LabeledStatement, ReturnStatement, SwitchStatement, SwitchStatementWithDefault, ThrowStatement, TryCatchStatement, TryFinallyStatement, VariableDeclarationStatement, WithStatement, FunctionDeclaration); - var Node = Union(Statement, Expression, PropertyName, ObjectProperty, ImportDeclaration, ExportDeclaration, BindingWithDefault, BindingIdentifier, ArrayBinding, ObjectBinding, BindingProperty, ClassElement, Module, ImportSpecifier, ExportSpecifier, Block, CatchClause, Directive, FormalParameters, FunctionBody, Script, SpreadElement, Super, SwitchCase, SwitchDefault, TemplateElement, VariableDeclaration, VariableDeclarator); - var Function = Union(FunctionExpression, FunctionDeclaration); - - SourceLocation.typeName = "SourceLocation"; - SourceLocation.fields = [ - { name: "line", type: DOUBLE }, - { name: "column", type: DOUBLE }, - { name: "offset", type: DOUBLE }, - ]; + /** + * Returns a singleton array containing the value provided. + * + * Note this `of` is different from the ES6 `of`; See + * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/of + * + * @func + * @memberOf R + * @category Function + * @sig a -> [a] + * @param {*} x any value + * @return {Array} An array wrapping `x`. + * @example + * + * R.of(null); //=> [null] + * R.of([42]); //=> [[42]] + */ + var of = _curry1(function of(x) { + return [x]; + }); - SourceSpan.typeName = "SourceSpan"; - SourceSpan.fields = [ - { name: "source", type: Maybe(STRING) }, - { name: "start", type: SourceLocation }, - { name: "end", type: SourceLocation }, - ]; + /** + * Accepts a function `fn` and returns a function that guards invocation of `fn` such that + * `fn` can only ever be called once, no matter how many times the returned function is + * invoked. + * + * @func + * @memberOf R + * @category Function + * @sig (a... -> b) -> (a... -> b) + * @param {Function} fn The function to wrap in a call-only-once wrapper. + * @return {Function} The wrapped function. + * @example + * + * var addOneOnce = R.once(function(x){ return x + 1; }); + * addOneOnce(10); //=> 11 + * addOneOnce(addOneOnce(50)); //=> 11 + */ + var once = _curry1(function once(fn) { + var called = false, result; + return function () { + if (called) { + return result; + } + called = true; + result = fn.apply(this, arguments); + return result; + }; + }); - BindingWithDefault.typeName = "BindingWithDefault"; - BindingWithDefault.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "BindingWithDefault" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "binding", type: Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression) }, - { name: "init", type: Expression }, - ]; + /** + * Returns the result of "setting" the portion of the given data structure + * focused by the given lens to the given value. + * + * @func + * @memberOf R + * @category Object + * @typedef Lens s a = Functor f => (a -> f a) -> s -> f s + * @sig Lens s a -> (a -> a) -> s -> s + * @param {Lens} lens + * @param {*} v + * @param {*} x + * @return {*} + * @see R.prop, R.lensIndex, R.lensProp + * @example + * + * var headLens = R.lensIndex(0); + * + * R.over(headLens, R.toUpper, ['foo', 'bar', 'baz']); //=> ['FOO', 'bar', 'baz'] + */ + var over = function () { + var Identity = function (x) { + return { + value: x, + map: function (f) { + return Identity(f(x)); + } + }; + }; + return _curry3(function over(lens, f, x) { + return lens(function (y) { + return Identity(f(y)); + })(x).value; + }); + }(); - BindingIdentifier.typeName = "BindingIdentifier"; - BindingIdentifier.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "BindingIdentifier" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "name", type: STRING }, - ]; + /** + * Retrieve the value at a given path. + * + * @func + * @memberOf R + * @category Object + * @sig [String] -> {k: v} -> v | Undefined + * @param {Array} path The path to use. + * @return {*} The data at `path`. + * @example + * + * R.path(['a', 'b'], {a: {b: 2}}); //=> 2 + * R.path(['a', 'b'], {c: {b: 2}}); //=> undefined + */ + var path = _curry2(function path(paths, obj) { + if (obj == null) { + return; + } else { + var val = obj; + for (var idx = 0, len = paths.length; idx < len && val != null; idx += 1) { + val = val[paths[idx]]; + } + return val; + } + }); - ArrayBinding.typeName = "ArrayBinding"; - ArrayBinding.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ArrayBinding" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "elements", type: List(Maybe(Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression, BindingWithDefault))) }, - { name: "restElement", type: Maybe(Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression)) }, - ]; + /** + * Returns a partial copy of an object containing only the keys specified. If the key does not exist, the + * property is ignored. + * + * @func + * @memberOf R + * @category Object + * @sig [k] -> {k: v} -> {k: v} + * @param {Array} names an array of String property names to copy onto a new object + * @param {Object} obj The object to copy from + * @return {Object} A new object with only properties from `names` on it. + * @see R.omit + * @example + * + * R.pick(['a', 'd'], {a: 1, b: 2, c: 3, d: 4}); //=> {a: 1, d: 4} + * R.pick(['a', 'e', 'f'], {a: 1, b: 2, c: 3, d: 4}); //=> {a: 1} + */ + var pick = _curry2(function pick(names, obj) { + var result = {}; + var idx = 0; + while (idx < names.length) { + if (names[idx] in obj) { + result[names[idx]] = obj[names[idx]]; + } + idx += 1; + } + return result; + }); - ObjectBinding.typeName = "ObjectBinding"; - ObjectBinding.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ObjectBinding" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "properties", type: List(BindingProperty) }, - ]; + /** + * Similar to `pick` except that this one includes a `key: undefined` pair for properties that don't exist. + * + * @func + * @memberOf R + * @category Object + * @sig [k] -> {k: v} -> {k: v} + * @param {Array} names an array of String property names to copy onto a new object + * @param {Object} obj The object to copy from + * @return {Object} A new object with only properties from `names` on it. + * @see R.pick + * @example + * + * R.pickAll(['a', 'd'], {a: 1, b: 2, c: 3, d: 4}); //=> {a: 1, d: 4} + * R.pickAll(['a', 'e', 'f'], {a: 1, b: 2, c: 3, d: 4}); //=> {a: 1, e: undefined, f: undefined} + */ + var pickAll = _curry2(function pickAll(names, obj) { + var result = {}; + var idx = 0; + var len = names.length; + while (idx < len) { + var name = names[idx]; + result[name] = obj[name]; + idx += 1; + } + return result; + }); - BindingPropertyIdentifier.typeName = "BindingPropertyIdentifier"; - BindingPropertyIdentifier.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "BindingPropertyIdentifier" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "binding", type: BindingIdentifier }, - { name: "init", type: Maybe(Expression) }, - ]; + /** + * Returns a partial copy of an object containing only the keys that + * satisfy the supplied predicate. + * + * @func + * @memberOf R + * @category Object + * @sig (v, k -> Boolean) -> {k: v} -> {k: v} + * @param {Function} pred A predicate to determine whether or not a key + * should be included on the output object. + * @param {Object} obj The object to copy from + * @return {Object} A new object with only properties that satisfy `pred` + * on it. + * @see R.pick + * @example + * + * var isUpperCase = function(val, key) { return key.toUpperCase() === key; } + * R.pickBy(isUpperCase, {a: 1, b: 2, A: 3, B: 4}); //=> {A: 3, B: 4} + */ + var pickBy = _curry2(function pickBy(test, obj) { + var result = {}; + for (var prop in obj) { + if (test(obj[prop], prop, obj)) { + result[prop] = obj[prop]; + } + } + return result; + }); - BindingPropertyProperty.typeName = "BindingPropertyProperty"; - BindingPropertyProperty.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "BindingPropertyProperty" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "name", type: PropertyName }, - { name: "binding", type: Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression, BindingWithDefault) }, - ]; + /** + * Returns a new list with the given element at the front, followed by the contents of the + * list. + * + * @func + * @memberOf R + * @category List + * @sig a -> [a] -> [a] + * @param {*} el The item to add to the head of the output list. + * @param {Array} list The array to add to the tail of the output list. + * @return {Array} A new array. + * @see R.append + * @example + * + * R.prepend('fee', ['fi', 'fo', 'fum']); //=> ['fee', 'fi', 'fo', 'fum'] + */ + var prepend = _curry2(function prepend(el, list) { + return _concat([el], list); + }); - ClassExpression.typeName = "ClassExpression"; - ClassExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ClassExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "name", type: Maybe(BindingIdentifier) }, - { name: "super", type: Maybe(Expression) }, - { name: "elements", type: List(ClassElement) }, - ]; + /** + * Returns a function that when supplied an object returns the indicated property of that object, if it exists. + * + * @func + * @memberOf R + * @category Object + * @sig s -> {s: a} -> a | Undefined + * @param {String} p The property name + * @param {Object} obj The object to query + * @return {*} The value at `obj.p`. + * @example + * + * R.prop('x', {x: 100}); //=> 100 + * R.prop('x', {}); //=> undefined + */ + var prop = _curry2(function prop(p, obj) { + return obj[p]; + }); - ClassDeclaration.typeName = "ClassDeclaration"; - ClassDeclaration.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ClassDeclaration" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "name", type: BindingIdentifier }, - { name: "super", type: Maybe(Expression) }, - { name: "elements", type: List(ClassElement) }, - ]; + /** + * If the given, non-null object has an own property with the specified name, + * returns the value of that property. + * Otherwise returns the provided default value. + * + * @func + * @memberOf R + * @category Object + * @sig a -> String -> Object -> a + * @param {*} val The default value. + * @param {String} p The name of the property to return. + * @param {Object} obj The object to query. + * @return {*} The value of given property of the supplied object or the default value. + * @example + * + * var alice = { + * name: 'ALICE', + * age: 101 + * }; + * var favorite = R.prop('favoriteLibrary'); + * var favoriteWithDefault = R.propOr('Ramda', 'favoriteLibrary'); + * + * favorite(alice); //=> undefined + * favoriteWithDefault(alice); //=> 'Ramda' + */ + var propOr = _curry3(function propOr(val, p, obj) { + return obj != null && _has(p, obj) ? obj[p] : val; + }); - ClassElement.typeName = "ClassElement"; - ClassElement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ClassElement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "isStatic", type: BOOLEAN }, - { name: "method", type: MethodDefinition }, - ]; + /** + * Returns `true` if the specified object property satisfies the given + * predicate; `false` otherwise. + * + * @func + * @memberOf R + * @category Logic + * @sig (a -> Boolean) -> String -> {String: a} -> Boolean + * @param {Function} pred + * @param {String} name + * @param {*} obj + * @return {Boolean} + * @see R.propEq + * @see R.propIs + * @example + * + * R.propSatisfies(x => x > 0, 'x', {x: 1, y: 2}); //=> true + */ + var propSatisfies = _curry3(function propSatisfies(pred, name, obj) { + return pred(obj[name]); + }); - Module.typeName = "Module"; - Module.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "Module" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "directives", type: List(Directive) }, - { name: "items", type: List(Union(ImportDeclaration, ExportDeclaration, Statement)) }, - ]; + /** + * Acts as multiple `prop`: array of keys in, array of values out. Preserves order. + * + * @func + * @memberOf R + * @category Object + * @sig [k] -> {k: v} -> [v] + * @param {Array} ps The property names to fetch + * @param {Object} obj The object to query + * @return {Array} The corresponding values or partially applied function. + * @example + * + * R.props(['x', 'y'], {x: 1, y: 2}); //=> [1, 2] + * R.props(['c', 'a', 'b'], {b: 2, a: 1}); //=> [undefined, 1, 2] + * + * var fullName = R.compose(R.join(' '), R.props(['first', 'last'])); + * fullName({last: 'Bullet-Tooth', age: 33, first: 'Tony'}); //=> 'Tony Bullet-Tooth' + */ + var props = _curry2(function props(ps, obj) { + var len = ps.length; + var out = []; + var idx = 0; + while (idx < len) { + out[idx] = obj[ps[idx]]; + idx += 1; + } + return out; + }); - Import.typeName = "Import"; - Import.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "Import" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "moduleSpecifier", type: STRING }, - { name: "defaultBinding", type: Maybe(BindingIdentifier) }, - { name: "namedImports", type: List(ImportSpecifier) }, - ]; + /** + * Returns a list of numbers from `from` (inclusive) to `to` + * (exclusive). + * + * @func + * @memberOf R + * @category List + * @sig Number -> Number -> [Number] + * @param {Number} from The first number in the list. + * @param {Number} to One more than the last number in the list. + * @return {Array} The list of numbers in tthe set `[a, b)`. + * @example + * + * R.range(1, 5); //=> [1, 2, 3, 4] + * R.range(50, 53); //=> [50, 51, 52] + */ + var range = _curry2(function range(from, to) { + if (!(_isNumber(from) && _isNumber(to))) { + throw new TypeError('Both arguments to range must be numbers'); + } + var result = []; + var n = from; + while (n < to) { + result.push(n); + n += 1; + } + return result; + }); - ImportNamespace.typeName = "ImportNamespace"; - ImportNamespace.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ImportNamespace" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "moduleSpecifier", type: STRING }, - { name: "defaultBinding", type: Maybe(BindingIdentifier) }, - { name: "namespaceBinding", type: BindingIdentifier }, - ]; - - ImportSpecifier.typeName = "ImportSpecifier"; - ImportSpecifier.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ImportSpecifier" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "name", type: Maybe(STRING) }, - { name: "binding", type: BindingIdentifier }, - ]; - - ExportAllFrom.typeName = "ExportAllFrom"; - ExportAllFrom.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ExportAllFrom" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "moduleSpecifier", type: STRING }, - ]; - - ExportFrom.typeName = "ExportFrom"; - ExportFrom.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ExportFrom" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "namedExports", type: List(ExportSpecifier) }, - { name: "moduleSpecifier", type: Maybe(STRING) }, - ]; - - Export.typeName = "Export"; - Export.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "Export" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "declaration", type: Union(FunctionDeclaration, ClassDeclaration, VariableDeclaration) }, - ]; + /** + * Returns a single item by iterating through the list, successively calling the iterator + * function and passing it an accumulator value and the current value from the array, and + * then passing the result to the next call. + * + * Similar to `reduce`, except moves through the input list from the right to the left. + * + * The iterator function receives two values: *(acc, value)* + * + * Note: `R.reduceRight` does not skip deleted or unassigned indices (sparse arrays), unlike + * the native `Array.prototype.reduce` method. For more details on this behavior, see: + * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduceRight#Description + * + * @func + * @memberOf R + * @category List + * @sig (a,b -> a) -> a -> [b] -> a + * @param {Function} fn The iterator function. Receives two values, the accumulator and the + * current element from the array. + * @param {*} acc The accumulator value. + * @param {Array} list The list to iterate over. + * @return {*} The final, accumulated value. + * @example + * + * var pairs = [ ['a', 1], ['b', 2], ['c', 3] ]; + * var flattenPairs = function(acc, pair) { + * return acc.concat(pair); + * }; + * + * R.reduceRight(flattenPairs, [], pairs); //=> [ 'c', 3, 'b', 2, 'a', 1 ] + */ + var reduceRight = _curry3(function reduceRight(fn, acc, list) { + var idx = list.length - 1; + while (idx >= 0) { + acc = fn(acc, list[idx]); + idx -= 1; + } + return acc; + }); - ExportDefault.typeName = "ExportDefault"; - ExportDefault.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ExportDefault" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "body", type: Union(FunctionDeclaration, ClassDeclaration, Expression) }, - ]; + /** + * Returns a value wrapped to indicate that it is the final value of the + * reduce and transduce functions. The returned value + * should be considered a black box: the internal structure is not + * guaranteed to be stable. + * + * Note: this optimization is unavailable to functions not explicitly listed + * above. For instance, it is not currently supported by reduceIndexed, + * reduceRight, or reduceRightIndexed. + * + * @func + * @memberOf R + * @category List + * @see R.reduce, R.transduce + * @sig a -> * + * @param {*} x The final value of the reduce. + * @return {*} The wrapped value. + * @example + * + * R.reduce( + * R.pipe(R.add, R.ifElse(R.lte(10), R.reduced, R.identity)), + * 0, + * [1, 2, 3, 4, 5]) // 10 + */ + var reduced = _curry1(_reduced); - ExportSpecifier.typeName = "ExportSpecifier"; - ExportSpecifier.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ExportSpecifier" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "name", type: Maybe(STRING) }, - { name: "exportedName", type: STRING }, - ]; + /** + * Removes the sub-list of `list` starting at index `start` and containing + * `count` elements. _Note that this is not destructive_: it returns a + * copy of the list with the changes. + * No lists have been harmed in the application of this function. + * + * @func + * @memberOf R + * @category List + * @sig Number -> Number -> [a] -> [a] + * @param {Number} start The position to start removing elements + * @param {Number} count The number of elements to remove + * @param {Array} list The list to remove from + * @return {Array} A new Array with `count` elements from `start` removed. + * @example + * + * R.remove(2, 3, [1,2,3,4,5,6,7,8]); //=> [1,2,6,7,8] + */ + var remove = _curry3(function remove(start, count, list) { + return _concat(_slice(list, 0, Math.min(start, list.length)), _slice(list, Math.min(list.length, start + count))); + }); - Method.typeName = "Method"; - Method.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "Method" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "name", type: PropertyName }, - { name: "isGenerator", type: BOOLEAN }, - { name: "params", type: FormalParameters }, - { name: "body", type: FunctionBody }, - ]; + /** + * Replace a substring or regex match in a string with a replacement. + * + * @func + * @memberOf R + * @category String + * @sig RegExp|String -> String -> String -> String + * @param {RegExp|String} pattern A regular expression or a substring to match. + * @param {String} replacement The string to replace the matches with. + * @param {String} str The String to do the search and replacement in. + * @return {String} The result. + * @example + * + * R.replace('foo', 'bar', 'foo foo foo'); //=> 'bar foo foo' + * R.replace(/foo/, 'bar', 'foo foo foo'); //=> 'bar foo foo' + * + * // Use the "g" (global) flag to replace all occurrences: + * R.replace(/foo/g, 'bar', 'foo foo foo'); //=> 'bar bar bar' + */ + var replace = _curry3(function replace(regex, replacement, str) { + return str.replace(regex, replacement); + }); - Getter.typeName = "Getter"; - Getter.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "Getter" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "name", type: PropertyName }, - { name: "body", type: FunctionBody }, - ]; + /** + * Returns a new list with the same elements as the original list, just + * in the reverse order. + * + * @func + * @memberOf R + * @category List + * @sig [a] -> [a] + * @param {Array} list The list to reverse. + * @return {Array} A copy of the list in reverse order. + * @example + * + * R.reverse([1, 2, 3]); //=> [3, 2, 1] + * R.reverse([1, 2]); //=> [2, 1] + * R.reverse([1]); //=> [1] + * R.reverse([]); //=> [] + */ + var reverse = _curry1(function reverse(list) { + return _slice(list).reverse(); + }); - Setter.typeName = "Setter"; - Setter.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "Setter" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "name", type: PropertyName }, - { name: "param", type: Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression, BindingWithDefault) }, - { name: "body", type: FunctionBody }, - ]; + /** + * Scan is similar to reduce, but returns a list of successively reduced values from the left + * + * @func + * @memberOf R + * @category List + * @sig (a,b -> a) -> a -> [b] -> [a] + * @param {Function} fn The iterator function. Receives two values, the accumulator and the + * current element from the array + * @param {*} acc The accumulator value. + * @param {Array} list The list to iterate over. + * @return {Array} A list of all intermediately reduced values. + * @example + * + * var numbers = [1, 2, 3, 4]; + * var factorials = R.scan(R.multiply, 1, numbers); //=> [1, 1, 2, 6, 24] + */ + var scan = _curry3(function scan(fn, acc, list) { + var idx = 0, len = list.length, result = [acc]; + while (idx < len) { + acc = fn(acc, list[idx]); + result[idx + 1] = acc; + idx += 1; + } + return result; + }); - DataProperty.typeName = "DataProperty"; - DataProperty.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "DataProperty" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "name", type: PropertyName }, - { name: "expression", type: Expression }, - ]; + /** + * Returns the result of "setting" the portion of the given data structure + * focused by the given lens to the given value. + * + * @func + * @memberOf R + * @category Object + * @typedef Lens s a = Functor f => (a -> f a) -> s -> f s + * @sig Lens s a -> a -> s -> s + * @param {Lens} lens + * @param {*} v + * @param {*} x + * @return {*} + * @see R.prop, R.lensIndex, R.lensProp + * @example + * + * var xLens = R.lensProp('x'); + * + * R.set(xLens, 4, {x: 1, y: 2}); //=> {x: 4, y: 2} + * R.set(xLens, 8, {x: 1, y: 2}); //=> {x: 8, y: 2} + */ + var set = _curry3(function set(lens, v, x) { + return over(lens, always(v), x); + }); - ShorthandProperty.typeName = "ShorthandProperty"; - ShorthandProperty.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ShorthandProperty" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "name", type: STRING }, - ]; + /** + * Returns a copy of the list, sorted according to the comparator function, which should accept two values at a + * time and return a negative number if the first value is smaller, a positive number if it's larger, and zero + * if they are equal. Please note that this is a **copy** of the list. It does not modify the original. + * + * @func + * @memberOf R + * @category List + * @sig (a,a -> Number) -> [a] -> [a] + * @param {Function} comparator A sorting function :: a -> b -> Int + * @param {Array} list The list to sort + * @return {Array} a new array with its elements sorted by the comparator function. + * @example + * + * var diff = function(a, b) { return a - b; }; + * R.sort(diff, [4,2,7,5]); //=> [2, 4, 5, 7] + */ + var sort = _curry2(function sort(comparator, list) { + return _slice(list).sort(comparator); + }); - ComputedPropertyName.typeName = "ComputedPropertyName"; - ComputedPropertyName.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ComputedPropertyName" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "expression", type: Expression }, - ]; + /** + * Sorts the list according to the supplied function. + * + * @func + * @memberOf R + * @category Relation + * @sig Ord b => (a -> b) -> [a] -> [a] + * @param {Function} fn + * @param {Array} list The list to sort. + * @return {Array} A new list sorted by the keys generated by `fn`. + * @example + * + * var sortByFirstItem = R.sortBy(prop(0)); + * var sortByNameCaseInsensitive = R.sortBy(R.compose(R.toLower, R.prop('name'))); + * var pairs = [[-1, 1], [-2, 2], [-3, 3]]; + * sortByFirstItem(pairs); //=> [[-3, 3], [-2, 2], [-1, 1]] + * var alice = { + * name: 'ALICE', + * age: 101 + * }; + * var bob = { + * name: 'Bob', + * age: -10 + * }; + * var clara = { + * name: 'clara', + * age: 314.159 + * }; + * var people = [clara, bob, alice]; + * sortByNameCaseInsensitive(people); //=> [alice, bob, clara] + */ + var sortBy = _curry2(function sortBy(fn, list) { + return _slice(list).sort(function (a, b) { + var aa = fn(a); + var bb = fn(b); + return aa < bb ? -1 : aa > bb ? 1 : 0; + }); + }); - StaticPropertyName.typeName = "StaticPropertyName"; - StaticPropertyName.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "StaticPropertyName" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "value", type: STRING }, - ]; + /** + * Subtracts two numbers. Equivalent to `a - b` but curried. + * + * @func + * @memberOf R + * @category Math + * @sig Number -> Number -> Number + * @param {Number} a The first value. + * @param {Number} b The second value. + * @return {Number} The result of `a - b`. + * @see R.add + * @example + * + * R.subtract(10, 8); //=> 2 + * + * var minus5 = R.subtract(R.__, 5); + * minus5(17); //=> 12 + * + * var complementaryAngle = R.subtract(90); + * complementaryAngle(30); //=> 60 + * complementaryAngle(72); //=> 18 + */ + var subtract = _curry2(function subtract(a, b) { + return a - b; + }); - LiteralBooleanExpression.typeName = "LiteralBooleanExpression"; - LiteralBooleanExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "LiteralBooleanExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "value", type: BOOLEAN }, - ]; + /** + * Returns a new list containing the last `n` elements of a given list, passing each value + * to the supplied predicate function, and terminating when the predicate function returns + * `false`. Excludes the element that caused the predicate function to fail. The predicate + * function is passed one argument: *(value)*. + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> [a] + * @param {Function} fn The function called per iteration. + * @param {Array} list The collection to iterate over. + * @return {Array} A new array. + * @see R.dropLastWhile + * @example + * + * var isNotOne = function(x) { + * return !(x === 1); + * }; + * + * R.takeLastWhile(isNotOne, [1, 2, 3, 4]); //=> [2, 3, 4] + */ + var takeLastWhile = _curry2(function takeLastWhile(fn, list) { + var idx = list.length - 1; + while (idx >= 0 && fn(list[idx])) { + idx -= 1; + } + return _slice(list, idx + 1, Infinity); + }); - LiteralInfinityExpression.typeName = "LiteralInfinityExpression"; - LiteralInfinityExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "LiteralInfinityExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - ]; + /** + * Runs the given function with the supplied object, then returns the object. + * + * @func + * @memberOf R + * @category Function + * @sig (a -> *) -> a -> a + * @param {Function} fn The function to call with `x`. The return value of `fn` will be thrown away. + * @param {*} x + * @return {*} `x`. + * @example + * + * var sayX = function(x) { console.log('x is ' + x); }; + * R.tap(sayX, 100); //=> 100 + * //-> 'x is 100' + */ + var tap = _curry2(function tap(fn, x) { + fn(x); + return x; + }); - LiteralNullExpression.typeName = "LiteralNullExpression"; - LiteralNullExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "LiteralNullExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - ]; + /** + * Determines whether a given string matches a given regular expression. + * + * @func + * @memberOf R + * @see R.match + * @category String + * @sig RegExp -> String -> Boolean + * @param {RegExp} pattern + * @param {String} str + * @return {Boolean} + * @example + * + * R.test(/^x/, 'xyz'); //=> true + * R.test(/^y/, 'xyz'); //=> false + */ + var test = _curry2(function test(pattern, str) { + return _cloneRegExp(pattern).test(str); + }); - LiteralNumericExpression.typeName = "LiteralNumericExpression"; - LiteralNumericExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "LiteralNumericExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "value", type: DOUBLE }, - ]; + /** + * Calls an input function `n` times, returning an array containing the results of those + * function calls. + * + * `fn` is passed one argument: The current value of `n`, which begins at `0` and is + * gradually incremented to `n - 1`. + * + * @func + * @memberOf R + * @category List + * @sig (i -> a) -> i -> [a] + * @param {Function} fn The function to invoke. Passed one argument, the current value of `n`. + * @param {Number} n A value between `0` and `n - 1`. Increments after each function call. + * @return {Array} An array containing the return values of all calls to `fn`. + * @example + * + * R.times(R.identity, 5); //=> [0, 1, 2, 3, 4] + */ + var times = _curry2(function times(fn, n) { + var len = Number(n); + var list = new Array(len); + var idx = 0; + while (idx < len) { + list[idx] = fn(idx); + idx += 1; + } + return list; + }); - LiteralRegExpExpression.typeName = "LiteralRegExpExpression"; - LiteralRegExpExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "LiteralRegExpExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "pattern", type: STRING }, - { name: "flags", type: STRING }, - ]; + /** + * Converts an object into an array of key, value arrays. + * Only the object's own properties are used. + * Note that the order of the output array is not guaranteed to be + * consistent across different JS platforms. + * + * @func + * @memberOf R + * @category Object + * @sig {String: *} -> [[String,*]] + * @param {Object} obj The object to extract from + * @return {Array} An array of key, value arrays from the object's own properties. + * @see R.fromPairs + * @example + * + * R.toPairs({a: 1, b: 2, c: 3}); //=> [['a', 1], ['b', 2], ['c', 3]] + */ + var toPairs = _curry1(function toPairs(obj) { + var pairs = []; + for (var prop in obj) { + if (_has(prop, obj)) { + pairs[pairs.length] = [ + prop, + obj[prop] + ]; + } + } + return pairs; + }); - LiteralStringExpression.typeName = "LiteralStringExpression"; - LiteralStringExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "LiteralStringExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "value", type: STRING }, - ]; - - ArrayExpression.typeName = "ArrayExpression"; - ArrayExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ArrayExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "elements", type: List(Maybe(Union(SpreadElement, Expression))) }, - ]; - - ArrowExpression.typeName = "ArrowExpression"; - ArrowExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ArrowExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "params", type: FormalParameters }, - { name: "body", type: Union(FunctionBody, Expression) }, - ]; - - AssignmentExpression.typeName = "AssignmentExpression"; - AssignmentExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "AssignmentExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "binding", type: Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression) }, - { name: "expression", type: Expression }, - ]; - - BinaryExpression.typeName = "BinaryExpression"; - BinaryExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "BinaryExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "operator", type: BinaryOperator }, - { name: "left", type: Expression }, - { name: "right", type: Expression }, - ]; + /** + * Converts an object into an array of key, value arrays. + * The object's own properties and prototype properties are used. + * Note that the order of the output array is not guaranteed to be + * consistent across different JS platforms. + * + * @func + * @memberOf R + * @category Object + * @sig {String: *} -> [[String,*]] + * @param {Object} obj The object to extract from + * @return {Array} An array of key, value arrays from the object's own + * and prototype properties. + * @example + * + * var F = function() { this.x = 'X'; }; + * F.prototype.y = 'Y'; + * var f = new F(); + * R.toPairsIn(f); //=> [['x','X'], ['y','Y']] + */ + var toPairsIn = _curry1(function toPairsIn(obj) { + var pairs = []; + for (var prop in obj) { + pairs[pairs.length] = [ + prop, + obj[prop] + ]; + } + return pairs; + }); - CallExpression.typeName = "CallExpression"; - CallExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "CallExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "callee", type: Union(Expression, Super) }, - { name: "arguments", type: List(Union(SpreadElement, Expression)) }, - ]; + /** + * Removes (strips) whitespace from both ends of the string. + * + * @func + * @memberOf R + * @category String + * @sig String -> String + * @param {String} str The string to trim. + * @return {String} Trimmed version of `str`. + * @example + * + * R.trim(' xyz '); //=> 'xyz' + * R.map(R.trim, R.split(',', 'x, y, z')); //=> ['x', 'y', 'z'] + */ + var trim = function () { + var ws = '\t\n\x0B\f\r \xA0\u1680\u180E\u2000\u2001\u2002\u2003' + '\u2004\u2005\u2006\u2007\u2008\u2009\u200A\u202F\u205F\u3000\u2028' + '\u2029\uFEFF'; + var zeroWidth = '\u200B'; + var hasProtoTrim = typeof String.prototype.trim === 'function'; + if (!hasProtoTrim || (ws.trim() || !zeroWidth.trim())) { + return _curry1(function trim(str) { + var beginRx = new RegExp('^[' + ws + '][' + ws + ']*'); + var endRx = new RegExp('[' + ws + '][' + ws + ']*$'); + return str.replace(beginRx, '').replace(endRx, ''); + }); + } else { + return _curry1(function trim(str) { + return str.trim(); + }); + } + }(); - CompoundAssignmentExpression.typeName = "CompoundAssignmentExpression"; - CompoundAssignmentExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "CompoundAssignmentExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "operator", type: CompoundAssignmentOperator }, - { name: "binding", type: Union(BindingIdentifier, MemberExpression) }, - { name: "expression", type: Expression }, - ]; + /** + * Gives a single-word string description of the (native) type of a value, returning such + * answers as 'Object', 'Number', 'Array', or 'Null'. Does not attempt to distinguish user + * Object types any further, reporting them all as 'Object'. + * + * @func + * @memberOf R + * @category Type + * @sig (* -> {*}) -> String + * @param {*} val The value to test + * @return {String} + * @example + * + * R.type({}); //=> "Object" + * R.type(1); //=> "Number" + * R.type(false); //=> "Boolean" + * R.type('s'); //=> "String" + * R.type(null); //=> "Null" + * R.type([]); //=> "Array" + * R.type(/[A-z]/); //=> "RegExp" + */ + var type = _curry1(function type(val) { + return val === null ? 'Null' : val === undefined ? 'Undefined' : Object.prototype.toString.call(val).slice(8, -1); + }); - ComputedMemberExpression.typeName = "ComputedMemberExpression"; - ComputedMemberExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ComputedMemberExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "object", type: Union(Expression, Super) }, - { name: "expression", type: Expression }, - ]; + /** + * Takes a function `fn`, which takes a single array argument, and returns + * a function which: + * + * - takes any number of positional arguments; + * - passes these arguments to `fn` as an array; and + * - returns the result. + * + * In other words, R.unapply derives a variadic function from a function + * which takes an array. R.unapply is the inverse of R.apply. + * + * @func + * @memberOf R + * @category Function + * @sig ([*...] -> a) -> (*... -> a) + * @param {Function} fn + * @return {Function} + * @see R.apply + * @example + * + * R.unapply(JSON.stringify)(1, 2, 3); //=> '[1,2,3]' + */ + var unapply = _curry1(function unapply(fn) { + return function () { + return fn(_slice(arguments)); + }; + }); - ConditionalExpression.typeName = "ConditionalExpression"; - ConditionalExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ConditionalExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "test", type: Expression }, - { name: "consequent", type: Expression }, - { name: "alternate", type: Expression }, - ]; + /** + * Wraps a function of any arity (including nullary) in a function that accepts exactly 1 + * parameter. Any extraneous parameters will not be passed to the supplied function. + * + * @func + * @memberOf R + * @category Function + * @sig (* -> b) -> (a -> b) + * @param {Function} fn The function to wrap. + * @return {Function} A new function wrapping `fn`. The new function is guaranteed to be of + * arity 1. + * @example + * + * var takesTwoArgs = function(a, b) { + * return [a, b]; + * }; + * takesTwoArgs.length; //=> 2 + * takesTwoArgs(1, 2); //=> [1, 2] + * + * var takesOneArg = R.unary(takesTwoArgs); + * takesOneArg.length; //=> 1 + * // Only 1 argument is passed to the wrapped function + * takesOneArg(1, 2); //=> [1, undefined] + */ + var unary = _curry1(function unary(fn) { + return nAry(1, fn); + }); - FunctionExpression.typeName = "FunctionExpression"; - FunctionExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "FunctionExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "isGenerator", type: BOOLEAN }, - { name: "name", type: Maybe(BindingIdentifier) }, - { name: "params", type: FormalParameters }, - { name: "body", type: FunctionBody }, - ]; + /** + * Returns a function of arity `n` from a (manually) curried function. + * + * @func + * @memberOf R + * @category Function + * @sig Number -> (a -> b) -> (a -> c) + * @param {Number} length The arity for the returned function. + * @param {Function} fn The function to uncurry. + * @return {Function} A new function. + * @see R.curry + * @example + * + * var addFour = function(a) { + * return function(b) { + * return function(c) { + * return function(d) { + * return a + b + c + d; + * }; + * }; + * }; + * }; + * + * var uncurriedAddFour = R.uncurryN(4, addFour); + * curriedAddFour(1, 2, 3, 4); //=> 10 + */ + var uncurryN = _curry2(function uncurryN(depth, fn) { + return curryN(depth, function () { + var currentDepth = 1; + var value = fn; + var idx = 0; + var endIdx; + while (currentDepth <= depth && typeof value === 'function') { + endIdx = currentDepth === depth ? arguments.length : idx + value.length; + value = value.apply(this, _slice(arguments, idx, endIdx)); + currentDepth += 1; + idx = endIdx; + } + return value; + }); + }); - IdentifierExpression.typeName = "IdentifierExpression"; - IdentifierExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "IdentifierExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "name", type: STRING }, - ]; + /** + * Builds a list from a seed value. Accepts an iterator function, which returns either false + * to stop iteration or an array of length 2 containing the value to add to the resulting + * list and the seed to be used in the next call to the iterator function. + * + * The iterator function receives one argument: *(seed)*. + * + * @func + * @memberOf R + * @category List + * @sig (a -> [b]) -> * -> [b] + * @param {Function} fn The iterator function. receives one argument, `seed`, and returns + * either false to quit iteration or an array of length two to proceed. The element + * at index 0 of this array will be added to the resulting array, and the element + * at index 1 will be passed to the next call to `fn`. + * @param {*} seed The seed value. + * @return {Array} The final list. + * @example + * + * var f = function(n) { return n > 50 ? false : [-n, n + 10] }; + * R.unfold(f, 10); //=> [-10, -20, -30, -40, -50] + */ + var unfold = _curry2(function unfold(fn, seed) { + var pair = fn(seed); + var result = []; + while (pair && pair.length) { + result[result.length] = pair[0]; + pair = fn(pair[1]); + } + return result; + }); - NewExpression.typeName = "NewExpression"; - NewExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "NewExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "callee", type: Expression }, - { name: "arguments", type: List(Union(SpreadElement, Expression)) }, - ]; + /** + * Returns a new list containing only one copy of each element in the original list, based + * upon the value returned by applying the supplied predicate to two list elements. Prefers + * the first item if two items compare equal based on the predicate. + * + * @func + * @memberOf R + * @category List + * @sig (a, a -> Boolean) -> [a] -> [a] + * @param {Function} pred A predicate used to test whether two items are equal. + * @param {Array} list The array to consider. + * @return {Array} The list of unique items. + * @example + * + * var strEq = function(a, b) { return String(a) === String(b); }; + * R.uniqWith(strEq)([1, '1', 2, 1]); //=> [1, 2] + * R.uniqWith(strEq)([{}, {}]); //=> [{}] + * R.uniqWith(strEq)([1, '1', 1]); //=> [1] + * R.uniqWith(strEq)(['1', 1, 1]); //=> ['1'] + */ + var uniqWith = _curry2(function uniqWith(pred, list) { + var idx = 0, len = list.length; + var result = [], item; + while (idx < len) { + item = list[idx]; + if (!_containsWith(pred, item, result)) { + result[result.length] = item; + } + idx += 1; + } + return result; + }); - NewTargetExpression.typeName = "NewTargetExpression"; - NewTargetExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "NewTargetExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - ]; + /** + * Returns a new copy of the array with the element at the + * provided index replaced with the given value. + * @see R.adjust + * + * @func + * @memberOf R + * @category List + * @sig Number -> a -> [a] -> [a] + * @param {Number} idx The index to update. + * @param {*} x The value to exist at the given index of the returned array. + * @param {Array|Arguments} list The source array-like object to be updated. + * @return {Array} A copy of `list` with the value at index `idx` replaced with `x`. + * @example + * + * R.update(1, 11, [0, 1, 2]); //=> [0, 11, 2] + * R.update(1)(11)([0, 1, 2]); //=> [0, 11, 2] + */ + var update = _curry3(function update(idx, x, list) { + return adjust(always(x), idx, list); + }); - ObjectExpression.typeName = "ObjectExpression"; - ObjectExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ObjectExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "properties", type: List(ObjectProperty) }, - ]; + /** + * Returns a list of all the enumerable own properties of the supplied object. + * Note that the order of the output array is not guaranteed across + * different JS platforms. + * + * @func + * @memberOf R + * @category Object + * @sig {k: v} -> [v] + * @param {Object} obj The object to extract values from + * @return {Array} An array of the values of the object's own properties. + * @example + * + * R.values({a: 1, b: 2, c: 3}); //=> [1, 2, 3] + */ + var values = _curry1(function values(obj) { + var props = keys(obj); + var len = props.length; + var vals = []; + var idx = 0; + while (idx < len) { + vals[idx] = obj[props[idx]]; + idx += 1; + } + return vals; + }); - UnaryExpression.typeName = "UnaryExpression"; - UnaryExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "UnaryExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "operator", type: UnaryOperator }, - { name: "operand", type: Expression }, - ]; + /** + * Returns a list of all the properties, including prototype properties, + * of the supplied object. + * Note that the order of the output array is not guaranteed to be + * consistent across different JS platforms. + * + * @func + * @memberOf R + * @category Object + * @sig {k: v} -> [v] + * @param {Object} obj The object to extract values from + * @return {Array} An array of the values of the object's own and prototype properties. + * @example + * + * var F = function() { this.x = 'X'; }; + * F.prototype.y = 'Y'; + * var f = new F(); + * R.valuesIn(f); //=> ['X', 'Y'] + */ + var valuesIn = _curry1(function valuesIn(obj) { + var prop, vs = []; + for (prop in obj) { + vs[vs.length] = obj[prop]; + } + return vs; + }); - StaticMemberExpression.typeName = "StaticMemberExpression"; - StaticMemberExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "StaticMemberExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "object", type: Union(Expression, Super) }, - { name: "property", type: STRING }, - ]; + /** + * Returns a "view" of the given data structure, determined by the given lens. + * The lens's focus determines which portion of the data structure is visible. + * + * @func + * @memberOf R + * @category Object + * @typedef Lens s a = Functor f => (a -> f a) -> s -> f s + * @sig Lens s a -> s -> a + * @param {Lens} lens + * @param {*} x + * @return {*} + * @see R.prop, R.lensIndex, R.lensProp + * @example + * + * var xLens = R.lensProp('x'); + * + * R.view(xLens, {x: 1, y: 2}); //=> 1 + * R.view(xLens, {x: 4, y: 2}); //=> 4 + */ + var view = function () { + var Const = function (x) { + return { + value: x, + map: function () { + return this; + } + }; + }; + return _curry2(function view(lens, x) { + return lens(Const)(x).value; + }); + }(); - TemplateExpression.typeName = "TemplateExpression"; - TemplateExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "TemplateExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "tag", type: Maybe(Expression) }, - { name: "elements", type: List(Union(Expression, TemplateElement)) }, - ]; + /** + * Takes a spec object and a test object; returns true if the test satisfies + * the spec. Each of the spec's own properties must be a predicate function. + * Each predicate is applied to the value of the corresponding property of + * the test object. `where` returns true if all the predicates return true, + * false otherwise. + * + * `where` is well suited to declaratively expressing constraints for other + * functions such as `filter` and `find`. + * + * @func + * @memberOf R + * @category Object + * @sig {String: (* -> Boolean)} -> {String: *} -> Boolean + * @param {Object} spec + * @param {Object} testObj + * @return {Boolean} + * @example + * + * // pred :: Object -> Boolean + * var pred = R.where({ + * a: R.equals('foo'), + * b: R.complement(R.equals('bar')), + * x: R.gt(_, 10), + * y: R.lt(_, 20) + * }); + * + * pred({a: 'foo', b: 'xxx', x: 11, y: 19}); //=> true + * pred({a: 'xxx', b: 'xxx', x: 11, y: 19}); //=> false + * pred({a: 'foo', b: 'bar', x: 11, y: 19}); //=> false + * pred({a: 'foo', b: 'xxx', x: 10, y: 19}); //=> false + * pred({a: 'foo', b: 'xxx', x: 11, y: 20}); //=> false + */ + var where = _curry2(function where(spec, testObj) { + for (var prop in spec) { + if (_has(prop, spec) && !spec[prop](testObj[prop])) { + return false; + } + } + return true; + }); - ThisExpression.typeName = "ThisExpression"; - ThisExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ThisExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - ]; - - UpdateExpression.typeName = "UpdateExpression"; - UpdateExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "UpdateExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "isPrefix", type: BOOLEAN }, - { name: "operator", type: UpdateOperator }, - { name: "operand", type: Union(BindingIdentifier, MemberExpression) }, - ]; - - YieldExpression.typeName = "YieldExpression"; - YieldExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "YieldExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "expression", type: Maybe(Expression) }, - ]; - - YieldGeneratorExpression.typeName = "YieldGeneratorExpression"; - YieldGeneratorExpression.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "YieldGeneratorExpression" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "expression", type: Expression }, - ]; - - BlockStatement.typeName = "BlockStatement"; - BlockStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "BlockStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "block", type: Block }, - ]; - - BreakStatement.typeName = "BreakStatement"; - BreakStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "BreakStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "label", type: Maybe(STRING) }, - ]; - - ContinueStatement.typeName = "ContinueStatement"; - ContinueStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ContinueStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "label", type: Maybe(STRING) }, - ]; + /** + * Wrap a function inside another to allow you to make adjustments to the parameters, or do + * other processing either before the internal function is called or with its results. + * + * @func + * @memberOf R + * @category Function + * @sig (a... -> b) -> ((a... -> b) -> a... -> c) -> (a... -> c) + * @param {Function} fn The function to wrap. + * @param {Function} wrapper The wrapper function. + * @return {Function} The wrapped function. + * @example + * + * var greet = function(name) {return 'Hello ' + name;}; + * + * var shoutedGreet = R.wrap(greet, function(gr, name) { + * return gr(name).toUpperCase(); + * }); + * shoutedGreet("Kathy"); //=> "HELLO KATHY" + * + * var shortenedGreet = R.wrap(greet, function(gr, name) { + * return gr(name.substring(0, 3)); + * }); + * shortenedGreet("Robert"); //=> "Hello Rob" + */ + var wrap = _curry2(function wrap(fn, wrapper) { + return curryN(fn.length, function () { + return wrapper.apply(this, _concat([fn], arguments)); + }); + }); - DebuggerStatement.typeName = "DebuggerStatement"; - DebuggerStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "DebuggerStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - ]; + /** + * Creates a new list out of the two supplied by creating each possible + * pair from the lists. + * + * @func + * @memberOf R + * @category List + * @sig [a] -> [b] -> [[a,b]] + * @param {Array} as The first list. + * @param {Array} bs The second list. + * @return {Array} The list made by combining each possible pair from + * `as` and `bs` into pairs (`[a, b]`). + * @example + * + * R.xprod([1, 2], ['a', 'b']); //=> [[1, 'a'], [1, 'b'], [2, 'a'], [2, 'b']] + */ + // = xprodWith(prepend); (takes about 3 times as long...) + var xprod = _curry2(function xprod(a, b) { + // = xprodWith(prepend); (takes about 3 times as long...) + var idx = 0; + var ilen = a.length; + var j; + var jlen = b.length; + var result = []; + while (idx < ilen) { + j = 0; + while (j < jlen) { + result[result.length] = [ + a[idx], + b[j] + ]; + j += 1; + } + idx += 1; + } + return result; + }); - DoWhileStatement.typeName = "DoWhileStatement"; - DoWhileStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "DoWhileStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "body", type: Statement }, - { name: "test", type: Expression }, - ]; + /** + * Creates a new list out of the two supplied by pairing up + * equally-positioned items from both lists. The returned list is + * truncated to the length of the shorter of the two input lists. + * Note: `zip` is equivalent to `zipWith(function(a, b) { return [a, b] })`. + * + * @func + * @memberOf R + * @category List + * @sig [a] -> [b] -> [[a,b]] + * @param {Array} list1 The first array to consider. + * @param {Array} list2 The second array to consider. + * @return {Array} The list made by pairing up same-indexed elements of `list1` and `list2`. + * @example + * + * R.zip([1, 2, 3], ['a', 'b', 'c']); //=> [[1, 'a'], [2, 'b'], [3, 'c']] + */ + var zip = _curry2(function zip(a, b) { + var rv = []; + var idx = 0; + var len = Math.min(a.length, b.length); + while (idx < len) { + rv[idx] = [ + a[idx], + b[idx] + ]; + idx += 1; + } + return rv; + }); - EmptyStatement.typeName = "EmptyStatement"; - EmptyStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "EmptyStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - ]; + /** + * Creates a new object out of a list of keys and a list of values. + * + * @func + * @memberOf R + * @category List + * @sig [String] -> [*] -> {String: *} + * @param {Array} keys The array that will be properties on the output object. + * @param {Array} values The list of values on the output object. + * @return {Object} The object made by pairing up same-indexed elements of `keys` and `values`. + * @example + * + * R.zipObj(['a', 'b', 'c'], [1, 2, 3]); //=> {a: 1, b: 2, c: 3} + */ + var zipObj = _curry2(function zipObj(keys, values) { + var idx = 0, len = keys.length, out = {}; + while (idx < len) { + out[keys[idx]] = values[idx]; + idx += 1; + } + return out; + }); - ExpressionStatement.typeName = "ExpressionStatement"; - ExpressionStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ExpressionStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "expression", type: Expression }, - ]; + /** + * Creates a new list out of the two supplied by applying the function to + * each equally-positioned pair in the lists. The returned list is + * truncated to the length of the shorter of the two input lists. + * + * @function + * @memberOf R + * @category List + * @sig (a,b -> c) -> [a] -> [b] -> [c] + * @param {Function} fn The function used to combine the two elements into one value. + * @param {Array} list1 The first array to consider. + * @param {Array} list2 The second array to consider. + * @return {Array} The list made by combining same-indexed elements of `list1` and `list2` + * using `fn`. + * @example + * + * var f = function(x, y) { + * // ... + * }; + * R.zipWith(f, [1, 2, 3], ['a', 'b', 'c']); + * //=> [f(1, 'a'), f(2, 'b'), f(3, 'c')] + */ + var zipWith = _curry3(function zipWith(fn, a, b) { + var rv = [], idx = 0, len = Math.min(a.length, b.length); + while (idx < len) { + rv[idx] = fn(a[idx], b[idx]); + idx += 1; + } + return rv; + }); - ForInStatement.typeName = "ForInStatement"; - ForInStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ForInStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "left", type: Union(VariableDeclaration, ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression) }, - { name: "right", type: Expression }, - { name: "body", type: Statement }, - ]; + /** + * A function that always returns `false`. Any passed in parameters are ignored. + * + * @func + * @memberOf R + * @category Function + * @sig * -> false + * @return {Boolean} false + * @see R.always, R.T + * @example + * + * R.F(); //=> false + */ + var F = always(false); - ForOfStatement.typeName = "ForOfStatement"; - ForOfStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ForOfStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "left", type: Union(VariableDeclaration, ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression) }, - { name: "right", type: Expression }, - { name: "body", type: Statement }, - ]; + /** + * A function that always returns `true`. Any passed in parameters are ignored. + * + * @func + * @memberOf R + * @category Function + * @sig * -> true + * @return {Boolean} `true`. + * @see R.always, R.F + * @example + * + * R.T(); //=> true + */ + var T = always(true); - ForStatement.typeName = "ForStatement"; - ForStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ForStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "init", type: Maybe(Union(VariableDeclaration, Expression)) }, - { name: "test", type: Maybe(Expression) }, - { name: "update", type: Maybe(Expression) }, - { name: "body", type: Statement }, - ]; + /** + * Similar to hasMethod, this checks whether a function has a [methodname] + * function. If it isn't an array it will execute that function otherwise it will + * default to the ramda implementation. + * + * @private + * @param {Function} fn ramda implemtation + * @param {String} methodname property to check for a custom implementation + * @return {Object} Whatever the return value of the method is. + */ + var _checkForMethod = function _checkForMethod(methodname, fn) { + return function () { + var length = arguments.length; + if (length === 0) { + return fn(); + } + var obj = arguments[length - 1]; + return _isArray(obj) || typeof obj[methodname] !== 'function' ? fn.apply(this, arguments) : obj[methodname].apply(obj, _slice(arguments, 0, length - 1)); + }; + }; - IfStatement.typeName = "IfStatement"; - IfStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "IfStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "test", type: Expression }, - { name: "consequent", type: Statement }, - { name: "alternate", type: Maybe(Statement) }, - ]; + /** + * Copies an object. + * + * @private + * @param {*} value The value to be copied + * @param {Array} refFrom Array containing the source references + * @param {Array} refTo Array containing the copied source references + * @return {*} The copied value. + */ + var _clone = function _clone(value, refFrom, refTo) { + var copy = function copy(copiedValue) { + var len = refFrom.length; + var idx = 0; + while (idx < len) { + if (value === refFrom[idx]) { + return refTo[idx]; + } + idx += 1; + } + refFrom[idx + 1] = value; + refTo[idx + 1] = copiedValue; + for (var key in value) { + copiedValue[key] = _clone(value[key], refFrom, refTo); + } + return copiedValue; + }; + switch (type(value)) { + case 'Object': + return copy({}); + case 'Array': + return copy([]); + case 'Date': + return new Date(value); + case 'RegExp': + return _cloneRegExp(value); + default: + return value; + } + }; - LabeledStatement.typeName = "LabeledStatement"; - LabeledStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "LabeledStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "label", type: STRING }, - { name: "body", type: Statement }, - ]; + var _createPartialApplicator = function _createPartialApplicator(concat) { + return function (fn) { + var args = _slice(arguments, 1); + return _arity(Math.max(0, fn.length - args.length), function () { + return fn.apply(this, concat(args, arguments)); + }); + }; + }; - ReturnStatement.typeName = "ReturnStatement"; - ReturnStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ReturnStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "expression", type: Maybe(Expression) }, - ]; + /** + * Returns a function that dispatches with different strategies based on the + * object in list position (last argument). If it is an array, executes [fn]. + * Otherwise, if it has a function with [methodname], it will execute that + * function (functor case). Otherwise, if it is a transformer, uses transducer + * [xf] to return a new transformer (transducer case). Otherwise, it will + * default to executing [fn]. + * + * @private + * @param {String} methodname property to check for a custom implementation + * @param {Function} xf transducer to initialize if object is transformer + * @param {Function} fn default ramda implementation + * @return {Function} A function that dispatches on object in list position + */ + var _dispatchable = function _dispatchable(methodname, xf, fn) { + return function () { + var length = arguments.length; + if (length === 0) { + return fn(); + } + var obj = arguments[length - 1]; + if (!_isArray(obj)) { + var args = _slice(arguments, 0, length - 1); + if (typeof obj[methodname] === 'function') { + return obj[methodname].apply(obj, args); + } + if (_isTransformer(obj)) { + var transducer = xf.apply(null, args); + return transducer(obj); + } + } + return fn.apply(this, arguments); + }; + }; - SwitchStatement.typeName = "SwitchStatement"; - SwitchStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "SwitchStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "discriminant", type: Expression }, - { name: "cases", type: List(SwitchCase) }, - ]; + // The algorithm used to handle cyclic structures is + // inspired by underscore's isEqual + // RegExp equality algorithm: http://stackoverflow.com/a/10776635 + var _equals = function _equals(a, b, stackA, stackB) { + var typeA = type(a); + if (typeA !== type(b)) { + return false; + } + if (typeA === 'Boolean' || typeA === 'Number' || typeA === 'String') { + return typeof a === 'object' ? typeof b === 'object' && identical(a.valueOf(), b.valueOf()) : identical(a, b); + } + if (identical(a, b)) { + return true; + } + if (typeA === 'RegExp') { + // RegExp equality algorithm: http://stackoverflow.com/a/10776635 + return a.source === b.source && a.global === b.global && a.ignoreCase === b.ignoreCase && a.multiline === b.multiline && a.sticky === b.sticky && a.unicode === b.unicode; + } + if (Object(a) === a) { + if (typeA === 'Date' && a.getTime() !== b.getTime()) { + return false; + } + var keysA = keys(a); + if (keysA.length !== keys(b).length) { + return false; + } + var idx = stackA.length - 1; + while (idx >= 0) { + if (stackA[idx] === a) { + return stackB[idx] === b; + } + idx -= 1; + } + stackA[stackA.length] = a; + stackB[stackB.length] = b; + idx = keysA.length - 1; + while (idx >= 0) { + var key = keysA[idx]; + if (!_has(key, b) || !_equals(b[key], a[key], stackA, stackB)) { + return false; + } + idx -= 1; + } + stackA.pop(); + stackB.pop(); + return true; + } + return false; + }; - SwitchStatementWithDefault.typeName = "SwitchStatementWithDefault"; - SwitchStatementWithDefault.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "SwitchStatementWithDefault" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "discriminant", type: Expression }, - { name: "preDefaultCases", type: List(SwitchCase) }, - { name: "defaultCase", type: SwitchDefault }, - { name: "postDefaultCases", type: List(SwitchCase) }, - ]; + /** + * Private function that determines whether or not a provided object has a given method. + * Does not ignore methods stored on the object's prototype chain. Used for dynamically + * dispatching Ramda methods to non-Array objects. + * + * @private + * @param {String} methodName The name of the method to check for. + * @param {Object} obj The object to test. + * @return {Boolean} `true` has a given method, `false` otherwise. + * @example + * + * var person = { name: 'John' }; + * person.shout = function() { alert(this.name); }; + * + * _hasMethod('shout', person); //=> true + * _hasMethod('foo', person); //=> false + */ + var _hasMethod = function _hasMethod(methodName, obj) { + return obj != null && !_isArray(obj) && typeof obj[methodName] === 'function'; + }; - ThrowStatement.typeName = "ThrowStatement"; - ThrowStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "ThrowStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "expression", type: Expression }, - ]; + /** + * `_makeFlat` is a helper function that returns a one-level or fully recursive function + * based on the flag passed in. + * + * @private + */ + var _makeFlat = function _makeFlat(recursive) { + return function flatt(list) { + var value, result = [], idx = 0, j, ilen = list.length, jlen; + while (idx < ilen) { + if (isArrayLike(list[idx])) { + value = recursive ? flatt(list[idx]) : list[idx]; + j = 0; + jlen = value.length; + while (j < jlen) { + result[result.length] = value[j]; + j += 1; + } + } else { + result[result.length] = list[idx]; + } + idx += 1; + } + return result; + }; + }; - TryCatchStatement.typeName = "TryCatchStatement"; - TryCatchStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "TryCatchStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "body", type: Block }, - { name: "catchClause", type: CatchClause }, - ]; - - TryFinallyStatement.typeName = "TryFinallyStatement"; - TryFinallyStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "TryFinallyStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "body", type: Block }, - { name: "catchClause", type: Maybe(CatchClause) }, - { name: "finalizer", type: Block }, - ]; + var _reduce = function () { + function _arrayReduce(xf, acc, list) { + var idx = 0, len = list.length; + while (idx < len) { + acc = xf['@@transducer/step'](acc, list[idx]); + if (acc && acc['@@transducer/reduced']) { + acc = acc['@@transducer/value']; + break; + } + idx += 1; + } + return xf['@@transducer/result'](acc); + } + function _iterableReduce(xf, acc, iter) { + var step = iter.next(); + while (!step.done) { + acc = xf['@@transducer/step'](acc, step.value); + if (acc && acc['@@transducer/reduced']) { + acc = acc['@@transducer/value']; + break; + } + step = iter.next(); + } + return xf['@@transducer/result'](acc); + } + function _methodReduce(xf, acc, obj) { + return xf['@@transducer/result'](obj.reduce(bind(xf['@@transducer/step'], xf), acc)); + } + var symIterator = typeof Symbol !== 'undefined' ? Symbol.iterator : '@@iterator'; + return function _reduce(fn, acc, list) { + if (typeof fn === 'function') { + fn = _xwrap(fn); + } + if (isArrayLike(list)) { + return _arrayReduce(fn, acc, list); + } + if (typeof list.reduce === 'function') { + return _methodReduce(fn, acc, list); + } + if (list[symIterator] != null) { + return _iterableReduce(fn, acc, list[symIterator]()); + } + if (typeof list.next === 'function') { + return _iterableReduce(fn, acc, list); + } + throw new TypeError('reduce: list must be array or iterable'); + }; + }(); - VariableDeclarationStatement.typeName = "VariableDeclarationStatement"; - VariableDeclarationStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "VariableDeclarationStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "declaration", type: VariableDeclaration }, - ]; + var _stepCat = function () { + var _stepCatArray = { + '@@transducer/init': Array, + '@@transducer/step': function (xs, x) { + return _concat(xs, [x]); + }, + '@@transducer/result': _identity + }; + var _stepCatString = { + '@@transducer/init': String, + '@@transducer/step': function (a, b) { + return a + b; + }, + '@@transducer/result': _identity + }; + var _stepCatObject = { + '@@transducer/init': Object, + '@@transducer/step': function (result, input) { + return merge(result, isArrayLike(input) ? createMapEntry(input[0], input[1]) : input); + }, + '@@transducer/result': _identity + }; + return function _stepCat(obj) { + if (_isTransformer(obj)) { + return obj; + } + if (isArrayLike(obj)) { + return _stepCatArray; + } + if (typeof obj === 'string') { + return _stepCatString; + } + if (typeof obj === 'object') { + return _stepCatObject; + } + throw new Error('Cannot create transformer for ' + obj); + }; + }(); - WhileStatement.typeName = "WhileStatement"; - WhileStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "WhileStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "test", type: Expression }, - { name: "body", type: Statement }, - ]; + var _xall = function () { + function XAll(f, xf) { + this.xf = xf; + this.f = f; + this.all = true; + } + XAll.prototype['@@transducer/init'] = _xfBase.init; + XAll.prototype['@@transducer/result'] = function (result) { + if (this.all) { + result = this.xf['@@transducer/step'](result, true); + } + return this.xf['@@transducer/result'](result); + }; + XAll.prototype['@@transducer/step'] = function (result, input) { + if (!this.f(input)) { + this.all = false; + result = _reduced(this.xf['@@transducer/step'](result, false)); + } + return result; + }; + return _curry2(function _xall(f, xf) { + return new XAll(f, xf); + }); + }(); - WithStatement.typeName = "WithStatement"; - WithStatement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "WithStatement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "object", type: Expression }, - { name: "body", type: Statement }, - ]; + var _xany = function () { + function XAny(f, xf) { + this.xf = xf; + this.f = f; + this.any = false; + } + XAny.prototype['@@transducer/init'] = _xfBase.init; + XAny.prototype['@@transducer/result'] = function (result) { + if (!this.any) { + result = this.xf['@@transducer/step'](result, false); + } + return this.xf['@@transducer/result'](result); + }; + XAny.prototype['@@transducer/step'] = function (result, input) { + if (this.f(input)) { + this.any = true; + result = _reduced(this.xf['@@transducer/step'](result, true)); + } + return result; + }; + return _curry2(function _xany(f, xf) { + return new XAny(f, xf); + }); + }(); - Block.typeName = "Block"; - Block.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "Block" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "statements", type: List(Statement) }, - ]; + var _xdrop = function () { + function XDrop(n, xf) { + this.xf = xf; + this.n = n; + } + XDrop.prototype['@@transducer/init'] = _xfBase.init; + XDrop.prototype['@@transducer/result'] = _xfBase.result; + XDrop.prototype['@@transducer/step'] = function (result, input) { + if (this.n > 0) { + this.n -= 1; + return result; + } + return this.xf['@@transducer/step'](result, input); + }; + return _curry2(function _xdrop(n, xf) { + return new XDrop(n, xf); + }); + }(); - CatchClause.typeName = "CatchClause"; - CatchClause.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "CatchClause" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "binding", type: Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression) }, - { name: "body", type: Block }, - ]; + var _xdropWhile = function () { + function XDropWhile(f, xf) { + this.xf = xf; + this.f = f; + } + XDropWhile.prototype['@@transducer/init'] = _xfBase.init; + XDropWhile.prototype['@@transducer/result'] = _xfBase.result; + XDropWhile.prototype['@@transducer/step'] = function (result, input) { + if (this.f) { + if (this.f(input)) { + return result; + } + this.f = null; + } + return this.xf['@@transducer/step'](result, input); + }; + return _curry2(function _xdropWhile(f, xf) { + return new XDropWhile(f, xf); + }); + }(); - Directive.typeName = "Directive"; - Directive.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "Directive" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "rawValue", type: STRING }, - ]; + var _xgroupBy = function () { + function XGroupBy(f, xf) { + this.xf = xf; + this.f = f; + this.inputs = {}; + } + XGroupBy.prototype['@@transducer/init'] = _xfBase.init; + XGroupBy.prototype['@@transducer/result'] = function (result) { + var key; + for (key in this.inputs) { + if (_has(key, this.inputs)) { + result = this.xf['@@transducer/step'](result, this.inputs[key]); + if (result['@@transducer/reduced']) { + result = result['@@transducer/value']; + break; + } + } + } + return this.xf['@@transducer/result'](result); + }; + XGroupBy.prototype['@@transducer/step'] = function (result, input) { + var key = this.f(input); + this.inputs[key] = this.inputs[key] || [ + key, + [] + ]; + this.inputs[key][1] = append(input, this.inputs[key][1]); + return result; + }; + return _curry2(function _xgroupBy(f, xf) { + return new XGroupBy(f, xf); + }); + }(); - FormalParameters.typeName = "FormalParameters"; - FormalParameters.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "FormalParameters" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "items", type: List(Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression, BindingWithDefault)) }, - { name: "rest", type: Maybe(BindingIdentifier) }, - ]; + /** + * Creates a new list iteration function from an existing one by adding two new parameters + * to its callback function: the current index, and the entire list. + * + * This would turn, for instance, Ramda's simple `map` function into one that more closely + * resembles `Array.prototype.map`. Note that this will only work for functions in which + * the iteration callback function is the first parameter, and where the list is the last + * parameter. (This latter might be unimportant if the list parameter is not used.) + * + * @func + * @memberOf R + * @category Function + * @category List + * @sig ((a ... -> b) ... -> [a] -> *) -> (a ..., Int, [a] -> b) ... -> [a] -> *) + * @param {Function} fn A list iteration function that does not pass index or list to its callback + * @return {Function} An altered list iteration function that passes (item, index, list) to its callback + * @example + * + * var mapIndexed = R.addIndex(R.map); + * mapIndexed(function(val, idx) {return idx + '-' + val;}, ['f', 'o', 'o', 'b', 'a', 'r']); + * //=> ['0-f', '1-o', '2-o', '3-b', '4-a', '5-r'] + */ + var addIndex = _curry1(function addIndex(fn) { + return curryN(fn.length, function () { + var idx = 0; + var origFn = arguments[0]; + var list = arguments[arguments.length - 1]; + var args = _slice(arguments); + args[0] = function () { + var result = origFn.apply(this, _concat(arguments, [ + idx, + list + ])); + idx += 1; + return result; + }; + return fn.apply(this, args); + }); + }); - FunctionBody.typeName = "FunctionBody"; - FunctionBody.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "FunctionBody" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "directives", type: List(Directive) }, - { name: "statements", type: List(Statement) }, - ]; + /** + * Returns `true` if all elements of the list match the predicate, `false` if there are any + * that don't. + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> Boolean + * @param {Function} fn The predicate function. + * @param {Array} list The array to consider. + * @return {Boolean} `true` if the predicate is satisfied by every element, `false` + * otherwise. + * @see R.any, R.none + * @example + * + * var lessThan2 = R.flip(R.lt)(2); + * var lessThan3 = R.flip(R.lt)(3); + * R.all(lessThan2)([1, 2]); //=> false + * R.all(lessThan3)([1, 2]); //=> true + */ + var all = _curry2(_dispatchable('all', _xall, function all(fn, list) { + var idx = 0; + while (idx < list.length) { + if (!fn(list[idx])) { + return false; + } + idx += 1; + } + return true; + })); - FunctionDeclaration.typeName = "FunctionDeclaration"; - FunctionDeclaration.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "FunctionDeclaration" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "isGenerator", type: BOOLEAN }, - { name: "name", type: BindingIdentifier }, - { name: "params", type: FormalParameters }, - { name: "body", type: FunctionBody }, - ]; + /** + * A function that returns the first argument if it's falsy otherwise the second + * argument. Note that this is NOT short-circuited, meaning that if expressions + * are passed they are both evaluated. + * + * Dispatches to the `and` method of the first argument if applicable. + * + * @func + * @memberOf R + * @category Logic + * @sig * -> * -> * + * @param {*} a any value + * @param {*} b any other value + * @return {*} the first argument if falsy otherwise the second argument. + * @see R.both + * @example + * + * R.and(false, true); //=> false + * R.and(0, []); //=> 0 + * R.and(null, ''); => null + */ + var and = _curry2(function and(a, b) { + return _hasMethod('and', a) ? a.and(b) : a && b; + }); - Script.typeName = "Script"; - Script.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "Script" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "directives", type: List(Directive) }, - { name: "statements", type: List(Statement) }, - ]; + /** + * Returns `true` if at least one of elements of the list match the predicate, `false` + * otherwise. + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> Boolean + * @param {Function} fn The predicate function. + * @param {Array} list The array to consider. + * @return {Boolean} `true` if the predicate is satisfied by at least one element, `false` + * otherwise. + * @see R.all, R.none + * @example + * + * var lessThan0 = R.flip(R.lt)(0); + * var lessThan2 = R.flip(R.lt)(2); + * R.any(lessThan0)([1, 2]); //=> false + * R.any(lessThan2)([1, 2]); //=> true + */ + var any = _curry2(_dispatchable('any', _xany, function any(fn, list) { + var idx = 0; + while (idx < list.length) { + if (fn(list[idx])) { + return true; + } + idx += 1; + } + return false; + })); - SpreadElement.typeName = "SpreadElement"; - SpreadElement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "SpreadElement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "expression", type: Expression }, - ]; + /** + * Wraps a function of any arity (including nullary) in a function that accepts exactly 2 + * parameters. Any extraneous parameters will not be passed to the supplied function. + * + * @func + * @memberOf R + * @category Function + * @sig (* -> c) -> (a, b -> c) + * @param {Function} fn The function to wrap. + * @return {Function} A new function wrapping `fn`. The new function is guaranteed to be of + * arity 2. + * @example + * + * var takesThreeArgs = function(a, b, c) { + * return [a, b, c]; + * }; + * takesThreeArgs.length; //=> 3 + * takesThreeArgs(1, 2, 3); //=> [1, 2, 3] + * + * var takesTwoArgs = R.binary(takesThreeArgs); + * takesTwoArgs.length; //=> 2 + * // Only 2 arguments are passed to the wrapped function + * takesTwoArgs(1, 2, 3); //=> [1, 2, undefined] + */ + var binary = _curry1(function binary(fn) { + return nAry(2, fn); + }); - Super.typeName = "Super"; - Super.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "Super" }, - { name: "loc", type: Maybe(SourceSpan) }, - ]; + /** + * Creates a deep copy of the value which may contain (nested) `Array`s and + * `Object`s, `Number`s, `String`s, `Boolean`s and `Date`s. `Function`s are + * not copied, but assigned by their reference. + * + * @func + * @memberOf R + * @category Object + * @sig {*} -> {*} + * @param {*} value The object or array to clone + * @return {*} A new object or array. + * @example + * + * var objects = [{}, {}, {}]; + * var objectsClone = R.clone(objects); + * objects[0] === objectsClone[0]; //=> false + */ + var clone = _curry1(function clone(value) { + return _clone(value, [], []); + }); - SwitchCase.typeName = "SwitchCase"; - SwitchCase.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "SwitchCase" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "test", type: Expression }, - { name: "consequent", type: List(Statement) }, - ]; + /** + * Returns a new list consisting of the elements of the first list followed by the elements + * of the second. + * + * @func + * @memberOf R + * @category List + * @sig [a] -> [a] -> [a] + * @param {Array} list1 The first list to merge. + * @param {Array} list2 The second set to merge. + * @return {Array} A new array consisting of the contents of `list1` followed by the + * contents of `list2`. If, instead of an Array for `list1`, you pass an + * object with a `concat` method on it, `concat` will call `list1.concat` + * and pass it the value of `list2`. + * + * @example + * + * R.concat([], []); //=> [] + * R.concat([4, 5, 6], [1, 2, 3]); //=> [4, 5, 6, 1, 2, 3] + * R.concat('ABC', 'DEF'); // 'ABCDEF' + */ + var concat = _curry2(function concat(set1, set2) { + if (_isArray(set2)) { + return _concat(set1, set2); + } else if (_hasMethod('concat', set1)) { + return set1.concat(set2); + } else { + throw new TypeError('can\'t concat ' + typeof set1); + } + }); - SwitchDefault.typeName = "SwitchDefault"; - SwitchDefault.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "SwitchDefault" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "consequent", type: List(Statement) }, - ]; - - TemplateElement.typeName = "TemplateElement"; - TemplateElement.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "TemplateElement" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "rawValue", type: STRING }, - ]; - - VariableDeclaration.typeName = "VariableDeclaration"; - VariableDeclaration.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "VariableDeclaration" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "kind", type: VariableDeclarationKind }, - { name: "declarators", type: List(VariableDeclarator) }, - ]; - - VariableDeclarator.typeName = "VariableDeclarator"; - VariableDeclarator.fields = [ - { name: "type", type: Const(TYPE_INDICATOR), value: "VariableDeclarator" }, - { name: "loc", type: Maybe(SourceSpan) }, - { name: "binding", type: Union(ObjectBinding, ArrayBinding, BindingIdentifier, MemberExpression) }, - { name: "init", type: Maybe(Expression) }, - ]; - - return SPEC; - }()); - - -/***/ }, -/* 36 */ -/***/ function(module, exports, __webpack_require__) { - - "use strict"; - - var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); - - var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; }; /** - * Copyright 2014 Shape Security, Inc. - * - * Licensed under the Apache License, Version 2.0 (the "License") - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - - Object.defineProperty(exports, "__esModule", { - value: true - }); - - var _shiftSpec = __webpack_require__(35); - - var _shiftSpec2 = _interopRequireDefault(_shiftSpec); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + /** + * Returns a curried equivalent of the provided function. The curried + * function has two unusual capabilities. First, its arguments needn't + * be provided one at a time. If `f` is a ternary function and `g` is + * `R.curry(f)`, the following are equivalent: + * + * - `g(1)(2)(3)` + * - `g(1)(2, 3)` + * - `g(1, 2)(3)` + * - `g(1, 2, 3)` + * + * Secondly, the special placeholder value `R.__` may be used to specify + * "gaps", allowing partial application of any combination of arguments, + * regardless of their positions. If `g` is as above and `_` is `R.__`, + * the following are equivalent: + * + * - `g(1, 2, 3)` + * - `g(_, 2, 3)(1)` + * - `g(_, _, 3)(1)(2)` + * - `g(_, _, 3)(1, 2)` + * - `g(_, 2)(1)(3)` + * - `g(_, 2)(1, 3)` + * - `g(_, 2)(_, 3)(1)` + * + * @func + * @memberOf R + * @category Function + * @sig (* -> a) -> (* -> a) + * @param {Function} fn The function to curry. + * @return {Function} A new, curried function. + * @see R.curryN + * @example + * + * var addFourNumbers = function(a, b, c, d) { + * return a + b + c + d; + * }; + * + * var curriedAddFourNumbers = R.curry(addFourNumbers); + * var f = curriedAddFourNumbers(1, 2); + * var g = f(3); + * g(4); //=> 10 + */ + var curry = _curry1(function curry(fn) { + return curryN(fn.length, fn); + }); - function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + /** + * Returns a new list containing the last `n` elements of a given list, passing each value + * to the supplied predicate function, skipping elements while the predicate function returns + * `true`. The predicate function is passed one argument: *(value)*. + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> [a] + * @param {Function} fn The function called per iteration. + * @param {Array} list The collection to iterate over. + * @return {Array} A new array. + * @see R.takeWhile + * @example + * + * var lteTwo = function(x) { + * return x <= 2; + * }; + * + * R.dropWhile(lteTwo, [1, 2, 3, 4, 3, 2, 1]); //=> [3, 4, 3, 2, 1] + */ + var dropWhile = _curry2(_dispatchable('dropWhile', _xdropWhile, function dropWhile(pred, list) { + var idx = 0, len = list.length; + while (idx < len && pred(list[idx])) { + idx += 1; + } + return _slice(list, idx); + })); - var methods = {}; + /** + * Returns `true` if its arguments are equivalent, `false` otherwise. + * Dispatches to an `equals` method if present. Handles cyclical data + * structures. + * + * @func + * @memberOf R + * @category Relation + * @sig a -> b -> Boolean + * @param {*} a + * @param {*} b + * @return {Boolean} + * @example + * + * R.equals(1, 1); //=> true + * R.equals(1, '1'); //=> false + * R.equals([1, 2, 3], [1, 2, 3]); //=> true + * + * var a = {}; a.v = a; + * var b = {}; b.v = b; + * R.equals(a, b); //=> true + */ + var equals = _curry2(function equals(a, b) { + return _hasMethod('equals', a) ? a.equals(b) : _hasMethod('equals', b) ? b.equals(a) : _equals(a, b, [], []); + }); - function id(x) { - return x; - } + /** + * Returns a new list containing only those items that match a given predicate function. + * The predicate function is passed one argument: *(value)*. + * + * Note that `R.filter` does not skip deleted or unassigned indices, unlike the native + * `Array.prototype.filter` method. For more details on this behavior, see: + * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter#Description + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> [a] + * @param {Function} fn The function called per iteration. + * @param {Array} list The collection to iterate over. + * @return {Array} The new filtered array. + * @see R.reject + * @example + * + * var isEven = function(n) { + * return n % 2 === 0; + * }; + * R.filter(isEven, [1, 2, 3, 4]); //=> [2, 4] + */ + var filter = _curry2(_dispatchable('filter', _xfilter, _filter)); - function handlerForFieldOfType(type) { - switch (type.typeName) { - case "Enum": - case "String": - case "Boolean": - case "Number": - case "SourceSpan": - return null; - case "Const": - return handlerForFieldOfType(type.argument); - case "Maybe": - { - var _ret = function () { - var subHandler = handlerForFieldOfType(type.argument); - if (subHandler == null) return { - v: null - }; - return { - v: function v(t) { - return t == null ? this.identity : subHandler.call(this, t); + /** + * Returns the first element of the list which matches the predicate, or `undefined` if no + * element matches. + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> a | undefined + * @param {Function} fn The predicate function used to determine if the element is the + * desired one. + * @param {Array} list The array to consider. + * @return {Object} The element found, or `undefined`. + * @example + * + * var xs = [{a: 1}, {a: 2}, {a: 3}]; + * R.find(R.propEq('a', 2))(xs); //=> {a: 2} + * R.find(R.propEq('a', 4))(xs); //=> undefined + */ + var find = _curry2(_dispatchable('find', _xfind, function find(fn, list) { + var idx = 0; + var len = list.length; + while (idx < len) { + if (fn(list[idx])) { + return list[idx]; } - }; - }(); - - if ((typeof _ret === "undefined" ? "undefined" : _typeof(_ret)) === "object") return _ret.v; - } - case "List": - { - var _ret2 = function () { - var subHandler = handlerForFieldOfType(type.argument); - if (subHandler == null) return { - v: null - }; - return { - v: function v(t) { - var _this = this; + idx += 1; + } + })); - return this.fold(t.map(function (x) { - return subHandler.call(_this, x); - })); + /** + * Returns the index of the first element of the list which matches the predicate, or `-1` + * if no element matches. + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> Number + * @param {Function} fn The predicate function used to determine if the element is the + * desired one. + * @param {Array} list The array to consider. + * @return {Number} The index of the element found, or `-1`. + * @example + * + * var xs = [{a: 1}, {a: 2}, {a: 3}]; + * R.findIndex(R.propEq('a', 2))(xs); //=> 1 + * R.findIndex(R.propEq('a', 4))(xs); //=> -1 + */ + var findIndex = _curry2(_dispatchable('findIndex', _xfindIndex, function findIndex(fn, list) { + var idx = 0; + var len = list.length; + while (idx < len) { + if (fn(list[idx])) { + return idx; } - }; - }(); + idx += 1; + } + return -1; + })); - if ((typeof _ret2 === "undefined" ? "undefined" : _typeof(_ret2)) === "object") return _ret2.v; - } - default: - return id; - } - } + /** + * Returns the last element of the list which matches the predicate, or `undefined` if no + * element matches. + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> a | undefined + * @param {Function} fn The predicate function used to determine if the element is the + * desired one. + * @param {Array} list The array to consider. + * @return {Object} The element found, or `undefined`. + * @example + * + * var xs = [{a: 1, b: 0}, {a:1, b: 1}]; + * R.findLast(R.propEq('a', 1))(xs); //=> {a: 1, b: 1} + * R.findLast(R.propEq('a', 4))(xs); //=> undefined + */ + var findLast = _curry2(_dispatchable('findLast', _xfindLast, function findLast(fn, list) { + var idx = list.length - 1; + while (idx >= 0) { + if (fn(list[idx])) { + return list[idx]; + } + idx -= 1; + } + })); - var _loop = function _loop(typeName) { - var type = _shiftSpec2.default[typeName]; + /** + * Returns the index of the last element of the list which matches the predicate, or + * `-1` if no element matches. + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> Number + * @param {Function} fn The predicate function used to determine if the element is the + * desired one. + * @param {Array} list The array to consider. + * @return {Number} The index of the element found, or `-1`. + * @example + * + * var xs = [{a: 1, b: 0}, {a:1, b: 1}]; + * R.findLastIndex(R.propEq('a', 1))(xs); //=> 1 + * R.findLastIndex(R.propEq('a', 4))(xs); //=> -1 + */ + var findLastIndex = _curry2(_dispatchable('findLastIndex', _xfindLastIndex, function findLastIndex(fn, list) { + var idx = list.length - 1; + while (idx >= 0) { + if (fn(list[idx])) { + return idx; + } + idx -= 1; + } + return -1; + })); - var handlers = {}; - type.fields.forEach(function (field) { - var handler = handlerForFieldOfType(field.type); - if (handler != null) handlers[field.name] = handler; - }); - var fieldNames = Object.keys(handlers); + /** + * Returns a new list by pulling every item out of it (and all its sub-arrays) and putting + * them in a new array, depth-first. + * + * @func + * @memberOf R + * @category List + * @sig [a] -> [b] + * @param {Array} list The array to consider. + * @return {Array} The flattened list. + * @see R.unnest + * @example + * + * R.flatten([1, 2, [3, 4], 5, [6, [7, 8, [9, [10, 11], 12]]]]); + * //=> [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12] + */ + var flatten = _curry1(_makeFlat(true)); - methods["reduce" + typeName] = { - value: function value(node, state) { - var _this3 = this; + /** + * Returns a new function much like the supplied one, except that the first two arguments' + * order is reversed. + * + * @func + * @memberOf R + * @category Function + * @sig (a -> b -> c -> ... -> z) -> (b -> a -> c -> ... -> z) + * @param {Function} fn The function to invoke with its first two parameters reversed. + * @return {*} The result of invoking `fn` with its first two parameters' order reversed. + * @example + * + * var mergeThree = function(a, b, c) { + * return ([]).concat(a, b, c); + * }; + * + * mergeThree(1, 2, 3); //=> [1, 2, 3] + * + * R.flip(mergeThree)(1, 2, 3); //=> [2, 1, 3] + */ + var flip = _curry1(function flip(fn) { + return curry(function (a, b) { + var args = _slice(arguments); + args[0] = b; + args[1] = a; + return fn.apply(this, args); + }); + }); - return this.fold(fieldNames.map(function (fieldName) { - return handlers[fieldName].call(_this3, state[fieldName]); - })); - } - }; - }; + /** + * Iterate over an input `list`, calling a provided function `fn` for each element in the + * list. + * + * `fn` receives one argument: *(value)*. + * + * Note: `R.forEach` does not skip deleted or unassigned indices (sparse arrays), unlike + * the native `Array.prototype.forEach` method. For more details on this behavior, see: + * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach#Description + * + * Also note that, unlike `Array.prototype.forEach`, Ramda's `forEach` returns the original + * array. In some libraries this function is named `each`. + * + * @func + * @memberOf R + * @category List + * @sig (a -> *) -> [a] -> [a] + * @param {Function} fn The function to invoke. Receives one argument, `value`. + * @param {Array} list The list to iterate over. + * @return {Array} The original list. + * @example + * + * var printXPlusFive = function(x) { console.log(x + 5); }; + * R.forEach(printXPlusFive, [1, 2, 3]); //=> [1, 2, 3] + * //-> 6 + * //-> 7 + * //-> 8 + */ + var forEach = _curry2(_checkForMethod('forEach', function forEach(fn, list) { + var len = list.length; + var idx = 0; + while (idx < len) { + fn(list[idx]); + idx += 1; + } + return list; + })); - for (var typeName in _shiftSpec2.default) { - _loop(typeName); - } + /** + * Returns a list of function names of object's own functions + * + * @func + * @memberOf R + * @category Object + * @sig {*} -> [String] + * @param {Object} obj The objects with functions in it + * @return {Array} A list of the object's own properties that map to functions. + * @example + * + * R.functions(R); // returns list of ramda's own function names + * + * var F = function() { this.x = function(){}; this.y = 1; } + * F.prototype.z = function() {}; + * F.prototype.a = 100; + * R.functions(new F()); //=> ["x"] + */ + var functions = _curry1(_functionsWith(keys)); - var MonoidalReducer = function () { - function MonoidalReducer(monoid) { - _classCallCheck(this, MonoidalReducer); + /** + * Returns a list of function names of object's own and prototype functions + * + * @func + * @memberOf R + * @category Object + * @sig {*} -> [String] + * @param {Object} obj The objects with functions in it + * @return {Array} A list of the object's own properties and prototype + * properties that map to functions. + * @example + * + * R.functionsIn(R); // returns list of ramda's own and prototype function names + * + * var F = function() { this.x = function(){}; this.y = 1; } + * F.prototype.z = function() {}; + * F.prototype.a = 100; + * R.functionsIn(new F()); //=> ["x", "z"] + */ + var functionsIn = _curry1(_functionsWith(keysIn)); - this.identity = monoid.empty(); - var concat = monoid.prototype && monoid.prototype.concat || monoid.concat; - this.append = function (a, b) { - return concat.call(a, b); - }; - } + /** + * Splits a list into sub-lists stored in an object, based on the result of calling a String-returning function + * on each element, and grouping the results according to values returned. + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig (a -> String) -> [a] -> {String: [a]} + * @param {Function} fn Function :: a -> String + * @param {Array} list The array to group + * @return {Object} An object with the output of `fn` for keys, mapped to arrays of elements + * that produced that key when passed to `fn`. + * @example + * + * var byGrade = R.groupBy(function(student) { + * var score = student.score; + * return score < 65 ? 'F' : + * score < 70 ? 'D' : + * score < 80 ? 'C' : + * score < 90 ? 'B' : 'A'; + * }); + * var students = [{name: 'Abby', score: 84}, + * {name: 'Eddy', score: 58}, + * // ... + * {name: 'Jack', score: 69}]; + * byGrade(students); + * // { + * // 'A': [{name: 'Dianne', score: 99}], + * // 'B': [{name: 'Abby', score: 84}] + * // // ..., + * // 'F': [{name: 'Eddy', score: 58}] + * // } + */ + var groupBy = _curry2(_dispatchable('groupBy', _xgroupBy, function groupBy(fn, list) { + return _reduce(function (acc, elt) { + var key = fn(elt); + acc[key] = append(elt, acc[key] || (acc[key] = [])); + return acc; + }, {}, list); + })); - _createClass(MonoidalReducer, [{ - key: "fold", - value: function fold(list, a) { - var _this2 = this; + /** + * Returns the first element of the given list or string. In some libraries + * this function is named `first`. + * + * @func + * @memberOf R + * @category List + * @see R.tail, R.init, R.last + * @sig [a] -> a | Undefined + * @sig String -> String + * @param {*} list + * @return {*} + * @example + * + * R.head(['fi', 'fo', 'fum']); //=> 'fi' + * R.head([]); //=> undefined + * + * R.head('abc'); //=> 'a' + * R.head(''); //=> '' + */ + var head = nth(0); - return list.reduce(function (memo, x) { - return _this2.append(memo, x); - }, a == null ? this.identity : a); - } - }]); + /** + * Combines two lists into a set (i.e. no duplicates) composed of those + * elements common to both lists. Duplication is determined according + * to the value returned by applying the supplied predicate to two list + * elements. + * + * @func + * @memberOf R + * @category Relation + * @sig (a,a -> Boolean) -> [a] -> [a] -> [a] + * @param {Function} pred A predicate function that determines whether + * the two supplied elements are equal. + * @param {Array} list1 One list of items to compare + * @param {Array} list2 A second list of items to compare + * @see R.intersection + * @return {Array} A new list containing those elements common to both lists. + * @example + * + * var buffaloSpringfield = [ + * {id: 824, name: 'Richie Furay'}, + * {id: 956, name: 'Dewey Martin'}, + * {id: 313, name: 'Bruce Palmer'}, + * {id: 456, name: 'Stephen Stills'}, + * {id: 177, name: 'Neil Young'} + * ]; + * var csny = [ + * {id: 204, name: 'David Crosby'}, + * {id: 456, name: 'Stephen Stills'}, + * {id: 539, name: 'Graham Nash'}, + * {id: 177, name: 'Neil Young'} + * ]; + * + * var sameId = function(o1, o2) {return o1.id === o2.id;}; + * + * R.intersectionWith(sameId, buffaloSpringfield, csny); + * //=> [{id: 456, name: 'Stephen Stills'}, {id: 177, name: 'Neil Young'}] + */ + var intersectionWith = _curry3(function intersectionWith(pred, list1, list2) { + var results = [], idx = 0; + while (idx < list1.length) { + if (_containsWith(pred, list1[idx], list2)) { + results[results.length] = list1[idx]; + } + idx += 1; + } + return uniqWith(pred, results); + }); - return MonoidalReducer; - }(); + /** + * Creates a new list with the separator interposed between elements. + * + * @func + * @memberOf R + * @category List + * @sig a -> [a] -> [a] + * @param {*} separator The element to add to the list. + * @param {Array} list The list to be interposed. + * @return {Array} The new list. + * @example + * + * R.intersperse('n', ['ba', 'a', 'a']); //=> ['ba', 'n', 'a', 'n', 'a'] + */ + var intersperse = _curry2(_checkForMethod('intersperse', function intersperse(separator, list) { + var out = []; + var idx = 0; + var length = list.length; + while (idx < length) { + if (idx === length - 1) { + out.push(list[idx]); + } else { + out.push(list[idx], separator); + } + idx += 1; + } + return out; + })); - exports.default = MonoidalReducer; + /** + * Transforms the items of the list with the transducer and appends the transformed items to + * the accumulator using an appropriate iterator function based on the accumulator type. + * + * The accumulator can be an array, string, object or a transformer. Iterated items will + * be appended to arrays and concatenated to strings. Objects will be merged directly or 2-item + * arrays will be merged as key, value pairs. + * + * The accumulator can also be a transformer object that provides a 2-arity reducing iterator + * function, step, 0-arity initial value function, init, and 1-arity result extraction function + * result. The step function is used as the iterator function in reduce. The result function is + * used to convert the final accumulator into the return type and in most cases is R.identity. + * The init function is used to provide the initial accumulator. + * + * The iteration is performed with R.reduce after initializing the transducer. + * + * @func + * @memberOf R + * @category List + * @sig a -> (b -> b) -> [c] -> a + * @param {*} acc The initial accumulator value. + * @param {Function} xf The transducer function. Receives a transformer and returns a transformer. + * @param {Array} list The list to iterate over. + * @return {*} The final, accumulated value. + * @example + * + * var numbers = [1, 2, 3, 4]; + * var transducer = R.compose(R.map(R.add(1)), R.take(2)); + * + * R.into([], transducer, numbers); //=> [2, 3] + * + * var intoArray = R.into([]); + * intoArray(transducer, numbers); //=> [2, 3] + */ + var into = _curry3(function into(acc, xf, list) { + return _isTransformer(acc) ? _reduce(xf(acc), acc['@@transducer/init'](), list) : _reduce(xf(_stepCat(acc)), acc, list); + }); - Object.defineProperties(MonoidalReducer.prototype, methods); + /** + * Same as R.invertObj, however this accounts for objects + * with duplicate values by putting the values into an + * array. + * + * @func + * @memberOf R + * @category Object + * @sig {s: x} -> {x: [ s, ... ]} + * @param {Object} obj The object or array to invert + * @return {Object} out A new object with keys + * in an array. + * @example + * + * var raceResultsByFirstName = { + * first: 'alice', + * second: 'jake', + * third: 'alice', + * }; + * R.invert(raceResultsByFirstName); + * //=> { 'alice': ['first', 'third'], 'jake':['second'] } + */ + var invert = _curry1(function invert(obj) { + var props = keys(obj); + var len = props.length; + var idx = 0; + var out = {}; + while (idx < len) { + var key = props[idx]; + var val = obj[key]; + var list = _has(val, out) ? out[val] : out[val] = []; + list[list.length] = key; + idx += 1; + } + return out; + }); -/***/ }, -/* 37 */ -/***/ function(module, exports, __webpack_require__) { + /** + * Returns a new object with the keys of the given object + * as values, and the values of the given object as keys. + * + * @func + * @memberOf R + * @category Object + * @sig {s: x} -> {x: s} + * @param {Object} obj The object or array to invert + * @return {Object} out A new object + * @example + * + * var raceResults = { + * first: 'alice', + * second: 'jake' + * }; + * R.invertObj(raceResults); + * //=> { 'alice': 'first', 'jake':'second' } + * + * // Alternatively: + * var raceResults = ['alice', 'jake']; + * R.invertObj(raceResults); + * //=> { 'alice': '0', 'jake':'1' } + */ + var invertObj = _curry1(function invertObj(obj) { + var props = keys(obj); + var len = props.length; + var idx = 0; + var out = {}; + while (idx < len) { + var key = props[idx]; + out[obj[key]] = key; + idx += 1; + } + return out; + }); - "use strict"; + /** + * Returns the last element of the given list or string. + * + * @func + * @memberOf R + * @category List + * @see R.init, R.head, R.tail + * @sig [a] -> a | Undefined + * @sig String -> String + * @param {*} list + * @return {*} + * @example + * + * R.last(['fi', 'fo', 'fum']); //=> 'fum' + * R.last([]); //=> undefined + * + * R.last('abc'); //=> 'c' + * R.last(''); //=> '' + */ + var last = nth(-1); - Object.defineProperty(exports, "__esModule", { - value: true - }); + /** + * Returns the position of the last occurrence of an item in + * an array, or -1 if the item is not included in the array. + * `R.equals` is used to determine equality. + * + * @func + * @memberOf R + * @category List + * @sig a -> [a] -> Number + * @param {*} target The item to find. + * @param {Array} xs The array to search in. + * @return {Number} the index of the target, or -1 if the target is not found. + * @see R.indexOf + * @example + * + * R.lastIndexOf(3, [-1,3,3,0,1,2,3,4]); //=> 6 + * R.lastIndexOf(10, [1,2,3,4]); //=> -1 + */ + var lastIndexOf = _curry2(function lastIndexOf(target, xs) { + if (_hasMethod('lastIndexOf', xs)) { + return xs.lastIndexOf(target); + } else { + var idx = xs.length - 1; + while (idx >= 0) { + if (equals(xs[idx], target)) { + return idx; + } + idx -= 1; + } + return -1; + } + }); - var _terms = __webpack_require__(28); + /** + * Returns a new list, constructed by applying the supplied function to every element of the + * supplied list. + * + * Note: `R.map` does not skip deleted or unassigned indices (sparse arrays), unlike the + * native `Array.prototype.map` method. For more details on this behavior, see: + * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map#Description + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig (a -> b) -> [a] -> [b] + * @param {Function} fn The function to be called on every element of the input `list`. + * @param {Array} list The list to be iterated over. + * @return {Array} The new list. + * @example + * + * var double = function(x) { + * return x * 2; + * }; + * + * R.map(double, [1, 2, 3]); //=> [2, 4, 6] + */ + var map = _curry2(_dispatchable('map', _xmap, _map)); - var _terms2 = _interopRequireDefault(_terms); + /** + * Map, but for objects. Creates an object with the same keys as `obj` and values + * generated by running each property of `obj` through `fn`. `fn` is passed one argument: + * *(value)*. + * + * @func + * @memberOf R + * @category Object + * @sig (v -> v) -> {k: v} -> {k: v} + * @param {Function} fn A function called for each property in `obj`. Its return value will + * become a new property on the return object. + * @param {Object} obj The object to iterate over. + * @return {Object} A new object with the same keys as `obj` and values that are the result + * of running each property through `fn`. + * @example + * + * var values = { x: 1, y: 2, z: 3 }; + * var double = function(num) { + * return num * 2; + * }; + * + * R.mapObj(double, values); //=> { x: 2, y: 4, z: 6 } + */ + var mapObj = _curry2(function mapObj(fn, obj) { + return _reduce(function (acc, key) { + acc[key] = fn(obj[key]); + return acc; + }, {}, keys(obj)); + }); - var _shiftReducer = __webpack_require__(33); + /** + * Like `mapObj`, but but passes additional arguments to the predicate function. The + * predicate function is passed three arguments: *(value, key, obj)*. + * + * @func + * @memberOf R + * @category Object + * @sig (v, k, {k: v} -> v) -> {k: v} -> {k: v} + * @param {Function} fn A function called for each property in `obj`. Its return value will + * become a new property on the return object. + * @param {Object} obj The object to iterate over. + * @return {Object} A new object with the same keys as `obj` and values that are the result + * of running each property through `fn`. + * @example + * + * var values = { x: 1, y: 2, z: 3 }; + * var prependKeyAndDouble = function(num, key, obj) { + * return key + (num * 2); + * }; + * + * R.mapObjIndexed(prependKeyAndDouble, values); //=> { x: 'x2', y: 'y4', z: 'z6' } + */ + var mapObjIndexed = _curry2(function mapObjIndexed(fn, obj) { + return _reduce(function (acc, key) { + acc[key] = fn(obj[key], key, obj); + return acc; + }, {}, keys(obj)); + }); - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + /** + * Returns `true` if no elements of the list match the predicate, + * `false` otherwise. + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> Boolean + * @param {Function} fn The predicate function. + * @param {Array} list The array to consider. + * @return {Boolean} `true` if the predicate is not satisfied by every element, `false` otherwise. + * @see R.all, R.any + * @example + * + * R.none(R.isNaN, [1, 2, 3]); //=> true + * R.none(R.isNaN, [1, 2, 3, NaN]); //=> false + */ + var none = _curry2(_complement(_dispatchable('any', _xany, any))); - class ParseReducer extends _shiftReducer.CloneReducer { - constructor(context_573) { - super(); - this.context = context_573; - } - reduceModule(node_574, state_575) { - return new _terms2.default("Module", { directives: state_575.directives.toArray(), items: state_575.items.toArray() }); - } - reduceImport(node_576, state_577) { - let moduleSpecifier_578 = state_577.moduleSpecifier ? state_577.moduleSpecifier.val() : null; - return new _terms2.default("Import", { defaultBinding: state_577.defaultBinding, namedImports: state_577.namedImports.toArray(), moduleSpecifier: moduleSpecifier_578, forSyntax: node_576.forSyntax }); - } - reduceImportNamespace(node_579, state_580) { - let moduleSpecifier_581 = state_580.moduleSpecifier ? state_580.moduleSpecifier.val() : null; - return new _terms2.default("ImportNamespace", { defaultBinding: state_580.defaultBinding, namespaceBinding: state_580.namespaceBinding, moduleSpecifier: moduleSpecifier_581, forSyntax: node_579.forSyntax }); - } - reduceExport(node_582, state_583) { - return new _terms2.default("Export", { declaration: state_583.declaration }); - } - reduceExportAllFrom(node_584, state_585) { - let moduleSpecifier_586 = state_585.moduleSpecifier ? state_585.moduleSpecifier.val() : null; - return new _terms2.default("ExportAllFrom", { moduleSpecifier: moduleSpecifier_586 }); - } - reduceExportFrom(node_587, state_588) { - let moduleSpecifier_589 = state_588.moduleSpecifier ? state_588.moduleSpecifier.val() : null; - return new _terms2.default("ExportFrom", { moduleSpecifier: moduleSpecifier_589, namedExports: state_588.namedExports.toArray() }); - } - reduceExportSpecifier(node_590, state_591) { - let name_592 = state_591.name, - exportedName_593 = state_591.exportedName; - if (name_592 == null) { - name_592 = exportedName_593.resolve(this.context.phase); - exportedName_593 = exportedName_593.val(); - } else { - name_592 = name_592.resolve(this.context.phase); - exportedName_593 = exportedName_593.val(); - } - return new _terms2.default("ExportSpecifier", { name: name_592, exportedName: exportedName_593 }); - } - reduceImportSpecifier(node_594, state_595) { - let name_596 = state_595.name ? state_595.name.resolve(this.context.phase) : null; - return new _terms2.default("ImportSpecifier", { name: name_596, binding: state_595.binding }); - } - reduceIdentifierExpression(node_597, state_598) { - return new _terms2.default("IdentifierExpression", { name: node_597.name.resolve(this.context.phase) }); - } - reduceLiteralNumericExpression(node_599, state_600) { - return new _terms2.default("LiteralNumericExpression", { value: node_599.value.val() }); - } - reduceLiteralBooleanExpression(node_601, state_602) { - return new _terms2.default("LiteralBooleanExpression", { value: node_601.value.val() === "true" }); - } - reduceLiteralStringExpression(node_603, state_604) { - return new _terms2.default("LiteralStringExpression", { value: node_603.value.token.str }); - } - reduceCallExpression(node_605, state_606) { - return new _terms2.default("CallExpression", { callee: state_606.callee, arguments: state_606.arguments.toArray() }); - } - reduceFunctionBody(node_607, state_608) { - return new _terms2.default("FunctionBody", { directives: state_608.directives.toArray(), statements: state_608.statements.toArray() }); - } - reduceFormalParameters(node_609, state_610) { - return new _terms2.default("FormalParameters", { items: state_610.items.toArray(), rest: state_610.rest }); - } - reduceBindingIdentifier(node_611, state_612) { - return new _terms2.default("BindingIdentifier", { name: node_611.name.resolve(this.context.phase) }); - } - reduceBinaryExpression(node_613, state_614) { - return new _terms2.default("BinaryExpression", { left: state_614.left, operator: node_613.operator.val(), right: state_614.right }); - } - reduceObjectExpression(node_615, state_616) { - return new _terms2.default("ObjectExpression", { properties: state_616.properties.toArray() }); - } - reduceVariableDeclaration(node_617, state_618) { - return new _terms2.default("VariableDeclaration", { kind: state_618.kind, declarators: state_618.declarators.toArray() }); - } - reduceStaticPropertyName(node_619, state_620) { - return new _terms2.default("StaticPropertyName", { value: node_619.value.val().toString() }); - } - reduceArrayExpression(node_621, state_622) { - return new _terms2.default("ArrayExpression", { elements: state_622.elements.toArray() }); - } - reduceStaticMemberExpression(node_623, state_624) { - return new _terms2.default("StaticMemberExpression", { object: state_624.object, property: state_624.property.val() }); - } - } - exports.default = ParseReducer; - //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/parse-reducer.js"],"names":[],"mappings":"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","file":"parse-reducer.js","sourcesContent":["import Term from \"./terms\";\nimport {CloneReducer} from \"shift-reducer\";\nexport default class ParseReducer extends CloneReducer {\n  constructor(context_573) {\n    super();\n    this.context = context_573;\n  }\n  reduceModule(node_574, state_575) {\n    return new Term(\"Module\", {directives: state_575.directives.toArray(), items: state_575.items.toArray()});\n  }\n  reduceImport(node_576, state_577) {\n    let moduleSpecifier_578 = state_577.moduleSpecifier ? state_577.moduleSpecifier.val() : null;\n    return new Term(\"Import\", {defaultBinding: state_577.defaultBinding, namedImports: state_577.namedImports.toArray(), moduleSpecifier: moduleSpecifier_578, forSyntax: node_576.forSyntax});\n  }\n  reduceImportNamespace(node_579, state_580) {\n    let moduleSpecifier_581 = state_580.moduleSpecifier ? state_580.moduleSpecifier.val() : null;\n    return new Term(\"ImportNamespace\", {defaultBinding: state_580.defaultBinding, namespaceBinding: state_580.namespaceBinding, moduleSpecifier: moduleSpecifier_581, forSyntax: node_579.forSyntax});\n  }\n  reduceExport(node_582, state_583) {\n    return new Term(\"Export\", {declaration: state_583.declaration});\n  }\n  reduceExportAllFrom(node_584, state_585) {\n    let moduleSpecifier_586 = state_585.moduleSpecifier ? state_585.moduleSpecifier.val() : null;\n    return new Term(\"ExportAllFrom\", {moduleSpecifier: moduleSpecifier_586});\n  }\n  reduceExportFrom(node_587, state_588) {\n    let moduleSpecifier_589 = state_588.moduleSpecifier ? state_588.moduleSpecifier.val() : null;\n    return new Term(\"ExportFrom\", {moduleSpecifier: moduleSpecifier_589, namedExports: state_588.namedExports.toArray()});\n  }\n  reduceExportSpecifier(node_590, state_591) {\n    let name_592 = state_591.name, exportedName_593 = state_591.exportedName;\n    if (name_592 == null) {\n      name_592 = exportedName_593.resolve(this.context.phase);\n      exportedName_593 = exportedName_593.val();\n    } else {\n      name_592 = name_592.resolve(this.context.phase);\n      exportedName_593 = exportedName_593.val();\n    }\n    return new Term(\"ExportSpecifier\", {name: name_592, exportedName: exportedName_593});\n  }\n  reduceImportSpecifier(node_594, state_595) {\n    let name_596 = state_595.name ? state_595.name.resolve(this.context.phase) : null;\n    return new Term(\"ImportSpecifier\", {name: name_596, binding: state_595.binding});\n  }\n  reduceIdentifierExpression(node_597, state_598) {\n    return new Term(\"IdentifierExpression\", {name: node_597.name.resolve(this.context.phase)});\n  }\n  reduceLiteralNumericExpression(node_599, state_600) {\n    return new Term(\"LiteralNumericExpression\", {value: node_599.value.val()});\n  }\n  reduceLiteralBooleanExpression(node_601, state_602) {\n    return new Term(\"LiteralBooleanExpression\", {value: node_601.value.val() === \"true\"});\n  }\n  reduceLiteralStringExpression(node_603, state_604) {\n    return new Term(\"LiteralStringExpression\", {value: node_603.value.token.str});\n  }\n  reduceCallExpression(node_605, state_606) {\n    return new Term(\"CallExpression\", {callee: state_606.callee, arguments: state_606.arguments.toArray()});\n  }\n  reduceFunctionBody(node_607, state_608) {\n    return new Term(\"FunctionBody\", {directives: state_608.directives.toArray(), statements: state_608.statements.toArray()});\n  }\n  reduceFormalParameters(node_609, state_610) {\n    return new Term(\"FormalParameters\", {items: state_610.items.toArray(), rest: state_610.rest});\n  }\n  reduceBindingIdentifier(node_611, state_612) {\n    return new Term(\"BindingIdentifier\", {name: node_611.name.resolve(this.context.phase)});\n  }\n  reduceBinaryExpression(node_613, state_614) {\n    return new Term(\"BinaryExpression\", {left: state_614.left, operator: node_613.operator.val(), right: state_614.right});\n  }\n  reduceObjectExpression(node_615, state_616) {\n    return new Term(\"ObjectExpression\", {properties: state_616.properties.toArray()});\n  }\n  reduceVariableDeclaration(node_617, state_618) {\n    return new Term(\"VariableDeclaration\", {kind: state_618.kind, declarators: state_618.declarators.toArray()});\n  }\n  reduceStaticPropertyName(node_619, state_620) {\n    return new Term(\"StaticPropertyName\", {value: node_619.value.val().toString()});\n  }\n  reduceArrayExpression(node_621, state_622) {\n    return new Term(\"ArrayExpression\", {elements: state_622.elements.toArray()});\n  }\n  reduceStaticMemberExpression(node_623, state_624) {\n    return new Term(\"StaticMemberExpression\", {object: state_624.object, property: state_624.property.val()});\n  }\n}\n"]} + /** + * A function that returns the first truthy of two arguments otherwise the + * last argument. Note that this is NOT short-circuited, meaning that if + * expressions are passed they are both evaluated. + * + * Dispatches to the `or` method of the first argument if applicable. + * + * @func + * @memberOf R + * @category Logic + * @sig * -> * -> * + * @param {*} a any value + * @param {*} b any other value + * @return {*} the first truthy argument, otherwise the last argument. + * @see R.either + * @example + * + * R.or(false, true); //=> true + * R.or(0, []); //=> [] + * R.or(null, ''); => '' + */ + var or = _curry2(function or(a, b) { + return _hasMethod('or', a) ? a.or(b) : a || b; + }); -/***/ }, -/* 38 */ -/***/ function(module, exports, __webpack_require__) { + /** + * Accepts as its arguments a function and any number of values and returns a function that, + * when invoked, calls the original function with all of the values prepended to the + * original function's arguments list. In some libraries this function is named `applyLeft`. + * + * @func + * @memberOf R + * @category Function + * @sig (a -> b -> ... -> i -> j -> ... -> m -> n) -> a -> b-> ... -> i -> (j -> ... -> m -> n) + * @param {Function} fn The function to invoke. + * @param {...*} [args] Arguments to prepend to `fn` when the returned function is invoked. + * @return {Function} A new function wrapping `fn`. When invoked, it will call `fn` + * with `args` prepended to `fn`'s arguments list. + * @example + * + * var multiply = function(a, b) { return a * b; }; + * var double = R.partial(multiply, 2); + * double(2); //=> 4 + * + * var greet = function(salutation, title, firstName, lastName) { + * return salutation + ', ' + title + ' ' + firstName + ' ' + lastName + '!'; + * }; + * var sayHello = R.partial(greet, 'Hello'); + * var sayHelloToMs = R.partial(sayHello, 'Ms.'); + * sayHelloToMs('Jane', 'Jones'); //=> 'Hello, Ms. Jane Jones!' + */ + var partial = curry(_createPartialApplicator(_concat)); - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.SemiOp = exports.CommaSep = exports.Semi = exports.Seq = exports.ContainsIn = exports.NoIn = exports.Brace = exports.Bracket = exports.Paren = exports.NumberCodeRep = exports.Token = exports.Empty = exports.CodeRep = exports.escapeStringLiteral = exports.getPrecedence = exports.Precedence = exports.Sep = exports.FormattedCodeGen = exports.ExtensibleCodeGen = exports.MinimalCodeGen = undefined; - exports.default = codeGen; - - var _minimalCodegen = __webpack_require__(39); - - Object.defineProperty(exports, "MinimalCodeGen", { - enumerable: true, - get: function get() { - return _minimalCodegen.default; - } - }); - - var _formattedCodegen = __webpack_require__(42); - - Object.defineProperty(exports, "ExtensibleCodeGen", { - enumerable: true, - get: function get() { - return _formattedCodegen.ExtensibleCodeGen; - } - }); - Object.defineProperty(exports, "FormattedCodeGen", { - enumerable: true, - get: function get() { - return _formattedCodegen.FormattedCodeGen; - } - }); - Object.defineProperty(exports, "Sep", { - enumerable: true, - get: function get() { - return _formattedCodegen.Sep; - } - }); - - var _coderep = __webpack_require__(41); - - Object.defineProperty(exports, "Precedence", { - enumerable: true, - get: function get() { - return _coderep.Precedence; - } - }); - Object.defineProperty(exports, "getPrecedence", { - enumerable: true, - get: function get() { - return _coderep.getPrecedence; - } - }); - Object.defineProperty(exports, "escapeStringLiteral", { - enumerable: true, - get: function get() { - return _coderep.escapeStringLiteral; - } - }); - Object.defineProperty(exports, "CodeRep", { - enumerable: true, - get: function get() { - return _coderep.CodeRep; - } - }); - Object.defineProperty(exports, "Empty", { - enumerable: true, - get: function get() { - return _coderep.Empty; - } - }); - Object.defineProperty(exports, "Token", { - enumerable: true, - get: function get() { - return _coderep.Token; - } - }); - Object.defineProperty(exports, "NumberCodeRep", { - enumerable: true, - get: function get() { - return _coderep.NumberCodeRep; - } - }); - Object.defineProperty(exports, "Paren", { - enumerable: true, - get: function get() { - return _coderep.Paren; - } - }); - Object.defineProperty(exports, "Bracket", { - enumerable: true, - get: function get() { - return _coderep.Bracket; - } - }); - Object.defineProperty(exports, "Brace", { - enumerable: true, - get: function get() { - return _coderep.Brace; - } - }); - Object.defineProperty(exports, "NoIn", { - enumerable: true, - get: function get() { - return _coderep.NoIn; - } - }); - Object.defineProperty(exports, "ContainsIn", { - enumerable: true, - get: function get() { - return _coderep.ContainsIn; - } - }); - Object.defineProperty(exports, "Seq", { - enumerable: true, - get: function get() { - return _coderep.Seq; - } - }); - Object.defineProperty(exports, "Semi", { - enumerable: true, - get: function get() { - return _coderep.Semi; - } - }); - Object.defineProperty(exports, "CommaSep", { - enumerable: true, - get: function get() { - return _coderep.CommaSep; - } - }); - Object.defineProperty(exports, "SemiOp", { - enumerable: true, - get: function get() { - return _coderep.SemiOp; - } - }); - - var _shiftReducer = __webpack_require__(33); - - var _shiftReducer2 = _interopRequireDefault(_shiftReducer); - - var _token_stream = __webpack_require__(43); - - var _minimalCodegen2 = _interopRequireDefault(_minimalCodegen); + /** + * Accepts as its arguments a function and any number of values and returns a function that, + * when invoked, calls the original function with all of the values appended to the original + * function's arguments list. + * + * Note that `partialRight` is the opposite of `partial`: `partialRight` fills `fn`'s arguments + * from the right to the left. In some libraries this function is named `applyRight`. + * + * @func + * @memberOf R + * @category Function + * @sig (a -> b-> ... -> i -> j -> ... -> m -> n) -> j -> ... -> m -> n -> (a -> b-> ... -> i) + * @param {Function} fn The function to invoke. + * @param {...*} [args] Arguments to append to `fn` when the returned function is invoked. + * @return {Function} A new function wrapping `fn`. When invoked, it will call `fn` with + * `args` appended to `fn`'s arguments list. + * @example + * + * var greet = function(salutation, title, firstName, lastName) { + * return salutation + ', ' + title + ' ' + firstName + ' ' + lastName + '!'; + * }; + * var greetMsJaneJones = R.partialRight(greet, 'Ms.', 'Jane', 'Jones'); + * + * greetMsJaneJones('Hello'); //=> 'Hello, Ms. Jane Jones!' + */ + var partialRight = curry(_createPartialApplicator(flip(_concat))); - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + /** + * Takes a predicate and a list and returns the pair of lists of + * elements which do and do not satisfy the predicate, respectively. + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> [[a],[a]] + * @param {Function} pred A predicate to determine which array the element belongs to. + * @param {Array} list The array to partition. + * @return {Array} A nested array, containing first an array of elements that satisfied the predicate, + * and second an array of elements that did not satisfy. + * @example + * + * R.partition(R.contains('s'), ['sss', 'ttt', 'foo', 'bars']); + * //=> [ [ 'sss', 'bars' ], [ 'ttt', 'foo' ] ] + */ + var partition = _curry2(function partition(pred, list) { + return _reduce(function (acc, elt) { + var xs = acc[pred(elt) ? 0 : 1]; + xs[xs.length] = elt; + return acc; + }, [ + [], + [] + ], list); + }); - function codeGen(script) { - var generator = arguments.length <= 1 || arguments[1] === undefined ? new _minimalCodegen2.default() : arguments[1]; + /** + * Determines whether a nested path on an object has a specific value, + * in `R.equals` terms. Most likely used to filter a list. + * + * @func + * @memberOf R + * @category Relation + * @sig [String] -> * -> {String: *} -> Boolean + * @param {Array} path The path of the nested property to use + * @param {*} val The value to compare the nested property with + * @param {Object} obj The object to check the nested property in + * @return {Boolean} `true` if the value equals the nested object property, + * `false` otherwise. + * @example + * + * var user1 = { address: { zipCode: 90210 } }; + * var user2 = { address: { zipCode: 55555 } }; + * var user3 = { name: 'Bob' }; + * var users = [ user1, user2, user3 ]; + * var isFamous = R.pathEq(['address', 'zipCode'], 90210); + * R.filter(isFamous, users); //=> [ user1 ] + */ + var pathEq = _curry3(function pathEq(_path, val, obj) { + return equals(path(_path, obj), val); + }); - var ts = new _token_stream.TokenStream(); - var rep = (0, _shiftReducer2.default)(generator, script); - rep.emit(ts); - return ts.result; - } + /** + * Returns a new list by plucking the same named property off all objects in the list supplied. + * + * @func + * @memberOf R + * @category List + * @sig k -> [{k: v}] -> [v] + * @param {Number|String} key The key name to pluck off of each object. + * @param {Array} list The array to consider. + * @return {Array} The list of values for the given key. + * @example + * + * R.pluck('a')([{a: 1}, {a: 2}]); //=> [1, 2] + * R.pluck(0)([[1, 2], [3, 4]]); //=> [1, 3] + */ + var pluck = _curry2(function pluck(p, list) { + return map(prop(p), list); + }); -/***/ }, -/* 39 */ -/***/ function(module, exports, __webpack_require__) { + /** + * Returns `true` if the specified object property is equal, in `R.equals` + * terms, to the given value; `false` otherwise. + * + * @func + * @memberOf R + * @category Relation + * @sig String -> a -> Object -> Boolean + * @param {String} name + * @param {*} val + * @param {*} obj + * @return {Boolean} + * @see R.equals, R.propSatisfies + * @example + * + * var abby = {name: 'Abby', age: 7, hair: 'blond'}; + * var fred = {name: 'Fred', age: 12, hair: 'brown'}; + * var rusty = {name: 'Rusty', age: 10, hair: 'brown'}; + * var alois = {name: 'Alois', age: 15, disposition: 'surly'}; + * var kids = [abby, fred, rusty, alois]; + * var hasBrownHair = R.propEq('hair', 'brown'); + * R.filter(hasBrownHair, kids); //=> [fred, rusty] + */ + var propEq = _curry3(function propEq(name, val, obj) { + return propSatisfies(equals(val), name, obj); + }); - "use strict"; + /** + * Returns `true` if the specified object property is of the given type; + * `false` otherwise. + * + * @func + * @memberOf R + * @category Type + * @sig Type -> String -> Object -> Boolean + * @param {Function} type + * @param {String} name + * @param {*} obj + * @return {Boolean} + * @see R.is + * @see R.propSatisfies + * @example + * + * R.propIs(Number, 'x', {x: 1, y: 2}); //=> true + * R.propIs(Number, 'x', {x: 'foo'}); //=> false + * R.propIs(Number, 'x', {}); //=> false + */ + var propIs = _curry3(function propIs(type, name, obj) { + return propSatisfies(is(type), name, obj); + }); - var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); + /** + * Returns a single item by iterating through the list, successively calling the iterator + * function and passing it an accumulator value and the current value from the array, and + * then passing the result to the next call. + * + * The iterator function receives two values: *(acc, value)*. It may use `R.reduced` to + * shortcut the iteration. + * + * Note: `R.reduce` does not skip deleted or unassigned indices (sparse arrays), unlike + * the native `Array.prototype.reduce` method. For more details on this behavior, see: + * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce#Description + * @see R.reduced + * + * @func + * @memberOf R + * @category List + * @sig (a,b -> a) -> a -> [b] -> a + * @param {Function} fn The iterator function. Receives two values, the accumulator and the + * current element from the array. + * @param {*} acc The accumulator value. + * @param {Array} list The list to iterate over. + * @return {*} The final, accumulated value. + * @example + * + * var numbers = [1, 2, 3]; + * var add = function(a, b) { + * return a + b; + * }; + * + * R.reduce(add, 10, numbers); //=> 16 + */ + var reduce = _curry3(_reduce); - Object.defineProperty(exports, "__esModule", { - value: true - }); + /** + * Similar to `filter`, except that it keeps only values for which the given predicate + * function returns falsy. The predicate function is passed one argument: *(value)*. + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> [a] + * @param {Function} fn The function called per iteration. + * @param {Array} list The collection to iterate over. + * @return {Array} The new filtered array. + * @see R.filter + * @example + * + * var isOdd = function(n) { + * return n % 2 === 1; + * }; + * R.reject(isOdd, [1, 2, 3, 4]); //=> [2, 4] + */ + var reject = _curry2(function reject(fn, list) { + return filter(_complement(fn), list); + }); - var _objectAssign = __webpack_require__(40); + /** + * Returns a fixed list of size `n` containing a specified identical value. + * + * @func + * @memberOf R + * @category List + * @sig a -> n -> [a] + * @param {*} value The value to repeat. + * @param {Number} n The desired size of the output list. + * @return {Array} A new array containing `n` `value`s. + * @example + * + * R.repeat('hi', 5); //=> ['hi', 'hi', 'hi', 'hi', 'hi'] + * + * var obj = {}; + * var repeatedObjs = R.repeat(obj, 5); //=> [{}, {}, {}, {}, {}] + * repeatedObjs[0] === repeatedObjs[1]; //=> true + */ + var repeat = _curry2(function repeat(value, n) { + return times(always(value), n); + }); - var _objectAssign2 = _interopRequireDefault(_objectAssign); + /** + * Returns the elements of the given list or string (or object with a `slice` + * method) from `fromIndex` (inclusive) to `toIndex` (exclusive). + * + * @func + * @memberOf R + * @category List + * @sig Number -> Number -> [a] -> [a] + * @sig Number -> Number -> String -> String + * @param {Number} fromIndex The start index (inclusive). + * @param {Number} toIndex The end index (exclusive). + * @param {*} list + * @return {*} + * @example + * + * R.slice(1, 3, ['a', 'b', 'c', 'd']); //=> ['b', 'c'] + * R.slice(1, Infinity, ['a', 'b', 'c', 'd']); //=> ['b', 'c', 'd'] + * R.slice(0, -1, ['a', 'b', 'c', 'd']); //=> ['a', 'b', 'c'] + * R.slice(-3, -1, ['a', 'b', 'c', 'd']); //=> ['b', 'c'] + * R.slice(0, 3, 'ramda'); //=> 'ram' + */ + var slice = _curry3(_checkForMethod('slice', function slice(fromIndex, toIndex, list) { + return Array.prototype.slice.call(list, fromIndex, toIndex); + })); - var _esutils = __webpack_require__(6); + /** + * Splits a collection into slices of the specified length. + * + * @func + * @memberOf R + * @category List + * @sig Number -> [a] -> [[a]] + * @sig Number -> String -> [String] + * @param {Number} n + * @param {Array} list + * @return {Array} + * @example + * + * R.splitEvery(3, [1, 2, 3, 4, 5, 6, 7]); //=> [[1, 2, 3], [4, 5, 6], [7]] + * R.splitEvery(3, 'foobarbaz'); //=> ['foo', 'bar', 'baz'] + */ + var splitEvery = _curry2(function splitEvery(n, list) { + if (n <= 0) { + throw new Error('First argument to splitEvery must be a positive integer'); + } + var result = []; + var idx = 0; + while (idx < list.length) { + result.push(slice(idx, idx += n, list)); + } + return result; + }); - var _coderep = __webpack_require__(41); + /** + * Adds together all the elements of a list. + * + * @func + * @memberOf R + * @category Math + * @sig [Number] -> Number + * @param {Array} list An array of numbers + * @return {Number} The sum of all the numbers in the list. + * @see R.reduce + * @example + * + * R.sum([2,4,6,8,100,1]); //=> 121 + */ + var sum = reduce(add, 0); - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + /** + * Returns all but the first element of the given list or string (or object + * with a `tail` method). + * + * @func + * @memberOf R + * @category List + * @see R.head, R.init, R.last + * @sig [a] -> [a] + * @sig String -> String + * @param {*} list + * @return {*} + * @example + * + * R.tail([1, 2, 3]); //=> [2, 3] + * R.tail([1, 2]); //=> [2] + * R.tail([1]); //=> [] + * R.tail([]); //=> [] + * + * R.tail('abc'); //=> 'bc' + * R.tail('ab'); //=> 'b' + * R.tail('a'); //=> '' + * R.tail(''); //=> '' + */ + var tail = _checkForMethod('tail', slice(1, Infinity)); - function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } + /** + * Returns the first `n` elements of the given list, string, or + * transducer/transformer (or object with a `take` method). + * + * @func + * @memberOf R + * @category List + * @sig Number -> [a] -> [a] + * @sig Number -> String -> String + * @param {Number} n + * @param {*} list + * @return {*} + * @see R.drop + * @example + * + * R.take(1, ['foo', 'bar', 'baz']); //=> ['foo'] + * R.take(2, ['foo', 'bar', 'baz']); //=> ['foo', 'bar'] + * R.take(3, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] + * R.take(4, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] + * R.take(3, 'ramda'); //=> 'ram' + * + * var personnel = [ + * 'Dave Brubeck', + * 'Paul Desmond', + * 'Eugene Wright', + * 'Joe Morello', + * 'Gerry Mulligan', + * 'Bob Bates', + * 'Joe Dodge', + * 'Ron Crotty' + * ]; + * + * var takeFive = R.take(5); + * takeFive(personnel); + * //=> ['Dave Brubeck', 'Paul Desmond', 'Eugene Wright', 'Joe Morello', 'Gerry Mulligan'] + */ + var take = _curry2(_dispatchable('take', _xtake, function take(n, xs) { + return slice(0, n < 0 ? Infinity : n, xs); + })); - function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - - function p(node, precedence, a) { - return (0, _coderep.getPrecedence)(node) < precedence ? paren(a) : a; - } - - function t(token) { - return new _coderep.Token(token); - } - - function paren(rep) { - return new _coderep.Paren(rep); - } + /** + * Returns a new list containing the first `n` elements of a given list, passing each value + * to the supplied predicate function, and terminating when the predicate function returns + * `false`. Excludes the element that caused the predicate function to fail. The predicate + * function is passed one argument: *(value)*. + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig (a -> Boolean) -> [a] -> [a] + * @param {Function} fn The function called per iteration. + * @param {Array} list The collection to iterate over. + * @return {Array} A new array. + * @see R.dropWhile + * @example + * + * var isNotFour = function(x) { + * return !(x === 4); + * }; + * + * R.takeWhile(isNotFour, [1, 2, 3, 4]); //=> [1, 2, 3] + */ + var takeWhile = _curry2(_dispatchable('takeWhile', _xtakeWhile, function takeWhile(fn, list) { + var idx = 0, len = list.length; + while (idx < len && fn(list[idx])) { + idx += 1; + } + return _slice(list, 0, idx); + })); - function brace(rep) { - return new _coderep.Brace(rep); - } + /** + * Initializes a transducer using supplied iterator function. Returns a single item by + * iterating through the list, successively calling the transformed iterator function and + * passing it an accumulator value and the current value from the array, and then passing + * the result to the next call. + * + * The iterator function receives two values: *(acc, value)*. It will be wrapped as a + * transformer to initialize the transducer. A transformer can be passed directly in place + * of an iterator function. In both cases, iteration may be stopped early with the + * `R.reduced` function. + * + * A transducer is a function that accepts a transformer and returns a transformer and can + * be composed directly. + * + * A transformer is an an object that provides a 2-arity reducing iterator function, step, + * 0-arity initial value function, init, and 1-arity result extraction function, result. + * The step function is used as the iterator function in reduce. The result function is used + * to convert the final accumulator into the return type and in most cases is R.identity. + * The init function can be used to provide an initial accumulator, but is ignored by transduce. + * + * The iteration is performed with R.reduce after initializing the transducer. + * + * @func + * @memberOf R + * @category List + * @see R.reduce, R.reduced, R.into + * @sig (c -> c) -> (a,b -> a) -> a -> [b] -> a + * @param {Function} xf The transducer function. Receives a transformer and returns a transformer. + * @param {Function} fn The iterator function. Receives two values, the accumulator and the + * current element from the array. Wrapped as transformer, if necessary, and used to + * initialize the transducer + * @param {*} acc The initial accumulator value. + * @param {Array} list The list to iterate over. + * @return {*} The final, accumulated value. + * @example + * + * var numbers = [1, 2, 3, 4]; + * var transducer = R.compose(R.map(R.add(1)), R.take(2)); + * + * R.transduce(transducer, R.flip(R.append), [], numbers); //=> [2, 3] + */ + var transduce = curryN(4, function transduce(xf, fn, acc, list) { + return _reduce(xf(typeof fn === 'function' ? _xwrap(fn) : fn), acc, list); + }); - function bracket(rep) { - return new _coderep.Bracket(rep); - } + /** + * Combines two lists into a set (i.e. no duplicates) composed of the elements of each list. Duplication is + * determined according to the value returned by applying the supplied predicate to two list elements. + * + * @func + * @memberOf R + * @category Relation + * @sig (a,a -> Boolean) -> [a] -> [a] -> [a] + * @param {Function} pred A predicate used to test whether two items are equal. + * @param {Array} list1 The first list. + * @param {Array} list2 The second list. + * @return {Array} The first and second lists concatenated, with + * duplicates removed. + * @see R.union + * @example + * + * function cmp(x, y) { return x.a === y.a; } + * var l1 = [{a: 1}, {a: 2}]; + * var l2 = [{a: 1}, {a: 4}]; + * R.unionWith(cmp, l1, l2); //=> [{a: 1}, {a: 2}, {a: 4}] + */ + var unionWith = _curry3(function unionWith(pred, list1, list2) { + return uniqWith(pred, _concat(list1, list2)); + }); - function noIn(rep) { - return new _coderep.NoIn(rep); - } + /** + * Returns a new list containing only one copy of each element in the original list. + * `R.equals` is used to determine equality. + * + * @func + * @memberOf R + * @category List + * @sig [a] -> [a] + * @param {Array} list The array to consider. + * @return {Array} The list of unique items. + * @example + * + * R.uniq([1, 1, 2, 1]); //=> [1, 2] + * R.uniq([1, '1']); //=> [1, '1'] + * R.uniq([[42], [42]]); //=> [[42]] + */ + var uniq = uniqWith(equals); - function markContainsIn(state) { - return state.containsIn ? new _coderep.ContainsIn(state) : state; - } + /** + * Returns a new list by pulling every item at the first level of nesting out, and putting + * them in a new array. + * + * @func + * @memberOf R + * @category List + * @sig [a] -> [b] + * @param {Array} list The array to consider. + * @return {Array} The flattened list. + * @see R.flatten + * @example + * + * R.unnest([1, [2], [[3]]]); //=> [1, 2, [3]] + * R.unnest([[1, 2], [3, 4], [5, 6]]); //=> [1, 2, 3, 4, 5, 6] + */ + var unnest = _curry1(_makeFlat(false)); - function seq() { - for (var _len = arguments.length, reps = Array(_len), _key = 0; _key < _len; _key++) { - reps[_key] = arguments[_key]; - } + /** + * Accepts a function `fn` and any number of transformer functions and returns a new + * function. When the new function is invoked, it calls the function `fn` with parameters + * consisting of the result of calling each supplied handler on successive arguments to the + * new function. + * + * If more arguments are passed to the returned function than transformer functions, those + * arguments are passed directly to `fn` as additional parameters. If you expect additional + * arguments that don't need to be transformed, although you can ignore them, it's best to + * pass an identity function so that the new function reports the correct arity. + * + * @func + * @memberOf R + * @category Function + * @sig (x1 -> x2 -> ... -> z) -> ((a -> x1), (b -> x2), ...) -> (a -> b -> ... -> z) + * @param {Function} fn The function to wrap. + * @param {...Function} transformers A variable number of transformer functions + * @return {Function} The wrapped function. + * @example + * + * var double = function(y) { return y * 2; }; + * var square = function(x) { return x * x; }; + * var add = function(a, b) { return a + b; }; + * // Adds any number of arguments together + * var addAll = function() { + * return R.reduce(add, 0, arguments); + * }; + * + * // Basic example + * var addDoubleAndSquare = R.useWith(addAll, double, square); + * + * //≅ addAll(double(10), square(5)); + * addDoubleAndSquare(10, 5); //=> 45 + * + * // Example of passing more arguments than transformers + * //≅ addAll(double(10), square(5), 100); + * addDoubleAndSquare(10, 5, 100); //=> 145 + * + * // If there are extra _expected_ arguments that don't need to be transformed, although + * // you can ignore them, it might be best to pass in the identity function so that the new + * // function correctly reports arity. + * var addDoubleAndSquareWithExtraParams = R.useWith(addAll, double, square, R.identity); + * // addDoubleAndSquareWithExtraParams.length //=> 3 + * //≅ addAll(double(10), square(5), R.identity(100)); + * addDoubleAndSquare(10, 5, 100); //=> 145 + */ + /*, transformers */ + var useWith = curry(function useWith(fn) { + var transformers = _slice(arguments, 1); + var tlen = transformers.length; + return curry(_arity(tlen, function () { + var args = [], idx = 0; + while (idx < tlen) { + args[idx] = transformers[idx](arguments[idx]); + idx += 1; + } + return fn.apply(this, args.concat(_slice(arguments, tlen))); + })); + }); - return new _coderep.Seq(reps); - } + /** + * Takes a spec object and a test object; returns true if the test satisfies + * the spec, false otherwise. An object satisfies the spec if, for each of the + * spec's own properties, accessing that property of the object gives the same + * value (in `R.equals` terms) as accessing that property of the spec. + * + * `whereEq` is a specialization of [`where`](#where). + * + * @func + * @memberOf R + * @category Object + * @sig {String: *} -> {String: *} -> Boolean + * @param {Object} spec + * @param {Object} testObj + * @return {Boolean} + * @see R.where + * @example + * + * // pred :: Object -> Boolean + * var pred = R.whereEq({a: 1, b: 2}); + * + * pred({a: 1}); //=> false + * pred({a: 1, b: 2}); //=> true + * pred({a: 1, b: 2, c: 3}); //=> true + * pred({a: 1, b: 1}); //=> false + */ + var whereEq = _curry2(function whereEq(spec, testObj) { + return where(mapObj(equals, spec), testObj); + }); - function semi() { - return new _coderep.Semi(); - } + var _flatCat = function () { + var preservingReduced = function (xf) { + return { + '@@transducer/init': _xfBase.init, + '@@transducer/result': function (result) { + return xf['@@transducer/result'](result); + }, + '@@transducer/step': function (result, input) { + var ret = xf['@@transducer/step'](result, input); + return ret['@@transducer/reduced'] ? _forceReduced(ret) : ret; + } + }; + }; + return function _xcat(xf) { + var rxf = preservingReduced(xf); + return { + '@@transducer/init': _xfBase.init, + '@@transducer/result': function (result) { + return rxf['@@transducer/result'](result); + }, + '@@transducer/step': function (result, input) { + return !isArrayLike(input) ? _reduce(rxf, result, [input]) : _reduce(rxf, result, input); + } + }; + }; + }(); - function semiOp() { - return new _coderep.SemiOp(); - } + var _indexOf = function _indexOf(list, item, from) { + var idx = from; + while (idx < list.length) { + if (equals(list[idx], item)) { + return idx; + } + idx += 1; + } + return -1; + }; - function empty() { - return new _coderep.Empty(); - } + /** + * Create a predicate wrapper which will call a pick function (all/any) for each predicate + * + * @private + * @see R.all + * @see R.any + */ + // Call function immediately if given arguments + // Return a function which will call the predicates with the provided arguments + var _predicateWrap = function _predicateWrap(predPicker) { + return function (preds) { + var predIterator = function () { + var args = arguments; + return predPicker(function (predicate) { + return predicate.apply(null, args); + }, preds); + }; + return arguments.length > 1 ? // Call function immediately if given arguments + predIterator.apply(null, _slice(arguments, 1)) : // Return a function which will call the predicates with the provided arguments + _arity(Math.max.apply(Math, pluck('length', preds)), predIterator); + }; + }; - function commaSep(pieces) { - return new _coderep.CommaSep(pieces); - } + var _xchain = _curry2(function _xchain(f, xf) { + return map(f, _flatCat(xf)); + }); - function getAssignmentExpr(state) { - return state ? state.containsGroup ? paren(state) : state : empty(); - } + /** + * Given a list of predicates, returns a new predicate that will be true exactly when all of them are. + * + * @func + * @memberOf R + * @category Logic + * @sig [(*... -> Boolean)] -> (*... -> Boolean) + * @param {Array} list An array of predicate functions + * @param {*} optional Any arguments to pass into the predicates + * @return {Function} a function that applies its arguments to each of + * the predicates, returning `true` if all are satisfied. + * @see R.anyPass + * @example + * + * var gt10 = function(x) { return x > 10; }; + * var even = function(x) { return x % 2 === 0}; + * var f = R.allPass([gt10, even]); + * f(11); //=> false + * f(12); //=> true + */ + var allPass = _curry1(_predicateWrap(all)); - var MinimalCodeGen = function () { - function MinimalCodeGen() { - _classCallCheck(this, MinimalCodeGen); - } + /** + * Given a list of predicates returns a new predicate that will be true exactly when any one of them is. + * + * @func + * @memberOf R + * @category Logic + * @sig [(*... -> Boolean)] -> (*... -> Boolean) + * @param {Array} list An array of predicate functions + * @param {*} optional Any arguments to pass into the predicates + * @return {Function} A function that applies its arguments to each of the predicates, returning + * `true` if all are satisfied. + * @see R.allPass + * @example + * + * var gt10 = function(x) { return x > 10; }; + * var even = function(x) { return x % 2 === 0}; + * var f = R.anyPass([gt10, even]); + * f(11); //=> true + * f(8); //=> true + * f(9); //=> false + */ + var anyPass = _curry1(_predicateWrap(any)); - _createClass(MinimalCodeGen, [{ - key: "parenToAvoidBeingDirective", - value: function parenToAvoidBeingDirective(element, original) { - if (element && element.type === "ExpressionStatement" && element.expression.type === "LiteralStringExpression") { - return seq(paren(original.children[0]), semiOp()); - } - return original; - } - }, { - key: "reduceArrayExpression", - value: function reduceArrayExpression(node, _ref) { - var elements = _ref.elements; + /** + * ap applies a list of functions to a list of values. + * + * @func + * @memberOf R + * @category Function + * @sig [f] -> [a] -> [f a] + * @param {Array} fns An array of functions + * @param {Array} vs An array of values + * @return {Array} An array of results of applying each of `fns` to all of `vs` in turn. + * @example + * + * R.ap([R.multiply(2), R.add(3)], [1,2,3]); //=> [2, 4, 6, 4, 5, 6] + */ + var ap = _curry2(function ap(fns, vs) { + return _hasMethod('ap', fns) ? fns.ap(vs) : _reduce(function (acc, fn) { + return _concat(acc, map(fn, vs)); + }, [], fns); + }); - if (elements.length === 0) { - return bracket(empty()); - } + /** + * Returns the result of calling its first argument with the remaining + * arguments. This is occasionally useful as a converging function for + * `R.converge`: the left branch can produce a function while the right + * branch produces a value to be passed to that function as an argument. + * + * @func + * @memberOf R + * @category Function + * @sig (*... -> a),*... -> a + * @param {Function} fn The function to apply to the remaining arguments. + * @param {...*} args Any number of positional arguments. + * @return {*} + * @see R.apply + * @example + * + * var indentN = R.pipe(R.times(R.always(' ')), + * R.join(''), + * R.replace(/^(?!$)/gm)); + * + * var format = R.converge(R.call, + * R.pipe(R.prop('indent'), indentN), + * R.prop('value')); + * + * format({indent: 2, value: 'foo\nbar\nbaz\n'}); //=> ' foo\n bar\n baz\n' + */ + var call = curry(function call(fn) { + return fn.apply(this, _slice(arguments, 1)); + }); - var content = commaSep(elements.map(getAssignmentExpr)); - if (elements.length > 0 && elements[elements.length - 1] == null) { - content = seq(content, t(",")); - } - return bracket(content); - } - }, { - key: "reduceSpreadElement", - value: function reduceSpreadElement(node, _ref2) { - var expression = _ref2.expression; + /** + * `chain` maps a function over a list and concatenates the results. + * This implementation is compatible with the + * Fantasy-land Chain spec, and will work with types that implement that spec. + * `chain` is also known as `flatMap` in some libraries + * + * @func + * @memberOf R + * @category List + * @sig (a -> [b]) -> [a] -> [b] + * @param {Function} fn + * @param {Array} list + * @return {Array} + * @example + * + * var duplicate = function(n) { + * return [n, n]; + * }; + * R.chain(duplicate, [1, 2, 3]); //=> [1, 1, 2, 2, 3, 3] + */ + var chain = _curry2(_dispatchable('chain', _xchain, function chain(fn, list) { + return unnest(map(fn, list)); + })); - return seq(t("..."), p(node.expression, _coderep.Precedence.Assignment, expression)); - } - }, { - key: "reduceAssignmentExpression", - value: function reduceAssignmentExpression(node, _ref3) { - var binding = _ref3.binding; - var expression = _ref3.expression; + /** + * Turns a list of Functors into a Functor of a list, applying + * a mapping function to the elements of the list along the way. + * + * @func + * @memberOf R + * @category List + * @see R.commute + * @sig Functor f => (f a -> f b) -> (x -> f x) -> [f a] -> f [b] + * @param {Function} fn The transformation function + * @param {Function} of A function that returns the data type to return + * @param {Array} list An array of functors of the same type + * @return {*} + * @example + * + * R.commuteMap(R.map(R.add(10)), R.of, [[1], [2, 3]]); //=> [[11, 12], [11, 13]] + * R.commuteMap(R.map(R.add(10)), R.of, [[1, 2], [3]]); //=> [[11, 13], [12, 13]] + * R.commuteMap(R.map(R.add(10)), R.of, [[1], [2], [3]]); //=> [[11, 12, 13]] + * R.commuteMap(R.map(R.add(10)), Maybe.of, [Just(1), Just(2), Just(3)]); //=> Just([11, 12, 13]) + * R.commuteMap(R.map(R.add(10)), Maybe.of, [Just(1), Just(2), Nothing()]); //=> Nothing() + */ + var commuteMap = _curry3(function commuteMap(fn, of, list) { + function consF(acc, ftor) { + return ap(map(append, fn(ftor)), acc); + } + return _reduce(consF, of([]), list); + }); - var leftCode = binding; - var rightCode = expression; - var containsIn = expression.containsIn; - var startsWithCurly = binding.startsWithCurly; - var startsWithLetSquareBracket = binding.startsWithLetSquareBracket; - var startsWithFunctionOrClass = binding.startsWithFunctionOrClass; - if ((0, _coderep.getPrecedence)(node.expression) < (0, _coderep.getPrecedence)(node)) { - rightCode = paren(rightCode); - containsIn = false; - } - return (0, _objectAssign2.default)(seq(leftCode, t("="), rightCode), { containsIn: containsIn, startsWithCurly: startsWithCurly, startsWithLetSquareBracket: startsWithLetSquareBracket, startsWithFunctionOrClass: startsWithFunctionOrClass }); - } - }, { - key: "reduceCompoundAssignmentExpression", - value: function reduceCompoundAssignmentExpression(node, _ref4) { - var binding = _ref4.binding; - var expression = _ref4.expression; + /** + * Wraps a constructor function inside a curried function that can be called with the same + * arguments and returns the same type. The arity of the function returned is specified + * to allow using variadic constructor functions. + * + * @func + * @memberOf R + * @category Function + * @sig Number -> (* -> {*}) -> (* -> {*}) + * @param {Number} n The arity of the constructor function. + * @param {Function} Fn The constructor function to wrap. + * @return {Function} A wrapped, curried constructor function. + * @example + * + * // Variadic constructor function + * var Widget = function() { + * this.children = Array.prototype.slice.call(arguments); + * // ... + * }; + * Widget.prototype = { + * // ... + * }; + * var allConfigs = [ + * // ... + * ]; + * R.map(R.constructN(1, Widget), allConfigs); // a list of Widgets + */ + var constructN = _curry2(function constructN(n, Fn) { + if (n > 10) { + throw new Error('Constructor with greater than ten arguments'); + } + if (n === 0) { + return function () { + return new Fn(); + }; + } + return curry(nAry(n, function ($0, $1, $2, $3, $4, $5, $6, $7, $8, $9) { + switch (arguments.length) { + case 1: + return new Fn($0); + case 2: + return new Fn($0, $1); + case 3: + return new Fn($0, $1, $2); + case 4: + return new Fn($0, $1, $2, $3); + case 5: + return new Fn($0, $1, $2, $3, $4); + case 6: + return new Fn($0, $1, $2, $3, $4, $5); + case 7: + return new Fn($0, $1, $2, $3, $4, $5, $6); + case 8: + return new Fn($0, $1, $2, $3, $4, $5, $6, $7); + case 9: + return new Fn($0, $1, $2, $3, $4, $5, $6, $7, $8); + case 10: + return new Fn($0, $1, $2, $3, $4, $5, $6, $7, $8, $9); + } + })); + }); - var leftCode = binding; - var rightCode = expression; - var containsIn = expression.containsIn; - var startsWithCurly = binding.startsWithCurly; - var startsWithLetSquareBracket = binding.startsWithLetSquareBracket; - var startsWithFunctionOrClass = binding.startsWithFunctionOrClass; - if ((0, _coderep.getPrecedence)(node.expression) < (0, _coderep.getPrecedence)(node)) { - rightCode = paren(rightCode); - containsIn = false; - } - return (0, _objectAssign2.default)(seq(leftCode, t(node.operator), rightCode), { containsIn: containsIn, startsWithCurly: startsWithCurly, startsWithLetSquareBracket: startsWithLetSquareBracket, startsWithFunctionOrClass: startsWithFunctionOrClass }); - } - }, { - key: "reduceBinaryExpression", - value: function reduceBinaryExpression(node, _ref5) { - var left = _ref5.left; - var right = _ref5.right; + /** + * Accepts at least three functions and returns a new function. When invoked, this new + * function will invoke the first function, `after`, passing as its arguments the + * results of invoking the subsequent functions with whatever arguments are passed to + * the new function. + * + * @func + * @memberOf R + * @category Function + * @sig (x1 -> x2 -> ... -> z) -> ((a -> b -> ... -> x1), (a -> b -> ... -> x2), ...) -> (a -> b -> ... -> z) + * @param {Function} after A function. `after` will be invoked with the return values of + * `fn1` and `fn2` as its arguments. + * @param {...Function} functions A variable number of functions. + * @return {Function} A new function. + * @example + * + * var add = function(a, b) { return a + b; }; + * var multiply = function(a, b) { return a * b; }; + * var subtract = function(a, b) { return a - b; }; + * + * //≅ multiply( add(1, 2), subtract(1, 2) ); + * R.converge(multiply, add, subtract)(1, 2); //=> -3 + * + * var add3 = function(a, b, c) { return a + b + c; }; + * R.converge(add3, multiply, add, subtract)(1, 2); //=> 4 + */ + var converge = curryN(3, function converge(after) { + var fns = _slice(arguments, 1); + return curryN(Math.max.apply(Math, pluck('length', fns)), function () { + var args = arguments; + var context = this; + return after.apply(context, _map(function (fn) { + return fn.apply(context, args); + }, fns)); + }); + }); - var leftCode = left; - var startsWithCurly = left.startsWithCurly; - var startsWithLetSquareBracket = left.startsWithLetSquareBracket; - var startsWithFunctionOrClass = left.startsWithFunctionOrClass; - var leftContainsIn = left.containsIn; - if ((0, _coderep.getPrecedence)(node.left) < (0, _coderep.getPrecedence)(node)) { - leftCode = paren(leftCode); - startsWithCurly = false; - startsWithLetSquareBracket = false; - startsWithFunctionOrClass = false; - leftContainsIn = false; - } - var rightCode = right; - var rightContainsIn = right.containsIn; - if ((0, _coderep.getPrecedence)(node.right) <= (0, _coderep.getPrecedence)(node)) { - rightCode = paren(rightCode); - rightContainsIn = false; - } - return (0, _objectAssign2.default)(seq(leftCode, t(node.operator), rightCode), { - containsIn: leftContainsIn || rightContainsIn || node.operator === "in", - containsGroup: node.operator == ",", - startsWithCurly: startsWithCurly, - startsWithLetSquareBracket: startsWithLetSquareBracket, - startsWithFunctionOrClass: startsWithFunctionOrClass - }); - } - }, { - key: "reduceBindingWithDefault", - value: function reduceBindingWithDefault(node, _ref6) { - var binding = _ref6.binding; - var init = _ref6.init; + /** + * Returns all but the first `n` elements of the given list, string, or + * transducer/transformer (or object with a `drop` method). + * + * @func + * @memberOf R + * @category List + * @see R.transduce + * @sig Number -> [a] -> [a] + * @sig Number -> String -> String + * @param {Number} n + * @param {*} list + * @return {*} + * @see R.take + * @example + * + * R.drop(1, ['foo', 'bar', 'baz']); //=> ['bar', 'baz'] + * R.drop(2, ['foo', 'bar', 'baz']); //=> ['baz'] + * R.drop(3, ['foo', 'bar', 'baz']); //=> [] + * R.drop(4, ['foo', 'bar', 'baz']); //=> [] + * R.drop(3, 'ramda'); //=> 'da' + */ + var drop = _curry2(_dispatchable('drop', _xdrop, function drop(n, xs) { + return slice(Math.max(0, n), Infinity, xs); + })); - return seq(binding, t("="), init); - } - }, { - key: "reduceBindingIdentifier", - value: function reduceBindingIdentifier(node) { - var a = t(node.name); - if (node.name === "let") { - a.startsWithLet = true; - } - return a; - } - }, { - key: "reduceArrayBinding", - value: function reduceArrayBinding(node, _ref7) { - var elements = _ref7.elements; - var restElement = _ref7.restElement; + /** + * Returns a list containing all but the last `n` elements of the given `list`. + * + * @func + * @memberOf R + * @category List + * @sig Number -> [a] -> [a] + * @sig Number -> String -> String + * @param {Number} n The number of elements of `xs` to skip. + * @param {Array} xs The collection to consider. + * @return {Array} + * @see R.takeLast + * @example + * + * R.dropLast(1, ['foo', 'bar', 'baz']); //=> ['foo', 'bar'] + * R.dropLast(2, ['foo', 'bar', 'baz']); //=> ['foo'] + * R.dropLast(3, ['foo', 'bar', 'baz']); //=> [] + * R.dropLast(4, ['foo', 'bar', 'baz']); //=> [] + * R.dropLast(3, 'ramda'); //=> 'ra' + */ + var dropLast = _curry2(function dropLast(n, xs) { + return take(n < xs.length ? xs.length - n : 0, xs); + }); - var content = undefined; - if (elements.length === 0) { - content = restElement == null ? empty() : seq(t("..."), restElement); - } else { - elements = elements.concat(restElement == null ? [] : [seq(t("..."), restElement)]); - content = commaSep(elements.map(getAssignmentExpr)); - if (elements.length > 0 && elements[elements.length - 1] == null) { - content = seq(content, t(",")); + /** + * Returns a new list without any consecutively repeating elements. Equality is + * determined by applying the supplied predicate two consecutive elements. + * The first element in a series of equal element is the one being preserved. + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig (a, a -> Boolean) -> [a] -> [a] + * @param {Function} pred A predicate used to test whether two items are equal. + * @param {Array} list The array to consider. + * @return {Array} `list` without repeating elements. + * @example + * + * function lengthEq(x, y) { return Math.abs(x) === Math.abs(y); }; + * var l = [1, -1, 1, 3, 4, -4, -4, -5, 5, 3, 3]; + * R.dropRepeatsWith(lengthEq, l); //=> [1, 3, 4, -5, 3] + */ + var dropRepeatsWith = _curry2(_dispatchable('dropRepeatsWith', _xdropRepeatsWith, function dropRepeatsWith(pred, list) { + var result = []; + var idx = 1; + var len = list.length; + if (len !== 0) { + result[0] = list[0]; + while (idx < len) { + if (!pred(last(result), list[idx])) { + result[result.length] = list[idx]; + } + idx += 1; + } } - } - return bracket(content); - } - }, { - key: "reduceObjectBinding", - value: function reduceObjectBinding(node, _ref8) { - var properties = _ref8.properties; - - var state = brace(commaSep(properties)); - state.startsWithCurly = true; - return state; - } - }, { - key: "reduceBindingPropertyIdentifier", - value: function reduceBindingPropertyIdentifier(node, _ref9) { - var binding = _ref9.binding; - var init = _ref9.init; + return result; + })); - if (node.init == null) return binding; - return seq(binding, t("="), init); - } - }, { - key: "reduceBindingPropertyProperty", - value: function reduceBindingPropertyProperty(node, _ref10) { - var name = _ref10.name; - var binding = _ref10.binding; + /** + * Reports whether two objects have the same value, in `R.equals` terms, + * for the specified property. Useful as a curried predicate. + * + * @func + * @memberOf R + * @category Object + * @sig k -> {k: v} -> {k: v} -> Boolean + * @param {String} prop The name of the property to compare + * @param {Object} obj1 + * @param {Object} obj2 + * @return {Boolean} + * + * @example + * + * var o1 = { a: 1, b: 2, c: 3, d: 4 }; + * var o2 = { a: 10, b: 20, c: 3, d: 40 }; + * R.eqProps('a', o1, o2); //=> false + * R.eqProps('c', o1, o2); //=> true + */ + var eqProps = _curry3(function eqProps(prop, obj1, obj2) { + return equals(obj1[prop], obj2[prop]); + }); - return seq(name, t(":"), binding); - } - }, { - key: "reduceBlock", - value: function reduceBlock(node, _ref11) { - var statements = _ref11.statements; + /** + * Returns the position of the first occurrence of an item in an array, + * or -1 if the item is not included in the array. `R.equals` is used to + * determine equality. + * + * @func + * @memberOf R + * @category List + * @sig a -> [a] -> Number + * @param {*} target The item to find. + * @param {Array} xs The array to search in. + * @return {Number} the index of the target, or -1 if the target is not found. + * @see R.lastIndexOf + * @example + * + * R.indexOf(3, [1,2,3,4]); //=> 2 + * R.indexOf(10, [1,2,3,4]); //=> -1 + */ + var indexOf = _curry2(function indexOf(target, xs) { + return _hasMethod('indexOf', xs) ? xs.indexOf(target) : _indexOf(xs, target, 0); + }); - return brace(seq.apply(undefined, _toConsumableArray(statements))); - } - }, { - key: "reduceBlockStatement", - value: function reduceBlockStatement(node, _ref12) { - var block = _ref12.block; + /** + * Returns all but the last element of the given list or string. + * + * @func + * @memberOf R + * @category List + * @see R.last, R.head, R.tail + * @sig [a] -> [a] + * @sig String -> String + * @param {*} list + * @return {*} + * @example + * + * R.init([1, 2, 3]); //=> [1, 2] + * R.init([1, 2]); //=> [1] + * R.init([1]); //=> [] + * R.init([]); //=> [] + * + * R.init('abc'); //=> 'ab' + * R.init('ab'); //=> 'a' + * R.init('a'); //=> '' + * R.init(''); //=> '' + */ + var init = slice(0, -1); - return block; - } - }, { - key: "reduceBreakStatement", - value: function reduceBreakStatement(node, _ref13) { - var label = _ref13.label; + /** + * Returns `true` if all elements are unique, in `R.equals` terms, + * otherwise `false`. + * + * @func + * @memberOf R + * @category List + * @sig [a] -> Boolean + * @param {Array} list The array to consider. + * @return {Boolean} `true` if all elements are unique, else `false`. + * @example + * + * R.isSet(['1', 1]); //=> true + * R.isSet([1, 1]); //=> false + * R.isSet([[42], [42]]); //=> false + */ + var isSet = _curry1(function isSet(list) { + var len = list.length; + var idx = 0; + while (idx < len) { + if (_indexOf(list, list[idx], idx + 1) >= 0) { + return false; + } + idx += 1; + } + return true; + }); - return seq(t("break"), label ? t(label) : empty(), semiOp()); - } - }, { - key: "reduceCallExpression", - value: function reduceCallExpression(node, _ref14) { - var callee = _ref14.callee; - var args = _ref14.arguments; + /** + * Returns a lens for the given getter and setter functions. The getter "gets" + * the value of the focus; the setter "sets" the value of the focus. The setter + * should not mutate the data structure. + * + * @func + * @memberOf R + * @category Object + * @typedef Lens s a = Functor f => (a -> f a) -> s -> f s + * @sig (s -> a) -> ((a, s) -> s) -> Lens s a + * @param {Function} getter + * @param {Function} setter + * @return {Lens} + * @see R.view, R.set, R.over, R.lensIndex, R.lensProp + * @example + * + * var xLens = R.lens(R.prop('x'), R.assoc('x')); + * + * R.view(xLens, {x: 1, y: 2}); //=> 1 + * R.set(xLens, 4, {x: 1, y: 2}); //=> {x: 4, y: 2} + * R.over(xLens, R.negate, {x: 1, y: 2}); //=> {x: -1, y: 2} + */ + var lens = _curry2(function lens(getter, setter) { + return function (f) { + return function (s) { + return map(function (v) { + return setter(v, s); + }, f(getter(s))); + }; + }; + }); - return (0, _objectAssign2.default)(seq(p(node.callee, (0, _coderep.getPrecedence)(node), callee), paren(commaSep(args))), { - startsWithCurly: callee.startsWithCurly, - startsWithLetSquareBracket: callee.startsWithLetSquareBracket, - startsWithFunctionOrClass: callee.startsWithFunctionOrClass - }); - } - }, { - key: "reduceCatchClause", - value: function reduceCatchClause(node, _ref15) { - var binding = _ref15.binding; - var body = _ref15.body; + /** + * Returns a lens whose focus is the specified index. + * + * @func + * @memberOf R + * @category Object + * @typedef Lens s a = Functor f => (a -> f a) -> s -> f s + * @sig Number -> Lens s a + * @param {Number} n + * @return {Lens} + * @see R.view, R.set, R.over + * @example + * + * var headLens = R.lensIndex(0); + * + * R.view(headLens, ['a', 'b', 'c']); //=> 'a' + * R.set(headLens, 'x', ['a', 'b', 'c']); //=> ['x', 'b', 'c'] + * R.over(headLens, R.toUpper, ['a', 'b', 'c']); //=> ['A', 'b', 'c'] + */ + var lensIndex = _curry1(function lensIndex(n) { + return lens(nth(n), update(n)); + }); - return seq(t("catch"), paren(binding), body); - } - }, { - key: "reduceClassDeclaration", - value: function reduceClassDeclaration(node, _ref16) { - var name = _ref16.name; - var _super = _ref16.super; - var elements = _ref16.elements; + /** + * Returns a lens whose focus is the specified property. + * + * @func + * @memberOf R + * @category Object + * @typedef Lens s a = Functor f => (a -> f a) -> s -> f s + * @sig String -> Lens s a + * @param {String} k + * @return {Lens} + * @see R.view, R.set, R.over + * @example + * + * var xLens = R.lensProp('x'); + * + * R.view(xLens, {x: 1, y: 2}); //=> 1 + * R.set(xLens, 4, {x: 1, y: 2}); //=> {x: 4, y: 2} + * R.over(xLens, R.negate, {x: 1, y: 2}); //=> {x: -1, y: 2} + */ + var lensProp = _curry1(function lensProp(k) { + return lens(prop(k), assoc(k)); + }); - var state = seq(t("class"), name); - if (_super != null) { - state = seq(state, t("extends"), _super); - } - state = seq.apply(undefined, [state, t("{")].concat(_toConsumableArray(elements), [t("}")])); - return state; - } - }, { - key: "reduceClassExpression", - value: function reduceClassExpression(node, _ref17) { - var name = _ref17.name; - var _super = _ref17.super; - var elements = _ref17.elements; - - var state = t("class"); - if (name != null) { - state = seq(state, name); - } - if (_super != null) { - state = seq(state, t("extends"), _super); - } - state = seq.apply(undefined, [state, t("{")].concat(_toConsumableArray(elements), [t("}")])); - state.startsWithFunctionOrClass = true; - return state; - } - }, { - key: "reduceClassElement", - value: function reduceClassElement(node, _ref18) { - var method = _ref18.method; - - if (!node.isStatic) return method; - return seq(t("static"), method); - } - }, { - key: "reduceComputedMemberExpression", - value: function reduceComputedMemberExpression(node, _ref19) { - var object = _ref19.object; - var expression = _ref19.expression; + /** + * "lifts" a function to be the specified arity, so that it may "map over" that many + * lists (or other Functors). + * + * @func + * @memberOf R + * @see R.lift + * @category Function + * @sig Number -> (*... -> *) -> ([*]... -> [*]) + * @param {Function} fn The function to lift into higher context + * @return {Function} The function `fn` applicable to mappable objects. + * @example + * + * var madd3 = R.liftN(3, R.curryN(3, function() { + * return R.reduce(R.add, 0, arguments); + * })); + * madd3([1,2,3], [1,2,3], [1]); //=> [3, 4, 5, 4, 5, 6, 5, 6, 7] + */ + var liftN = _curry2(function liftN(arity, fn) { + var lifted = curryN(arity, fn); + return curryN(arity, function () { + return _reduce(ap, map(lifted, arguments[0]), _slice(arguments, 1)); + }); + }); - var startsWithLetSquareBracket = object.startsWithLetSquareBracket || node.object.type === "IdentifierExpression" && node.object.name === "let"; - return (0, _objectAssign2.default)(seq(p(node.object, (0, _coderep.getPrecedence)(node), object), bracket(expression)), { - startsWithLet: object.startsWithLet, - startsWithLetSquareBracket: startsWithLetSquareBracket, - startsWithCurly: object.startsWithCurly, - startsWithFunctionOrClass: object.startsWithFunctionOrClass - }); - } - }, { - key: "reduceComputedPropertyName", - value: function reduceComputedPropertyName(node, _ref20) { - var expression = _ref20.expression; + /** + * Returns the mean of the given list of numbers. + * + * @func + * @memberOf R + * @category Math + * @sig [Number] -> Number + * @param {Array} list + * @return {Number} + * @example + * + * R.mean([2, 7, 9]); //=> 6 + * R.mean([]); //=> NaN + */ + var mean = _curry1(function mean(list) { + return sum(list) / list.length; + }); - return bracket(expression); - } - }, { - key: "reduceConditionalExpression", - value: function reduceConditionalExpression(node, _ref21) { - var test = _ref21.test; - var consequent = _ref21.consequent; - var alternate = _ref21.alternate; + /** + * Returns the median of the given list of numbers. + * + * @func + * @memberOf R + * @category Math + * @sig [Number] -> Number + * @param {Array} list + * @return {Number} + * @example + * + * R.median([2, 9, 7]); //=> 7 + * R.median([7, 2, 10, 9]); //=> 8 + * R.median([]); //=> NaN + */ + var median = _curry1(function median(list) { + var len = list.length; + if (len === 0) { + return NaN; + } + var width = 2 - len % 2; + var idx = (len - width) / 2; + return mean(_slice(list).sort(function (a, b) { + return a < b ? -1 : a > b ? 1 : 0; + }).slice(idx, idx + width)); + }); - var containsIn = test.containsIn || alternate.containsIn; - var startsWithCurly = test.startsWithCurly; - var startsWithLetSquareBracket = test.startsWithLetSquareBracket; - var startsWithFunctionOrClass = test.startsWithFunctionOrClass; - return (0, _objectAssign2.default)(seq(p(node.test, _coderep.Precedence.LogicalOR, test), t("?"), p(node.consequent, _coderep.Precedence.Assignment, consequent), t(":"), p(node.alternate, _coderep.Precedence.Assignment, alternate)), { - containsIn: containsIn, - startsWithCurly: startsWithCurly, - startsWithLetSquareBracket: startsWithLetSquareBracket, - startsWithFunctionOrClass: startsWithFunctionOrClass - }); - } - }, { - key: "reduceContinueStatement", - value: function reduceContinueStatement(node, _ref22) { - var label = _ref22.label; + /** + * Merges a list of objects together into one object. + * + * @func + * @memberOf R + * @category List + * @sig [{k: v}] -> {k: v} + * @param {Array} list An array of objects + * @return {Object} A merged object. + * @see R.reduce + * @example + * + * R.mergeAll([{foo:1},{bar:2},{baz:3}]); //=> {foo:1,bar:2,baz:3} + * R.mergeAll([{foo:1},{foo:2},{bar:2}]); //=> {foo:2,bar:2} + */ + var mergeAll = _curry1(function mergeAll(list) { + return reduce(merge, {}, list); + }); - return seq(t("continue"), label ? t(label) : empty(), semiOp()); - } - }, { - key: "reduceDataProperty", - value: function reduceDataProperty(node, _ref23) { - var name = _ref23.name; - var expression = _ref23.expression; + /** + * Performs left-to-right function composition. The leftmost function may have + * any arity; the remaining functions must be unary. + * + * In some libraries this function is named `sequence`. + * + * @func + * @memberOf R + * @category Function + * @sig (((a, b, ..., n) -> o), (o -> p), ..., (x -> y), (y -> z)) -> (a -> b -> ... -> n -> z) + * @param {...Function} functions + * @return {Function} + * @see R.compose + * @example + * + * var f = R.pipe(Math.pow, R.negate, R.inc); + * + * f(3, 4); // -(3^4) + 1 + */ + var pipe = function pipe() { + if (arguments.length === 0) { + throw new Error('pipe requires at least one argument'); + } + return curryN(arguments[0].length, reduce(_pipe, arguments[0], tail(arguments))); + }; - return seq(name, t(":"), getAssignmentExpr(expression)); - } - }, { - key: "reduceDebuggerStatement", - value: function reduceDebuggerStatement(node) { - return seq(t("debugger"), semiOp()); - } - }, { - key: "reduceDoWhileStatement", - value: function reduceDoWhileStatement(node, _ref24) { - var body = _ref24.body; - var test = _ref24.test; + /** + * Performs left-to-right composition of one or more Promise-returning + * functions. The leftmost function may have any arity; the remaining + * functions must be unary. + * + * @func + * @memberOf R + * @category Function + * @sig ((a -> Promise b), (b -> Promise c), ..., (y -> Promise z)) -> (a -> Promise z) + * @param {...Function} functions + * @return {Function} + * @see R.composeP + * @example + * + * // followersForUser :: String -> Promise [User] + * var followersForUser = R.pipeP(db.getUserById, db.getFollowers); + */ + var pipeP = function pipeP() { + if (arguments.length === 0) { + throw new Error('pipeP requires at least one argument'); + } + return curryN(arguments[0].length, reduce(_pipeP, arguments[0], tail(arguments))); + }; - return seq(t("do"), body, t("while"), paren(test), semiOp()); - } - }, { - key: "reduceEmptyStatement", - value: function reduceEmptyStatement(node) { - return semi(); - } - }, { - key: "reduceExpressionStatement", - value: function reduceExpressionStatement(node, _ref25) { - var expression = _ref25.expression; + /** + * Multiplies together all the elements of a list. + * + * @func + * @memberOf R + * @category Math + * @sig [Number] -> Number + * @param {Array} list An array of numbers + * @return {Number} The product of all the numbers in the list. + * @see R.reduce + * @example + * + * R.product([2,4,6,8,100,1]); //=> 38400 + */ + var product = reduce(multiply, 1); - var needsParens = expression.startsWithCurly || expression.startsWithLetSquareBracket || expression.startsWithFunctionOrClass; - return seq(needsParens ? paren(expression) : expression, semiOp()); - } - }, { - key: "reduceForInStatement", - value: function reduceForInStatement(node, _ref26) { - var left = _ref26.left; - var right = _ref26.right; - var body = _ref26.body; + /** + * Reasonable analog to SQL `select` statement. + * + * @func + * @memberOf R + * @category Object + * @category Relation + * @sig [k] -> [{k: v}] -> [{k: v}] + * @param {Array} props The property names to project + * @param {Array} objs The objects to query + * @return {Array} An array of objects with just the `props` properties. + * @example + * + * var abby = {name: 'Abby', age: 7, hair: 'blond', grade: 2}; + * var fred = {name: 'Fred', age: 12, hair: 'brown', grade: 7}; + * var kids = [abby, fred]; + * R.project(['name', 'grade'], kids); //=> [{name: 'Abby', grade: 2}, {name: 'Fred', grade: 7}] + */ + // passing `identity` gives correct arity + var project = useWith(_map, pickAll, identity); - var leftP = left; - switch (node.left.type) { - case "VariableDeclaration": - leftP = noIn(markContainsIn(left)); - break; - case "BindingIdentifier": - if (node.left.name === "let") { - leftP = paren(left); - } - break; - } - return (0, _objectAssign2.default)(seq(t("for"), paren(seq(leftP, t("in"), right)), body), { endsWithMissingElse: body.endsWithMissingElse }); - } - }, { - key: "reduceForOfStatement", - value: function reduceForOfStatement(node, _ref27) { - var left = _ref27.left; - var right = _ref27.right; - var body = _ref27.body; + /** + * Returns a new list containing the last `n` elements of the given list. + * If `n > list.length`, returns a list of `list.length` elements. + * + * @func + * @memberOf R + * @category List + * @sig Number -> [a] -> [a] + * @sig Number -> String -> String + * @param {Number} n The number of elements to return. + * @param {Array} xs The collection to consider. + * @return {Array} + * @see R.dropLast + * @example + * + * R.takeLast(1, ['foo', 'bar', 'baz']); //=> ['baz'] + * R.takeLast(2, ['foo', 'bar', 'baz']); //=> ['for', 'baz'] + * R.takeLast(3, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] + * R.takeLast(4, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz'] + * R.takeLast(3, 'ramda'); //=> 'mda' + */ + var takeLast = _curry2(function takeLast(n, xs) { + return drop(n >= 0 ? xs.length - n : 0, xs); + }); - left = node.left.type === "VariableDeclaration" ? noIn(markContainsIn(left)) : left; - return (0, _objectAssign2.default)(seq(t("for"), paren(seq(left.startsWithLet ? paren(left) : left, t("of"), right)), body), { endsWithMissingElse: body.endsWithMissingElse }); - } - }, { - key: "reduceForStatement", - value: function reduceForStatement(node, _ref28) { - var init = _ref28.init; - var test = _ref28.test; - var update = _ref28.update; - var body = _ref28.body; + var _contains = function _contains(a, list) { + return _indexOf(list, a, 0) >= 0; + }; - return (0, _objectAssign2.default)(seq(t("for"), paren(seq(init ? noIn(markContainsIn(init)) : empty(), semi(), test || empty(), semi(), update || empty())), body), { - endsWithMissingElse: body.endsWithMissingElse - }); - } - }, { - key: "reduceFunctionBody", - value: function reduceFunctionBody(node, _ref29) { - var directives = _ref29.directives; - var statements = _ref29.statements; + // mapPairs :: (Object, [String]) -> [String] + // Function, RegExp, user-defined types + var _toString = function _toString(x, seen) { + var recur = function recur(y) { + var xs = seen.concat([x]); + return _contains(y, xs) ? '' : _toString(y, xs); + }; + // mapPairs :: (Object, [String]) -> [String] + var mapPairs = function (obj, keys) { + return _map(function (k) { + return _quote(k) + ': ' + recur(obj[k]); + }, keys.slice().sort()); + }; + switch (Object.prototype.toString.call(x)) { + case '[object Arguments]': + return '(function() { return arguments; }(' + _map(recur, x).join(', ') + '))'; + case '[object Array]': + return '[' + _map(recur, x).concat(mapPairs(x, reject(test(/^\d+$/), keys(x)))).join(', ') + ']'; + case '[object Boolean]': + return typeof x === 'object' ? 'new Boolean(' + recur(x.valueOf()) + ')' : x.toString(); + case '[object Date]': + return 'new Date(' + _quote(_toISOString(x)) + ')'; + case '[object Null]': + return 'null'; + case '[object Number]': + return typeof x === 'object' ? 'new Number(' + recur(x.valueOf()) + ')' : 1 / x === -Infinity ? '-0' : x.toString(10); + case '[object String]': + return typeof x === 'object' ? 'new String(' + recur(x.valueOf()) + ')' : _quote(x); + case '[object Undefined]': + return 'undefined'; + default: + return typeof x.constructor === 'function' && x.constructor.name !== 'Object' && typeof x.toString === 'function' && x.toString() !== '[object Object]' ? x.toString() : // Function, RegExp, user-defined types + '{' + mapPairs(x, keys(x)).join(', ') + '}'; + } + }; - if (statements.length) { - statements[0] = this.parenToAvoidBeingDirective(node.statements[0], statements[0]); - } - return seq.apply(undefined, _toConsumableArray(directives).concat(_toConsumableArray(statements))); - } - }, { - key: "reduceFunctionDeclaration", - value: function reduceFunctionDeclaration(node, _ref30) { - var name = _ref30.name; - var params = _ref30.params; - var body = _ref30.body; + /** + * Turns a list of Functors into a Functor of a list. + * + * @func + * @memberOf R + * @category List + * @see R.commuteMap + * @sig Functor f => (x -> f x) -> [f a] -> f [a] + * @param {Function} of A function that returns the data type to return + * @param {Array} list An array of functors of the same type + * @return {*} + * @example + * + * R.commute(R.of, [[1], [2, 3]]); //=> [[1, 2], [1, 3]] + * R.commute(R.of, [[1, 2], [3]]); //=> [[1, 3], [2, 3]] + * R.commute(R.of, [[1], [2], [3]]); //=> [[1, 2, 3]] + * R.commute(Maybe.of, [Just(1), Just(2), Just(3)]); //=> Just([1, 2, 3]) + * R.commute(Maybe.of, [Just(1), Just(2), Nothing()]); //=> Nothing() + */ + var commute = commuteMap(identity); - return seq(t("function"), node.isGenerator ? t("*") : empty(), node.name.name === "*default*" ? empty() : name, paren(params), brace(body)); - } - }, { - key: "reduceFunctionExpression", - value: function reduceFunctionExpression(node, _ref31) { - var name = _ref31.name; - var params = _ref31.params; - var body = _ref31.body; + /** + * Performs right-to-left function composition. The rightmost function may have + * any arity; the remaining functions must be unary. + * + * @func + * @memberOf R + * @category Function + * @sig ((y -> z), (x -> y), ..., (o -> p), ((a, b, ..., n) -> o)) -> (a -> b -> ... -> n -> z) + * @param {...Function} functions + * @return {Function} + * @see R.pipe + * @example + * + * var f = R.compose(R.inc, R.negate, Math.pow); + * + * f(3, 4); // -(3^4) + 1 + */ + var compose = function compose() { + if (arguments.length === 0) { + throw new Error('compose requires at least one argument'); + } + return pipe.apply(this, reverse(arguments)); + }; - var state = seq(t("function"), node.isGenerator ? t("*") : empty(), name ? name : empty(), paren(params), brace(body)); - state.startsWithFunctionOrClass = true; - return state; - } - }, { - key: "reduceFormalParameters", - value: function reduceFormalParameters(node, _ref32) { - var items = _ref32.items; - var rest = _ref32.rest; + /** + * Returns the right-to-left Kleisli composition of the provided functions, + * each of which must return a value of a type supported by [`chain`](#chain). + * + * `R.composeK(h, g, f)` is equivalent to `R.compose(R.chain(h), R.chain(g), R.chain(f))`. + * + * @func + * @memberOf R + * @category Function + * @see R.pipeK + * @sig Chain m => ((y -> m z), (x -> m y), ..., (a -> m b)) -> (m a -> m z) + * @param {...Function} + * @return {Function} + * @example + * + * // parseJson :: String -> Maybe * + * // get :: String -> Object -> Maybe * + * + * // getStateCode :: Maybe String -> Maybe String + * var getStateCode = R.composeK( + * R.compose(Maybe.of, R.toUpper), + * get('state'), + * get('address'), + * get('user'), + * parseJson + * ); + * + * getStateCode(Maybe.of('{"user":{"address":{"state":"ny"}}}')); + * //=> Just('NY') + * getStateCode(Maybe.of('[Invalid JSON]')); + * //=> Nothing() + */ + var composeK = function composeK() { + return arguments.length === 0 ? identity : compose.apply(this, map(chain, arguments)); + }; - return commaSep(items.concat(rest == null ? [] : [seq(t("..."), rest)])); - } - }, { - key: "reduceArrowExpression", - value: function reduceArrowExpression(node, _ref33) { - var params = _ref33.params; - var body = _ref33.body; + /** + * Performs right-to-left composition of one or more Promise-returning + * functions. The rightmost function may have any arity; the remaining + * functions must be unary. + * + * @func + * @memberOf R + * @category Function + * @sig ((y -> Promise z), (x -> Promise y), ..., (a -> Promise b)) -> (a -> Promise z) + * @param {...Function} functions + * @return {Function} + * @see R.pipeP + * @example + * + * // followersForUser :: String -> Promise [User] + * var followersForUser = R.composeP(db.getFollowers, db.getUserById); + */ + var composeP = function composeP() { + if (arguments.length === 0) { + throw new Error('composeP requires at least one argument'); + } + return pipeP.apply(this, reverse(arguments)); + }; - if (node.params.rest != null || node.params.items.length !== 1 || node.params.items[0].type !== "BindingIdentifier") { - params = paren(params); - } - if (node.body.type === "FunctionBody") { - body = brace(body); - } else if (body.startsWithCurly) { - body = paren(body); - } - return seq(params, t("=>"), p(node.body, _coderep.Precedence.Assignment, body)); - } - }, { - key: "reduceGetter", - value: function reduceGetter(node, _ref34) { - var name = _ref34.name; - var body = _ref34.body; - - return seq(t("get"), name, paren(empty()), brace(body)); - } - }, { - key: "reduceIdentifierExpression", - value: function reduceIdentifierExpression(node) { - var a = t(node.name); - if (node.name === "let") { - a.startsWithLet = true; - } - return a; - } - }, { - key: "reduceIfStatement", - value: function reduceIfStatement(node, _ref35) { - var test = _ref35.test; - var consequent = _ref35.consequent; - var alternate = _ref35.alternate; - - if (alternate && consequent.endsWithMissingElse) { - consequent = brace(consequent); - } - return (0, _objectAssign2.default)(seq(t("if"), paren(test), consequent, alternate ? seq(t("else"), alternate) : empty()), { endsWithMissingElse: alternate ? alternate.endsWithMissingElse : true }); - } - }, { - key: "reduceImport", - value: function reduceImport(node, _ref36) { - var defaultBinding = _ref36.defaultBinding; - var namedImports = _ref36.namedImports; - - var bindings = []; - if (defaultBinding != null) { - bindings.push(defaultBinding); - } - if (namedImports.length > 0) { - bindings.push(brace(commaSep(namedImports))); - } - if (bindings.length === 0) { - return seq(t("import"), t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), semiOp()); - } - return seq(t("import"), commaSep(bindings), t("from"), t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), semiOp()); - } - }, { - key: "reduceImportNamespace", - value: function reduceImportNamespace(node, _ref37) { - var defaultBinding = _ref37.defaultBinding; - var namespaceBinding = _ref37.namespaceBinding; + /** + * Wraps a constructor function inside a curried function that can be called with the same + * arguments and returns the same type. + * + * @func + * @memberOf R + * @category Function + * @sig (* -> {*}) -> (* -> {*}) + * @param {Function} Fn The constructor function to wrap. + * @return {Function} A wrapped, curried constructor function. + * @example + * + * // Constructor function + * var Widget = function(config) { + * // ... + * }; + * Widget.prototype = { + * // ... + * }; + * var allConfigs = [ + * // ... + * ]; + * R.map(R.construct(Widget), allConfigs); // a list of Widgets + */ + var construct = _curry1(function construct(Fn) { + return constructN(Fn.length, Fn); + }); - return seq(t("import"), defaultBinding == null ? empty() : seq(defaultBinding, t(",")), t("*"), t("as"), namespaceBinding, t("from"), t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), semiOp()); - } - }, { - key: "reduceImportSpecifier", - value: function reduceImportSpecifier(node, _ref38) { - var binding = _ref38.binding; + /** + * Returns `true` if the specified value is equal, in `R.equals` terms, + * to at least one element of the given list; `false` otherwise. + * + * @func + * @memberOf R + * @category List + * @sig a -> [a] -> Boolean + * @param {Object} a The item to compare against. + * @param {Array} list The array to consider. + * @return {Boolean} `true` if the item is in the list, `false` otherwise. + * + * @example + * + * R.contains(3, [1, 2, 3]); //=> true + * R.contains(4, [1, 2, 3]); //=> false + * R.contains([42], [[42]]); //=> true + */ + var contains = _curry2(_contains); - if (node.name == null) return binding; - return seq(t(node.name), t("as"), binding); - } - }, { - key: "reduceExportAllFrom", - value: function reduceExportAllFrom(node) { - return seq(t("export"), t("*"), t("from"), t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), semiOp()); - } - }, { - key: "reduceExportFrom", - value: function reduceExportFrom(node, _ref39) { - var namedExports = _ref39.namedExports; + /** + * Finds the set (i.e. no duplicates) of all elements in the first list not contained in the second list. + * + * @func + * @memberOf R + * @category Relation + * @sig [a] -> [a] -> [a] + * @param {Array} list1 The first list. + * @param {Array} list2 The second list. + * @return {Array} The elements in `list1` that are not in `list2`. + * @see R.differenceWith + * @example + * + * R.difference([1,2,3,4], [7,6,5,4,3]); //=> [1,2] + * R.difference([7,6,5,4,3], [1,2,3,4]); //=> [7,6,5] + */ + var difference = _curry2(function difference(first, second) { + var out = []; + var idx = 0; + var firstLen = first.length; + while (idx < firstLen) { + if (!_contains(first[idx], second) && !_contains(first[idx], out)) { + out[out.length] = first[idx]; + } + idx += 1; + } + return out; + }); - return seq(t("export"), brace(commaSep(namedExports)), node.moduleSpecifier == null ? empty() : seq(t("from"), t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), semiOp())); - } - }, { - key: "reduceExport", - value: function reduceExport(node, _ref40) { - var declaration = _ref40.declaration; + /** + * Returns a new list without any consecutively repeating elements. + * `R.equals` is used to determine equality. + * + * Acts as a transducer if a transformer is given in list position. + * @see R.transduce + * + * @func + * @memberOf R + * @category List + * @sig [a] -> [a] + * @param {Array} list The array to consider. + * @return {Array} `list` without repeating elements. + * @example + * + * R.dropRepeats([1, 1, 1, 2, 3, 4, 4, 2, 2]); //=> [1, 2, 3, 4, 2] + */ + var dropRepeats = _curry1(_dispatchable('dropRepeats', _xdropRepeatsWith(equals), dropRepeatsWith(equals))); - switch (node.declaration.type) { - case "FunctionDeclaration": - case "ClassDeclaration": - break; - default: - declaration = seq(declaration, semiOp()); - } - return seq(t("export"), declaration); - } - }, { - key: "reduceExportDefault", - value: function reduceExportDefault(node, _ref41) { - var body = _ref41.body; + /** + * Combines two lists into a set (i.e. no duplicates) composed of those elements common to both lists. + * + * @func + * @memberOf R + * @category Relation + * @sig [a] -> [a] -> [a] + * @param {Array} list1 The first list. + * @param {Array} list2 The second list. + * @see R.intersectionWith + * @return {Array} The list of elements found in both `list1` and `list2`. + * @example + * + * R.intersection([1,2,3,4], [7,6,5,4,3]); //=> [4, 3] + */ + var intersection = _curry2(function intersection(list1, list2) { + return uniq(_filter(flip(_contains)(list1), list2)); + }); - body = body.startsWithFunctionOrClass ? paren(body) : body; - switch (node.body.type) { - case "FunctionDeclaration": - case "ClassDeclaration": - break; - default: - body = seq(body, semiOp()); - } - return seq(t("export default"), body); - } - }, { - key: "reduceExportSpecifier", - value: function reduceExportSpecifier(node) { - if (node.name == null) return t(node.exportedName); - return seq(t(node.name), t("as"), t(node.exportedName)); - } - }, { - key: "reduceLabeledStatement", - value: function reduceLabeledStatement(node, _ref42) { - var label = _ref42.label; - var body = _ref42.body; + /** + * "lifts" a function of arity > 1 so that it may "map over" an Array or + * other Functor. + * + * @func + * @memberOf R + * @see R.liftN + * @category Function + * @sig (*... -> *) -> ([*]... -> [*]) + * @param {Function} fn The function to lift into higher context + * @return {Function} The function `fn` applicable to mappable objects. + * @example + * + * var madd3 = R.lift(R.curry(function(a, b, c) { + * return a + b + c; + * })); + * madd3([1,2,3], [1,2,3], [1]); //=> [3, 4, 5, 4, 5, 6, 5, 6, 7] + * + * var madd5 = R.lift(R.curry(function(a, b, c, d, e) { + * return a + b + c + d + e; + * })); + * madd5([1,2], [3], [4, 5], [6], [7, 8]); //=> [21, 22, 22, 23, 22, 23, 23, 24] + */ + var lift = _curry1(function lift(fn) { + return liftN(fn.length, fn); + }); - return (0, _objectAssign2.default)(seq(t(label + ":"), body), { endsWithMissingElse: body.endsWithMissingElse }); - } - }, { - key: "reduceLiteralBooleanExpression", - value: function reduceLiteralBooleanExpression(node) { - return t(node.value.toString()); - } - }, { - key: "reduceLiteralNullExpression", - value: function reduceLiteralNullExpression(node) { - return t("null"); - } - }, { - key: "reduceLiteralInfinityExpression", - value: function reduceLiteralInfinityExpression(node) { - return t("2e308"); - } - }, { - key: "reduceLiteralNumericExpression", - value: function reduceLiteralNumericExpression(node) { - return new _coderep.NumberCodeRep(node.value); - } - }, { - key: "reduceLiteralRegExpExpression", - value: function reduceLiteralRegExpExpression(node) { - return t("/" + node.pattern + "/" + node.flags); - } - }, { - key: "reduceLiteralStringExpression", - value: function reduceLiteralStringExpression(node) { - return t((0, _coderep.escapeStringLiteral)(node.value)); - } - }, { - key: "reduceMethod", - value: function reduceMethod(node, _ref43) { - var name = _ref43.name; - var params = _ref43.params; - var body = _ref43.body; + /** + * Returns a partial copy of an object omitting the keys specified. + * + * @func + * @memberOf R + * @category Object + * @sig [String] -> {String: *} -> {String: *} + * @param {Array} names an array of String property names to omit from the new object + * @param {Object} obj The object to copy from + * @return {Object} A new object with properties from `names` not on it. + * @see R.pick + * @example + * + * R.omit(['a', 'd'], {a: 1, b: 2, c: 3, d: 4}); //=> {b: 2, c: 3} + */ + var omit = _curry2(function omit(names, obj) { + var result = {}; + for (var prop in obj) { + if (!_contains(prop, names)) { + result[prop] = obj[prop]; + } + } + return result; + }); - return seq(node.isGenerator ? t("*") : empty(), name, paren(params), brace(body)); - } - }, { - key: "reduceModule", - value: function reduceModule(node, _ref44) { - var directives = _ref44.directives; - var items = _ref44.items; + /** + * Returns the left-to-right Kleisli composition of the provided functions, + * each of which must return a value of a type supported by [`chain`](#chain). + * + * `R.pipeK(f, g, h)` is equivalent to `R.pipe(R.chain(f), R.chain(g), R.chain(h))`. + * + * @func + * @memberOf R + * @category Function + * @see R.composeK + * @sig Chain m => ((a -> m b), (b -> m c), ..., (y -> m z)) -> (m a -> m z) + * @param {...Function} + * @return {Function} + * @example + * + * // parseJson :: String -> Maybe * + * // get :: String -> Object -> Maybe * + * + * // getStateCode :: Maybe String -> Maybe String + * var getStateCode = R.pipeK( + * parseJson, + * get('user'), + * get('address'), + * get('state'), + * R.compose(Maybe.of, R.toUpper) + * ); + * + * getStateCode(Maybe.of('{"user":{"address":{"state":"ny"}}}')); + * //=> Just('NY') + * getStateCode(Maybe.of('[Invalid JSON]')); + * //=> Nothing() + */ + var pipeK = function pipeK() { + return composeK.apply(this, reverse(arguments)); + }; - if (items.length) { - items[0] = this.parenToAvoidBeingDirective(node.items[0], items[0]); - } - return seq.apply(undefined, _toConsumableArray(directives).concat(_toConsumableArray(items))); - } - }, { - key: "reduceNewExpression", - value: function reduceNewExpression(node, _ref45) { - var callee = _ref45.callee; - var args = _ref45.arguments; + /** + * Returns the string representation of the given value. `eval`'ing the output + * should result in a value equivalent to the input value. Many of the built-in + * `toString` methods do not satisfy this requirement. + * + * If the given value is an `[object Object]` with a `toString` method other + * than `Object.prototype.toString`, this method is invoked with no arguments + * to produce the return value. This means user-defined constructor functions + * can provide a suitable `toString` method. For example: + * + * function Point(x, y) { + * this.x = x; + * this.y = y; + * } + * + * Point.prototype.toString = function() { + * return 'new Point(' + this.x + ', ' + this.y + ')'; + * }; + * + * R.toString(new Point(1, 2)); //=> 'new Point(1, 2)' + * + * @func + * @memberOf R + * @category String + * @sig * -> String + * @param {*} val + * @return {String} + * @example + * + * R.toString(42); //=> '42' + * R.toString('abc'); //=> '"abc"' + * R.toString([1, 2, 3]); //=> '[1, 2, 3]' + * R.toString({foo: 1, bar: 2, baz: 3}); //=> '{"bar": 2, "baz": 3, "foo": 1}' + * R.toString(new Date('2001-02-03T04:05:06Z')); //=> 'new Date("2001-02-03T04:05:06.000Z")' + */ + var toString = _curry1(function toString(val) { + return _toString(val, []); + }); - var calleeRep = (0, _coderep.getPrecedence)(node.callee) == _coderep.Precedence.Call ? paren(callee) : p(node.callee, (0, _coderep.getPrecedence)(node), callee); - return seq(t("new"), calleeRep, args.length === 0 ? empty() : paren(commaSep(args))); - } - }, { - key: "reduceNewTargetExpression", - value: function reduceNewTargetExpression() { - return t("new.target"); - } - }, { - key: "reduceObjectExpression", - value: function reduceObjectExpression(node, _ref46) { - var properties = _ref46.properties; + /** + * Combines two lists into a set (i.e. no duplicates) composed of the + * elements of each list. + * + * @func + * @memberOf R + * @category Relation + * @sig [a] -> [a] -> [a] + * @param {Array} as The first list. + * @param {Array} bs The second list. + * @return {Array} The first and second lists concatenated, with + * duplicates removed. + * @example + * + * R.union([1, 2, 3], [2, 3, 4]); //=> [1, 2, 3, 4] + */ + var union = _curry2(compose(uniq, _concat)); - var state = brace(commaSep(properties)); - state.startsWithCurly = true; - return state; - } - }, { - key: "reduceUpdateExpression", - value: function reduceUpdateExpression(node, _ref47) { - var operand = _ref47.operand; + /** + * Returns a new list containing only one copy of each element in the + * original list, based upon the value returned by applying the supplied + * function to each list element. Prefers the first item if the supplied + * function produces the same value on two items. `R.equals` is used for + * comparison. + * + * @func + * @memberOf R + * @category List + * @sig (a -> b) -> [a] -> [a] + * @param {Function} fn A function used to produce a value to use during comparisons. + * @param {Array} list The array to consider. + * @return {Array} The list of unique items. + * @example + * + * R.uniqBy(Math.abs, [-1, -5, 2, 10, 1, 2]); //=> [-1, -5, 2, 10] + */ + var uniqBy = _curry2(function uniqBy(fn, list) { + var idx = 0, applied = [], result = [], appliedItem, item; + while (idx < list.length) { + item = list[idx]; + appliedItem = fn(item); + if (!_contains(appliedItem, applied)) { + result.push(item); + applied.push(appliedItem); + } + idx += 1; + } + return result; + }); - if (node.isPrefix) { - return this.reduceUnaryExpression.apply(this, arguments); - } else { - return (0, _objectAssign2.default)(seq(p(node.operand, _coderep.Precedence.New, operand), t(node.operator)), { - startsWithCurly: operand.startsWithCurly, - startsWithLetSquareBracket: operand.startsWithLetSquareBracket, - startsWithFunctionOrClass: operand.startsWithFunctionOrClass + /** + * Turns a named method with a specified arity into a function + * that can be called directly supplied with arguments and a target object. + * + * The returned function is curried and accepts `arity + 1` parameters where + * the final parameter is the target object. + * + * @func + * @memberOf R + * @category Function + * @sig Number -> String -> (a -> b -> ... -> n -> Object -> *) + * @param {Number} arity Number of arguments the returned function should take + * before the target object. + * @param {Function} method Name of the method to call. + * @return {Function} A new curried function. + * @example + * + * var sliceFrom = R.invoker(1, 'slice'); + * sliceFrom(6, 'abcdefghijklm'); //=> 'ghijklm' + * var sliceFrom6 = R.invoker(2, 'slice')(6); + * sliceFrom6(8, 'abcdefghijklm'); //=> 'gh' + */ + var invoker = _curry2(function invoker(arity, method) { + return curryN(arity + 1, function () { + var target = arguments[arity]; + if (target != null && is(Function, target[method])) { + return target[method].apply(target, _slice(arguments, 0, arity)); + } + throw new TypeError(toString(target) + ' does not have a method named "' + method + '"'); }); - } - } - }, { - key: "reduceUnaryExpression", - value: function reduceUnaryExpression(node, _ref48) { - var operand = _ref48.operand; + }); - return seq(t(node.operator), p(node.operand, (0, _coderep.getPrecedence)(node), operand)); - } - }, { - key: "reduceReturnStatement", - value: function reduceReturnStatement(node, _ref49) { - var expression = _ref49.expression; + /** + * Returns a string made by inserting the `separator` between each + * element and concatenating all the elements into a single string. + * + * @func + * @memberOf R + * @category List + * @sig String -> [a] -> String + * @param {Number|String} separator The string used to separate the elements. + * @param {Array} xs The elements to join into a string. + * @return {String} str The string made by concatenating `xs` with `separator`. + * @see R.split + * @example + * + * var spacer = R.join(' '); + * spacer(['a', 2, 3.4]); //=> 'a 2 3.4' + * R.join('|', [1, 2, 3]); //=> '1|2|3' + */ + var join = invoker(1, 'join'); - return seq(t("return"), expression || empty(), semiOp()); - } - }, { - key: "reduceScript", - value: function reduceScript(node, _ref50) { - var directives = _ref50.directives; - var statements = _ref50.statements; + /** + * Creates a new function that, when invoked, caches the result of calling `fn` for a given + * argument set and returns the result. Subsequent calls to the memoized `fn` with the same + * argument set will not result in an additional call to `fn`; instead, the cached result + * for that set of arguments will be returned. + * + * @func + * @memberOf R + * @category Function + * @sig (*... -> a) -> (*... -> a) + * @param {Function} fn The function to memoize. + * @return {Function} Memoized version of `fn`. + * @example + * + * var count = 0; + * var factorial = R.memoize(function(n) { + * count += 1; + * return R.product(R.range(1, n + 1)); + * }); + * factorial(5); //=> 120 + * factorial(5); //=> 120 + * factorial(5); //=> 120 + * count; //=> 1 + */ + var memoize = _curry1(function memoize(fn) { + var cache = {}; + return function () { + var key = toString(arguments); + if (!_has(key, cache)) { + cache[key] = fn.apply(this, arguments); + } + return cache[key]; + }; + }); - if (statements.length) { - statements[0] = this.parenToAvoidBeingDirective(node.statements[0], statements[0]); - } - return seq.apply(undefined, _toConsumableArray(directives).concat(_toConsumableArray(statements))); - } - }, { - key: "reduceSetter", - value: function reduceSetter(node, _ref51) { - var name = _ref51.name; - var param = _ref51.param; - var body = _ref51.body; + /** + * Splits a string into an array of strings based on the given + * separator. + * + * @func + * @memberOf R + * @category String + * @sig String -> String -> [String] + * @param {String} sep The separator string. + * @param {String} str The string to separate into an array. + * @return {Array} The array of strings from `str` separated by `str`. + * @see R.join + * @example + * + * var pathComponents = R.split('/'); + * R.tail(pathComponents('/usr/local/bin/node')); //=> ['usr', 'local', 'bin', 'node'] + * + * R.split('.', 'a.b.c.xyz.d'); //=> ['a', 'b', 'c', 'xyz', 'd'] + */ + var split = invoker(1, 'split'); - return seq(t("set"), name, paren(param), brace(body)); - } - }, { - key: "reduceShorthandProperty", - value: function reduceShorthandProperty(node) { - return t(node.name); - } - }, { - key: "reduceStaticMemberExpression", - value: function reduceStaticMemberExpression(node, _ref52) { - var object = _ref52.object; - var property = _ref52.property; + /** + * The lower case version of a string. + * + * @func + * @memberOf R + * @category String + * @sig String -> String + * @param {String} str The string to lower case. + * @return {String} The lower case version of `str`. + * @see R.toUpper + * @example + * + * R.toLower('XYZ'); //=> 'xyz' + */ + var toLower = invoker(0, 'toLowerCase'); - var state = seq(p(node.object, (0, _coderep.getPrecedence)(node), object), t("."), t(property)); - state.startsWithLet = object.startsWithLet; - state.startsWithCurly = object.startsWithCurly; - state.startsWithLetSquareBracket = object.startsWithLetSquareBracket; - state.startsWithFunctionOrClass = object.startsWithFunctionOrClass; - return state; - } - }, { - key: "reduceStaticPropertyName", - value: function reduceStaticPropertyName(node) { - var n; - if (_esutils.keyword.isIdentifierNameES6(node.value)) { - return t(node.value); - } else if (n = parseFloat(node.value), n === n) { - return new _coderep.NumberCodeRep(n); - } - return t((0, _coderep.escapeStringLiteral)(node.value)); - } - }, { - key: "reduceSuper", - value: function reduceSuper() { - return t("super"); - } - }, { - key: "reduceSwitchCase", - value: function reduceSwitchCase(node, _ref53) { - var test = _ref53.test; - var consequent = _ref53.consequent; + /** + * The upper case version of a string. + * + * @func + * @memberOf R + * @category String + * @sig String -> String + * @param {String} str The string to upper case. + * @return {String} The upper case version of `str`. + * @see R.toLower + * @example + * + * R.toUpper('abc'); //=> 'ABC' + */ + var toUpper = invoker(0, 'toUpperCase'); - return seq(t("case"), test, t(":"), seq.apply(undefined, _toConsumableArray(consequent))); - } - }, { - key: "reduceSwitchDefault", - value: function reduceSwitchDefault(node, _ref54) { - var consequent = _ref54.consequent; + var R = { + F: F, + T: T, + __: __, + add: add, + addIndex: addIndex, + adjust: adjust, + all: all, + allPass: allPass, + always: always, + and: and, + any: any, + anyPass: anyPass, + ap: ap, + aperture: aperture, + append: append, + apply: apply, + assoc: assoc, + assocPath: assocPath, + binary: binary, + bind: bind, + both: both, + call: call, + chain: chain, + clone: clone, + commute: commute, + commuteMap: commuteMap, + comparator: comparator, + complement: complement, + compose: compose, + composeK: composeK, + composeP: composeP, + concat: concat, + cond: cond, + construct: construct, + constructN: constructN, + contains: contains, + containsWith: containsWith, + converge: converge, + countBy: countBy, + createMapEntry: createMapEntry, + curry: curry, + curryN: curryN, + dec: dec, + defaultTo: defaultTo, + difference: difference, + differenceWith: differenceWith, + dissoc: dissoc, + dissocPath: dissocPath, + divide: divide, + drop: drop, + dropLast: dropLast, + dropLastWhile: dropLastWhile, + dropRepeats: dropRepeats, + dropRepeatsWith: dropRepeatsWith, + dropWhile: dropWhile, + either: either, + empty: empty, + eqProps: eqProps, + equals: equals, + evolve: evolve, + filter: filter, + find: find, + findIndex: findIndex, + findLast: findLast, + findLastIndex: findLastIndex, + flatten: flatten, + flip: flip, + forEach: forEach, + fromPairs: fromPairs, + functions: functions, + functionsIn: functionsIn, + groupBy: groupBy, + gt: gt, + gte: gte, + has: has, + hasIn: hasIn, + head: head, + identical: identical, + identity: identity, + ifElse: ifElse, + inc: inc, + indexOf: indexOf, + init: init, + insert: insert, + insertAll: insertAll, + intersection: intersection, + intersectionWith: intersectionWith, + intersperse: intersperse, + into: into, + invert: invert, + invertObj: invertObj, + invoker: invoker, + is: is, + isArrayLike: isArrayLike, + isEmpty: isEmpty, + isNil: isNil, + isSet: isSet, + join: join, + keys: keys, + keysIn: keysIn, + last: last, + lastIndexOf: lastIndexOf, + length: length, + lens: lens, + lensIndex: lensIndex, + lensProp: lensProp, + lift: lift, + liftN: liftN, + lt: lt, + lte: lte, + map: map, + mapAccum: mapAccum, + mapAccumRight: mapAccumRight, + mapObj: mapObj, + mapObjIndexed: mapObjIndexed, + match: match, + mathMod: mathMod, + max: max, + maxBy: maxBy, + mean: mean, + median: median, + memoize: memoize, + merge: merge, + mergeAll: mergeAll, + min: min, + minBy: minBy, + modulo: modulo, + multiply: multiply, + nAry: nAry, + negate: negate, + none: none, + not: not, + nth: nth, + nthArg: nthArg, + nthChar: nthChar, + nthCharCode: nthCharCode, + of: of, + omit: omit, + once: once, + or: or, + over: over, + partial: partial, + partialRight: partialRight, + partition: partition, + path: path, + pathEq: pathEq, + pick: pick, + pickAll: pickAll, + pickBy: pickBy, + pipe: pipe, + pipeK: pipeK, + pipeP: pipeP, + pluck: pluck, + prepend: prepend, + product: product, + project: project, + prop: prop, + propEq: propEq, + propIs: propIs, + propOr: propOr, + propSatisfies: propSatisfies, + props: props, + range: range, + reduce: reduce, + reduceRight: reduceRight, + reduced: reduced, + reject: reject, + remove: remove, + repeat: repeat, + replace: replace, + reverse: reverse, + scan: scan, + set: set, + slice: slice, + sort: sort, + sortBy: sortBy, + split: split, + splitEvery: splitEvery, + subtract: subtract, + sum: sum, + tail: tail, + take: take, + takeLast: takeLast, + takeLastWhile: takeLastWhile, + takeWhile: takeWhile, + tap: tap, + test: test, + times: times, + toLower: toLower, + toPairs: toPairs, + toPairsIn: toPairsIn, + toString: toString, + toUpper: toUpper, + transduce: transduce, + trim: trim, + type: type, + unapply: unapply, + unary: unary, + uncurryN: uncurryN, + unfold: unfold, + union: union, + unionWith: unionWith, + uniq: uniq, + uniqBy: uniqBy, + uniqWith: uniqWith, + unnest: unnest, + update: update, + useWith: useWith, + values: values, + valuesIn: valuesIn, + view: view, + where: where, + whereEq: whereEq, + wrap: wrap, + xprod: xprod, + zip: zip, + zipObj: zipObj, + zipWith: zipWith + }; - return seq(t("default:"), seq.apply(undefined, _toConsumableArray(consequent))); - } - }, { - key: "reduceSwitchStatement", - value: function reduceSwitchStatement(node, _ref55) { - var discriminant = _ref55.discriminant; - var cases = _ref55.cases; + /* TEST_ENTRY_POINT */ - return seq(t("switch"), paren(discriminant), brace(seq.apply(undefined, _toConsumableArray(cases)))); - } - }, { - key: "reduceSwitchStatementWithDefault", - value: function reduceSwitchStatementWithDefault(node, _ref56) { - var discriminant = _ref56.discriminant; - var preDefaultCases = _ref56.preDefaultCases; - var defaultCase = _ref56.defaultCase; - var postDefaultCases = _ref56.postDefaultCases; + if (true) { + module.exports = R; + } else if (typeof define === 'function' && define.amd) { + define(function() { return R; }); + } else { + this.R = R; + } - return seq(t("switch"), paren(discriminant), brace(seq.apply(undefined, _toConsumableArray(preDefaultCases).concat([defaultCase], _toConsumableArray(postDefaultCases))))); - } - }, { - key: "reduceTemplateExpression", - value: function reduceTemplateExpression(node, _ref57) { - var tag = _ref57.tag; - var elements = _ref57.elements; + }.call(this)); - var state = node.tag == null ? empty() : p(node.tag, (0, _coderep.getPrecedence)(node), tag); - var templateData = ""; - state = seq(state, t("`")); - for (var i = 0, l = node.elements.length; i < l; ++i) { - if (node.elements[i].type === "TemplateElement") { - var d = ""; - if (i > 0) d += "}"; - d += node.elements[i].rawValue; - if (i < l - 1) d += "${"; - state = seq(state, t(d)); - } else { - state = seq(state, elements[i]); - } - } - state = seq(state, t("`")); - if (node.tag != null) { - state.startsWithCurly = tag.startsWithCurly; - state.startsWithLetSquareBracket = tag.startsWithLetSquareBracket; - state.startsWithFunctionOrClass = tag.startsWithFunctionOrClass; - } - return state; - } - }, { - key: "reduceTemplateElement", - value: function reduceTemplateElement(node) { - return t(node.rawValue); - } - }, { - key: "reduceThisExpression", - value: function reduceThisExpression(node) { - return t("this"); - } - }, { - key: "reduceThrowStatement", - value: function reduceThrowStatement(node, _ref58) { - var expression = _ref58.expression; - return seq(t("throw"), expression, semiOp()); - } - }, { - key: "reduceTryCatchStatement", - value: function reduceTryCatchStatement(node, _ref59) { - var body = _ref59.body; - var catchClause = _ref59.catchClause; +/***/ }, +/* 27 */ +/***/ function(module, exports, __webpack_require__) { - return seq(t("try"), body, catchClause); - } - }, { - key: "reduceTryFinallyStatement", - value: function reduceTryFinallyStatement(node, _ref60) { - var body = _ref60.body; - var catchClause = _ref60.catchClause; - var finalizer = _ref60.finalizer; + var _equals = __webpack_require__(26).equals; - return seq(t("try"), body, catchClause || empty(), t("finally"), finalizer); - } - }, { - key: "reduceYieldExpression", - value: function reduceYieldExpression(node, _ref61) { - var expression = _ref61.expression; - if (node.expression == null) return t("yield"); - return seq(t("yield"), p(node.expression, (0, _coderep.getPrecedence)(node), expression)); - } - }, { - key: "reduceYieldGeneratorExpression", - value: function reduceYieldGeneratorExpression(node, _ref62) { - var expression = _ref62.expression; + module.exports = { - return seq(t("yield"), t("*"), p(node.expression, (0, _coderep.getPrecedence)(node), expression)); - } - }, { - key: "reduceDirective", - value: function reduceDirective(node) { - var delim = /^(?:[^"\\]|\\.)*$/.test(node.rawValue) ? "\"" : "'"; - return seq(t(delim + node.rawValue + delim), semiOp()); - } - }, { - key: "reduceVariableDeclaration", - value: function reduceVariableDeclaration(node, _ref63) { - var declarators = _ref63.declarators; + baseMap: function(f) { + return f(this.value); + }, - return seq(t(node.kind), commaSep(declarators)); - } - }, { - key: "reduceVariableDeclarationStatement", - value: function reduceVariableDeclarationStatement(node, _ref64) { - var declaration = _ref64.declaration; - - return seq(declaration, semiOp()); - } - }, { - key: "reduceVariableDeclarator", - value: function reduceVariableDeclarator(node, _ref65) { - var binding = _ref65.binding; - var init = _ref65.init; - - var containsIn = init && init.containsIn && !init.containsGroup; - if (init) { - if (init.containsGroup) { - init = paren(init); - } else { - init = markContainsIn(init); - } - } - return (0, _objectAssign2.default)(init == null ? binding : seq(binding, t("="), init), { containsIn: containsIn }); - } - }, { - key: "reduceWhileStatement", - value: function reduceWhileStatement(node, _ref66) { - var test = _ref66.test; - var body = _ref66.body; - - return (0, _objectAssign2.default)(seq(t("while"), paren(test), body), { endsWithMissingElse: body.endsWithMissingElse }); - } - }, { - key: "reduceWithStatement", - value: function reduceWithStatement(node, _ref67) { - var object = _ref67.object; - var body = _ref67.body; + getEquals: function(constructor) { + return function equals(that) { + return that instanceof constructor && _equals(this.value, that.value); + }; + }, - return (0, _objectAssign2.default)(seq(t("with"), paren(object), body), { endsWithMissingElse: body.endsWithMissingElse }); + extend: function(Child, Parent) { + function Ctor() { + this.constructor = Child; } - }]); + Ctor.prototype = Parent.prototype; + Child.prototype = new Ctor(); + Child.super_ = Parent.prototype; + }, - return MinimalCodeGen; - }(); + identity: function(x) { return x; }, - exports.default = MinimalCodeGen; + notImplemented: function(str) { + return function() { + throw new Error(str + ' is not implemented'); + }; + }, -/***/ }, -/* 40 */ -/***/ function(module, exports) { + notCallable: function(fn) { + return function() { + throw new Error(fn + ' cannot be called directly'); + }; + }, - 'use strict'; - var propIsEnumerable = Object.prototype.propertyIsEnumerable; + returnThis: function() { return this; } - function ToObject(val) { - if (val == null) { - throw new TypeError('Object.assign cannot be called with null or undefined'); - } + }; - return Object(val); - } - function ownEnumerableKeys(obj) { - var keys = Object.getOwnPropertyNames(obj); +/***/ }, +/* 28 */ +/***/ function(module, exports, __webpack_require__) { - if (Object.getOwnPropertySymbols) { - keys = keys.concat(Object.getOwnPropertySymbols(obj)); - } + var R = __webpack_require__(26); - return keys.filter(function (key) { - return propIsEnumerable.call(obj, key); - }); + // `f` is a function that takes two function arguments: `reject` (failure) and `resolve` (success) + function Future(f) { + if (!(this instanceof Future)) { + return new Future(f); + } + this._fork = f; } - module.exports = Object.assign || function (target, source) { - var from; - var keys; - var to = ToObject(target); - - for (var s = 1; s < arguments.length; s++) { - from = arguments[s]; - keys = ownEnumerableKeys(Object(from)); - - for (var i = 0; i < keys.length; i++) { - to[keys[i]] = from[keys[i]]; - } - } - - return to; + Future.prototype.fork = function(reject, resolve) { + try { + this._fork(reject, resolve); + } catch(e) { + reject(e); + } }; + // functor + Future.prototype.map = function(f) { + return this.chain(function(a) { return Future.of(f(a)); }); + }; -/***/ }, -/* 41 */ -/***/ function(module, exports) { + // apply + Future.prototype.ap = function(m) { + var self = this; - "use strict"; + return new Future(function(rej, res) { + var applyFn, val; + var doReject = R.once(rej); - var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); + function resolveIfDone() { + if (applyFn != null && val != null) { + return res(applyFn(val)); + } + } - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.getPrecedence = getPrecedence; - exports.escapeStringLiteral = escapeStringLiteral; + self.fork(doReject, function(fn) { + applyFn = fn; + resolveIfDone(); + }); - function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + m.fork(doReject, function(v) { + val = v; + resolveIfDone(); + }); - function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + }); - function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + }; - var Precedence = { - Sequence: 0, - Yield: 1, - Assignment: 1, - Conditional: 2, - ArrowFunction: 2, - LogicalOR: 3, - LogicalAND: 4, - BitwiseOR: 5, - BitwiseXOR: 6, - BitwiseAND: 7, - Equality: 8, - Relational: 9, - BitwiseSHIFT: 10, - Additive: 11, - Multiplicative: 12, - Prefix: 13, - Postfix: 14, - New: 15, - Call: 16, - TaggedTemplate: 17, - Member: 18, - Primary: 19 + // applicative + Future.of = function(x) { + // should include a default rejection? + return new Future(function(_, resolve) { return resolve(x); }); }; - exports.Precedence = Precedence; + Future.prototype.of = Future.of; - var BinaryPrecedence = { - ",": Precedence.Sequence, - "||": Precedence.LogicalOR, - "&&": Precedence.LogicalAND, - "|": Precedence.BitwiseOR, - "^": Precedence.BitwiseXOR, - "&": Precedence.BitwiseAND, - "==": Precedence.Equality, - "!=": Precedence.Equality, - "===": Precedence.Equality, - "!==": Precedence.Equality, - "<": Precedence.Relational, - ">": Precedence.Relational, - "<=": Precedence.Relational, - ">=": Precedence.Relational, - "in": Precedence.Relational, - "instanceof": Precedence.Relational, - "<<": Precedence.BitwiseSHIFT, - ">>": Precedence.BitwiseSHIFT, - ">>>": Precedence.BitwiseSHIFT, - "+": Precedence.Additive, - "-": Precedence.Additive, - "*": Precedence.Multiplicative, - "%": Precedence.Multiplicative, - "/": Precedence.Multiplicative + // chain + // f must be a function which returns a value + // f must return a value of the same Chain + // chain must return a value of the same Chain + //:: Future a, b => (b -> Future c) -> Future c + Future.prototype.chain = function(f) { // Sorella's: + return new Future(function(reject, resolve) { + return this.fork(function(a) { return reject(a); }, + function(b) { return f(b).fork(reject, resolve); }); + }.bind(this)); }; - function getPrecedence(node) { - switch (node.type) { - case "ArrayExpression": - case "FunctionExpression": - case "IdentifierExpression": - case "LiteralBooleanExpression": - case "LiteralNullExpression": - case "LiteralNumericExpression": - case "LiteralInfinityExpression": - case "LiteralRegExpExpression": - case "LiteralStringExpression": - case "ObjectExpression": - case "ThisExpression": - return Precedence.Primary; + // chainReject + // Like chain but operates on the reject instead of the resolve case. + //:: Future a, b => (a -> Future c) -> Future c + Future.prototype.chainReject = function(f) { + return new Future(function(reject, resolve) { + return this.fork(function(a) { return f(a).fork(reject, resolve); }, + function(b) { return resolve(b); + }); + }.bind(this)); + }; - case "ArrowExpression": - case "AssignmentExpression": - case "CompoundAssignmentExpression": - case "YieldExpression": - case "YieldGeneratorExpression": - return Precedence.Assignment; + // monad + // A value that implements the Monad specification must also implement the Applicative and Chain specifications. + // see above. - case "ConditionalExpression": - return Precedence.Conditional; + Future.prototype.bimap = function(errFn, successFn) { + var self = this; + return new Future(function(reject, resolve) { + self.fork(function(err) { + reject(errFn(err)); + }, function(val) { + resolve(successFn(val)); + }); + }); + }; - case "ComputedMemberExpression": - case "StaticMemberExpression": - switch (node.object.type) { - case "CallExpression": - case "ComputedMemberExpression": - case "StaticMemberExpression": - case "TemplateExpression": - return getPrecedence(node.object); - default: - return Precedence.Member; - } + Future.reject = function(val) { + return new Future(function(reject) { + reject(val); + }); + }; - case "TemplateExpression": - if (node.tag == null) return Precedence.Member; - switch (node.tag.type) { - case "CallExpression": - case "ComputedMemberExpression": - case "StaticMemberExpression": - case "TemplateExpression": - return getPrecedence(node.tag); - default: - return Precedence.Member; - } + Future.prototype.toString = function() { + return 'Future(' + R.toString(this._fork) + ')'; + }; - case "BinaryExpression": - return BinaryPrecedence[node.operator]; + Future.cache = function(f) { + var status = 'IDLE'; + var listeners = []; + var cachedValue; - case "CallExpression": - return Precedence.Call; - case "NewExpression": - return node.arguments.length === 0 ? Precedence.New : Precedence.Member; - case "UpdateExpression": - return node.isPrefix ? Precedence.Prefix : Precedence.Postfix; - case "UnaryExpression": - return Precedence.Prefix; - } - } + var handleCompletion = R.curry(function(newStatus, cb, val) { + status = newStatus; + cachedValue = val; + cb(val); + R.forEach(function(listener) { + listener[status](cachedValue); + }, listeners); + }); - function escapeStringLiteral(stringValue) { - var result = ""; - var nSingle = 0, - nDouble = 0; - for (var i = 0, l = stringValue.length; i < l; ++i) { - var ch = stringValue[i]; - if (ch === "\"") { - ++nDouble; - } else if (ch === "'") { - ++nSingle; - } - } - var delim = nDouble > nSingle ? "'" : "\""; - result += delim; - for (var i = 0; i < stringValue.length; i++) { - var ch = stringValue.charAt(i); - switch (ch) { - case delim: - result += "\\" + delim; - break; - case "\b": - result += "\\b"; - break; - case "\t": - result += "\\t"; - break; - case "\n": - result += "\\n"; - break; - case "\u000b": - result += "\\v"; - break; - case "\f": - result += "\\f"; - break; - case "\r": - result += "\\r"; - break; - case "\\": - result += "\\\\"; - break; - case "\u2028": - result += "\\u2028"; - break; - case "\u2029": - result += "\\u2029"; - break; - default: - result += ch; - break; - } + function addListeners(reject, resolve) { + listeners.push({ REJECTED: reject, RESOLVED: resolve } ); } - result += delim; - return result; - } - - var CodeRep = exports.CodeRep = function () { - function CodeRep() { - _classCallCheck(this, CodeRep); - this.containsIn = false; - this.containsGroup = false; - // restricted lookaheads: {, function, class, let, let [ - this.startsWithCurly = false; - this.startsWithFunctionOrClass = false; - this.startsWithLet = false; - this.startsWithLetSquareBracket = false; - this.endsWithMissingElse = false; + function doResolve(reject, resolve) { + status = 'PENDING'; + return f.fork( + handleCompletion('REJECTED', reject), + handleCompletion('RESOLVED', resolve) + ); } - _createClass(CodeRep, [{ - key: "forEach", - value: function forEach(f) { - // Call a function on every CodeRep represented by this node. Always calls f on a node and then its children, so if you're careful you can modify a node's children online. - f(this); - } - }]); + return new Future(function(reject, resolve) { - return CodeRep; - }(); + switch(status) { + case 'IDLE': doResolve(reject, resolve); break; + case 'PENDING': addListeners(reject, resolve); break; + case 'REJECTED': reject(cachedValue); break; + case 'RESOLVED': resolve(cachedValue); break; + } - var Empty = exports.Empty = function (_CodeRep) { - _inherits(Empty, _CodeRep); + }); + }; - function Empty() { - _classCallCheck(this, Empty); + module.exports = Future; - return _possibleConstructorReturn(this, Object.getPrototypeOf(Empty).call(this)); - } - _createClass(Empty, [{ - key: "emit", - value: function emit() {} - }]); +/***/ }, +/* 29 */ +/***/ function(module, exports, __webpack_require__) { - return Empty; - }(CodeRep); + var R = __webpack_require__(26); - var Token = exports.Token = function (_CodeRep2) { - _inherits(Token, _CodeRep2); + var util = __webpack_require__(27); - function Token(token) { - _classCallCheck(this, Token); - var _this2 = _possibleConstructorReturn(this, Object.getPrototypeOf(Token).call(this)); + /** + * A data type that holds a value and exposes a monadic api. + */ - _this2.token = token; - return _this2; + /** + * Constructs a new `Identity[a]` data type that holds a single + * value `a`. + * @param {*} a Value of any type + * @sig a -> Identity[a] + */ + function Identity(x) { + if (!(this instanceof Identity)) { + return new Identity(x); } + this.value = x; + } - _createClass(Token, [{ - key: "emit", - value: function emit(ts) { - ts.put(this.token); - } - }]); + /** + * Applicative specification. Creates a new `Identity[a]` holding the value `a`. + * @param {*} a Value of any type + * @returns Identity[a] + * @sig a -> Identity[a] + */ + Identity.of = function(x) { + return new Identity(x); + }; + Identity.prototype.of = Identity.of; - return Token; - }(CodeRep); + /** + * Functor specification. Creates a new `Identity[a]` mapping function `f` onto + * `a` returning any value b. + * @param {Function} f Maps `a` to any value `b` + * @returns Identity[b] + * @sig @Identity[a] => (a -> b) -> Identity[b] + */ + Identity.prototype.map = function(f) { + return new Identity(f(this.value)); + }; - var NumberCodeRep = exports.NumberCodeRep = function (_CodeRep3) { - _inherits(NumberCodeRep, _CodeRep3); + /** + * Apply specification. Applies the function inside the `Identity[a]` + * type to another applicative type. + * @param {Applicative[a]} app Applicative that will apply its function + * @returns Applicative[b] + * @sig (Identity[a -> b], f: Applicative[_]) => f[a] -> f[b] + */ + Identity.prototype.ap = function(app) { + return app.map(this.value); + }; - function NumberCodeRep(number) { - _classCallCheck(this, NumberCodeRep); + /** + * Chain specification. Transforms the value of the `Identity[a]` + * type using an unary function to monads. The `Identity[a]` type + * should contain a function, otherwise an error is thrown. + * + * @param {Function} fn Transforms `a` into a `Monad[b]` + * @returns Monad[b] + * @sig (Identity[a], m: Monad[_]) => (a -> m[b]) -> m[b] + */ + Identity.prototype.chain = function(fn) { + return fn(this.value); + }; - var _this3 = _possibleConstructorReturn(this, Object.getPrototypeOf(NumberCodeRep).call(this)); + /** + * Returns the value of `Identity[a]` + * + * @returns a + * @sig (Identity[a]) => a + */ + Identity.prototype.get = function() { + return this.value; + }; - _this3.number = number; - return _this3; - } + // equality method to enable testing + Identity.prototype.equals = util.getEquals(Identity); - _createClass(NumberCodeRep, [{ - key: "emit", - value: function emit(ts) { - ts.putNumber(this.number); - } - }]); + Identity.prototype.toString = function() { + return 'Identity(' + R.toString(this.value) + ')'; + }; - return NumberCodeRep; - }(CodeRep); + module.exports = Identity; - var Paren = exports.Paren = function (_CodeRep4) { - _inherits(Paren, _CodeRep4); - function Paren(expr) { - _classCallCheck(this, Paren); +/***/ }, +/* 30 */ +/***/ function(module, exports, __webpack_require__) { - var _this4 = _possibleConstructorReturn(this, Object.getPrototypeOf(Paren).call(this)); + var R = __webpack_require__(26); - _this4.expr = expr; - return _this4; - } + module.exports = IO; - _createClass(Paren, [{ - key: "emit", - value: function emit(ts) { - ts.put("("); - this.expr.emit(ts, false); - ts.put(")"); - } - }, { - key: "forEach", - value: function forEach(f) { - f(this); - this.expr.forEach(f); - } - }]); + var compose = R.compose; - return Paren; - }(CodeRep); + function IO(fn) { + if (!(this instanceof IO)) { + return new IO(fn); + } + this.fn = fn; + } - var Bracket = exports.Bracket = function (_CodeRep5) { - _inherits(Bracket, _CodeRep5); + // `f` must return an IO + IO.prototype.chain = function(f) { + var io = this; + return new IO(function() { + var next = f(io.fn.apply(io, arguments)); + return next.fn.apply(next, arguments); + }); + }; - function Bracket(expr) { - _classCallCheck(this, Bracket); + IO.prototype.map = function(f) { + var io = this; + return new IO(compose(f, io.fn)); + }; - var _this5 = _possibleConstructorReturn(this, Object.getPrototypeOf(Bracket).call(this)); + // `this` IO must wrap a function `f` that takes an IO (`thatIo`) as input + // `f` must return an IO + IO.prototype.ap = function(thatIo) { + return this.chain(function(f) { + return thatIo.map(f); + }); + }; - _this5.expr = expr; - return _this5; - } + IO.runIO = function(io) { + return io.runIO.apply(io, [].slice.call(arguments, 1)); + }; - _createClass(Bracket, [{ - key: "emit", - value: function emit(ts) { - ts.put("["); - this.expr.emit(ts, false); - ts.put("]"); - } - }, { - key: "forEach", - value: function forEach(f) { - f(this); - this.expr.forEach(f); - } - }]); + IO.prototype.runIO = function() { + return this.fn.apply(this, arguments); + }; - return Bracket; - }(CodeRep); + IO.prototype.of = function(x) { + return new IO(function() { return x; }); + }; - var Brace = exports.Brace = function (_CodeRep6) { - _inherits(Brace, _CodeRep6); + IO.of = IO.prototype.of; - function Brace(expr) { - _classCallCheck(this, Brace); + IO.prototype.toString = function() { + return 'IO(' + R.toString(this.fn) + ')'; + }; - var _this6 = _possibleConstructorReturn(this, Object.getPrototypeOf(Brace).call(this)); - _this6.expr = expr; - return _this6; - } +/***/ }, +/* 31 */ +/***/ function(module, exports, __webpack_require__) { - _createClass(Brace, [{ - key: "emit", - value: function emit(ts) { - ts.put("{"); - this.expr.emit(ts, false); - ts.put("}"); - } - }, { - key: "forEach", - value: function forEach(f) { - f(this); - this.expr.forEach(f); - } - }]); + var R = __webpack_require__(26); - return Brace; - }(CodeRep); + module.exports = R.curryN(3, function lift2(f, a1, a2) { + return a1.map(f).ap(a2); + }); - var NoIn = exports.NoIn = function (_CodeRep7) { - _inherits(NoIn, _CodeRep7); - function NoIn(expr) { - _classCallCheck(this, NoIn); +/***/ }, +/* 32 */ +/***/ function(module, exports, __webpack_require__) { - var _this7 = _possibleConstructorReturn(this, Object.getPrototypeOf(NoIn).call(this)); + var R = __webpack_require__(26); - _this7.expr = expr; - return _this7; - } + module.exports = R.curryN(4, function lift3(f, a1, a2, a3) { + return a1.map(f).ap(a2).ap(a3); + }); - _createClass(NoIn, [{ - key: "emit", - value: function emit(ts) { - this.expr.emit(ts, true); - } - }, { - key: "forEach", - value: function forEach(f) { - f(this); - this.expr.forEach(f); - } - }]); - return NoIn; - }(CodeRep); +/***/ }, +/* 33 */ +/***/ function(module, exports, __webpack_require__) { - var ContainsIn = exports.ContainsIn = function (_CodeRep8) { - _inherits(ContainsIn, _CodeRep8); + var R = __webpack_require__(26); - function ContainsIn(expr) { - _classCallCheck(this, ContainsIn); + var util = __webpack_require__(27); - var _this8 = _possibleConstructorReturn(this, Object.getPrototypeOf(ContainsIn).call(this)); + function Maybe(x) { + return x == null ? _nothing : Maybe.Just(x); + } - _this8.expr = expr; - return _this8; - } + function _Just(x) { + this.value = x; + } + util.extend(_Just, Maybe); - _createClass(ContainsIn, [{ - key: "emit", - value: function emit(ts, noIn) { - if (noIn) { - ts.put("("); - this.expr.emit(ts, false); - ts.put(")"); - } else { - this.expr.emit(ts, false); - } - } - }, { - key: "forEach", - value: function forEach(f) { - f(this); - this.expr.forEach(f); - } - }]); + function _Nothing() {} + util.extend(_Nothing, Maybe); - return ContainsIn; - }(CodeRep); + var _nothing = new _Nothing(); - var Seq = exports.Seq = function (_CodeRep9) { - _inherits(Seq, _CodeRep9); + Maybe.Nothing = function() { + return _nothing; + }; - function Seq(children) { - _classCallCheck(this, Seq); + Maybe.Just = function(x) { + return new _Just(x); + }; - var _this9 = _possibleConstructorReturn(this, Object.getPrototypeOf(Seq).call(this)); + Maybe.of = Maybe.Just; - _this9.children = children; - return _this9; - } + Maybe.prototype.of = Maybe.Just; - _createClass(Seq, [{ - key: "emit", - value: function emit(ts, noIn) { - this.children.forEach(function (cr) { - return cr.emit(ts, noIn); - }); - } - }, { - key: "forEach", - value: function forEach(f) { - f(this); - this.children.forEach(function (x) { - return x.forEach(f); - }); - } - }]); + Maybe.isJust = function(x) { + return x instanceof _Just; + }; - return Seq; - }(CodeRep); + Maybe.isNothing = function(x) { + return x === _nothing; + }; - var Semi = exports.Semi = function (_Token) { - _inherits(Semi, _Token); + Maybe.maybe = R.curry(function(nothingVal, justFn, m) { + return m.reduce(function(_, x) { + return justFn(x); + }, nothingVal); + }); - function Semi() { - _classCallCheck(this, Semi); + // functor + _Just.prototype.map = function(f) { + return this.of(f(this.value)); + }; - return _possibleConstructorReturn(this, Object.getPrototypeOf(Semi).call(this, ";")); - } + _Nothing.prototype.map = util.returnThis; - return Semi; - }(Token); + // apply + // takes a Maybe that wraps a function (`app`) and applies its `map` + // method to this Maybe's value, which must be a function. + _Just.prototype.ap = function(m) { + return m.map(this.value); + }; - var CommaSep = exports.CommaSep = function (_CodeRep10) { - _inherits(CommaSep, _CodeRep10); + _Nothing.prototype.ap = util.returnThis; - function CommaSep(children) { - _classCallCheck(this, CommaSep); + // applicative + // `of` inherited from `Maybe` - var _this11 = _possibleConstructorReturn(this, Object.getPrototypeOf(CommaSep).call(this)); - _this11.children = children; - return _this11; - } + // chain + // f must be a function which returns a value + // f must return a value of the same Chain + // chain must return a value of the same Chain + _Just.prototype.chain = util.baseMap; - _createClass(CommaSep, [{ - key: "emit", - value: function emit(ts, noIn) { - var first = true; - this.children.forEach(function (cr) { - if (first) { - first = false; - } else { - ts.put(","); - } - cr.emit(ts, noIn); - }); - } - }, { - key: "forEach", - value: function forEach(f) { - f(this); - this.children.forEach(function (x) { - return x.forEach(f); - }); - } - }]); + _Nothing.prototype.chain = util.returnThis; - return CommaSep; - }(CodeRep); - var SemiOp = exports.SemiOp = function (_CodeRep11) { - _inherits(SemiOp, _CodeRep11); + // + _Just.prototype.datatype = _Just; - function SemiOp() { - _classCallCheck(this, SemiOp); + _Nothing.prototype.datatype = _Nothing; - return _possibleConstructorReturn(this, Object.getPrototypeOf(SemiOp).call(this)); - } + // monad + // A value that implements the Monad specification must also implement the Applicative and Chain specifications. + // see above. - _createClass(SemiOp, [{ - key: "emit", - value: function emit(ts) { - ts.putOptionalSemi(); - } - }]); + // equality method to enable testing + _Just.prototype.equals = util.getEquals(_Just); - return SemiOp; - }(CodeRep); + _Nothing.prototype.equals = function(that) { + return that === _nothing; + }; -/***/ }, -/* 42 */ -/***/ function(module, exports, __webpack_require__) { + Maybe.prototype.isNothing = function() { + return this === _nothing; + }; - "use strict"; + Maybe.prototype.isJust = function() { + return this instanceof _Just; + }; - var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); + _Just.prototype.getOrElse = function() { + return this.value; + }; - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.FormattedCodeGen = exports.ExtensibleCodeGen = exports.Sep = undefined; + _Nothing.prototype.getOrElse = function(a) { + return a; + }; - var _objectAssign = __webpack_require__(40); + _Just.prototype.reduce = function(f, x) { + return f(x, this.value); + }; - var _objectAssign2 = _interopRequireDefault(_objectAssign); + _Nothing.prototype.reduce = function(f, x) { + return x; + }; - var _esutils = __webpack_require__(6); + _Just.prototype.toString = function() { + return 'Maybe.Just(' + R.toString(this.value) + ')'; + }; - var _coderep = __webpack_require__(41); + _Nothing.prototype.toString = function() { + return 'Maybe.Nothing()'; + }; - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + module.exports = Maybe; - function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } - function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } +/***/ }, +/* 34 */ +/***/ function(module, exports, __webpack_require__) { - function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } + var R = __webpack_require__(26); - function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - function empty() { - return new _coderep.Empty(); + function Tuple(x, y) { + switch (arguments.length) { + case 0: + throw new TypeError('no arguments to Tuple'); + case 1: + return function(y) { + return new _Tuple(x, y); + }; + default: + return new _Tuple(x, y); + } } - function noIn(rep) { - return new _coderep.NoIn(rep); + function _Tuple(x, y) { + this[0] = x; + this[1] = y; + this.length = 2; } - function markContainsIn(state) { - return state.containsIn ? new _coderep.ContainsIn(state) : state; + function ensureConcat(xs) { + xs.forEach(function(x) { + if (typeof x.concat != 'function') { + throw new TypeError(R.toString(x) + ' must be a semigroup to perform this operation'); + } + }); } - function seq() { - for (var _len = arguments.length, reps = Array(_len), _key = 0; _key < _len; _key++) { - reps[_key] = arguments[_key]; - } - - return new _coderep.Seq(reps); - } + Tuple.fst = function(x) { + return x[0]; + }; - function isEmpty(codeRep) { - return codeRep instanceof _coderep.Empty || codeRep instanceof Linebreak || codeRep instanceof _coderep.Seq && codeRep.children.every(isEmpty); - } + Tuple.snd = function(x) { + return x[1]; + }; - var Sep = {}; - var separatorNames = ["ARRAY_EMPTY", "ARRAY_BEFORE_COMMA", "ARRAY_AFTER_COMMA", "SPREAD", "BEFORE_DEFAULT_EQUALS", "AFTER_DEFAULT_EQUALS", "REST", "OBJECT_BEFORE_COMMA", "OBJECT_AFTER_COMMA", "BEFORE_PROP", "AFTER_PROP", "BEFORE_JUMP_LABEL", "ARGS_BEFORE_COMMA", "ARGS_AFTER_COMMA", "CALL", "BEFORE_CATCH_BINDING", "AFTER_CATCH_BINDING", "BEFORE_CLASS_NAME", "BEFORE_EXTENDS", "AFTER_EXTENDS", "BEFORE_CLASS_DECLARATION_ELEMENTS", "BEFORE_CLASS_EXPRESSION_ELEMENTS", "AFTER_STATIC", "BEFORE_CLASS_ELEMENT", "AFTER_CLASS_ELEMENT", "BEFORE_TERNARY_QUESTION", "AFTER_TERNARY_QUESTION", "BEFORE_TERNARY_COLON", "AFTER_TERNARY_COLON", "COMPUTED_MEMBER_EXPRESSION", "AFTER_DO", "BEFORE_DOWHILE_WHILE", "AFTER_DOWHILE_WHILE", "AFTER_FORIN_FOR", "BEFORE_FORIN_IN", "AFTER_FORIN_FOR", "BEFORE_FORIN_BODY", "AFTER_FOROF_FOR", "BEFORE_FOROF_OF", "AFTER_FOROF_FOR", "BEFORE_FOROF_BODY", "AFTER_FOR_FOR", "BEFORE_FOR_INIT", "AFTER_FOR_INIT", "EMPTY_FOR_INIT", "BEFORE_FOR_TEST", "AFTER_FOR_TEST", "EMPTY_FOR_TEST", "BEFORE_FOR_UPDATE", "AFTER_FOR_UPDATE", "EMPTY_FOR_UPDATE", "BEFORE_FOR_BODY", "BEFORE_GENERATOR_STAR", "AFTER_GENERATOR_STAR", "BEFORE_FUNCTION_PARAMS", "BEFORE_FUNCTION_DECLARATION_BODY", "BEFORE_FUNCTION_EXPRESSION_BODY", "AFTER_FUNCTION_DIRECTIVES", "BEFORE_ARROW", "AFTER_ARROW", "AFTER_GET", "BEFORE_GET_PARAMS", "BEFORE_GET_BODY", "AFTER_IF", "AFTER_IF_TEST", "BEFORE_ELSE", "AFTER_ELSE", "PARAMETER_BEFORE_COMMA", "PARAMETER_AFTER_COMMA", "NAMED_IMPORT_BEFORE_COMMA", "NAMED_IMPORT_AFTER_COMMA", "IMPORT_BEFORE_COMMA", "IMPORT_AFTER_COMMA", "BEFORE_IMPORT_BINDINGS", "BEFORE_IMPORT_MODULE", "AFTER_IMPORT_BINDINGS", "AFTER_FROM", "BEFORE_IMPORT_NAMESPACE", "BEFORE_IMPORT_STAR", "AFTER_IMPORT_STAR", "AFTER_IMPORT_AS", "AFTER_NAMESPACE_BINDING", "BEFORE_IMPORT_AS", "AFTER_IMPORT_AS", "EXPORTS_BEFORE_COMMA", "EXPORTS_AFTER_COMMA", "BEFORE_EXPORT_STAR", "AFTER_EXPORT_STAR", "BEFORE_EXPORT_BINDINGS", "AFTER_EXPORT_BINDINGS", "AFTER_EXPORT", "EXPORT_DEFAULT", "AFTER_EXPORT_DEFAULT", "BEFORE_EXPORT_AS", "AFTER_EXPORT_AS", "BEFORE_LABEL_COLON", "AFTER_LABEL_COLON", "AFTER_METHOD_GENERATOR_STAR", "AFTER_METHOD_NAME", "BEFORE_METHOD_BODY", "AFTER_MODULE_DIRECTIVES", "AFTER_NEW", "BEFORE_NEW_ARGS", "EMPTY_NEW_CALL", "NEW_TARGET_BEFORE_DOT", "NEW_TARGET_AFTER_DOT", "RETURN", "AFTER_SET", "BEFORE_SET_PARAMS", "BEFORE_SET_BODY", "AFTER_SCRIPT_DIRECTIVES", "BEFORE_STATIC_MEMBER_DOT", "AFTER_STATIC_MEMBER_DOT", "BEFORE_CASE_TEST", "AFTER_CASE_TEST", "BEFORE_CASE_BODY", "AFTER_CASE_BODY", "DEFAULT", "AFTER_DEFAULT_BODY", "BEFORE_SWITCH_DISCRIM", "BEFORE_SWITCH_BODY", "TEMPLATE_TAG", "BEFORE_TEMPLATE_EXPRESSION", "AFTER_TEMPLATE_EXPRESSION", "THROW", "AFTER_TRY", "BEFORE_CATCH", "BEFORE_FINALLY", "AFTER_FINALLY", "VARIABLE_DECLARATION", "YIELD", "BEFORE_YIELD_STAR", "AFTER_YIELD_STAR", "DECLARATORS_BEFORE_COMMA", "DECLARATORS_AFTER_COMMA", "BEFORE_INIT_EQUALS", "AFTER_INIT_EQUALS", "AFTER_WHILE", "BEFORE_WHILE_BODY", "AFTER_WITH", "BEFORE_WITH_BODY", "PAREN_AVOIDING_DIRECTIVE_BEFORE", "PAREN_AVOIDING_DIRECTIVE_AFTER", "PRECEDENCE_BEFORE", "PRECEDENCE_AFTER", "EXPRESSION_PAREN_BEFORE", "EXPRESSION_PAREN_AFTER", "CALL_PAREN_BEFORE", "CALL_PAREN_AFTER", "CALL_PAREN_EMPTY", "CATCH_PAREN_BEFORE", "CATCH_PAREN_AFTER", "DO_WHILE_TEST_PAREN_BEFORE", "DO_WHILE_TEST_PAREN_AFTER", "EXPRESSION_STATEMENT_PAREN_BEFORE", "EXPRESSION_STATEMENT_PAREN_AFTER", "FOR_IN_LET_PAREN_BEFORE", "FOR_IN_LET_PAREN_AFTER", "FOR_IN_PAREN_BEFORE", "FOR_IN_PAREN_AFTER", "FOR_OF_LET_PAREN_BEFORE", "FOR_OF_LET_PAREN_AFTER", "FOR_OF_PAREN_BEFORE", "FOR_OF_PAREN_AFTER", "PARAMETERS_PAREN_BEFORE", "PARAMETERS_PAREN_AFTER", "PARAMETERS_PAREN_EMPTY", "ARROW_PARAMETERS_PAREN_BEFORE", "ARROW_PARAMETERS_PAREN_AFTER", "ARROW_PARAMETERS_PAREN_EMPTY", "ARROW_BODY_PAREN_BEFORE", "ARROW_BODY_PAREN_AFTER", "GETTER_PARAMS", "IF_PAREN_BEFORE", "IF_PAREN_AFTER", "EXPORT_PAREN_BEFORE", "EXPORT_PAREN_AFTER", "NEW_CALLEE_PAREN_BEFORE", "NEW_CALLEE_PAREN_AFTER", "NEW_PAREN_BEFORE", "NEW_PAREN_AFTER", "NEW_PAREN_EMPTY", "SETTER_PARAM_BEFORE", "SETTER_PARAM_AFTER", "SWITCH_DISCRIM_PAREN_BEFORE", "SWITCH_DISCRIM_PAREN_AFTER", "WHILE_TEST_PAREN_BEFORE", "WHILE_TEST_PAREN_AFTER", "WITH_PAREN_BEFORE", "WITH_PAREN_AFTER", "OBJECT_BRACE_INITIAL", "OBJECT_BRACE_FINAL", "OBJECT_EMPTY", "BLOCK_BRACE_INITIAL", "BLOCK_BRACE_FINAL", "BLOCK_EMPTY", "CLASS_BRACE_INITIAL", "CLASS_BRACE_FINAL", "CLASS_EMPTY", "CLASS_EXPRESSION_BRACE_INITIAL", "CLASS_EXPRESSION_BRACE_FINAL", "CLASS_EXPRESSION_BRACE_EMPTY", "FUNCTION_BRACE_INITIAL", "FUNCTION_BRACE_FINAL", "FUNCTION_EMPTY", "FUNCTION_EXPRESSION_BRACE_INITIAL", "FUNCTION_EXPRESSION_BRACE_FINAL", "FUNCTION_EXPRESSION_EMPTY", "ARROW_BRACE_INITIAL", "ARROW_BRACE_FINAL", "ARROW_BRACE_EMPTY", "GET_BRACE_INTIAL", "GET_BRACE_FINAL", "GET_BRACE_EMPTY", "MISSING_ELSE_INTIIAL", "MISSING_ELSE_FINAL", "MISSING_ELSE_EMPTY", "IMPORT_BRACE_INTIAL", "IMPORT_BRACE_FINAL", "IMPORT_BRACE_EMPTY", "EXPORT_BRACE_INITIAL", "EXPORT_BRACE_FINAL", "EXPORT_BRACE_EMPTY", "METHOD_BRACE_INTIAL", "METHOD_BRACE_FINAL", "METHOD_BRACE_EMPTY", "SET_BRACE_INTIIAL", "SET_BRACE_FINAL", "SET_BRACE_EMPTY", "SWITCH_BRACE_INTIAL", "SWITCH_BRACE_FINAL", "SWITCH_BRACE_EMPTY", "ARRAY_INITIAL", "ARRAY_FINAL", "COMPUTED_MEMBER_BRACKET_INTIAL", "COMPUTED_MEMBER_BRACKET_FINAL", "COMPUTED_PROPERTY_BRACKET_INTIAL", "COMPUTED_PROPERTY_BRACKET_FINAL"]; - for (var i = 0; i < separatorNames.length; ++i) { - Sep[separatorNames[i]] = { type: separatorNames[i] }; - } + // semigroup + _Tuple.prototype.concat = function(x) { + ensureConcat([this[0], this[1]]); + return Tuple(this[0].concat(x[0]), this[1].concat(x[1])); + }; - Sep.BEFORE_ASSIGN_OP = function (op) { - return { - type: "BEFORE_ASSIGN_OP", - op: op - }; + // functor + _Tuple.prototype.map = function(f) { + return Tuple(this[0], f(this[1])); }; - Sep.AFTER_ASSIGN_OP = function (op) { - return { - type: "AFTER_ASSIGN_OP", - op: op - }; + // apply + _Tuple.prototype.ap = function(m) { + ensureConcat([this[0]]); + return Tuple(this[0].concat(m[0]), this[1](m[1])); }; - Sep.BEFORE_BINOP = function (op) { - return { - type: "BEFORE_BINOP", - op: op - }; + // setoid + _Tuple.prototype.equals = function(that) { + return that instanceof _Tuple && R.equals(this[0], that[0]) && R.equals(this[1], that[1]); }; - Sep.AFTER_BINOP = function (op) { - return { - type: "AFTER_BINOP", - op: op - }; + _Tuple.prototype.toString = function() { + return 'Tuple(' + R.toString(this[0]) + ', ' + R.toString(this[1]) + ')'; }; - Sep.BEFORE_POSTFIX = function (op) { - return { - type: "BEFORE_POSTFIX", - op: op - }; + module.exports = Tuple; + + +/***/ }, +/* 35 */ +/***/ function(module, exports, __webpack_require__) { + + var R = __webpack_require__(26); + + + function Reader(run) { + if (!(this instanceof Reader)) { + return new Reader(run); + } + this.run = run; + } + + Reader.run = function(reader) { + return reader.run.apply(reader, [].slice.call(arguments, 1)); }; - Sep.UNARY = function (op) { - return { - type: "UNARY", - op: op - }; + Reader.prototype.chain = function(f) { + var reader = this; + return new Reader(function(r) { + return f(reader.run(r)).run(r); + }); }; - Sep.AFTER_STATEMENT = function (node) { - return { - type: "AFTER_STATEMENT", - node: node - }; + Reader.prototype.ap = function(a) { + return this.chain(function(f) { + return a.map(f); + }); }; - Sep.BEFORE_FUNCTION_NAME = function (node) { - return { - type: "BEFORE_FUNCTION_NAME", - node: node - }; + Reader.prototype.map = function(f) { + return this.chain(function(a) { + return Reader.of(f(a)); + }); }; - exports.Sep = Sep; - var ExtensibleCodeGen = exports.ExtensibleCodeGen = function () { - function ExtensibleCodeGen() { - _classCallCheck(this, ExtensibleCodeGen); - } + Reader.prototype.of = function(a) { + return new Reader(function() { + return a; + }); + }; + Reader.of = Reader.prototype.of; - _createClass(ExtensibleCodeGen, [{ - key: "parenToAvoidBeingDirective", - value: function parenToAvoidBeingDirective(element, original) { - if (element && element.type === "ExpressionStatement" && element.expression.type === "LiteralStringExpression") { - return seq(this.paren(original.children[0], Sep.PAREN_AVOIDING_DIRECTIVE_BEFORE, Sep.PAREN_AVOIDING_DIRECTIVE_AFTER), this.semiOp()); - } - return original; - } - }, { - key: "t", - value: function t(token) { - return new _coderep.Token(token); - } - }, { - key: "p", - value: function p(node, precedence, a) { - return (0, _coderep.getPrecedence)(node) < precedence ? this.paren(a, Sep.PRECEDENCE_BEFORE, Sep.PRECEDENCE_AFTER) : a; - } - }, { - key: "getAssignmentExpr", - value: function getAssignmentExpr(state) { - return state ? state.containsGroup ? this.paren(state, Sep.EXPRESSION_PAREN_BEFORE, Sep.EXPRESSION_PAREN_AFTER) : state : empty(); - } - }, { - key: "paren", - value: function paren(rep, first, last, empty) { - if (isEmpty(rep)) { - return new _coderep.Paren(this.sep(empty)); - } - return new _coderep.Paren(seq(first ? this.sep(first) : new _coderep.Empty(), rep, last ? this.sep(last) : new _coderep.Empty())); - } - }, { - key: "brace", - value: function brace(rep, node, first, last, empty) { - if (isEmpty(rep)) { - return new _coderep.Brace(this.sep(empty)); - } - return new _coderep.Brace(seq(this.sep(first), rep, this.sep(last))); - } - }, { - key: "bracket", - value: function bracket(rep, first, last, empty) { - if (isEmpty(rep)) { - return new _coderep.Bracket(this.sep(empty)); - } - return new _coderep.Bracket(seq(this.sep(first), rep, this.sep(last))); - } - }, { - key: "commaSep", - value: function commaSep(pieces, before, after) { - var _this = this; + Reader.ask = Reader(R.identity); - var first = true; - pieces = pieces.map(function (p) { - if (first) { - first = false; - return p; - } else { - return seq(_this.sep(before), _this.t(","), _this.sep(after), p); - } - }); - return seq.apply(undefined, _toConsumableArray(pieces)); - } - }, { - key: "semiOp", - value: function semiOp() { - return new _coderep.SemiOp(); - } - }, { - key: "sep", - value: function sep(kind) { - return new _coderep.Empty(); + Reader.prototype.toString = function() { + return 'Reader(' + R.toString(this.run) + ')'; + }; + + Reader.T = function(M) { + var ReaderT = function ReaderT(run) { + if (!(this instanceof ReaderT)) { + return new ReaderT(run); } - }, { - key: "reduceArrayExpression", - value: function reduceArrayExpression(node, _ref) { - var _this2 = this; + this.run = run; + }; - var elements = _ref.elements; + ReaderT.lift = R.compose(ReaderT, R.always); - if (elements.length === 0) { - return this.bracket(empty(), null, null, Sep.ARRAY_EMPTY); - } + ReaderT.ask = ReaderT(M.of); - var content = this.commaSep(elements.map(function (e) { - return _this2.getAssignmentExpr(e); - }), Sep.ARRAY_BEFORE_COMMA, Sep.ARRAY_AFTER_COMMA); - if (elements.length > 0 && elements[elements.length - 1] == null) { - content = seq(content, this.sep(Sep.ARRAY_BEFORE_COMMA), this.t(","), this.sep(Sep.ARRAY_AFTER_COMMA)); - } - return this.bracket(content, Sep.ARRAY_INITIAL, Sep.ARRAY_FINAL); - } - }, { - key: "reduceSpreadElement", - value: function reduceSpreadElement(node, _ref2) { - var expression = _ref2.expression; + ReaderT.prototype.of = ReaderT.of = function(a) { + return ReaderT(function() { + return M.of(a); + }); + }; - return seq(this.t("..."), this.sep(Sep.SPREAD), this.p(node.expression, _coderep.Precedence.Assignment, expression)); - } - }, { - key: "reduceAssignmentExpression", - value: function reduceAssignmentExpression(node, _ref3) { - var binding = _ref3.binding; - var expression = _ref3.expression; + ReaderT.prototype.chain = function(f) { + var readerT = this; + return ReaderT(function(e) { + var m = readerT.run(e); + return m.chain(function(a) { + return f(a).run(e); + }); + }); + }; - var leftCode = binding; - var rightCode = expression; - var containsIn = expression.containsIn; - var startsWithCurly = binding.startsWithCurly; - var startsWithLetSquareBracket = binding.startsWithLetSquareBracket; - var startsWithFunctionOrClass = binding.startsWithFunctionOrClass; - if ((0, _coderep.getPrecedence)(node.expression) < (0, _coderep.getPrecedence)(node)) { - rightCode = this.paren(rightCode, Sep.EXPRESSION_PAREN_BEFORE, Sep.EXPRESSION_PAREN_AFTER); - containsIn = false; - } - return (0, _objectAssign2.default)(seq(leftCode, this.sep(Sep.BEFORE_ASSIGN_OP("=")), this.t("="), this.sep(Sep.AFTER_ASSIGN_OP("=")), rightCode), { containsIn: containsIn, startsWithCurly: startsWithCurly, startsWithLetSquareBracket: startsWithLetSquareBracket, startsWithFunctionOrClass: startsWithFunctionOrClass }); - } - }, { - key: "reduceCompoundAssignmentExpression", - value: function reduceCompoundAssignmentExpression(node, _ref4) { - var binding = _ref4.binding; - var expression = _ref4.expression; + ReaderT.prototype.map = function(f) { + return this.chain(function(a) { + return ReaderT.of(f(a)); + }); + }; - var leftCode = binding; - var rightCode = expression; - var containsIn = expression.containsIn; - var startsWithCurly = binding.startsWithCurly; - var startsWithLetSquareBracket = binding.startsWithLetSquareBracket; - var startsWithFunctionOrClass = binding.startsWithFunctionOrClass; - if ((0, _coderep.getPrecedence)(node.expression) < (0, _coderep.getPrecedence)(node)) { - rightCode = this.paren(rightCode, Sep.EXPRESSION_PAREN_BEFORE, Sep.EXPRESSION_PAREN_AFTER); - containsIn = false; - } - return (0, _objectAssign2.default)(seq(leftCode, this.sep(Sep.BEFORE_ASSIGN_OP(node.operator)), this.t(node.operator), this.sep(Sep.AFTER_ASSIGN_OP(node.operator)), rightCode), { containsIn: containsIn, startsWithCurly: startsWithCurly, startsWithLetSquareBracket: startsWithLetSquareBracket, startsWithFunctionOrClass: startsWithFunctionOrClass }); - } - }, { - key: "reduceBinaryExpression", - value: function reduceBinaryExpression(node, _ref5) { - var left = _ref5.left; - var right = _ref5.right; + ReaderT.prototype.ap = function(a) { + var readerT = this; + return ReaderT(function(e) { + return readerT.run(e).ap(a.run(e)); + }); + }; - var leftCode = left; - var startsWithCurly = left.startsWithCurly; - var startsWithLetSquareBracket = left.startsWithLetSquareBracket; - var startsWithFunctionOrClass = left.startsWithFunctionOrClass; - var leftContainsIn = left.containsIn; - if ((0, _coderep.getPrecedence)(node.left) < (0, _coderep.getPrecedence)(node)) { - leftCode = this.paren(leftCode, Sep.EXPRESSION_PAREN_BEFORE, Sep.EXPRESSION_PAREN_AFTER); - startsWithCurly = false; - startsWithLetSquareBracket = false; - startsWithFunctionOrClass = false; - leftContainsIn = false; - } - var rightCode = right; - var rightContainsIn = right.containsIn; - if ((0, _coderep.getPrecedence)(node.right) <= (0, _coderep.getPrecedence)(node)) { - rightCode = this.paren(rightCode, Sep.EXPRESSION_PAREN_BEFORE, Sep.EXPRESSION_PAREN_AFTER); - rightContainsIn = false; - } - return (0, _objectAssign2.default)(seq(leftCode, this.sep(Sep.BEFORE_BINOP(node.operator)), this.t(node.operator), this.sep(Sep.AFTER_BINOP(node.operator)), rightCode), { - containsIn: leftContainsIn || rightContainsIn || node.operator === "in", - containsGroup: node.operator == ",", - startsWithCurly: startsWithCurly, - startsWithLetSquareBracket: startsWithLetSquareBracket, - startsWithFunctionOrClass: startsWithFunctionOrClass - }); - } - }, { - key: "reduceBindingWithDefault", - value: function reduceBindingWithDefault(node, _ref6) { - var binding = _ref6.binding; - var init = _ref6.init; + ReaderT.prototype.equals = function(that) { + return this === that || + this.run === that.run || + R.equals(this.run().get(), that.run().get()); + }; - return seq(binding, this.sep(Sep.BEFORE_DEFAULT_EQUALS), this.t("="), this.sep(Sep.AFTER_DEFAULT_EQUALS), init); - } - }, { - key: "reduceBindingIdentifier", - value: function reduceBindingIdentifier(node) { - var a = this.t(node.name); - if (node.name === "let") { - a.startsWithLet = true; - } - return a; - } - }, { - key: "reduceArrayBinding", - value: function reduceArrayBinding(node, _ref7) { - var _this3 = this; + ReaderT.prototype.toString = function() { + return 'ReaderT[' + M.name + '](' + R.toString(this.run) + ')'; + }; - var elements = _ref7.elements; - var restElement = _ref7.restElement; + return ReaderT; + }; - var content = undefined; - if (elements.length === 0) { - content = restElement == null ? empty() : seq(this.t("..."), this.sep(Sep.REST), restElement); - } else { - elements = elements.concat(restElement == null ? [] : [seq(this.t("..."), this.sep(Sep.REST), restElement)]); - content = this.commaSep(elements.map(function (e) { - return _this3.getAssignmentExpr(e); - }), Sep.ARRAY_BEFORE_COMMA, Sep.ARRAY_AFTER_COMMA); - if (elements.length > 0 && elements[elements.length - 1] == null) { - content = seq(content, this.sep(Sep.ARRAY_BEFORE_COMMA), this.t(","), this.sep(Sep.ARRAY_AFTER_COMMA)); - } - } - return this.bracket(content, Sep.ARRAY_INITIAL, Sep.ARRAY_FINAL, Sep.ARRAY_EMPTY); - } - }, { - key: "reduceObjectBinding", - value: function reduceObjectBinding(node, _ref8) { - var properties = _ref8.properties; + module.exports = Reader; - var state = this.brace(this.commaSep(properties, Sep.OBJECT_BEFORE_COMMA, Sep.OBJECT_AFTER_COMMA), node, Sep.OBJECT_BRACE_INITIAL, Sep.OBJECT_BRACE_FINAL, Sep.OBJECT_EMPTY); - state.startsWithCurly = true; - return state; - } - }, { - key: "reduceBindingPropertyIdentifier", - value: function reduceBindingPropertyIdentifier(node, _ref9) { - var binding = _ref9.binding; - var init = _ref9.init; - if (node.init == null) return binding; - return seq(binding, this.sep(Sep.BEFORE_DEFAULT_EQUALS), this.t("="), this.sep(Sep.AFTER_DEFAULT_EQUALS), init); - } - }, { - key: "reduceBindingPropertyProperty", - value: function reduceBindingPropertyProperty(node, _ref10) { - var name = _ref10.name; - var binding = _ref10.binding; +/***/ }, +/* 36 */ +/***/ function(module, exports, __webpack_require__) { - return seq(name, this.sep(Sep.BEFORE_PROP), this.t(":"), this.sep(Sep.AFTER_PROP), binding); - } - }, { - key: "reduceBlock", - value: function reduceBlock(node, _ref11) { - var statements = _ref11.statements; + "use strict"; - return this.brace(seq.apply(undefined, _toConsumableArray(statements)), node, Sep.BLOCK_BRACE_INITIAL, Sep.BLOCK_BRACE_FINAL, Sep.BLOCK_EMPTY); - } - }, { - key: "reduceBlockStatement", - value: function reduceBlockStatement(node, _ref12) { - var block = _ref12.block; + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.Modules = exports.Module = undefined; - return seq(block, this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceBreakStatement", - value: function reduceBreakStatement(node, _ref13) { - var label = _ref13.label; + var _immutable = __webpack_require__(3); - return seq(this.t("break"), label ? seq(this.sep(Sep.BEFORE_JUMP_LABEL), this.t(label)) : empty(), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceCallExpression", - value: function reduceCallExpression(node, _ref14) { - var callee = _ref14.callee; - var args = _ref14.arguments; + var _env = __webpack_require__(37); - return (0, _objectAssign2.default)(seq(this.p(node.callee, (0, _coderep.getPrecedence)(node), callee), this.sep(Sep.CALL), this.paren(this.commaSep(args, Sep.ARGS_BEFORE_COMMA, Sep.ARGS_AFTER_COMMA), Sep.CALL_PAREN_BEFORE, Sep.CALL_PAREN_AFTER, Sep.CALL_PAREN_EMPTY)), { - startsWithCurly: callee.startsWithCurly, - startsWithLetSquareBracket: callee.startsWithLetSquareBracket, - startsWithFunctionOrClass: callee.startsWithFunctionOrClass - }); - } - }, { - key: "reduceCatchClause", - value: function reduceCatchClause(node, _ref15) { - var binding = _ref15.binding; - var body = _ref15.body; + var _env2 = _interopRequireDefault(_env); - return seq(this.t("catch"), this.sep(Sep.BEFORE_CATCH_BINDING), this.paren(binding, Sep.CATCH_PAREN_BEFORE, Sep.CATCH_PAREN_AFTER), this.sep(Sep.AFTER_CATCH_BINDING), body); - } - }, { - key: "reduceClassDeclaration", - value: function reduceClassDeclaration(node, _ref16) { - var name = _ref16.name; - var _super = _ref16.super; - var elements = _ref16.elements; + var _store = __webpack_require__(39); - var state = seq(this.t("class"), this.sep(Sep.BEFORE_CLASS_NAME), name); - if (_super != null) { - state = seq(state, this.sep(Sep.BEFORE_EXTENDS), this.t("extends"), this.sep(Sep.AFTER_EXTENDS), _super); - } - state = seq(state, this.sep(Sep.BEFORE_CLASS_DECLARATION_ELEMENTS), this.brace(seq.apply(undefined, _toConsumableArray(elements)), node, Sep.CLASS_BRACE_INITIAL, Sep.CLASS_BRACE_FINAL, Sep.CLASS_EMPTY), this.sep(Sep.AFTER_STATEMENT(node))); - return state; - } - }, { - key: "reduceClassExpression", - value: function reduceClassExpression(node, _ref17) { - var name = _ref17.name; - var _super = _ref17.super; - var elements = _ref17.elements; + var _store2 = _interopRequireDefault(_store); - var state = this.t("class"); - if (name != null) { - state = seq(state, this.sep(Sep.BEFORE_CLASS_NAME), name); - } - if (_super != null) { - state = seq(state, this.sep(Sep.BEFORE_EXTENDS), this.t("extends"), this.sep(Sep.AFTER_EXTENDS), _super); - } - state = seq(state, this.sep(Sep.BEFORE_CLASS_EXPRESSION_ELEMENTS), this.brace(seq.apply(undefined, _toConsumableArray(elements)), node, Sep.CLASS_EXPRESSION_BRACE_INITIAL, Sep.CLASS_EXPRESSION_BRACE_FINAL, Sep.CLASS_EXPRESSION_BRACE_EMPTY)); - state.startsWithFunctionOrClass = true; - return state; - } - }, { - key: "reduceClassElement", - value: function reduceClassElement(node, _ref18) { - var method = _ref18.method; + var _shiftReader = __webpack_require__(42); - method = seq(this.sep(Sep.BEFORE_CLASS_ELEMENT), method, this.sep(Sep.AFTER_CLASS_ELEMENT)); - if (!node.isStatic) return method; - return seq(this.t("static"), this.sep(Sep.AFTER_STATIC), method); - } - }, { - key: "reduceComputedMemberExpression", - value: function reduceComputedMemberExpression(node, _ref19) { - var object = _ref19.object; - var expression = _ref19.expression; + var _shiftReader2 = _interopRequireDefault(_shiftReader); - var startsWithLetSquareBracket = object.startsWithLetSquareBracket || node.object.type === "IdentifierExpression" && node.object.name === "let"; - return (0, _objectAssign2.default)(seq(this.p(node.object, (0, _coderep.getPrecedence)(node), object), this.sep(Sep.COMPUTED_MEMBER_EXPRESSION), this.bracket(expression, Sep.COMPUTED_MEMBER_BRACKET_INTIAL, Sep.COMPUTED_MEMBER_BRACKET_FINAL)), { - startsWithLet: object.startsWithLet, - startsWithLetSquareBracket: startsWithLetSquareBracket, - startsWithCurly: object.startsWithCurly, - startsWithFunctionOrClass: object.startsWithFunctionOrClass - }); - } - }, { - key: "reduceComputedPropertyName", - value: function reduceComputedPropertyName(node, _ref20) { - var expression = _ref20.expression; + var _ramda = __webpack_require__(10); - return this.bracket(expression, Sep.COMPUTED_PROPERTY_BRACKET_INTIAL, Sep.COMPUTED_PROPERTY_BRACKET_FINAL); - } - }, { - key: "reduceConditionalExpression", - value: function reduceConditionalExpression(node, _ref21) { - var test = _ref21.test; - var consequent = _ref21.consequent; - var alternate = _ref21.alternate; + var _ = _interopRequireWildcard(_ramda); - var containsIn = test.containsIn || alternate.containsIn; - var startsWithCurly = test.startsWithCurly; - var startsWithLetSquareBracket = test.startsWithLetSquareBracket; - var startsWithFunctionOrClass = test.startsWithFunctionOrClass; - return (0, _objectAssign2.default)(seq(this.p(node.test, _coderep.Precedence.LogicalOR, test), this.sep(Sep.BEFORE_TERNARY_QUESTION), this.t("?"), this.sep(Sep.AFTER_TERNARY_QUESTION), this.p(node.consequent, _coderep.Precedence.Assignment, consequent), this.sep(Sep.BEFORE_TERNARY_COLON), this.t(":"), this.sep(Sep.AFTER_TERNARY_COLON), this.p(node.alternate, _coderep.Precedence.Assignment, alternate)), { - containsIn: containsIn, - startsWithCurly: startsWithCurly, - startsWithLetSquareBracket: startsWithLetSquareBracket, - startsWithFunctionOrClass: startsWithFunctionOrClass - }); - } - }, { - key: "reduceContinueStatement", - value: function reduceContinueStatement(node, _ref22) { - var label = _ref22.label; + var _symbol = __webpack_require__(47); - return seq(this.t("continue"), label ? seq(this.sep(Sep.BEFORE_JUMP_LABEL), this.t(label)) : empty(), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceDataProperty", - value: function reduceDataProperty(node, _ref23) { - var name = _ref23.name; - var expression = _ref23.expression; + var _terms = __webpack_require__(9); - return seq(name, this.sep(Sep.BEFORE_PROP), this.t(":"), this.sep(Sep.AFTER_PROP), this.getAssignmentExpr(expression)); - } - }, { - key: "reduceDebuggerStatement", - value: function reduceDebuggerStatement(node) { - return seq(this.t("debugger"), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceDoWhileStatement", - value: function reduceDoWhileStatement(node, _ref24) { - var body = _ref24.body; - var test = _ref24.test; + var T = _interopRequireWildcard(_terms); - return seq(this.t("do"), this.sep(Sep.AFTER_DO), body, this.sep(Sep.BEFORE_DOWHILE_WHILE), this.t("while"), this.sep(Sep.AFTER_DOWHILE_WHILE), this.paren(test, Sep.DO_WHILE_TEST_PAREN_BEFORE, Sep.DO_WHILE_TEST_PAREN_AFTER), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceEmptyStatement", - value: function reduceEmptyStatement(node) { - return seq(this.t(";"), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceExpressionStatement", - value: function reduceExpressionStatement(node, _ref25) { - var expression = _ref25.expression; + var _loadSyntax = __webpack_require__(48); - var needsParens = expression.startsWithCurly || expression.startsWithLetSquareBracket || expression.startsWithFunctionOrClass; - return seq(needsParens ? this.paren(expression, Sep.EXPRESSION_STATEMENT_PAREN_BEFORE, Sep.EXPRESSION_STATEMENT_PAREN_AFTER) : expression, this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceForInStatement", - value: function reduceForInStatement(node, _ref26) { - var left = _ref26.left; - var right = _ref26.right; - var body = _ref26.body; + var _compiler = __webpack_require__(60); - var leftP = left; - switch (node.left.type) { - case "VariableDeclaration": - leftP = noIn(markContainsIn(left)); - break; - case "BindingIdentifier": - if (node.left.name === "let") { - leftP = this.paren(left, Sep.FOR_IN_LET_PAREN_BEFORE, Sep.FOR_IN_LET_PAREN_BEFORE); - } - break; - } - return (0, _objectAssign2.default)(seq(this.t("for"), this.sep(Sep.AFTER_FORIN_FOR), this.paren(seq(leftP, this.sep(Sep.BEFORE_FORIN_IN), this.t("in"), this.sep(Sep.AFTER_FORIN_FOR), right), Sep.FOR_IN_PAREN_BEFORE, Sep.FOR_IN_PAREN_AFTER), this.sep(Sep.BEFORE_FORIN_BODY), body, this.sep(Sep.AFTER_STATEMENT(node))), { endsWithMissingElse: body.endsWithMissingElse }); - } - }, { - key: "reduceForOfStatement", - value: function reduceForOfStatement(node, _ref27) { - var left = _ref27.left; - var right = _ref27.right; - var body = _ref27.body; + var _compiler2 = _interopRequireDefault(_compiler); - left = node.left.type === "VariableDeclaration" ? noIn(markContainsIn(left)) : left; - return (0, _objectAssign2.default)(seq(this.t("for"), this.sep(Sep.AFTER_FOROF_FOR), this.paren(seq(left.startsWithLet ? this.paren(left, Sep.FOR_OF_LET_PAREN_BEFORE, Sep.FOR_OF_LET_PAREN_AFTER) : left, this.sep(Sep.BEFORE_FOROF_OF), this.t("of"), this.sep(Sep.AFTER_FOROF_FOR), right), Sep.FOR_OF_PAREN_BEFORE, Sep.FOR_OF_PAREN_AFTER), this.sep(Sep.BEFORE_FOROF_BODY), body, this.sep(Sep.AFTER_STATEMENT(node))), { endsWithMissingElse: body.endsWithMissingElse }); - } - }, { - key: "reduceForStatement", - value: function reduceForStatement(node, _ref28) { - var init = _ref28.init; - var test = _ref28.test; - var update = _ref28.update; - var body = _ref28.body; + var _transforms = __webpack_require__(38); - return (0, _objectAssign2.default)(seq(this.t("for"), this.sep(Sep.AFTER_FOR_FOR), this.paren(seq(init ? seq(this.sep(Sep.BEFORE_FOR_INIT), noIn(markContainsIn(init)), this.sep(Sep.AFTER_FOR_INIT)) : this.sep(Sep.EMPTY_FOR_INIT), this.t(";"), test ? seq(this.sep(Sep.BEFORE_FOR_TEST), test, this.sep(Sep.AFTER_FOR_TEST)) : this.sep(Sep.EMPTY_FOR_TEST), this.t(";"), update ? seq(this.sep(Sep.BEFORE_FOR_UPDATE), update, this.sep(Sep.AFTER_FOR_UPDATE)) : this.sep(Sep.EMPTY_FOR_UPDATE))), this.sep(Sep.BEFORE_FOR_BODY), body, this.sep(Sep.AFTER_STATEMENT(node))), { - endsWithMissingElse: body.endsWithMissingElse - }); - } - }, { - key: "reduceFunctionBody", - value: function reduceFunctionBody(node, _ref29) { - var directives = _ref29.directives; - var statements = _ref29.statements; + var _scope = __webpack_require__(58); - if (statements.length) { - statements[0] = this.parenToAvoidBeingDirective(node.statements[0], statements[0]); - } - return seq.apply(undefined, _toConsumableArray(directives).concat([directives.length ? this.sep(Sep.AFTER_FUNCTION_DIRECTIVES) : empty()], _toConsumableArray(statements))); - } - }, { - key: "reduceFunctionDeclaration", - value: function reduceFunctionDeclaration(node, _ref30) { - var name = _ref30.name; - var params = _ref30.params; - var body = _ref30.body; + var _errors = __webpack_require__(23); - return seq(this.t("function"), node.isGenerator ? seq(this.sep(Sep.BEFORE_GENERATOR_STAR), this.t("*"), this.sep(Sep.AFTER_GENERATOR_STAR)) : empty(), this.sep(Sep.BEFORE_FUNCTION_NAME(node)), node.name.name === "*default*" ? empty() : name, this.sep(Sep.BEFORE_FUNCTION_PARAMS), this.paren(params, Sep.PARAMETERS_PAREN_BEFORE, Sep.PARAMETERS_PAREN_AFTER, Sep.PARAMETERS_PAREN_EMPTY), this.sep(Sep.BEFORE_FUNCTION_DECLARATION_BODY), this.brace(body, node, Sep.FUNCTION_BRACE_INITIAL, Sep.FUNCTION_BRACE_FINAL, Sep.FUNCTION_EMPTY), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceFunctionExpression", - value: function reduceFunctionExpression(node, _ref31) { - var name = _ref31.name; - var params = _ref31.params; - var body = _ref31.body; + var _hygieneUtils = __webpack_require__(65); - var state = seq(this.t("function"), node.isGenerator ? seq(this.sep(Sep.BEFORE_GENERATOR_STAR), this.t("*"), this.sep(Sep.AFTER_GENERATOR_STAR)) : empty(), this.sep(Sep.BEFORE_FUNCTION_NAME(node)), name ? name : empty(), this.sep(Sep.BEFORE_FUNCTION_PARAMS), this.paren(params, Sep.PARAMETERS_PAREN_BEFORE, Sep.PARAMETERS_PAREN_AFTER, Sep.PARAMETERS_PAREN_EMPTY), this.sep(Sep.BEFORE_FUNCTION_EXPRESSION_BODY), this.brace(body, node, Sep.FUNCTION_EXPRESSION_BRACE_INITIAL, Sep.FUNCTION_EXPRESSION_BRACE_FINAL, Sep.FUNCTION_EXPRESSION_EMPTY)); - state.startsWithFunctionOrClass = true; - return state; - } - }, { - key: "reduceFormalParameters", - value: function reduceFormalParameters(node, _ref32) { - var items = _ref32.items; - var rest = _ref32.rest; + var _syntax = __webpack_require__(46); - return this.commaSep(items.concat(rest == null ? [] : [seq(this.t("..."), this.sep(Sep.REST), rest)]), Sep.PARAMETER_BEFORE_COMMA, Sep.PARAMETER_AFTER_COMMA); - } - }, { - key: "reduceArrowExpression", - value: function reduceArrowExpression(node, _ref33) { - var params = _ref33.params; - var body = _ref33.body; + var _utilsDirname = __webpack_require__(66); - if (node.params.rest != null || node.params.items.length !== 1 || node.params.items[0].type !== "BindingIdentifier") { - params = this.paren(params, Sep.ARROW_PARAMETERS_PAREN_BEFORE, Sep.ARROW_PARAMETERS_PAREN_AFTER, Sep.ARROW_PARAMETERS_PAREN_EMPTY); - } - if (node.body.type === "FunctionBody") { - body = this.brace(body, node, Sep.ARROW_BRACE_INITIAL, Sep.ARROW_BRACE_FINAL, Sep.ARROW_BRACE_EMPTY); - } else if (body.startsWithCurly) { - body = this.paren(body, Sep.ARROW_BODY_PAREN_BEFORE, Sep.ARROW_BODY_PAREN_AFTER); - } - return seq(params, this.sep(Sep.BEFORE_ARROW), this.t("=>"), this.sep(Sep.AFTER_ARROW), this.p(node.body, _coderep.Precedence.Assignment, body)); - } - }, { - key: "reduceGetter", - value: function reduceGetter(node, _ref34) { - var name = _ref34.name; - var body = _ref34.body; + var _utilsDirname2 = _interopRequireDefault(_utilsDirname); - return seq(this.t("get"), this.sep(Sep.AFTER_GET), name, this.sep(Sep.BEFORE_GET_PARAMS), this.paren(empty(), null, null, Sep.GETTER_PARAMS), this.sep(Sep.BEFORE_GET_BODY), this.brace(body, node, Sep.GET_BRACE_INTIAL, Sep.GET_BRACE_FINAL, Sep.GET_BRACE_EMPTY)); - } - }, { - key: "reduceIdentifierExpression", - value: function reduceIdentifierExpression(node) { - var a = this.t(node.name); - if (node.name === "let") { - a.startsWithLet = true; - } - return a; - } - }, { - key: "reduceIfStatement", - value: function reduceIfStatement(node, _ref35) { - var test = _ref35.test; - var consequent = _ref35.consequent; - var alternate = _ref35.alternate; + function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } - if (alternate && consequent.endsWithMissingElse) { - consequent = this.brace(consequent, node, Sep.MISSING_ELSE_INTIIAL, Sep.MISSING_ELSE_FINAL, Sep.MISSING_ELSE_EMPTY); - } - return (0, _objectAssign2.default)(seq(this.t("if"), this.sep(Sep.AFTER_IF), this.paren(test, Sep.IF_PAREN_BEFORE, Sep.IF_PAREN_AFTER), this.sep(Sep.AFTER_IF_TEST), consequent, alternate ? seq(this.sep(Sep.BEFORE_ELSE), this.t("else"), this.sep(Sep.AFTER_ELSE), alternate) : empty(), this.sep(Sep.AFTER_STATEMENT(node))), { endsWithMissingElse: alternate ? alternate.endsWithMissingElse : true }); - } - }, { - key: "reduceImport", - value: function reduceImport(node, _ref36) { - var defaultBinding = _ref36.defaultBinding; - var namedImports = _ref36.namedImports; + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - var bindings = []; - if (defaultBinding != null) { - bindings.push(defaultBinding); - } - if (namedImports.length > 0) { - bindings.push(this.brace(this.commaSep(namedImports, Sep.NAMED_IMPORT_BEFORE_COMMA, Sep.NAMED_IMPORT_AFTER_COMMA), node, Sep.IMPORT_BRACE_INTIAL, Sep.IMPORT_BRACE_FINAL, Sep.IMPORT_BRACE_EMPTY)); - } - if (bindings.length === 0) { - return seq(this.t("import"), this.sep(Sep.BEFORE_IMPORT_MODULE), this.t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - return seq(this.t("import"), this.sep(Sep.BEFORE_IMPORT_BINDINGS), this.commaSep(bindings, Sep.IMPORT_BEFORE_COMMA, Sep.IMPORT_AFTER_COMMA), this.sep(Sep.AFTER_IMPORT_BINDINGS), this.t("from"), this.sep(Sep.AFTER_FROM), this.t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceImportNamespace", - value: function reduceImportNamespace(node, _ref37) { - var defaultBinding = _ref37.defaultBinding; - var namespaceBinding = _ref37.namespaceBinding; + class Module { + constructor(moduleSpecifier, isNative, importEntries, exportEntries, pragmas, body) { + this.moduleSpecifier = moduleSpecifier; + this.isNative = isNative; + this.importEntries = importEntries; + this.exportEntries = exportEntries; + this.pragmas = pragmas; + this.body = body; + } + } - return seq(this.t("import"), this.sep(Sep.BEFORE_IMPORT_NAMESPACE), defaultBinding == null ? empty() : seq(defaultBinding, this.sep(Sep.IMPORT_BEFORE_COMMA), this.t(","), this.sep(Sep.IMPORT_AFTER_COMMA)), this.sep(Sep.BEFORE_IMPORT_STAR), this.t("*"), this.sep(Sep.AFTER_IMPORT_STAR), this.t("as"), this.sep(Sep.AFTER_IMPORT_AS), namespaceBinding, this.sep(Sep.AFTER_NAMESPACE_BINDING), this.t("from"), this.sep(Sep.AFTER_FROM), this.t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceImportSpecifier", - value: function reduceImportSpecifier(node, _ref38) { - var binding = _ref38.binding; + exports.Module = Module; + const findBindingIdentifierName = term => { + // TODO: handle destructuring + (0, _errors.assert)(term.name, `not implemented yet for type ${ term.type }`); + return term.name; + }; - if (node.name == null) return binding; - return seq(this.t(node.name), this.sep(Sep.BEFORE_IMPORT_AS), this.t("as"), this.sep(Sep.AFTER_IMPORT_AS), binding); - } - }, { - key: "reduceExportAllFrom", - value: function reduceExportAllFrom(node) { - return seq(this.t("export"), this.sep(Sep.BEFORE_EXPORT_STAR), this.t("*"), this.sep(Sep.AFTER_EXPORT_STAR), this.t("from"), this.sep(Sep.AFTER_FROM), this.t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceExportFrom", - value: function reduceExportFrom(node, _ref39) { - var namedExports = _ref39.namedExports; + const convertExport = term => { + let declaration = term.declaration; + let bindings = []; + if (T.isVariableDeclaration(declaration)) { + bindings = declaration.declarators.map(decl => findBindingIdentifierName(decl.binding)); + } else if (T.isFunctionDeclaration(declaration) || T.isClassDeclaration(declaration)) { + bindings.push(findBindingIdentifierName(declaration.name)); + } - return seq(this.t("export"), this.sep(Sep.BEFORE_EXPORT_BINDINGS), this.brace(this.commaSep(namedExports, Sep.EXPORTS_BEFORE_COMMA, Sep.EXPORTS_AFTER_COMMA), node, Sep.EXPORT_BRACE_INITIAL, Sep.EXPORT_BRACE_FINAL, Sep.EXPORT_BRACE_EMPTY), node.moduleSpecifier == null ? empty() : seq(this.sep(Sep.AFTER_EXPORT_BINDINGS), this.t("from"), this.sep(Sep.AFTER_FROM), this.t((0, _coderep.escapeStringLiteral)(node.moduleSpecifier)), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node)))); - } - }, { - key: "reduceExport", - value: function reduceExport(node, _ref40) { - var declaration = _ref40.declaration; + let namedExports = bindings.map(binding => { + return new T.default('ExportSpecifier', { + name: null, + exportedName: binding + }); + }); + return new T.default('ExportFrom', { + moduleSpecifier: null, + namedExports: (0, _immutable.List)(namedExports) + }); + }; - switch (node.declaration.type) { - case "FunctionDeclaration": - case "ClassDeclaration": - break; - default: - declaration = seq(declaration, this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - return seq(this.t("export"), this.sep(Sep.AFTER_EXPORT), declaration); - } - }, { - key: "reduceExportDefault", - value: function reduceExportDefault(node, _ref41) { - var body = _ref41.body; + const pragmaRegep = /^\s*#\w*/; - body = body.startsWithFunctionOrClass ? this.paren(body, Sep.EXPORT_PAREN_BEFORE, Sep.EXPORT_PAREN_AFTER) : body; - switch (node.body.type) { - case "FunctionDeclaration": - case "ClassDeclaration": - break; - default: - body = seq(body, this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - return seq(this.t("export"), this.sep(Sep.EXPORT_DEFAULT), this.t("default"), this.sep(Sep.AFTER_EXPORT_DEFAULT), body); - } - }, { - key: "reduceExportSpecifier", - value: function reduceExportSpecifier(node) { - if (node.name == null) return this.t(node.exportedName); - return seq(this.t(node.name), this.sep(Sep.BEFORE_EXPORT_AS), this.t("as"), this.sep(Sep.AFTER_EXPORT_AS), this.t(node.exportedName)); - } - }, { - key: "reduceLabeledStatement", - value: function reduceLabeledStatement(node, _ref42) { - var label = _ref42.label; - var body = _ref42.body; + class Modules { + constructor(context) { + this.compiledModules = new Map(); + this.context = context; + this.context.modules = this; + } - return (0, _objectAssign2.default)(seq(this.t(label), this.sep(Sep.BEFORE_LABEL_COLON), this.t(":"), this.sep(Sep.AFTER_LABEL_COLON), body), { endsWithMissingElse: body.endsWithMissingElse }); - } - }, { - key: "reduceLiteralBooleanExpression", - value: function reduceLiteralBooleanExpression(node) { - return this.t(node.value.toString()); - } - }, { - key: "reduceLiteralNullExpression", - value: function reduceLiteralNullExpression(node) { - return this.t("null"); - } - }, { - key: "reduceLiteralInfinityExpression", - value: function reduceLiteralInfinityExpression(node) { - return this.t("2e308"); - } - }, { - key: "reduceLiteralNumericExpression", - value: function reduceLiteralNumericExpression(node) { - return new _coderep.NumberCodeRep(node.value); - } - }, { - key: "reduceLiteralRegExpExpression", - value: function reduceLiteralRegExpExpression(node) { - return this.t("/" + node.pattern + "/" + node.flags); - } - }, { - key: "reduceLiteralStringExpression", - value: function reduceLiteralStringExpression(node) { - return this.t((0, _coderep.escapeStringLiteral)(node.value)); - } - }, { - key: "reduceMethod", - value: function reduceMethod(node, _ref43) { - var name = _ref43.name; - var params = _ref43.params; - var body = _ref43.body; + loadString(str) { + let checkPragma = arguments.length <= 1 || arguments[1] === undefined ? true : arguments[1]; - return seq(node.isGenerator ? seq(this.t("*"), this.sep(Sep.AFTER_METHOD_GENERATOR_STAR)) : empty(), name, this.sep(Sep.AFTER_METHOD_NAME), this.paren(params, Sep.PARAMETERS_PAREN_BEFORE, Sep.PARAMETERS_PAREN_AFTER, Sep.PARAMETERS_PAREN_EMPTY), this.sep(Sep.BEFORE_METHOD_BODY), this.brace(body, node, Sep.METHOD_BRACE_INTIAL, Sep.METHOD_BRACE_FINAL, Sep.METHOD_BRACE_EMPTY)); + let hasPragma = pragmaRegep.test(str); + if (checkPragma && !hasPragma) { + return { + isNative: true, + body: (0, _immutable.List)() + }; } - }, { - key: "reduceModule", - value: function reduceModule(node, _ref44) { - var directives = _ref44.directives; - var items = _ref44.items; + return { + isNative: !hasPragma, + body: new _shiftReader2.default(str).read() + }; + } - if (items.length) { - items[0] = this.parenToAvoidBeingDirective(node.items[0], items[0]); - } - return seq.apply(undefined, _toConsumableArray(directives).concat([directives.length ? this.sep(Sep.AFTER_MODULE_DIRECTIVES) : empty()], _toConsumableArray(items))); - } - }, { - key: "reduceNewExpression", - value: function reduceNewExpression(node, _ref45) { - var callee = _ref45.callee; - var args = _ref45.arguments; + load(path) { + // TODO resolve and we need to carry the cwd through correctly + return this.loadString(this.context.moduleLoader(path)); + } - var calleeRep = (0, _coderep.getPrecedence)(node.callee) == _coderep.Precedence.Call ? this.paren(callee, Sep.NEW_CALLEE_PAREN_BEFORE, Sep.NEW_CALLEE_PAREN_AFTER) : this.p(node.callee, (0, _coderep.getPrecedence)(node), callee); - return seq(this.t("new"), this.sep(Sep.AFTER_NEW), calleeRep, args.length === 0 ? this.sep(Sep.EMPTY_NEW_CALL) : seq(this.sep(Sep.BEFORE_NEW_ARGS), this.paren(this.commaSep(args, Sep.ARGS_BEFORE_COMMA, Sep.ARGS_AFTER_COMMA), Sep.NEW_PAREN_BEFORE, Sep.NEW_PAREN_AFTER, Sep.NEW_PAREN_EMPTY))); - } - }, { - key: "reduceNewTargetExpression", - value: function reduceNewTargetExpression() { - return seq(this.t("new"), this.sep(Sep.NEW_TARGET_BEFORE_DOT), this.t("."), this.sep(Sep.NEW_TARGET_AFTER_DOT), this.t("target")); - } - }, { - key: "reduceObjectExpression", - value: function reduceObjectExpression(node, _ref46) { - var properties = _ref46.properties; + compile(mod, path) { + let stxl = mod.body; + let outScope = (0, _scope.freshScope)('outsideEdge'); + let inScope = (0, _scope.freshScope)(`insideEdge0`); + // the compiler starts at phase 0, with an empty environment and store + let compiler = new _compiler2.default(0, new _env2.default(), new _store2.default(), _.merge(this.context, { + currentScope: [outScope, inScope], + cwd: path === '<>' ? this.context.cwd : (0, _utilsDirname2.default)(path) + })); + let terms = compiler.compile(stxl.map(s => s.addScope(outScope, this.context.bindings, _syntax.ALL_PHASES).addScope(inScope, this.context.bindings, 0))); + + let importEntries = []; + let exportEntries = []; + let pragmas = []; + let filteredTerms = terms.reduce((acc, t) => { + return _.cond([[T.isImport, t => { + importEntries.push(t); + return acc; + }], [T.isExport, t => { + // exportEntries.push(t); + // return acc.concat(t); + if (t.declaration) { + exportEntries.push(convertExport(t)); + if (T.isVariableDeclaration(t.declaration)) { + return acc.concat(new T.default('VariableDeclarationStatement', { + declaration: t.declaration + })); + } + return acc.concat(t.declaration); + } + exportEntries.push(t); + return acc; + }], [T.isPragma, t => { + pragmas.push(t);return acc; + }], [_.T, t => acc.concat(t)]])(t); + }, (0, _immutable.List)()); + return new Module(path, mod.isNative, (0, _immutable.List)(importEntries), (0, _immutable.List)(exportEntries), (0, _immutable.List)(pragmas), filteredTerms); + } - var state = this.brace(this.commaSep(properties, Sep.OBJECT_BEFORE_COMMA, Sep.OBJECT_AFTER_COMMA), node, Sep.OBJECT_BRACE_INITIAL, Sep.OBJECT_BRACE_FINAL, Sep.OBJECT_EMPTY); - state.startsWithCurly = true; - return state; + compileEntrypoint(source, filename) { + let enforcePragma = arguments.length <= 2 || arguments[2] === undefined ? false : arguments[2]; + + let stxl = this.loadString(source, false); + if (enforcePragma && stxl.isNative) { + throw new Error(`Entrypoint ${ filename } must begin with #lang pragma`); } - }, { - key: "reduceUpdateExpression", - value: function reduceUpdateExpression(node, _ref47) { - var operand = _ref47.operand; + return this.getAtPhase('<>', 0, this.context.cwd, stxl); + } - if (node.isPrefix) { - return this.reduceUnaryExpression.apply(this, arguments); + // Modules have a unique scope per-phase. We compile each module once at + // phase 0 and store the compiled module in a map. Then, as we ask for + // the module in a particular phase, we add that new phase-specific scope + // to the compiled module and update the map with the module at that specific + // phase. + getAtPhase(rawPath, phase, cwd) { + let rawStxl = arguments.length <= 3 || arguments[3] === undefined ? null : arguments[3]; + + let path = rawPath === '<>' ? rawPath : this.context.moduleResolver(rawPath, cwd); + let mapKey = `${ path }:${ phase }`; + if (!this.compiledModules.has(mapKey)) { + if (phase === 0) { + let stxl = rawStxl != null ? rawStxl : this.load(path); + this.compiledModules.set(mapKey, this.compile(stxl, path)); } else { - return (0, _objectAssign2.default)(seq(this.p(node.operand, _coderep.Precedence.New, operand), this.sep(Sep.BEFORE_POSTFIX(node.operator)), this.t(node.operator)), { - startsWithCurly: operand.startsWithCurly, - startsWithLetSquareBracket: operand.startsWithLetSquareBracket, - startsWithFunctionOrClass: operand.startsWithFunctionOrClass - }); + let rawMod = this.getAtPhase(rawPath, 0, cwd, rawStxl); + let scope = (0, _scope.freshScope)(`insideEdge${ phase }`); + this.compiledModules.set(mapKey, new Module(rawMod.moduleSpecifier, false, rawMod.importEntries.map(term => term.addScope(scope, this.context.bindings, phase)), rawMod.exportEntries.map(term => term.addScope(scope, this.context.bindings, phase)), rawMod.pragmas, rawMod.body.map(term => term.addScope(scope, this.context.bindings, phase)))); } } - }, { - key: "reduceUnaryExpression", - value: function reduceUnaryExpression(node, _ref48) { - var operand = _ref48.operand; + return this.compiledModules.get(mapKey); + } - return seq(this.t(node.operator), this.sep(Sep.UNARY(node.operator)), this.p(node.operand, (0, _coderep.getPrecedence)(node), operand)); - } - }, { - key: "reduceReturnStatement", - value: function reduceReturnStatement(node, _ref49) { - var expression = _ref49.expression; + has(rawPath) { + let phase = arguments.length <= 1 || arguments[1] === undefined ? 0 : arguments[1]; - return seq(this.t("return"), expression ? seq(this.sep(Sep.RETURN), expression) : empty(), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceScript", - value: function reduceScript(node, _ref50) { - var directives = _ref50.directives; - var statements = _ref50.statements; + let path = rawPath === '<>' ? rawPath : this.context.moduleResolver(rawPath, this.context.cwd); + let key = `${ path }:${ phase }`; + return this.compiledModules.has(key) && !this.compiledModules.get(key).isNative; + } - if (statements.length) { - statements[0] = this.parenToAvoidBeingDirective(node.statements[0], statements[0]); - } - return seq.apply(undefined, _toConsumableArray(directives).concat([directives.length ? this.sep(Sep.AFTER_SCRIPT_DIRECTIVES) : empty()], _toConsumableArray(statements))); - } - }, { - key: "reduceSetter", - value: function reduceSetter(node, _ref51) { - var name = _ref51.name; - var param = _ref51.param; - var body = _ref51.body; + registerSyntaxDeclaration(term, phase, store) { + term.declarators.forEach(decl => { + let val = (0, _loadSyntax.evalCompiletimeValue)(decl.init.gen(), _.merge(this.context, { + phase: phase + 1, store: store + })); + (0, _hygieneUtils.collectBindings)(decl.binding).forEach(stx => { + if (phase !== 0) { + // phase 0 bindings extend the binding map during compilation + let newBinding = (0, _symbol.gensym)(stx.val()); + this.context.bindings.add(stx, { + binding: newBinding, + phase: phase, + skipDup: false + }); + } + let resolvedName = stx.resolve(phase); + store.set(resolvedName, new _transforms.CompiletimeTransform(val)); + }); + }); + } - return seq(this.t("set"), this.sep(Sep.AFTER_SET), name, this.sep(Sep.BEFORE_SET_PARAMS), this.paren(param, Sep.SETTER_PARAM_BEFORE, Sep.SETTER_PARAM_AFTER), this.sep(Sep.BEFORE_SET_BODY), this.brace(body, node, Sep.SET_BRACE_INTIIAL, Sep.SET_BRACE_FINAL, Sep.SET_BRACE_EMPTY)); - } - }, { - key: "reduceShorthandProperty", - value: function reduceShorthandProperty(node) { - return this.t(node.name); - } - }, { - key: "reduceStaticMemberExpression", - value: function reduceStaticMemberExpression(node, _ref52) { - var object = _ref52.object; - var property = _ref52.property; + registerVariableDeclaration(term, phase, store) { + term.declarators.forEach(decl => { + (0, _hygieneUtils.collectBindings)(decl.binding).forEach(stx => { + if (phase !== 0) { + // phase 0 bindings extend the binding map during compilation + let newBinding = (0, _symbol.gensym)(stx.val()); + this.context.bindings.add(stx, { + binding: newBinding, + phase: phase, + skipDup: term.kind === 'var' + }); + } + let resolvedName = stx.resolve(phase); + store.set(resolvedName, new _transforms.VarBindingTransform(stx)); + }); + }); + } - var state = seq(this.p(node.object, (0, _coderep.getPrecedence)(node), object), this.sep(Sep.BEFORE_STATIC_MEMBER_DOT), this.t("."), this.sep(Sep.AFTER_STATIC_MEMBER_DOT), this.t(property)); - state.startsWithLet = object.startsWithLet; - state.startsWithCurly = object.startsWithCurly; - state.startsWithLetSquareBracket = object.startsWithLetSquareBracket; - state.startsWithFunctionOrClass = object.startsWithFunctionOrClass; - return state; - } - }, { - key: "reduceStaticPropertyName", - value: function reduceStaticPropertyName(node) { - var n; - if (_esutils.keyword.isIdentifierNameES6(node.value)) { - return this.t(node.value); - } else if (n = parseFloat(node.value), n === n) { - return new _coderep.NumberCodeRep(n); + registerFunctionOrClass(term, phase, store) { + (0, _hygieneUtils.collectBindings)(term.name).forEach(stx => { + if (phase !== 0) { + let newBinding = (0, _symbol.gensym)(stx.val()); + this.context.bindings.add(stx, { + binding: newBinding, + phase: phase, + skipDup: false + }); } - return this.t((0, _coderep.escapeStringLiteral)(node.value)); - } - }, { - key: "reduceSuper", - value: function reduceSuper() { - return this.t("super"); - } - }, { - key: "reduceSwitchCase", - value: function reduceSwitchCase(node, _ref53) { - var test = _ref53.test; - var consequent = _ref53.consequent; + let resolvedName = stx.resolve(phase); + store.set(resolvedName, new _transforms.VarBindingTransform(stx)); + }); + } - return seq(this.t("case"), this.sep(Sep.BEFORE_CASE_TEST), test, this.sep(Sep.AFTER_CASE_TEST), this.t(":"), this.sep(Sep.BEFORE_CASE_BODY), seq.apply(undefined, _toConsumableArray(consequent)), this.sep(Sep.AFTER_CASE_BODY)); - } - }, { - key: "reduceSwitchDefault", - value: function reduceSwitchDefault(node, _ref54) { - var consequent = _ref54.consequent; + visit(mod, phase, store) { + // TODO: recursively visit imports + mod.body.forEach(term => { + if (T.isSyntaxDeclarationStatement(term)) { + this.registerSyntaxDeclaration(term.declaration, phase, store); + } + }); + return store; + } - return seq(this.t("default"), this.sep(Sep.DEFAULT), this.t(":"), this.sep(Sep.BEFORE_CASE_BODY), seq.apply(undefined, _toConsumableArray(consequent)), this.sep(Sep.AFTER_DEFAULT_BODY)); - } - }, { - key: "reduceSwitchStatement", - value: function reduceSwitchStatement(node, _ref55) { - var discriminant = _ref55.discriminant; - var cases = _ref55.cases; + invoke(mod, phase, store) { + // TODO: recursively visit imports + let body = mod.body.filter(_.complement(T.isCompiletimeStatement)).map(term => { + term = term.gen(); // TODO: can we remove the need for gen? have to deeply remove compiletime code + if (T.isVariableDeclarationStatement(term)) { + this.registerVariableDeclaration(term.declaration, phase, store); + } else if (T.isFunctionDeclaration(term)) { + this.registerFunctionOrClass(term, phase, store); + } + return term; + }); + (0, _loadSyntax.evalRuntimeValues)(body, _.merge(this.context, { + store: store, phase: phase + })); + return store; + } + } + exports.Modules = Modules; + //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/modules.js"],"names":[],"mappings":"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","file":"modules.js","sourcesContent":["import { List } from 'immutable';\nimport Env from \"./env\";\nimport Store from \"./store\";\nimport Reader from \"./shift-reader\";\nimport * as _ from \"ramda\";\nimport { gensym } from './symbol';\nimport Term, * as T from \"./terms\";\nimport { evalCompiletimeValue, evalRuntimeValues } from './load-syntax';\nimport Compiler from \"./compiler\";\nimport { VarBindingTransform, CompiletimeTransform } from './transforms';\nimport { freshScope } from \"./scope\";\nimport { assert } from './errors';\nimport { collectBindings } from './hygiene-utils';\n\nimport { ALL_PHASES } from './syntax';\n\nimport dirname from 'utils-dirname';\n\n\nexport class Module {\n  constructor(moduleSpecifier, isNative, importEntries, exportEntries, pragmas, body) {\n    this.moduleSpecifier = moduleSpecifier;\n    this.isNative = isNative;\n    this.importEntries = importEntries;\n    this.exportEntries = exportEntries;\n    this.pragmas = pragmas;\n    this.body = body;\n  }\n}\n\nconst findBindingIdentifierName = term => {\n  // TODO: handle destructuring\n  assert(term.name, `not implemented yet for type ${term.type}`);\n  return term.name;\n};\n\nconst convertExport = term => {\n  let declaration = term.declaration;\n  let bindings = [];\n  if (T.isVariableDeclaration(declaration)) {\n    bindings = declaration.declarators.map(decl =>  findBindingIdentifierName(decl.binding));\n  } else if (T.isFunctionDeclaration(declaration) || T.isClassDeclaration(declaration)) {\n    bindings.push(findBindingIdentifierName(declaration.name));\n  }\n\n  let namedExports = bindings.map(binding => {\n    return new Term('ExportSpecifier', {\n      name: null,\n      exportedName: binding\n    });\n  });\n  return new Term('ExportFrom', {\n    moduleSpecifier: null,\n    namedExports: List(namedExports)\n  });\n};\n\nconst pragmaRegep = /^\\s*#\\w*/;\n\nexport class Modules {\n  constructor(context) {\n    this.compiledModules = new Map();\n    this.context = context;\n    this.context.modules = this;\n  }\n\n  loadString(str, checkPragma = true) {\n    let hasPragma = pragmaRegep.test(str);\n    if (checkPragma && !hasPragma) {\n      return {\n        isNative: true,\n        body: List()\n      };\n    }\n    return {\n      isNative: !hasPragma,\n      body: new Reader(str).read()\n    };\n  }\n\n  load(path) {\n    // TODO resolve and we need to carry the cwd through correctly\n    return this.loadString(this.context.moduleLoader(path));\n  }\n\n  compile(mod, path) {\n    let stxl = mod.body;\n    let outScope = freshScope('outsideEdge');\n    let inScope = freshScope(`insideEdge0`);\n    // the compiler starts at phase 0, with an empty environment and store\n    let compiler = new Compiler(0, new Env(), new Store(), _.merge(this.context, {\n      currentScope: [outScope, inScope],\n      cwd: path === '<<entrypoint>>' ? this.context.cwd : dirname(path)\n    }));\n    let terms = compiler.compile(stxl.map(s =>\n      s.addScope(outScope, this.context.bindings, ALL_PHASES)\n       .addScope(inScope, this.context.bindings, 0)\n    ));\n\n    let importEntries = [];\n    let exportEntries = [];\n    let pragmas = [];\n    let filteredTerms = terms.reduce((acc, t) => {\n      return _.cond([\n        [T.isImport, t => {\n          importEntries.push(t);\n          return acc;\n        }],\n        [T.isExport, t => {\n          // exportEntries.push(t);\n          // return acc.concat(t);\n          if (t.declaration) {\n            exportEntries.push(convertExport(t));\n            if (T.isVariableDeclaration(t.declaration)) {\n              return acc.concat(new Term('VariableDeclarationStatement', {\n                declaration: t.declaration\n              }));\n            }\n            return acc.concat(t.declaration);\n          }\n          exportEntries.push(t);\n          return acc;\n        }],\n        [T.isPragma, t => { pragmas.push(t); return acc; } ],\n        [_.T, t => acc.concat(t) ]\n      ])(t);\n    }, List());\n    return new Module(\n      path,\n      mod.isNative,\n      List(importEntries),\n      List(exportEntries),\n      List(pragmas),\n      filteredTerms\n    );\n  }\n\n  compileEntrypoint(source, filename, enforcePragma = false) {\n    let stxl = this.loadString(source, false);\n    if (enforcePragma && stxl.isNative) {\n      throw new Error(`Entrypoint ${filename} must begin with #lang pragma`);\n    }\n    return this.getAtPhase('<<entrypoint>>', 0, this.context.cwd, stxl);\n  }\n\n  // Modules have a unique scope per-phase. We compile each module once at\n  // phase 0 and store the compiled module in a map. Then, as we ask for\n  // the module in a particular phase, we add that new phase-specific scope\n  // to the compiled module and update the map with the module at that specific\n  // phase.\n  getAtPhase(rawPath, phase, cwd, rawStxl = null) {\n    let path = rawPath === '<<entrypoint>>' ? rawPath : this.context.moduleResolver(rawPath, cwd);\n    let mapKey = `${path}:${phase}`;\n    if (!this.compiledModules.has(mapKey)) {\n      if (phase === 0) {\n        let stxl = rawStxl != null ? rawStxl : this.load(path);\n        this.compiledModules.set(mapKey, this.compile(stxl, path));\n      } else {\n        let rawMod = this.getAtPhase(rawPath, 0, cwd, rawStxl);\n        let scope = freshScope(`insideEdge${phase}`);\n        this.compiledModules.set(mapKey, new Module(\n          rawMod.moduleSpecifier,\n          false,\n          rawMod.importEntries.map(term => term.addScope(scope, this.context.bindings, phase)),\n          rawMod.exportEntries.map(term => term.addScope(scope, this.context.bindings, phase)),\n          rawMod.pragmas,\n          rawMod.body.map(term => term.addScope(scope, this.context.bindings, phase))\n        ));\n      }\n    }\n    return this.compiledModules.get(mapKey);\n  }\n\n  has(rawPath, phase = 0) {\n    let path = rawPath === '<<entrypoint>>' ? rawPath : this.context.moduleResolver(rawPath, this.context.cwd);\n    let key = `${path}:${phase}`;\n    return this.compiledModules.has(key) && !this.compiledModules.get(key).isNative;\n  }\n\n  registerSyntaxDeclaration(term, phase, store) {\n    term.declarators.forEach(decl => {\n      let val = evalCompiletimeValue(decl.init.gen(), _.merge(this.context, {\n        phase: phase + 1, store\n      }));\n      collectBindings(decl.binding).forEach(stx => {\n        if (phase !== 0) { // phase 0 bindings extend the binding map during compilation\n          let newBinding = gensym(stx.val());\n          this.context.bindings.add(stx, {\n            binding: newBinding,\n            phase: phase,\n            skipDup: false\n          });\n        }\n        let resolvedName = stx.resolve(phase);\n        store.set(resolvedName, new CompiletimeTransform(val));\n      });\n    });\n  }\n\n  registerVariableDeclaration(term, phase, store) {\n    term.declarators.forEach(decl => {\n      collectBindings(decl.binding).forEach(stx => {\n        if (phase !== 0) { // phase 0 bindings extend the binding map during compilation\n          let newBinding = gensym(stx.val());\n          this.context.bindings.add(stx, {\n            binding: newBinding,\n            phase: phase,\n            skipDup: term.kind === 'var'\n          });\n        }\n        let resolvedName = stx.resolve(phase);\n        store.set(resolvedName, new VarBindingTransform(stx));\n      });\n    });\n  }\n\n  registerFunctionOrClass(term, phase, store) {\n    collectBindings(term.name).forEach(stx => {\n      if (phase !== 0) {\n        let newBinding = gensym(stx.val());\n        this.context.bindings.add(stx, {\n          binding: newBinding,\n          phase: phase,\n          skipDup: false\n        });\n      }\n      let resolvedName = stx.resolve(phase);\n      store.set(resolvedName, new VarBindingTransform(stx));\n    });\n  }\n\n  visit(mod, phase, store) {\n    // TODO: recursively visit imports\n    mod.body.forEach(term => {\n      if (T.isSyntaxDeclarationStatement(term)) {\n        this.registerSyntaxDeclaration(term.declaration, phase, store);\n      }\n    });\n    return store;\n  }\n\n  invoke(mod, phase, store) {\n    // TODO: recursively visit imports\n    let body = mod.body.filter(_.complement(T.isCompiletimeStatement)).map(term => {\n      term = term.gen(); // TODO: can we remove the need for gen? have to deeply remove compiletime code\n      if (T.isVariableDeclarationStatement(term)) {\n        this.registerVariableDeclaration(term.declaration, phase, store);\n      } else if (T.isFunctionDeclaration(term)) {\n        this.registerFunctionOrClass(term, phase, store);\n      }\n      return term;\n    });\n    evalRuntimeValues(body, _.merge(this.context, {\n      store, phase\n    }));\n    return store;\n  }\n}\n"]} - return seq(this.t("switch"), this.sep(Sep.BEFORE_SWITCH_DISCRIM), this.paren(discriminant, Sep.SWITCH_DISCRIM_PAREN_BEFORE, Sep.SWITCH_DISCRIM_PAREN_AFTER), this.sep(Sep.BEFORE_SWITCH_BODY), this.brace(seq.apply(undefined, _toConsumableArray(cases)), node, Sep.SWITCH_BRACE_INTIAL, Sep.SWITCH_BRACE_FINAL, Sep.SWITCH_BRACE_EMPTY), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceSwitchStatementWithDefault", - value: function reduceSwitchStatementWithDefault(node, _ref56) { - var discriminant = _ref56.discriminant; - var preDefaultCases = _ref56.preDefaultCases; - var defaultCase = _ref56.defaultCase; - var postDefaultCases = _ref56.postDefaultCases; +/***/ }, +/* 37 */ +/***/ function(module, exports, __webpack_require__) { - return seq(this.t("switch"), this.sep(Sep.BEFORE_SWITCH_DISCRIM), this.paren(discriminant, Sep.SWITCH_DISCRIM_PAREN_BEFORE, Sep.SWITCH_DISCRIM_PAREN_AFTER), this.sep(Sep.BEFORE_SWITCH_BODY), this.brace(seq.apply(undefined, _toConsumableArray(preDefaultCases).concat([defaultCase], _toConsumableArray(postDefaultCases))), node, Sep.SWITCH_BRACE_INTIAL, Sep.SWITCH_BRACE_FINAL, Sep.SWITCH_BRACE_EMPTY), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceTemplateExpression", - value: function reduceTemplateExpression(node, _ref57) { - var tag = _ref57.tag; - var elements = _ref57.elements; + "use strict"; - var state = node.tag == null ? empty() : seq(this.p(node.tag, (0, _coderep.getPrecedence)(node), tag), this.sep(Sep.TEMPLATE_TAG)); - var templateData = ""; - state = seq(state, this.t("`")); - for (var i = 0, l = node.elements.length; i < l; ++i) { - if (node.elements[i].type === "TemplateElement") { - var d = ""; - if (i > 0) d += "}"; - d += node.elements[i].rawValue; - if (i < l - 1) d += "${"; - state = seq(state, this.t(d)); - } else { - state = seq(state, this.sep(Sep.BEFORE_TEMPLATE_EXPRESSION), elements[i], this.sep(Sep.AFTER_TEMPLATE_EXPRESSION)); - } - } - state = seq(state, this.t("`")); - if (node.tag != null) { - state.startsWithCurly = tag.startsWithCurly; - state.startsWithLetSquareBracket = tag.startsWithLetSquareBracket; - state.startsWithFunctionOrClass = tag.startsWithFunctionOrClass; - } - return state; - } - }, { - key: "reduceTemplateElement", - value: function reduceTemplateElement(node) { - return this.t(node.rawValue); - } - }, { - key: "reduceThisExpression", - value: function reduceThisExpression(node) { - return this.t("this"); - } - }, { - key: "reduceThrowStatement", - value: function reduceThrowStatement(node, _ref58) { - var expression = _ref58.expression; + Object.defineProperty(exports, "__esModule", { + value: true + }); - return seq(this.t("throw"), this.sep(Sep.THROW), expression, this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceTryCatchStatement", - value: function reduceTryCatchStatement(node, _ref59) { - var body = _ref59.body; - var catchClause = _ref59.catchClause; + var _transforms = __webpack_require__(38); - return seq(this.t("try"), this.sep(Sep.AFTER_TRY), body, this.sep(Sep.BEFORE_CATCH), catchClause, this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceTryFinallyStatement", - value: function reduceTryFinallyStatement(node, _ref60) { - var body = _ref60.body; - var catchClause = _ref60.catchClause; - var finalizer = _ref60.finalizer; + class Env { + constructor() { + this.map = new Map(); + this.map.set("function", _transforms.FunctionDeclTransform); + this.map.set("var", _transforms.VariableDeclTransform); + this.map.set("let", _transforms.LetDeclTransform); + this.map.set("const", _transforms.ConstDeclTransform); + this.map.set("syntaxQuote", _transforms.SyntaxQuoteTransform); + this.map.set("syntaxrec", _transforms.SyntaxrecDeclTransform); + this.map.set("syntax", _transforms.SyntaxDeclTransform); + this.map.set("return", _transforms.ReturnStatementTransform); + this.map.set("while", _transforms.WhileTransform); + this.map.set("if", _transforms.IfTransform); + this.map.set("for", _transforms.ForTransform); + this.map.set("switch", _transforms.SwitchTransform); + this.map.set("break", _transforms.BreakTransform); + this.map.set("continue", _transforms.ContinueTransform); + this.map.set("do", _transforms.DoTransform); + this.map.set("debugger", _transforms.DebuggerTransform); + this.map.set("with", _transforms.WithTransform); + this.map.set("try", _transforms.TryTransform); + this.map.set("throw", _transforms.ThrowTransform); + this.map.set("new", _transforms.NewTransform); + } - return seq(this.t("try"), this.sep(Sep.AFTER_TRY), body, catchClause ? seq(this.sep(Sep.BEFORE_CATCH), catchClause) : empty(), this.sep(Sep.BEFORE_FINALLY), this.t("finally"), this.sep(Sep.AFTER_FINALLY), finalizer, this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceYieldExpression", - value: function reduceYieldExpression(node, _ref61) { - var expression = _ref61.expression; + has(key) { + return this.map.has(key); + } - if (node.expression == null) return this.t("yield"); - return seq(this.t("yield"), this.sep(Sep.YIELD), this.p(node.expression, (0, _coderep.getPrecedence)(node), expression)); - } - }, { - key: "reduceYieldGeneratorExpression", - value: function reduceYieldGeneratorExpression(node, _ref62) { - var expression = _ref62.expression; + get(key) { + return this.map.get(key); + } - return seq(this.t("yield"), this.sep(Sep.BEFORE_YIELD_STAR), this.t("*"), this.sep(Sep.AFTER_YIELD_STAR), this.p(node.expression, (0, _coderep.getPrecedence)(node), expression)); - } - }, { - key: "reduceDirective", - value: function reduceDirective(node) { - var delim = /^(?:[^"\\]|\\.)*$/.test(node.rawValue) ? "\"" : "'"; - return seq(this.t(delim + node.rawValue + delim), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceVariableDeclaration", - value: function reduceVariableDeclaration(node, _ref63) { - var declarators = _ref63.declarators; + set(key, val) { + return this.map.set(key, val); + } + } + exports.default = Env; + //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lbnYuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7O0FBdUJlLE1BQU0sR0FBTixDQUFVO0FBQ3ZCLGdCQUFjO0FBQ1osU0FBSyxHQUFMLEdBQVcsSUFBSSxHQUFKLEVBQVg7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsVUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxLQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLEtBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsT0FBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxhQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLFdBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsUUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxRQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLE9BQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsSUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxLQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLFFBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsT0FBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxVQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLElBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsVUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxNQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLEtBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsT0FBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxLQUFiO0FBQ0Q7O0FBRUQsTUFBSSxHQUFKLEVBQVM7QUFDUCxXQUFPLEtBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxHQUFiLENBQVA7QUFDRDs7QUFFRCxNQUFJLEdBQUosRUFBUztBQUNQLFdBQU8sS0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLEdBQWIsQ0FBUDtBQUNEOztBQUVELE1BQUksR0FBSixFQUFTLEdBQVQsRUFBYztBQUNaLFdBQU8sS0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLEdBQWIsRUFBa0IsR0FBbEIsQ0FBUDtBQUNEO0FBbkNzQjtrQkFBSixHIiwiZmlsZSI6ImVudi5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEZ1bmN0aW9uRGVjbFRyYW5zZm9ybSxcbiAgVmFyaWFibGVEZWNsVHJhbnNmb3JtLFxuICBMZXREZWNsVHJhbnNmb3JtLFxuICBDb25zdERlY2xUcmFuc2Zvcm0sXG4gIFN5bnRheERlY2xUcmFuc2Zvcm0sXG4gIFN5bnRheHJlY0RlY2xUcmFuc2Zvcm0sXG4gIFN5bnRheFF1b3RlVHJhbnNmb3JtLFxuICBSZXR1cm5TdGF0ZW1lbnRUcmFuc2Zvcm0sXG4gIElmVHJhbnNmb3JtLFxuICBGb3JUcmFuc2Zvcm0sXG4gIFN3aXRjaFRyYW5zZm9ybSxcbiAgQnJlYWtUcmFuc2Zvcm0sXG4gIENvbnRpbnVlVHJhbnNmb3JtLFxuICBEb1RyYW5zZm9ybSxcbiAgRGVidWdnZXJUcmFuc2Zvcm0sXG4gIFdpdGhUcmFuc2Zvcm0sXG4gIFRyeVRyYW5zZm9ybSxcbiAgVGhyb3dUcmFuc2Zvcm0sXG4gIE5ld1RyYW5zZm9ybSxcbiAgV2hpbGVUcmFuc2Zvcm1cbn0gZnJvbSBcIi4vdHJhbnNmb3Jtc1wiO1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBFbnYge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLm1hcCA9IG5ldyBNYXAoKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJmdW5jdGlvblwiLCBGdW5jdGlvbkRlY2xUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcInZhclwiLCBWYXJpYWJsZURlY2xUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcImxldFwiLCBMZXREZWNsVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJjb25zdFwiLCBDb25zdERlY2xUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcInN5bnRheFF1b3RlXCIsIFN5bnRheFF1b3RlVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJzeW50YXhyZWNcIiwgU3ludGF4cmVjRGVjbFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwic3ludGF4XCIsIFN5bnRheERlY2xUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcInJldHVyblwiLCBSZXR1cm5TdGF0ZW1lbnRUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcIndoaWxlXCIsIFdoaWxlVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJpZlwiLCBJZlRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwiZm9yXCIsIEZvclRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwic3dpdGNoXCIsIFN3aXRjaFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwiYnJlYWtcIiwgQnJlYWtUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcImNvbnRpbnVlXCIsIENvbnRpbnVlVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJkb1wiLCBEb1RyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwiZGVidWdnZXJcIiwgRGVidWdnZXJUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcIndpdGhcIiwgV2l0aFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwidHJ5XCIsIFRyeVRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwidGhyb3dcIiwgVGhyb3dUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcIm5ld1wiLCBOZXdUcmFuc2Zvcm0pO1xuICB9XG5cbiAgaGFzKGtleSkge1xuICAgIHJldHVybiB0aGlzLm1hcC5oYXMoa2V5KTtcbiAgfVxuXG4gIGdldChrZXkpIHtcbiAgICByZXR1cm4gdGhpcy5tYXAuZ2V0KGtleSk7XG4gIH1cblxuICBzZXQoa2V5LCB2YWwpIHtcbiAgICByZXR1cm4gdGhpcy5tYXAuc2V0KGtleSwgdmFsKTtcbiAgfVxufVxuIl19 - return seq(this.t(node.kind), this.sep(Sep.VARIABLE_DECLARATION), this.commaSep(declarators, Sep.DECLARATORS_BEFORE_COMMA, Sep.DECLARATORS_AFTER_COMMA)); - } - }, { - key: "reduceVariableDeclarationStatement", - value: function reduceVariableDeclarationStatement(node, _ref64) { - var declaration = _ref64.declaration; +/***/ }, +/* 38 */ +/***/ function(module, exports) { - return seq(declaration, this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); - } - }, { - key: "reduceVariableDeclarator", - value: function reduceVariableDeclarator(node, _ref65) { - var binding = _ref65.binding; - var init = _ref65.init; + "use strict"; - var containsIn = init && init.containsIn && !init.containsGroup; - if (init) { - if (init.containsGroup) { - init = this.paren(init, Sep.EXPRESSION_PAREN_BEFORE, Sep.EXPRESSION_PAREN_AFTER); - } else { - init = markContainsIn(init); - } - } - return (0, _objectAssign2.default)(init == null ? binding : seq(binding, this.sep(Sep.BEFORE_INIT_EQUALS), this.t("="), this.sep(Sep.AFTER_INIT_EQUALS), init), { containsIn: containsIn }); - } - }, { - key: "reduceWhileStatement", - value: function reduceWhileStatement(node, _ref66) { - var test = _ref66.test; - var body = _ref66.body; + Object.defineProperty(exports, "__esModule", { + value: true + }); + class FunctionDeclTransform {} + exports.FunctionDeclTransform = FunctionDeclTransform; + class VariableDeclTransform {} + exports.VariableDeclTransform = VariableDeclTransform; + class NewTransform {} + exports.NewTransform = NewTransform; + class ThrowTransform {} + exports.ThrowTransform = ThrowTransform; + class LetDeclTransform {} + exports.LetDeclTransform = LetDeclTransform; + class ConstDeclTransform {} + exports.ConstDeclTransform = ConstDeclTransform; + class TryTransform {} + exports.TryTransform = TryTransform; + class WhileTransform {} + exports.WhileTransform = WhileTransform; + class IfTransform {} + exports.IfTransform = IfTransform; + class ForTransform {} + exports.ForTransform = ForTransform; + class SwitchTransform {} + exports.SwitchTransform = SwitchTransform; + class BreakTransform {} + exports.BreakTransform = BreakTransform; + class ContinueTransform {} + exports.ContinueTransform = ContinueTransform; + class DoTransform {} + exports.DoTransform = DoTransform; + class WithTransform {} + exports.WithTransform = WithTransform; + class DebuggerTransform {} + exports.DebuggerTransform = DebuggerTransform; + class SyntaxrecDeclTransform {} + exports.SyntaxrecDeclTransform = SyntaxrecDeclTransform; + class SyntaxDeclTransform {} + exports.SyntaxDeclTransform = SyntaxDeclTransform; + class SyntaxQuoteTransform {} + exports.SyntaxQuoteTransform = SyntaxQuoteTransform; + class ReturnStatementTransform {} + exports.ReturnStatementTransform = ReturnStatementTransform; + class VarBindingTransform { + constructor(id) { + this.id = id; + } + } + exports.VarBindingTransform = VarBindingTransform; + class CompiletimeTransform { + constructor(value) { + this.value = value; + } + } + exports.CompiletimeTransform = CompiletimeTransform; + //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90cmFuc2Zvcm1zLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQU8sTUFBTSxxQkFBTixDQUE0QjtRQUF0QixxQixHQUFBLHFCO0FBQ04sTUFBTSxxQkFBTixDQUE0QjtRQUF0QixxQixHQUFBLHFCO0FBQ04sTUFBTSxZQUFOLENBQW1CO1FBQWIsWSxHQUFBLFk7QUFDTixNQUFNLGNBQU4sQ0FBcUI7UUFBZixjLEdBQUEsYztBQUNOLE1BQU0sZ0JBQU4sQ0FBdUI7UUFBakIsZ0IsR0FBQSxnQjtBQUNOLE1BQU0sa0JBQU4sQ0FBeUI7UUFBbkIsa0IsR0FBQSxrQjtBQUNOLE1BQU0sWUFBTixDQUFtQjtRQUFiLFksR0FBQSxZO0FBQ04sTUFBTSxjQUFOLENBQXFCO1FBQWYsYyxHQUFBLGM7QUFDTixNQUFNLFdBQU4sQ0FBa0I7UUFBWixXLEdBQUEsVztBQUNOLE1BQU0sWUFBTixDQUFtQjtRQUFiLFksR0FBQSxZO0FBQ04sTUFBTSxlQUFOLENBQXNCO1FBQWhCLGUsR0FBQSxlO0FBQ04sTUFBTSxjQUFOLENBQXFCO1FBQWYsYyxHQUFBLGM7QUFDTixNQUFNLGlCQUFOLENBQXdCO1FBQWxCLGlCLEdBQUEsaUI7QUFDTixNQUFNLFdBQU4sQ0FBa0I7UUFBWixXLEdBQUEsVztBQUNOLE1BQU0sYUFBTixDQUFvQjtRQUFkLGEsR0FBQSxhO0FBQ04sTUFBTSxpQkFBTixDQUF3QjtRQUFsQixpQixHQUFBLGlCO0FBQ04sTUFBTSxzQkFBTixDQUE2QjtRQUF2QixzQixHQUFBLHNCO0FBQ04sTUFBTSxtQkFBTixDQUEwQjtRQUFwQixtQixHQUFBLG1CO0FBQ04sTUFBTSxvQkFBTixDQUEyQjtRQUFyQixvQixHQUFBLG9CO0FBQ04sTUFBTSx3QkFBTixDQUErQjtRQUF6Qix3QixHQUFBLHdCO0FBQ04sTUFBTSxtQkFBTixDQUEwQjtBQUMvQixjQUFZLEVBQVosRUFBZ0I7QUFDZCxTQUFLLEVBQUwsR0FBVSxFQUFWO0FBQ0Q7QUFIOEI7UUFBcEIsbUIsR0FBQSxtQjtBQUtOLE1BQU0sb0JBQU4sQ0FBMkI7QUFDaEMsY0FBWSxLQUFaLEVBQW1CO0FBQ2pCLFNBQUssS0FBTCxHQUFhLEtBQWI7QUFDRDtBQUgrQjtRQUFyQixvQixHQUFBLG9CIiwiZmlsZSI6InRyYW5zZm9ybXMuanMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgRnVuY3Rpb25EZWNsVHJhbnNmb3JtIHsgfVxuZXhwb3J0IGNsYXNzIFZhcmlhYmxlRGVjbFRyYW5zZm9ybSB7IH1cbmV4cG9ydCBjbGFzcyBOZXdUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgVGhyb3dUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgTGV0RGVjbFRyYW5zZm9ybSB7IH1cbmV4cG9ydCBjbGFzcyBDb25zdERlY2xUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgVHJ5VHJhbnNmb3JtIHsgfVxuZXhwb3J0IGNsYXNzIFdoaWxlVHJhbnNmb3JtIHsgfVxuZXhwb3J0IGNsYXNzIElmVHJhbnNmb3JtIHsgfVxuZXhwb3J0IGNsYXNzIEZvclRyYW5zZm9ybSB7IH1cbmV4cG9ydCBjbGFzcyBTd2l0Y2hUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgQnJlYWtUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgQ29udGludWVUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgRG9UcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgV2l0aFRyYW5zZm9ybSB7IH1cbmV4cG9ydCBjbGFzcyBEZWJ1Z2dlclRyYW5zZm9ybSB7IH1cbmV4cG9ydCBjbGFzcyBTeW50YXhyZWNEZWNsVHJhbnNmb3JtIHsgfVxuZXhwb3J0IGNsYXNzIFN5bnRheERlY2xUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgU3ludGF4UXVvdGVUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgUmV0dXJuU3RhdGVtZW50VHJhbnNmb3JtIHsgfVxuZXhwb3J0IGNsYXNzIFZhckJpbmRpbmdUcmFuc2Zvcm0ge1xuICBjb25zdHJ1Y3RvcihpZCkge1xuICAgIHRoaXMuaWQgPSBpZDtcbiAgfVxufVxuZXhwb3J0IGNsYXNzIENvbXBpbGV0aW1lVHJhbnNmb3JtIHtcbiAgY29uc3RydWN0b3IodmFsdWUpIHtcbiAgICB0aGlzLnZhbHVlID0gdmFsdWU7XG4gIH1cbn1cbiJdfQ== - return (0, _objectAssign2.default)(seq(this.t("while"), this.sep(Sep.AFTER_WHILE), this.paren(test, Sep.WHILE_TEST_PAREN_BEFORE, Sep.WHILE_TEST_PAREN_AFTER), this.sep(Sep.BEFORE_WHILE_BODY), body, this.sep(Sep.AFTER_STATEMENT(node))), { endsWithMissingElse: body.endsWithMissingElse }); - } - }, { - key: "reduceWithStatement", - value: function reduceWithStatement(node, _ref67) { - var object = _ref67.object; - var body = _ref67.body; +/***/ }, +/* 39 */ +/***/ function(module, exports, __webpack_require__) { - return (0, _objectAssign2.default)(seq(this.t("with"), this.sep(Sep.AFTER_WITH), this.paren(object, Sep.WITH_PAREN_BEFORE, Sep.WITH_PAREN_AFTER), this.sep(Sep.BEFORE_WITH_BODY), body, this.sep(Sep.AFTER_STATEMENT(node))), { endsWithMissingElse: body.endsWithMissingElse }); - } - }]); - - return ExtensibleCodeGen; - }(); + 'use strict'; - var INDENT = " "; + Object.defineProperty(exports, "__esModule", { + value: true + }); - var Linebreak = function (_CodeRep) { - _inherits(Linebreak, _CodeRep); + var _vm = __webpack_require__(40); - function Linebreak() { - _classCallCheck(this, Linebreak); + var _vm2 = _interopRequireDefault(_vm); - var _this4 = _possibleConstructorReturn(this, Object.getPrototypeOf(Linebreak).call(this)); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - _this4.indentation = 0; - return _this4; + class Store { + constructor() { + this.map = new Map(); + this.nodeContext = _vm2.default.createContext(); } - _createClass(Linebreak, [{ - key: "emit", - value: function emit(ts) { - ts.put("\n"); - for (var i = 0; i < this.indentation; ++i) { - ts.put(INDENT); - } - } - }]); - - return Linebreak; - }(_coderep.CodeRep); + has(key) { + return this.map.has(key); + } - function withoutTrailingLinebreak(state) { - if (state && state instanceof _coderep.Seq) { - var lastChild = state.children[state.children.length - 1]; - /* istanbul ignore next */ - while (lastChild instanceof _coderep.Empty) { - state.children.pop(); - lastChild = state.children[state.children.length - 1]; - } - /* istanbul ignore else */ - if (lastChild instanceof _coderep.Seq) { - withoutTrailingLinebreak(lastChild); - } else if (lastChild instanceof Linebreak) { - state.children.pop(); - } + get(key) { + return this.map.get(key); } - return state; - } - function indent(rep, includingFinal) { - var finalLinebreak = undefined; - function indentNode(node) { - if (node instanceof Linebreak) { - finalLinebreak = node; - ++node.indentation; - } + set(key, val) { + this.nodeContext[key] = val; + return this.map.set(key, val); } - rep.forEach(indentNode); - if (!includingFinal) { - --finalLinebreak.indentation; + + getNodeContext() { + return this.nodeContext; } - return rep; } + exports.default = Store; + //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zdG9yZS5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7Ozs7O0FBRWUsTUFBTSxLQUFOLENBQVk7QUFDekIsZ0JBQWM7QUFDWixTQUFLLEdBQUwsR0FBVyxJQUFJLEdBQUosRUFBWDtBQUNBLFNBQUssV0FBTCxHQUFtQixhQUFHLGFBQUgsRUFBbkI7QUFDRDs7QUFFRCxNQUFJLEdBQUosRUFBUztBQUNQLFdBQU8sS0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLEdBQWIsQ0FBUDtBQUNEOztBQUVELE1BQUksR0FBSixFQUFTO0FBQ1AsV0FBTyxLQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsR0FBYixDQUFQO0FBQ0Q7O0FBRUQsTUFBSSxHQUFKLEVBQVMsR0FBVCxFQUFjO0FBQ1osU0FBSyxXQUFMLENBQWlCLEdBQWpCLElBQXdCLEdBQXhCO0FBQ0EsV0FBTyxLQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsR0FBYixFQUFrQixHQUFsQixDQUFQO0FBQ0Q7O0FBRUQsbUJBQWlCO0FBQ2YsV0FBTyxLQUFLLFdBQVo7QUFDRDtBQXJCd0I7a0JBQU4sSyIsImZpbGUiOiJzdG9yZS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB2bSBmcm9tICd2bSc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFN0b3JlIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5tYXAgPSBuZXcgTWFwKCk7XG4gICAgdGhpcy5ub2RlQ29udGV4dCA9IHZtLmNyZWF0ZUNvbnRleHQoKTtcbiAgfVxuXG4gIGhhcyhrZXkpIHtcbiAgICByZXR1cm4gdGhpcy5tYXAuaGFzKGtleSk7XG4gIH1cblxuICBnZXQoa2V5KSB7XG4gICAgcmV0dXJuIHRoaXMubWFwLmdldChrZXkpO1xuICB9XG5cbiAgc2V0KGtleSwgdmFsKSB7XG4gICAgdGhpcy5ub2RlQ29udGV4dFtrZXldID0gdmFsO1xuICAgIHJldHVybiB0aGlzLm1hcC5zZXQoa2V5LCB2YWwpO1xuICB9XG5cbiAgZ2V0Tm9kZUNvbnRleHQoKSB7XG4gICAgcmV0dXJuIHRoaXMubm9kZUNvbnRleHQ7XG4gIH1cbn1cbiJdfQ== - var FormattedCodeGen = exports.FormattedCodeGen = function (_ExtensibleCodeGen) { - _inherits(FormattedCodeGen, _ExtensibleCodeGen); - - function FormattedCodeGen() { - _classCallCheck(this, FormattedCodeGen); +/***/ }, +/* 40 */ +/***/ function(module, exports, __webpack_require__) { - return _possibleConstructorReturn(this, Object.getPrototypeOf(FormattedCodeGen).apply(this, arguments)); - } + var indexOf = __webpack_require__(41); - _createClass(FormattedCodeGen, [{ - key: "parenToAvoidBeingDirective", - value: function parenToAvoidBeingDirective(element, original) { - if (element && element.type === "ExpressionStatement" && element.expression.type === "LiteralStringExpression") { - return seq(this.paren(original.children[0], Sep.PAREN_AVOIDING_DIRECTIVE_BEFORE, Sep.PAREN_AVOIDING_DIRECTIVE_AFTER), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(element))); - } - return original; + var Object_keys = function (obj) { + if (Object.keys) return Object.keys(obj) + else { + var res = []; + for (var key in obj) res.push(key) + return res; } - }, { - key: "brace", - value: function brace(rep, node) { - if (isEmpty(rep)) { - return this.t("{}"); - } - - switch (node.type) { - case "ObjectBinding": - case "Import": - case "ExportFrom": - case "ObjectExpression": - return new _coderep.Brace(rep); - } + }; - rep = seq(new Linebreak(), rep); - indent(rep, false); - return new _coderep.Brace(rep); + var forEach = function (xs, fn) { + if (xs.forEach) return xs.forEach(fn) + else for (var i = 0; i < xs.length; i++) { + fn(xs[i], i, xs); } - }, { - key: "reduceDoWhileStatement", - value: function reduceDoWhileStatement(node, _ref68) { - var body = _ref68.body; - var test = _ref68.test; + }; - return seq(this.t("do"), this.sep(Sep.AFTER_DO), withoutTrailingLinebreak(body), this.sep(Sep.BEFORE_DOWHILE_WHILE), this.t("while"), this.sep(Sep.AFTER_DOWHILE_WHILE), this.paren(test, Sep.DO_WHILE_TEST_PAREN_BEFORE, Sep.DO_WHILE_TEST_PAREN_AFTER), this.semiOp(), this.sep(Sep.AFTER_STATEMENT(node))); + var defineProp = (function() { + try { + Object.defineProperty({}, '_', {}); + return function(obj, name, value) { + Object.defineProperty(obj, name, { + writable: true, + enumerable: false, + configurable: true, + value: value + }) + }; + } catch(e) { + return function(obj, name, value) { + obj[name] = value; + }; } - }, { - key: "reduceIfStatement", - value: function reduceIfStatement(node, _ref69) { - var test = _ref69.test; - var consequent = _ref69.consequent; - var alternate = _ref69.alternate; + }()); - if (alternate && consequent.endsWithMissingElse) { - consequent = this.brace(consequent, node); - } - return (0, _objectAssign2.default)(seq(this.t("if"), this.sep(Sep.AFTER_IF), this.paren(test, Sep.IF_PAREN_BEFORE, Sep.IF_PAREN_AFTER), this.sep(Sep.AFTER_IF_TEST), withoutTrailingLinebreak(consequent), alternate ? seq(this.sep(Sep.BEFORE_ELSE), this.t("else"), this.sep(Sep.AFTER_ELSE), withoutTrailingLinebreak(alternate)) : empty(), this.sep(Sep.AFTER_STATEMENT(node))), { endsWithMissingElse: alternate ? alternate.endsWithMissingElse : true }); - } - }, { - key: "reduceSwitchCase", - value: function reduceSwitchCase(node, _ref70) { - var test = _ref70.test; - var consequent = _ref70.consequent; + var globals = ['Array', 'Boolean', 'Date', 'Error', 'EvalError', 'Function', + 'Infinity', 'JSON', 'Math', 'NaN', 'Number', 'Object', 'RangeError', + 'ReferenceError', 'RegExp', 'String', 'SyntaxError', 'TypeError', 'URIError', + 'decodeURI', 'decodeURIComponent', 'encodeURI', 'encodeURIComponent', 'escape', + 'eval', 'isFinite', 'isNaN', 'parseFloat', 'parseInt', 'undefined', 'unescape']; - consequent = indent(withoutTrailingLinebreak(seq.apply(undefined, [this.sep(Sep.BEFORE_CASE_BODY)].concat(_toConsumableArray(consequent)))), true); - return seq(this.t("case"), this.sep(Sep.BEFORE_CASE_TEST), test, this.sep(Sep.AFTER_CASE_TEST), this.t(":"), consequent, this.sep(Sep.AFTER_CASE_BODY)); - } - }, { - key: "reduceSwitchDefault", - value: function reduceSwitchDefault(node, _ref71) { - var consequent = _ref71.consequent; + function Context() {} + Context.prototype = {}; - consequent = indent(withoutTrailingLinebreak(seq.apply(undefined, [this.sep(Sep.BEFORE_CASE_BODY)].concat(_toConsumableArray(consequent)))), true); - return seq(this.t("default"), this.sep(Sep.DEFAULT), this.t(":"), consequent, this.sep(Sep.AFTER_DEFAULT_BODY)); + var Script = exports.Script = function NodeScript (code) { + if (!(this instanceof Script)) return new Script(code); + this.code = code; + }; + + Script.prototype.runInContext = function (context) { + if (!(context instanceof Context)) { + throw new TypeError("needs a 'context' argument."); } - }, { - key: "sep", - value: function sep(separator) { - switch (separator.type) { - case "ARRAY_AFTER_COMMA": - case "OBJECT_AFTER_COMMA": - case "ARGS_AFTER_COMMA": - case "PARAMETER_AFTER_COMMA": - case "DECLARATORS_AFTER_COMMA": - case "NAMED_IMPORT_AFTER_COMMA": - case "IMPORT_AFTER_COMMA": - case "BEFORE_DEFAULT_EQUALS": - case "AFTER_DEFAULT_EQUALS": - case "AFTER_PROP": - case "BEFORE_JUMP_LABEL": - case "BEFORE_CATCH": - case "BEFORE_CATCH_BINDING": - case "AFTER_CATCH_BINDING": - case "BEFORE_CLASS_NAME": - case "BEFORE_EXTENDS": - case "AFTER_EXTENDS": - case "BEFORE_CLASS_DECLARATION_ELEMENTS": - case "BEFORE_CLASS_EXPRESSION_ELEMENTS": - case "AFTER_STATIC": - case "BEFORE_TERNARY_QUESTION": - case "AFTER_TERNARY_QUESTION": - case "BEFORE_TERNARY_COLON": - case "AFTER_TERNARY_COLON": - case "AFTER_DO": - case "BEFORE_DOWHILE_WHILE": - case "AFTER_DOWHILE_WHILE": - case "AFTER_FORIN_FOR": - case "BEFORE_FORIN_IN": - case "AFTER_FORIN_FOR": - case "BEFORE_FORIN_BODY": - case "AFTER_FOROF_FOR": - case "BEFORE_FOROF_OF": - case "AFTER_FOROF_FOR": - case "BEFORE_FOROF_BODY": - case "AFTER_FOR_FOR": - case "BEFORE_FOR_TEST": - case "BEFORE_FOR_UPDATE": - case "BEFORE_FOR_BODY": - case "BEFORE_FUNCTION_DECLARATION_BODY": - case "BEFORE_FUNCTION_EXPRESSION_BODY": - case "BEFORE_ARROW": - case "AFTER_ARROW": - case "AFTER_GET": - case "BEFORE_GET_BODY": - case "AFTER_IF": - case "AFTER_IF_TEST": - case "BEFORE_ELSE": - case "AFTER_ELSE": - case "BEFORE_IMPORT_BINDINGS": - case "BEFORE_IMPORT_MODULE": - case "AFTER_IMPORT_BINDINGS": - case "AFTER_FROM": - case "BEFORE_IMPORT_NAMESPACE": - case "BEFORE_IMPORT_STAR": - case "AFTER_IMPORT_STAR": - case "AFTER_IMPORT_AS": - case "AFTER_NAMESPACE_BINDING": - case "BEFORE_IMPORT_AS": - case "AFTER_IMPORT_AS": - case "EXPORTS_AFTER_COMMA": - case "BEFORE_EXPORT_STAR": - case "AFTER_EXPORT_STAR": - case "BEFORE_EXPORT_BINDINGS": - case "AFTER_EXPORT_BINDINGS": - case "AFTER_EXPORT": - case "AFTER_EXPORT_DEFAULT": - case "BEFORE_EXPORT_AS": - case "AFTER_EXPORT_AS": - case "AFTER_LABEL_COLON": - case "BEFORE_METHOD_BODY": - case "AFTER_NEW": - case "RETURN": - case "AFTER_SET": - case "BEFORE_SET_BODY": - case "BEFORE_SET_PARAMS": - case "BEFORE_CASE_TEST": - case "BEFORE_SWITCH_DISCRIM": - case "BEFORE_SWITCH_BODY": - case "THROW": - case "AFTER_TRY": - case "BEFORE_CATCH": - case "BEFORE_FINALLY": - case "AFTER_FINALLY": - case "VARIABLE_DECLARATION": - case "YIELD": - case "AFTER_YIELD_STAR": - case "DECLARATORS_AFTER_COMMA": - case "BEFORE_INIT_EQUALS": - case "AFTER_INIT_EQUALS": - case "AFTER_WHILE": - case "BEFORE_WHILE_BODY": - case "AFTER_WITH": - case "BEFORE_WITH_BODY": - case "BEFORE_FUNCTION_NAME": - case "AFTER_BINOP": - case "BEFORE_ASSIGN_OP": - case "AFTER_ASSIGN_OP": - return this.t(" "); - case "AFTER_STATEMENT": - switch (separator.node.type) { - case "ForInStatement": - case "ForOfStatement": - case "ForStatement": - case "WhileStatement": - case "WithStatement": - return empty(); // because those already end with an AFTER_STATEMENT - default: - return new Linebreak(); - } - case "AFTER_CLASS_ELEMENT": - case "BEFORE_CASE_BODY": - case "AFTER_CASE_BODY": - case "AFTER_DEFAULT_BODY": - return new Linebreak(); - case "BEFORE_BINOP": - return separator.op === "," ? empty() : this.t(" "); - case "UNARY": - return separator.op === "delete" || separator.op === "void" || separator.op === "typeof" ? this.t(" ") : empty(); - default: - return empty(); - } + + var iframe = document.createElement('iframe'); + if (!iframe.style) iframe.style = {}; + iframe.style.display = 'none'; + + document.body.appendChild(iframe); + + var win = iframe.contentWindow; + var wEval = win.eval, wExecScript = win.execScript; + + if (!wEval && wExecScript) { + // win.eval() magically appears when this is called in IE: + wExecScript.call(win, 'null'); + wEval = win.eval; } - }]); + + forEach(Object_keys(context), function (key) { + win[key] = context[key]; + }); + forEach(globals, function (key) { + if (context[key]) { + win[key] = context[key]; + } + }); + + var winKeys = Object_keys(win); - return FormattedCodeGen; - }(ExtensibleCodeGen); + var res = wEval.call(win, this.code); + + forEach(Object_keys(win), function (key) { + // Avoid copying circular objects like `top` and `window` by only + // updating existing context properties or new properties in the `win` + // that was only introduced after the eval. + if (key in context || indexOf(winKeys, key) === -1) { + context[key] = win[key]; + } + }); -/***/ }, -/* 43 */ -/***/ function(module, exports, __webpack_require__) { + forEach(globals, function (key) { + if (!(key in context)) { + defineProp(context, key, win[key]); + } + }); + + document.body.removeChild(iframe); + + return res; + }; - "use strict"; + Script.prototype.runInThisContext = function () { + return eval(this.code); // maybe... + }; - var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); /** - * Copyright 2014 Shape Security, Inc. - * - * Licensed under the Apache License, Version 2.0 (the "License") - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ + Script.prototype.runInNewContext = function (context) { + var ctx = Script.createContext(context); + var res = this.runInContext(ctx); - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.TokenStream = undefined; + forEach(Object_keys(ctx), function (key) { + context[key] = ctx[key]; + }); - var _esutils = __webpack_require__(6); + return res; + }; - function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + forEach(Object_keys(Script.prototype), function (name) { + exports[name] = Script[name] = function (code) { + var s = Script(code); + return s[name].apply(s, [].slice.call(arguments, 1)); + }; + }); - function numberDot(fragment) { - if (fragment.indexOf(".") < 0 && fragment.indexOf("e") < 0) { - return ".."; - } - return "."; - } + exports.createScript = function (code) { + return exports.Script(code); + }; - function renderNumber(n) { - var s; - if (n >= 1e3 && n % 10 === 0) { - s = n.toString(10); - if (/[eE]/.test(s)) { - return s.replace(/[eE]\+/, "e"); - } - return n.toString(10).replace(/0+$/, function (match) { - return "e" + match.length; - }); - } else if (n % 1 === 0) { - if (n > 1e15 && n < 1e20) { - return "0x" + n.toString(16).toUpperCase(); + exports.createContext = Script.createContext = function (context) { + var copy = new Context(); + if(typeof context === 'object') { + forEach(Object_keys(context), function (key) { + copy[key] = context[key]; + }); } - return n.toString(10).replace(/[eE]\+/, "e"); - } else { - return n.toString(10).replace(/^0\./, ".").replace(/[eE]\+/, "e"); - } - } - - var TokenStream = exports.TokenStream = function () { - function TokenStream() { - _classCallCheck(this, TokenStream); + return copy; + }; - this.result = ""; - this.lastNumber = null; - this.lastChar = null; - this.optionalSemi = false; - } - _createClass(TokenStream, [{ - key: "putNumber", - value: function putNumber(number) { - var tokenStr = renderNumber(number); - this.put(tokenStr); - this.lastNumber = tokenStr; - } - }, { - key: "putOptionalSemi", - value: function putOptionalSemi() { - this.optionalSemi = true; - } - }, { - key: "put", - value: function put(tokenStr) { - if (this.optionalSemi) { - this.optionalSemi = false; - if (tokenStr !== "}") { - this.put(";"); - } - } - if (this.lastNumber !== null && tokenStr.length == 1) { - if (tokenStr === ".") { - this.result += numberDot(this.lastNumber); - this.lastNumber = null; - this.lastChar = "."; - return; - } - } - this.lastNumber = null; - var rightChar = tokenStr.charAt(0); - var lastChar = this.lastChar; - this.lastChar = tokenStr.charAt(tokenStr.length - 1); - if (lastChar && ((lastChar == "+" || lastChar == "-") && lastChar == rightChar || _esutils.code.isIdentifierPartES6(lastChar.charCodeAt(0)) && _esutils.code.isIdentifierPartES6(rightChar.charCodeAt(0)) || lastChar == "/" && rightChar == "i")) { - this.result += " "; - } +/***/ }, +/* 41 */ +/***/ function(module, exports) { - this.result += tokenStr; - } - }]); + + var indexOf = [].indexOf; - return TokenStream; - }(); + module.exports = function(arr, obj){ + if (indexOf) return arr.indexOf(obj); + for (var i = 0; i < arr.length; ++i) { + if (arr[i] === obj) return i; + } + return -1; + }; /***/ }, -/* 44 */ +/* 42 */ /***/ function(module, exports, __webpack_require__) { "use strict"; @@ -30026,504 +28590,423 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack Object.defineProperty(exports, "__esModule", { value: true }); - exports.Scope = exports.freshScope = undefined; - var _errors = __webpack_require__(13); + var _tokenizer = __webpack_require__(43); - var _symbol = __webpack_require__(45); + var _tokenizer2 = _interopRequireDefault(_tokenizer); - let scopeIndex_625 = 0; - function freshScope_626() { - let name_628 = arguments.length <= 0 || arguments[0] === undefined ? "scope" : arguments[0]; + var _immutable = __webpack_require__(3); - scopeIndex_625++; - return (0, _symbol.Symbol)(name_628 + "_" + scopeIndex_625); - } - ; - function Scope_627(name_629) { - return (0, _symbol.Symbol)(name_629); - } - exports.freshScope = freshScope_626; - exports.Scope = Scope_627; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L3Njb3BlLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQSxJQUFJLGlCQUFpQixDQUFyQjtBQUNBLFNBQVMsY0FBVCxHQUE0QztBQUFBLE1BQXBCLFFBQW9CLHlEQUFULE9BQVM7O0FBQzFDO0FBQ0EsU0FBTyxvQkFBTyxXQUFXLEdBQVgsR0FBaUIsY0FBeEIsQ0FBUDtBQUNEO0FBQ0Q7QUFDQSxTQUFTLFNBQVQsQ0FBbUIsUUFBbkIsRUFBNkI7QUFDM0IsU0FBTyxvQkFBTyxRQUFQLENBQVA7QUFDRDtRQUN5QixVLEdBQWxCLGM7UUFDYSxLLEdBQWIsUyIsImZpbGUiOiJzY29wZS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7ZXhwZWN0LCBhc3NlcnR9IGZyb20gXCIuL2Vycm9yc1wiO1xuaW1wb3J0IHtTeW1ib2wsIGdlbnN5bX0gZnJvbSBcIi4vc3ltYm9sXCI7XG5sZXQgc2NvcGVJbmRleF82MjUgPSAwO1xuZnVuY3Rpb24gZnJlc2hTY29wZV82MjYobmFtZV82MjggPSBcInNjb3BlXCIpIHtcbiAgc2NvcGVJbmRleF82MjUrKztcbiAgcmV0dXJuIFN5bWJvbChuYW1lXzYyOCArIFwiX1wiICsgc2NvcGVJbmRleF82MjUpO1xufVxuO1xuZnVuY3Rpb24gU2NvcGVfNjI3KG5hbWVfNjI5KSB7XG4gIHJldHVybiBTeW1ib2wobmFtZV82MjkpO1xufVxuZXhwb3J0IHtmcmVzaFNjb3BlXzYyNiBhcyBmcmVzaFNjb3BlfTtcbmV4cG9ydCB7U2NvcGVfNjI3IGFzIFNjb3BlfSJdfQ== + var _syntax = __webpack_require__(46); -/***/ }, -/* 45 */ -/***/ function(module, exports) { + var _syntax2 = _interopRequireDefault(_syntax); - "use strict"; + var _ramda = __webpack_require__(10); - Object.defineProperty(exports, "__esModule", { - value: true - }); - let internedMap_815 = new Map(); - let counter_816 = 0; - function gensym_817(name_820) { - let prefix_821 = name_820 == null ? "s_" : name_820 + "_"; - let sym_822 = new Symbol_818(prefix_821 + counter_816); - counter_816++; - return sym_822; - } - function Symbol_818(name_823) { - this.name = name_823; - } - Symbol_818.prototype.toString = function () { - return this.name; - }; - function makeSymbol_819(name_824) { - if (internedMap_815.has(name_824)) { - return internedMap_815.get(name_824); - } else { - let sym = new Symbol_818(name_824); - internedMap_815.set(name_824, sym); - return sym; - } - } - exports.Symbol = makeSymbol_819; - exports.SymbolClass = Symbol_818; - exports.gensym = gensym_817; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L3N5bWJvbC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLElBQUksa0JBQWtCLElBQUksR0FBSixFQUF0QjtBQUNBLElBQUksY0FBYyxDQUFsQjtBQUNBLFNBQVMsVUFBVCxDQUFvQixRQUFwQixFQUE4QjtBQUM1QixNQUFJLGFBQWEsWUFBWSxJQUFaLEdBQW1CLElBQW5CLEdBQTBCLFdBQVcsR0FBdEQ7QUFDQSxNQUFJLFVBQVUsSUFBSSxVQUFKLENBQWUsYUFBYSxXQUE1QixDQUFkO0FBQ0E7QUFDQSxTQUFPLE9BQVA7QUFDRDtBQUNELFNBQVMsVUFBVCxDQUFvQixRQUFwQixFQUE4QjtBQUM1QixPQUFLLElBQUwsR0FBWSxRQUFaO0FBQ0Q7QUFDRCxXQUFXLFNBQVgsQ0FBcUIsUUFBckIsR0FBZ0MsWUFBWTtBQUMxQyxTQUFPLEtBQUssSUFBWjtBQUNELENBRkQ7QUFHQSxTQUFTLGNBQVQsQ0FBd0IsUUFBeEIsRUFBa0M7QUFDaEMsTUFBSSxnQkFBZ0IsR0FBaEIsQ0FBb0IsUUFBcEIsQ0FBSixFQUFtQztBQUNqQyxXQUFPLGdCQUFnQixHQUFoQixDQUFvQixRQUFwQixDQUFQO0FBQ0QsR0FGRCxNQUVPO0FBQ0wsUUFBSSxNQUFNLElBQUksVUFBSixDQUFlLFFBQWYsQ0FBVjtBQUNBLG9CQUFnQixHQUFoQixDQUFvQixRQUFwQixFQUE4QixHQUE5QjtBQUNBLFdBQU8sR0FBUDtBQUNEO0FBQ0Y7UUFDeUIsTSxHQUFsQixjO1FBQXdDLFcsR0FBZCxVO1FBQ1osTSxHQUFkLFUiLCJmaWxlIjoic3ltYm9sLmpzIiwic291cmNlc0NvbnRlbnQiOlsibGV0IGludGVybmVkTWFwXzgxNSA9IG5ldyBNYXA7XG5sZXQgY291bnRlcl84MTYgPSAwO1xuZnVuY3Rpb24gZ2Vuc3ltXzgxNyhuYW1lXzgyMCkge1xuICBsZXQgcHJlZml4XzgyMSA9IG5hbWVfODIwID09IG51bGwgPyBcInNfXCIgOiBuYW1lXzgyMCArIFwiX1wiO1xuICBsZXQgc3ltXzgyMiA9IG5ldyBTeW1ib2xfODE4KHByZWZpeF84MjEgKyBjb3VudGVyXzgxNik7XG4gIGNvdW50ZXJfODE2Kys7XG4gIHJldHVybiBzeW1fODIyO1xufVxuZnVuY3Rpb24gU3ltYm9sXzgxOChuYW1lXzgyMykge1xuICB0aGlzLm5hbWUgPSBuYW1lXzgyMztcbn1cblN5bWJvbF84MTgucHJvdG90eXBlLnRvU3RyaW5nID0gZnVuY3Rpb24gKCkge1xuICByZXR1cm4gdGhpcy5uYW1lO1xufTtcbmZ1bmN0aW9uIG1ha2VTeW1ib2xfODE5KG5hbWVfODI0KSB7XG4gIGlmIChpbnRlcm5lZE1hcF84MTUuaGFzKG5hbWVfODI0KSkge1xuICAgIHJldHVybiBpbnRlcm5lZE1hcF84MTUuZ2V0KG5hbWVfODI0KTtcbiAgfSBlbHNlIHtcbiAgICBsZXQgc3ltID0gbmV3IFN5bWJvbF84MTgobmFtZV84MjQpO1xuICAgIGludGVybmVkTWFwXzgxNS5zZXQobmFtZV84MjQsIHN5bSk7XG4gICAgcmV0dXJuIHN5bTtcbiAgfVxufVxuZXhwb3J0IHttYWtlU3ltYm9sXzgxOSBhcyBTeW1ib2wsIFN5bWJvbF84MTggYXMgU3ltYm9sQ2xhc3N9O1xuZXhwb3J0IHtnZW5zeW1fODE3IGFzIGdlbnN5bX0iXX0= + var R = _interopRequireWildcard(_ramda); -/***/ }, -/* 46 */ -/***/ function(module, exports, __webpack_require__) { + var _ramdaFantasy = __webpack_require__(24); - "use strict"; + var _errors = __webpack_require__(23); - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.Modules = exports.Module = undefined; + var _terms = __webpack_require__(9); - var _immutable = __webpack_require__(11); + var _terms2 = _interopRequireDefault(_terms); - var _env = __webpack_require__(31); + function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } - var _env2 = _interopRequireDefault(_env); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - var _store = __webpack_require__(47); + const Just = _ramdaFantasy.Maybe.Just; + const Nothing = _ramdaFantasy.Maybe.Nothing; - var _store2 = _interopRequireDefault(_store); - var _shiftReader = __webpack_require__(3); + const LSYNTAX = { name: 'left-syntax' }; + const RSYNTAX = { name: 'right-syntax' }; + const AT = { klass: _tokenizer.TokenClass.Punctuator, name: "@" }; - var _shiftReader2 = _interopRequireDefault(_shiftReader); + // TODO: also, need to handle contextual yield + const literalKeywords = ['this', 'null', 'true', 'false']; - var _tokenExpander = __webpack_require__(50); + // Token -> Boolean + const isLeftBracket = R.whereEq({ type: _tokenizer.TokenType.LBRACK }); + const isLeftBrace = R.whereEq({ type: _tokenizer.TokenType.LBRACE }); + const isLeftParen = R.whereEq({ type: _tokenizer.TokenType.LPAREN }); + const isRightBracket = R.whereEq({ type: _tokenizer.TokenType.RBRACK }); + const isRightBrace = R.whereEq({ type: _tokenizer.TokenType.RBRACE }); + const isRightParen = R.whereEq({ type: _tokenizer.TokenType.RPAREN }); - var _tokenExpander2 = _interopRequireDefault(_tokenExpander); + const isEOS = R.whereEq({ type: _tokenizer.TokenType.EOS }); - var _termExpander = __webpack_require__(54); + // const isHash = R.whereEq({ type: TokenType.IDENTIFIER, value: '#'}); + const isLeftSyntax = R.whereEq({ type: LSYNTAX }); + const isRightSyntax = R.whereEq({ type: RSYNTAX }); - var _termExpander2 = _interopRequireDefault(_termExpander); + const isLeftDelimiter = R.anyPass([isLeftBracket, isLeftBrace, isLeftParen, isLeftSyntax]); - var _bindingMap = __webpack_require__(14); + const isRightDelimiter = R.anyPass([isRightBracket, isRightBrace, isRightParen, isRightSyntax]); - var _bindingMap2 = _interopRequireDefault(_bindingMap); + const isMatchingDelimiters = R.cond([[isLeftBracket, (_, b) => isRightBracket(b)], [isLeftBrace, (_, b) => isRightBrace(b)], [isLeftParen, (_, b) => isRightParen(b)], [isLeftSyntax, (_, b) => isRightSyntax(b)], [R.T, R.F]]); - var _symbol = __webpack_require__(45); + const assignOps = ["=", "+=", "-=", "*=", "/=", "%=", "<<=", ">>=", ">>>=", "&=", "|=", "^=", ","]; - var _terms = __webpack_require__(28); + const binaryOps = ["+", "-", "*", "/", "%", "<<", ">>", ">>>", "&", "|", "^", "&&", "||", "?", ":", "===", "==", ">=", "<=", "<", ">", "!=", "!==", "instanceof"]; - var _terms2 = _interopRequireDefault(_terms); + const unaryOps = ["++", "--", "~", "!", "delete", "void", "typeof", "yield", "throw", "new"]; - var _loadSyntax = __webpack_require__(53); + // List -> Boolean + const isEmpty = R.whereEq({ size: 0 }); - var _compiler = __webpack_require__(56); + // Syntax -> Boolean + const isPunctuator = s => s.match("punctuator"); + const isKeyword = s => s.match("keyword"); + const isParens = s => s.match("parens"); + const isBraces = s => s.match("braces"); + const isIdentifier = s => s.match("identifier"); - var _compiler2 = _interopRequireDefault(_compiler); + // Any -> Syntax -> Boolean + const isVal = R.curry((v, s) => s.val() === v); - var _transforms = __webpack_require__(32); + // Syntax -> Boolean + const isDot = R.allPass([isPunctuator, isVal('.')]); + const isColon = R.allPass([isPunctuator, isVal(':')]); + const isFunctionKeyword = R.allPass([isKeyword, isVal('function')]); + const isOperator = s => (s.match("punctuator") || s.match("keyword")) && R.any(R.equals(s.val()), assignOps.concat(binaryOps).concat(unaryOps)); + const isNonLiteralKeyword = R.allPass([isKeyword, s => R.none(R.equals(s.val()), literalKeywords)]); + const isKeywordExprPrefix = R.allPass([isKeyword, s => R.any(R.equals(s.val()), ['instanceof', 'typeof', 'delete', 'void', 'yield', 'throw', 'new', 'case'])]); + // List a -> a? + let last = p => p.last(); + // List a -> Maybe a + let safeLast = R.pipe(R.cond([[isEmpty, R.always(Nothing())], [R.T, R.compose(_ramdaFantasy.Maybe.of, last)]])); - var _scope = __webpack_require__(44); + // TODO: better name + // List -> Boolean -> Maybe List + let stuffTrue = R.curry((p, b) => b ? Just(p) : Nothing()); + let stuffFalse = R.curry((p, b) => !b ? Just(p) : Nothing()); - var _errors = __webpack_require__(13); + // List a -> Boolean + let isTopColon = R.pipe(safeLast, R.map(isColon), _ramdaFantasy.Maybe.maybe(false, R.identity)); + // List a -> Boolean + let isTopPunctuator = R.pipe(safeLast, R.map(isPunctuator), _ramdaFantasy.Maybe.maybe(false, R.identity)); - var _hygieneUtils = __webpack_require__(67); + // Number -> List -> Boolean + let isExprReturn = R.curry((l, p) => { + let retKwd = safeLast(p); + let maybeDot = pop(p).chain(safeLast); - var _syntax = __webpack_require__(12); + if (maybeDot.map(isDot).getOrElse(false)) { + return true; + } + return retKwd.map(s => { + return s.match("keyword") && s.val() === 'return' && s.lineNumber() === l; + }).getOrElse(false); + }); - var _utilsDirname = __webpack_require__(68); + const isTopOperator = R.pipe(safeLast, R.map(isOperator), _ramdaFantasy.Maybe.maybe(false, R.identity)); + + const isTopKeywordExprPrefix = R.pipe(safeLast, R.map(isKeywordExprPrefix), _ramdaFantasy.Maybe.maybe(false, R.identity)); + + // Number -> Boolean -> List -> Boolean + let isExprPrefix = R.curry((l, b) => R.cond([ + // ... ({x: 42} /r/i) + [isEmpty, R.always(b)], + // ... ({x: {x: 42} /r/i }) + [isTopColon, R.always(b)], + // ... throw {x: 42} /r/i + [isTopKeywordExprPrefix, R.T], + // ... 42 + {x: 42} /r/i + [isTopOperator, R.T], + // ... for ( ; {x: 42}/r/i) + [isTopPunctuator, R.always(b)], + // ... return {x: 42} /r /i + // ... return\n{x: 42} /r /i + [isExprReturn(l), R.T], [R.T, R.F]])); + + // List a -> Maybe List a + let curly = p => safeLast(p).map(isBraces).chain(stuffTrue(p)); + let paren = p => safeLast(p).map(isParens).chain(stuffTrue(p)); + let func = p => safeLast(p).map(isFunctionKeyword).chain(stuffTrue(p)); + let ident = p => safeLast(p).map(isIdentifier).chain(stuffTrue(p)); + let nonLiteralKeyword = p => safeLast(p).map(isNonLiteralKeyword).chain(stuffTrue(p)); + + let opt = R.curry((a, b, p) => { + let result = R.pipeK(a, b)(_ramdaFantasy.Maybe.of(p)); + return _ramdaFantasy.Maybe.isJust(result) ? result : _ramdaFantasy.Maybe.of(p); + }); - var _utilsDirname2 = _interopRequireDefault(_utilsDirname); + let notDot = R.ifElse(R.whereEq({ size: 0 }), Just, p => safeLast(p).map(s => !(s.match("punctuator") && s.val() === '.')).chain(stuffTrue(p))); + + // List a -> Maybe List a + let pop = R.compose(Just, p => p.pop()); + + // Maybe List a -> Maybe List a + const functionPrefix = R.pipeK(curly, pop, paren, pop, opt(ident, pop), func); + + // Boolean -> List a -> Boolean + const isRegexPrefix = b => R.anyPass([ + // ε + isEmpty, + // P . t where t ∈ Punctuator + isTopPunctuator, + // P . t . t' where t \not = "." and t' ∈ (Keyword \setminus LiteralKeyword) + R.pipe(_ramdaFantasy.Maybe.of, R.pipeK(nonLiteralKeyword, pop, notDot), _ramdaFantasy.Maybe.isJust), + // P . t . t' . (T) where t \not = "." and t' ∈ (Keyword \setminus LiteralKeyword) + R.pipe(_ramdaFantasy.Maybe.of, R.pipeK(paren, pop, nonLiteralKeyword, pop, notDot), _ramdaFantasy.Maybe.isJust), + // P . function^l . x? . () . {} where isExprPrefix(P, b, l) = false + R.pipe(_ramdaFantasy.Maybe.of, functionPrefix, R.chain(p => { + return safeLast(p).map(s => s.lineNumber()).chain(fnLine => { + return pop(p).map(isExprPrefix(fnLine, b)); + }).chain(stuffFalse(p)); + }), _ramdaFantasy.Maybe.isJust), + // P . {T}^l where isExprPrefix(P, b, l) = false + p => { + let alreadyCheckedFunction = R.pipe(_ramdaFantasy.Maybe.of, functionPrefix, _ramdaFantasy.Maybe.isJust)(p); + if (alreadyCheckedFunction) { + return false; + } + return R.pipe(_ramdaFantasy.Maybe.of, R.chain(curly), R.chain(p => { + return safeLast(p).map(s => s.lineNumber()).chain(curlyLine => { + return pop(p).map(isExprPrefix(curlyLine, b)); + }).chain(stuffFalse(p)); + }), _ramdaFantasy.Maybe.isJust)(p); + }]); - var _ramda = __webpack_require__(27); + function lastEl(l) { + return l[l.length - 1]; + } - var _ = _interopRequireWildcard(_ramda); + class Reader extends _tokenizer2.default { + constructor(strings, context, replacements) { + super(Array.isArray(strings) ? strings.join('') : strings); + this.delimStack = new Map(); + this.insideSyntaxTemplate = [false]; + this.context = context; - function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + // setup splicing replacement array + if (Array.isArray(strings)) { + let totalIndex = 0; + this.replacementIndex = R.reduce((acc, strRep) => { + acc.push({ + index: totalIndex + strRep[0].length, + replacement: strRep[1] + }); + totalIndex += strRep[0].length; + return acc; + }, [], R.zip(strings, replacements)); + } + } - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + read() { + let stack = arguments.length <= 0 || arguments[0] === undefined ? [] : arguments[0]; + let b = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1]; + let singleDelimiter = arguments.length <= 2 || arguments[2] === undefined ? false : arguments[2]; - class Module_469 { - constructor(moduleSpecifier_474, isNative_475, importEntries_476, exportEntries_477, pragmas_478, body_479) { - this.moduleSpecifier = moduleSpecifier_474; - this.isNative = isNative_475; - this.importEntries = importEntries_476; - this.exportEntries = exportEntries_477; - this.pragmas = pragmas_478; - this.body = body_479; - } - } - const findBindingIdentifierName_470 = term_480 => { - (0, _errors.assert)(term_480.name, `not implemented yet for type ${ term_480.type }`); - return term_480.name; - }; - const convertExport_471 = term_481 => { - let declaration_482 = term_481.declaration; - let bindings_483 = []; - if ((0, _terms.isVariableDeclaration)(declaration_482)) { - bindings_483 = declaration_482.declarators.map(decl_485 => findBindingIdentifierName_470(decl_485.binding)); - } else if ((0, _terms.isFunctionDeclaration)(declaration_482) || (0, _terms.isClassDeclaration)(declaration_482)) { - bindings_483.push(findBindingIdentifierName_470(declaration_482.name)); - } - let namedExports_484 = bindings_483.map(binding_486 => { - return new _terms2.default("ExportSpecifier", { name: null, exportedName: binding_486 }); - }); - return new _terms2.default("ExportFrom", { moduleSpecifier: null, namedExports: (0, _immutable.List)(namedExports_484) }); - }; - const pragmaRegep_472 = /^\s*#\w*/; - class Modules_473 { - constructor(context_487) { - this.compiledModules = new Map(); - this.context = context_487; - this.context.modules = this; - } - loadString(str_488) { - let checkPragma_489 = arguments.length <= 1 || arguments[1] === undefined ? true : arguments[1]; - - let hasPragma_490 = pragmaRegep_472.test(str_488); - if (checkPragma_489 && !hasPragma_490) { - return { isNative: true, body: (0, _immutable.List)() }; - } - return { isNative: !hasPragma_490, body: new _shiftReader2.default(str_488).read() }; - } - load(path_491) { - return this.loadString(this.context.moduleLoader(path_491)); - } - compile(mod_492, path_493) { - let stxl_494 = mod_492.body; - let outScope_495 = (0, _scope.freshScope)("outsideEdge"); - let inScope_496 = (0, _scope.freshScope)(`insideEdge0`); - let compiler_497 = new _compiler2.default(0, new _env2.default(), new _store2.default(), _.merge(this.context, { currentScope: [outScope_495, inScope_496], cwd: path_493 === "<>" ? this.context.cwd : (0, _utilsDirname2.default)(path_493) })); - let terms_498 = compiler_497.compile(stxl_494.map(s_503 => s_503.addScope(outScope_495, this.context.bindings, _syntax.ALL_PHASES).addScope(inScope_496, this.context.bindings, 0))); - let importEntries_499 = []; - let exportEntries_500 = []; - let pragmas_501 = []; - let filteredTerms_502 = terms_498.reduce((acc_504, t_505) => { - return _.cond([[_terms.isImport, t_506 => { - importEntries_499.push(t_506); - return acc_504; - }], [_terms.isExport, t_507 => { - if (t_507.declaration) { - exportEntries_500.push(convertExport_471(t_507)); - if ((0, _terms.isVariableDeclaration)(t_507.declaration)) { - return acc_504.concat(new _terms2.default("VariableDeclarationStatement", { declaration: t_507.declaration })); - } - return acc_504.concat(t_507.declaration); - } - exportEntries_500.push(t_507); - return acc_504; - }], [_terms.isPragma, t_508 => { - pragmas_501.push(t_508); - return acc_504; - }], [_.T, t_509 => acc_504.concat(t_509)]])(t_505); - }, (0, _immutable.List)()); - return new Module_469(path_493, mod_492.isNative, (0, _immutable.List)(importEntries_499), (0, _immutable.List)(exportEntries_500), (0, _immutable.List)(pragmas_501), filteredTerms_502); - } - compileEntrypoint(source_510, filename_511) { - let enforcePragma_512 = arguments.length <= 2 || arguments[2] === undefined ? false : arguments[2]; + let prefix = (0, _immutable.List)(); + while (true) { + let tok = this.advance(prefix, b); - let stxl_513 = this.loadString(source_510, false); - if (enforcePragma_512 && stxl_513.isNative) { - throw new Error(`Entrypoint ${ filename_511 } must begin with #lang pragma`); - } - return this.getAtPhase("<>", 0, this.context.cwd, stxl_513); - } - getAtPhase(rawPath_514, phase_515, cwd_516) { - let rawStxl_517 = arguments.length <= 3 || arguments[3] === undefined ? null : arguments[3]; + // splicing allows syntax and terms + if (tok.scopesets || tok instanceof _terms2.default) { + stack.push(tok); + continue; + } + if (Array.isArray(tok)) { + Array.prototype.push.apply(stack, tok); + continue; + } + if (_immutable.List.isList(tok)) { + Array.prototype.push.apply(stack, tok.toArray()); + continue; + } - let path_518 = rawPath_514 === "<>" ? rawPath_514 : this.context.moduleResolver(rawPath_514, cwd_516); - let mapKey_519 = `${ path_518 }:${ phase_515 }`; - if (!this.compiledModules.has(mapKey_519)) { - if (phase_515 === 0) { - let stxl = rawStxl_517 != null ? rawStxl_517 : this.load(path_518); - this.compiledModules.set(mapKey_519, this.compile(stxl, path_518)); - } else { - let rawMod = this.getAtPhase(rawPath_514, 0, cwd_516, rawStxl_517); - let scope = (0, _scope.freshScope)(`insideEdge${ phase_515 }`); - this.compiledModules.set(mapKey_519, new Module_469(rawMod.moduleSpecifier, false, rawMod.importEntries.map(term_520 => term_520.addScope(scope, this.context.bindings, phase_515)), rawMod.exportEntries.map(term_521 => term_521.addScope(scope, this.context.bindings, phase_515)), rawMod.pragmas, rawMod.body.map(term_522 => term_522.addScope(scope, this.context.bindings, phase_515)))); + if (isEOS(tok)) { + if (stack[0] && isLeftDelimiter(stack[0].token)) { + throw this.createUnexpected(tok); + } + break; } - } - return this.compiledModules.get(mapKey_519); - } - has(rawPath_523) { - let phase_524 = arguments.length <= 1 || arguments[1] === undefined ? 0 : arguments[1]; - let path_525 = rawPath_523 === "<>" ? rawPath_523 : this.context.moduleResolver(rawPath_523, this.context.cwd); - let key_526 = `${ path_525 }:${ phase_524 }`; - return this.compiledModules.has(key_526) && !this.compiledModules.get(key_526).isNative; - } - registerSyntaxDeclaration(term_527, phase_528, store_529) { - term_527.declarators.forEach(decl_530 => { - let val_531 = (0, _loadSyntax.evalCompiletimeValue)(decl_530.init.gen(), _.merge(this.context, { phase: phase_528 + 1, store: store_529 })); - (0, _hygieneUtils.collectBindings)(decl_530.binding).forEach(stx_532 => { - if (phase_528 !== 0) { - let newBinding = (0, _symbol.gensym)(stx_532.val()); - this.context.bindings.add(stx_532, { binding: newBinding, phase: phase_528, skipDup: false }); + if (isLeftDelimiter(tok)) { + if (isLeftSyntax(tok)) { + this.insideSyntaxTemplate.push(true); } - let resolvedName_533 = stx_532.resolve(phase_528); - store_529.set(resolvedName_533, new _transforms.CompiletimeTransform(val_531)); - }); - }); - } - registerVariableDeclaration(term_534, phase_535, store_536) { - term_534.declarators.forEach(decl_537 => { - (0, _hygieneUtils.collectBindings)(decl_537.binding).forEach(stx_538 => { - if (phase_535 !== 0) { - let newBinding = (0, _symbol.gensym)(stx_538.val()); - this.context.bindings.add(stx_538, { binding: newBinding, phase: phase_535, skipDup: term_534.kind === "var" }); + let line = tok.slice.startLocation.line; + let innerB = isLeftBrace(tok) ? isExprPrefix(line, b)(prefix) : true; + let inner = this.read([new _syntax2.default(tok, this.context)], innerB, false); + let stx = new _syntax2.default(inner, this.context); + prefix = prefix.concat(stx); + stack.push(stx); + if (singleDelimiter) { + break; } - let resolvedName_539 = stx_538.resolve(phase_535); - store_536.set(resolvedName_539, new _transforms.VarBindingTransform(stx_538)); - }); - }); - } - registerFunctionOrClass(term_540, phase_541, store_542) { - (0, _hygieneUtils.collectBindings)(term_540.name).forEach(stx_543 => { - if (phase_541 !== 0) { - let newBinding = (0, _symbol.gensym)(stx_543.val()); - this.context.bindings.add(stx_543, { binding: newBinding, phase: phase_541, skipDup: false }); - } - let resolvedName_544 = stx_543.resolve(phase_541); - store_542.set(resolvedName_544, new _transforms.VarBindingTransform(stx_543)); - }); - } - visit(mod_545, phase_546, store_547) { - mod_545.body.forEach(term_548 => { - if ((0, _terms.isSyntaxDeclarationStatement)(term_548)) { - this.registerSyntaxDeclaration(term_548.declaration, phase_546, store_547); - } - }); - return store_547; - } - invoke(mod_549, phase_550, store_551) { - let body_552 = mod_549.body.filter(_.complement(_terms.isCompiletimeStatement)).map(term_554 => { - term_554 = term_554.gen(); - if ((0, _terms.isVariableDeclarationStatement)(term_554)) { - this.registerVariableDeclaration(term_554.declaration, phase_550, store_551); - } else if ((0, _terms.isFunctionDeclaration)(term_554)) { - this.registerFunctionOrClass(term_554, phase_550, store_551); + } else if (isRightDelimiter(tok)) { + if (stack[0] && !isMatchingDelimiters(stack[0].token, tok)) { + throw this.createUnexpected(tok); + } + let stx = new _syntax2.default(tok, this.context); + stack.push(stx); + if (lastEl(this.insideSyntaxTemplate) && isRightSyntax(tok)) { + this.insideSyntaxTemplate.pop(); + } + break; + } else { + let stx = new _syntax2.default(tok, this.context); + prefix = prefix.concat(stx); + stack.push(stx); } - return term_554; - }); - let exportsObj_553 = (0, _loadSyntax.evalRuntimeValues)(body_552, _.merge(this.context, { store: store_551, phase: phase_550 })); - return store_551; + } + return (0, _immutable.List)(stack); } - } - exports.Module = Module_469; - exports.Modules = Modules_473; - //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/modules.js"],"names":[],"mappings":"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","file":"modules.js","sourcesContent":["import {List} from \"immutable\";\nimport Env from \"./env\";\nimport Store from \"./store\";\nimport Reader from \"./shift-reader\";\nimport TokenExpander from \"./token-expander.js\";\nimport TermExpander from \"./term-expander.js\";\nimport BindingMap from \"./binding-map.js\";\nimport {gensym} from \"./symbol\";\nimport Term, {isEOF, isBindingIdentifier, isFunctionDeclaration, isFunctionExpression, isFunctionTerm, isFunctionWithName, isSyntaxDeclaration, isSyntaxrecDeclaration, isVariableDeclaration, isVariableDeclarationStatement, isImport, isExport, isExportFrom, isExportAllFrom, isExportDefault, isExportSyntax, isSyntaxDeclarationStatement, isPragma, isCompiletimeDeclaration, isCompiletimeStatement, isClassDeclaration} from \"./terms\";\nimport {evalCompiletimeValue, evalRuntimeValues} from \"./load-syntax\";\nimport Compiler from \"./compiler\";\nimport {VarBindingTransform, CompiletimeTransform} from \"./transforms\";\nimport {Scope, freshScope} from \"./scope\";\nimport {assert} from \"./errors\";\nimport {collectBindings} from \"./hygiene-utils\";\nimport {ALL_PHASES} from \"./syntax\";\nimport dirname from \"utils-dirname\";\nimport  * as _ from \"ramda\";\nclass Module_469 {\n  constructor(moduleSpecifier_474, isNative_475, importEntries_476, exportEntries_477, pragmas_478, body_479) {\n    this.moduleSpecifier = moduleSpecifier_474;\n    this.isNative = isNative_475;\n    this.importEntries = importEntries_476;\n    this.exportEntries = exportEntries_477;\n    this.pragmas = pragmas_478;\n    this.body = body_479;\n  }\n}\nconst findBindingIdentifierName_470 = term_480 => {\n  assert(term_480.name, `not implemented yet for type ${term_480.type}`);\n  return term_480.name;\n};\nconst convertExport_471 = term_481 => {\n  let declaration_482 = term_481.declaration;\n  let bindings_483 = [];\n  if (isVariableDeclaration(declaration_482)) {\n    bindings_483 = declaration_482.declarators.map(decl_485 => findBindingIdentifierName_470(decl_485.binding));\n  } else if (isFunctionDeclaration(declaration_482) || isClassDeclaration(declaration_482)) {\n    bindings_483.push(findBindingIdentifierName_470(declaration_482.name));\n  }\n  let namedExports_484 = bindings_483.map(binding_486 => {\n    return new Term(\"ExportSpecifier\", {name: null, exportedName: binding_486});\n  });\n  return new Term(\"ExportFrom\", {moduleSpecifier: null, namedExports: List(namedExports_484)});\n};\nconst pragmaRegep_472 = /^\\s*#\\w*/;\nclass Modules_473 {\n  constructor(context_487) {\n    this.compiledModules = new Map;\n    this.context = context_487;\n    this.context.modules = this;\n  }\n  loadString(str_488, checkPragma_489 = true) {\n    let hasPragma_490 = pragmaRegep_472.test(str_488);\n    if (checkPragma_489 && !hasPragma_490) {\n      return {isNative: true, body: List()};\n    }\n    return {isNative: !hasPragma_490, body: new Reader(str_488).read()};\n  }\n  load(path_491) {\n    return this.loadString(this.context.moduleLoader(path_491));\n  }\n  compile(mod_492, path_493) {\n    let stxl_494 = mod_492.body;\n    let outScope_495 = freshScope(\"outsideEdge\");\n    let inScope_496 = freshScope(`insideEdge0`);\n    let compiler_497 = new Compiler(0, new Env, new Store, _.merge(this.context, {currentScope: [outScope_495, inScope_496], cwd: path_493 === \"<<entrypoint>>\" ? this.context.cwd : dirname(path_493)}));\n    let terms_498 = compiler_497.compile(stxl_494.map(s_503 => s_503.addScope(outScope_495, this.context.bindings, ALL_PHASES).addScope(inScope_496, this.context.bindings, 0)));\n    let importEntries_499 = [];\n    let exportEntries_500 = [];\n    let pragmas_501 = [];\n    let filteredTerms_502 = terms_498.reduce((acc_504, t_505) => {\n      return _.cond([[isImport, t_506 => {\n        importEntries_499.push(t_506);\n        return acc_504;\n      }], [isExport, t_507 => {\n        if (t_507.declaration) {\n          exportEntries_500.push(convertExport_471(t_507));\n          if (isVariableDeclaration(t_507.declaration)) {\n            return acc_504.concat(new Term(\"VariableDeclarationStatement\", {declaration: t_507.declaration}));\n          }\n          return acc_504.concat(t_507.declaration);\n        }\n        exportEntries_500.push(t_507);\n        return acc_504;\n      }], [isPragma, t_508 => {\n        pragmas_501.push(t_508);\n        return acc_504;\n      }], [_.T, t_509 => acc_504.concat(t_509)]])(t_505);\n    }, List());\n    return new Module_469(path_493, mod_492.isNative, List(importEntries_499), List(exportEntries_500), List(pragmas_501), filteredTerms_502);\n  }\n  compileEntrypoint(source_510, filename_511, enforcePragma_512 = false) {\n    let stxl_513 = this.loadString(source_510, false);\n    if (enforcePragma_512 && stxl_513.isNative) {\n      throw new Error(`Entrypoint ${filename_511} must begin with #lang pragma`);\n    }\n    return this.getAtPhase(\"<<entrypoint>>\", 0, this.context.cwd, stxl_513);\n  }\n  getAtPhase(rawPath_514, phase_515, cwd_516, rawStxl_517 = null) {\n    let path_518 = rawPath_514 === \"<<entrypoint>>\" ? rawPath_514 : this.context.moduleResolver(rawPath_514, cwd_516);\n    let mapKey_519 = `${path_518}:${phase_515}`;\n    if (!this.compiledModules.has(mapKey_519)) {\n      if (phase_515 === 0) {\n        let stxl = rawStxl_517 != null ? rawStxl_517 : this.load(path_518);\n        this.compiledModules.set(mapKey_519, this.compile(stxl, path_518));\n      } else {\n        let rawMod = this.getAtPhase(rawPath_514, 0, cwd_516, rawStxl_517);\n        let scope = freshScope(`insideEdge${phase_515}`);\n        this.compiledModules.set(mapKey_519, new Module_469(rawMod.moduleSpecifier, false, rawMod.importEntries.map(term_520 => term_520.addScope(scope, this.context.bindings, phase_515)), rawMod.exportEntries.map(term_521 => term_521.addScope(scope, this.context.bindings, phase_515)), rawMod.pragmas, rawMod.body.map(term_522 => term_522.addScope(scope, this.context.bindings, phase_515))));\n      }\n    }\n    return this.compiledModules.get(mapKey_519);\n  }\n  has(rawPath_523, phase_524 = 0) {\n    let path_525 = rawPath_523 === \"<<entrypoint>>\" ? rawPath_523 : this.context.moduleResolver(rawPath_523, this.context.cwd);\n    let key_526 = `${path_525}:${phase_524}`;\n    return this.compiledModules.has(key_526) && !this.compiledModules.get(key_526).isNative;\n  }\n  registerSyntaxDeclaration(term_527, phase_528, store_529) {\n    term_527.declarators.forEach(decl_530 => {\n      let val_531 = evalCompiletimeValue(decl_530.init.gen(), _.merge(this.context, {phase: phase_528 + 1, store: store_529}));\n      collectBindings(decl_530.binding).forEach(stx_532 => {\n        if (phase_528 !== 0) {\n          let newBinding = gensym(stx_532.val());\n          this.context.bindings.add(stx_532, {binding: newBinding, phase: phase_528, skipDup: false});\n        }\n        let resolvedName_533 = stx_532.resolve(phase_528);\n        store_529.set(resolvedName_533, new CompiletimeTransform(val_531));\n      });\n    });\n  }\n  registerVariableDeclaration(term_534, phase_535, store_536) {\n    term_534.declarators.forEach(decl_537 => {\n      collectBindings(decl_537.binding).forEach(stx_538 => {\n        if (phase_535 !== 0) {\n          let newBinding = gensym(stx_538.val());\n          this.context.bindings.add(stx_538, {binding: newBinding, phase: phase_535, skipDup: term_534.kind === \"var\"});\n        }\n        let resolvedName_539 = stx_538.resolve(phase_535);\n        store_536.set(resolvedName_539, new VarBindingTransform(stx_538));\n      });\n    });\n  }\n  registerFunctionOrClass(term_540, phase_541, store_542) {\n    collectBindings(term_540.name).forEach(stx_543 => {\n      if (phase_541 !== 0) {\n        let newBinding = gensym(stx_543.val());\n        this.context.bindings.add(stx_543, {binding: newBinding, phase: phase_541, skipDup: false});\n      }\n      let resolvedName_544 = stx_543.resolve(phase_541);\n      store_542.set(resolvedName_544, new VarBindingTransform(stx_543));\n    });\n  }\n  visit(mod_545, phase_546, store_547) {\n    mod_545.body.forEach(term_548 => {\n      if (isSyntaxDeclarationStatement(term_548)) {\n        this.registerSyntaxDeclaration(term_548.declaration, phase_546, store_547);\n      }\n    });\n    return store_547;\n  }\n  invoke(mod_549, phase_550, store_551) {\n    let body_552 = mod_549.body.filter(_.complement(isCompiletimeStatement)).map(term_554 => {\n      term_554 = term_554.gen();\n      if (isVariableDeclarationStatement(term_554)) {\n        this.registerVariableDeclaration(term_554.declaration, phase_550, store_551);\n      } else if (isFunctionDeclaration(term_554)) {\n        this.registerFunctionOrClass(term_554, phase_550, store_551);\n      }\n      return term_554;\n    });\n    let exportsObj_553 = evalRuntimeValues(body_552, _.merge(this.context, {store: store_551, phase: phase_550}));\n    return store_551;\n  }\n}\nexport {Module_469 as Module};\nexport {Modules_473 as Modules}"]} -/***/ }, -/* 47 */ -/***/ function(module, exports, __webpack_require__) { - - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - - var _vm = __webpack_require__(48); - - var _vm2 = _interopRequireDefault(_vm); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - - class Store { - constructor() { - this.map = new Map(); - this.nodeContext = _vm2.default.createContext(); - } - has(key_793) { - return this.map.has(key_793); - } - get(key_794) { - return this.map.get(key_794); - } - set(key_795, val_796) { - this.nodeContext[key_795] = val_796; - return this.map.set(key_795, val_796); - } - getNodeContext() { - return this.nodeContext; - } - } - exports.default = Store; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L3N0b3JlLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOzs7Ozs7QUFDZSxNQUFNLEtBQU4sQ0FBWTtBQUN6QixnQkFBYztBQUNaLFNBQUssR0FBTCxHQUFXLElBQUksR0FBSixFQUFYO0FBQ0EsU0FBSyxXQUFMLEdBQW1CLGFBQUcsYUFBSCxFQUFuQjtBQUNEO0FBQ0QsTUFBSSxPQUFKLEVBQWE7QUFDWCxXQUFPLEtBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxPQUFiLENBQVA7QUFDRDtBQUNELE1BQUksT0FBSixFQUFhO0FBQ1gsV0FBTyxLQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsT0FBYixDQUFQO0FBQ0Q7QUFDRCxNQUFJLE9BQUosRUFBYSxPQUFiLEVBQXNCO0FBQ3BCLFNBQUssV0FBTCxDQUFpQixPQUFqQixJQUE0QixPQUE1QjtBQUNBLFdBQU8sS0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLE9BQWIsRUFBc0IsT0FBdEIsQ0FBUDtBQUNEO0FBQ0QsbUJBQWlCO0FBQ2YsV0FBTyxLQUFLLFdBQVo7QUFDRDtBQWpCd0I7a0JBQU4sSyIsImZpbGUiOiJzdG9yZS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB2bSBmcm9tIFwidm1cIjtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFN0b3JlIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5tYXAgPSBuZXcgTWFwO1xuICAgIHRoaXMubm9kZUNvbnRleHQgPSB2bS5jcmVhdGVDb250ZXh0KCk7XG4gIH1cbiAgaGFzKGtleV83OTMpIHtcbiAgICByZXR1cm4gdGhpcy5tYXAuaGFzKGtleV83OTMpO1xuICB9XG4gIGdldChrZXlfNzk0KSB7XG4gICAgcmV0dXJuIHRoaXMubWFwLmdldChrZXlfNzk0KTtcbiAgfVxuICBzZXQoa2V5Xzc5NSwgdmFsXzc5Nikge1xuICAgIHRoaXMubm9kZUNvbnRleHRba2V5Xzc5NV0gPSB2YWxfNzk2O1xuICAgIHJldHVybiB0aGlzLm1hcC5zZXQoa2V5Xzc5NSwgdmFsXzc5Nik7XG4gIH1cbiAgZ2V0Tm9kZUNvbnRleHQoKSB7XG4gICAgcmV0dXJuIHRoaXMubm9kZUNvbnRleHQ7XG4gIH1cbn1cbiJdfQ== + advance(prefix, b) { + this.lastIndex = this.index; + this.lastLine = this.line; + this.lastLineStart = this.lineStart; -/***/ }, -/* 48 */ -/***/ function(module, exports, __webpack_require__) { + this.skipComment(); - var indexOf = __webpack_require__(49); + this.startIndex = this.index; + this.startLine = this.line; + this.startLineStart = this.lineStart; - var Object_keys = function (obj) { - if (Object.keys) return Object.keys(obj) - else { - var res = []; - for (var key in obj) res.push(key) - return res; + if (this.replacementIndex && this.replacementIndex[0] && this.index >= this.replacementIndex[0].index) { + let rep = this.replacementIndex[0].replacement; + this.replacementIndex.shift(); + return rep; } - }; - var forEach = function (xs, fn) { - if (xs.forEach) return xs.forEach(fn) - else for (var i = 0; i < xs.length; i++) { - fn(xs[i], i, xs); - } - }; + let charCode = this.source.charCodeAt(this.index); - var defineProp = (function() { - try { - Object.defineProperty({}, '_', {}); - return function(obj, name, value) { - Object.defineProperty(obj, name, { - writable: true, - enumerable: false, - configurable: true, - value: value - }) + if (charCode === 0x60) { + // ` + let element, + items = []; + let startLocation = this.getLocation(); + let start = this.index; + this.index++; + if (lastEl(this.insideSyntaxTemplate)) { + + let slice = this.getSlice(start, startLocation); + return { + type: RSYNTAX, + value: '`', + slice: slice }; - } catch(e) { - return function(obj, name, value) { - obj[name] = value; + } + do { + element = this.scanTemplateElement(); + items.push(element); + if (element.interp) { + // only read the single delimiter + element = this.read([], false, true); + (0, _errors.assert)(element.size === 1, "should only have read a single delimiter inside a template"); + items.push(element.get(0)); + } + } while (!element.tail); + return { + type: _tokenizer.TokenType.TEMPLATE, + items: (0, _immutable.List)(items), + slice: this.getSlice(start, startLocation) + }; + } else if (charCode === 35) { + // # + let startLocation = this.getLocation(); + let start = this.index; + let slice = this.getSlice(start, startLocation); + this.index++; + // TODO: handle ` inside of syntax template interpolations + if (this.source.charCodeAt(this.index) === 0x60) { + // ` + this.index++; + return { + type: LSYNTAX, + value: '#`', + slice: slice }; + } + return { + type: _tokenizer.TokenType.IDENTIFIER, + value: '#', + slice: slice + }; + } else if (charCode === 64) { + // @ + let startLocation = this.getLocation(); + let start = this.index; + let slice = this.getSlice(start, startLocation); + this.index++; + return { + type: AT, + value: '@', + slice: slice + }; } - }()); - - var globals = ['Array', 'Boolean', 'Date', 'Error', 'EvalError', 'Function', - 'Infinity', 'JSON', 'Math', 'NaN', 'Number', 'Object', 'RangeError', - 'ReferenceError', 'RegExp', 'String', 'SyntaxError', 'TypeError', 'URIError', - 'decodeURI', 'decodeURIComponent', 'encodeURI', 'encodeURIComponent', 'escape', - 'eval', 'isFinite', 'isNaN', 'parseFloat', 'parseInt', 'undefined', 'unescape']; - - function Context() {} - Context.prototype = {}; - - var Script = exports.Script = function NodeScript (code) { - if (!(this instanceof Script)) return new Script(code); - this.code = code; - }; - - Script.prototype.runInContext = function (context) { - if (!(context instanceof Context)) { - throw new TypeError("needs a 'context' argument."); - } - - var iframe = document.createElement('iframe'); - if (!iframe.style) iframe.style = {}; - iframe.style.display = 'none'; - - document.body.appendChild(iframe); - - var win = iframe.contentWindow; - var wEval = win.eval, wExecScript = win.execScript; - if (!wEval && wExecScript) { - // win.eval() magically appears when this is called in IE: - wExecScript.call(win, 'null'); - wEval = win.eval; + let lookahead = super.advance(); + if (lookahead.type === _tokenizer.TokenType.DIV && isRegexPrefix(b)(prefix)) { + return super.scanRegExp("/"); } - - forEach(Object_keys(context), function (key) { - win[key] = context[key]; - }); - forEach(globals, function (key) { - if (context[key]) { - win[key] = context[key]; - } - }); - - var winKeys = Object_keys(win); - - var res = wEval.call(win, this.code); - - forEach(Object_keys(win), function (key) { - // Avoid copying circular objects like `top` and `window` by only - // updating existing context properties or new properties in the `win` - // that was only introduced after the eval. - if (key in context || indexOf(winKeys, key) === -1) { - context[key] = win[key]; - } - }); - - forEach(globals, function (key) { - if (!(key in context)) { - defineProp(context, key, win[key]); - } - }); - - document.body.removeChild(iframe); - - return res; - }; - - Script.prototype.runInThisContext = function () { - return eval(this.code); // maybe... - }; - - Script.prototype.runInNewContext = function (context) { - var ctx = Script.createContext(context); - var res = this.runInContext(ctx); - - forEach(Object_keys(ctx), function (key) { - context[key] = ctx[key]; - }); - - return res; - }; - - forEach(Object_keys(Script.prototype), function (name) { - exports[name] = Script[name] = function (code) { - var s = Script(code); - return s[name].apply(s, [].slice.call(arguments, 1)); - }; - }); - - exports.createScript = function (code) { - return exports.Script(code); - }; + return lookahead; + } - exports.createContext = Script.createContext = function (context) { - var copy = new Context(); - if(typeof context === 'object') { - forEach(Object_keys(context), function (key) { - copy[key] = context[key]; - }); + // need to override how templates are lexed because of delimiters + scanTemplateElement() { + let startLocation = this.getLocation(); + let start = this.index; + while (this.index < this.source.length) { + let ch = this.source.charCodeAt(this.index); + switch (ch) { + case 0x60: + { + // ` + // don't include the traling "`" + let slice = this.getSlice(start, startLocation); + this.index++; + return { + type: _tokenizer.TokenType.TEMPLATE, + tail: true, + interp: false, + slice: slice + }; + } + case 0x24: + // $ + if (this.source.charCodeAt(this.index + 1) === 0x7B) { + // { + // don't include the trailing "$" + let slice = this.getSlice(start, startLocation); + this.index += 1; + return { + type: _tokenizer.TokenType.TEMPLATE, + tail: false, + interp: true, + slice: slice + }; + } + this.index++; + break; + case 0x5C: + // \\ + { + let octal = this.scanStringEscape("", null)[1]; + if (octal != null) { + throw this.createILLEGAL(); + } + break; + } + default: + this.index++; + } } - return copy; - }; - - -/***/ }, -/* 49 */ -/***/ function(module, exports) { - - - var indexOf = [].indexOf; - module.exports = function(arr, obj){ - if (indexOf) return arr.indexOf(obj); - for (var i = 0; i < arr.length; ++i) { - if (arr[i] === obj) return i; + throw this.createILLEGAL(); } - return -1; - }; + } + exports.default = Reader; + //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/shift-reader.js"],"names":[],"mappings":"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","file":"shift-reader.js","sourcesContent":["import Tokenizer from \"shift-parser/dist/tokenizer\";\nimport { TokenClass, TokenType } from \"shift-parser/dist/tokenizer\";\nimport { List } from \"immutable\";\nimport Syntax from \"./syntax\";\nimport * as R from 'ramda';\nimport { Maybe } from 'ramda-fantasy';\nimport { assert } from './errors';\nconst Just = Maybe.Just;\nconst Nothing = Maybe.Nothing;\nimport Term from './terms';\n\nconst LSYNTAX = { name: 'left-syntax' };\nconst RSYNTAX = { name: 'right-syntax' };\nconst AT = { klass: TokenClass.Punctuator, name: \"@\" };\n\n\n// TODO: also, need to handle contextual yield\nconst literalKeywords = ['this', 'null', 'true', 'false'];\n\n// Token -> Boolean\nconst isLeftBracket  = R.whereEq({ type: TokenType.LBRACK });\nconst isLeftBrace    = R.whereEq({ type: TokenType.LBRACE });\nconst isLeftParen    = R.whereEq({ type: TokenType.LPAREN });\nconst isRightBracket = R.whereEq({ type: TokenType.RBRACK });\nconst isRightBrace   = R.whereEq({ type: TokenType.RBRACE });\nconst isRightParen   = R.whereEq({ type: TokenType.RPAREN });\n\nconst isEOS = R.whereEq({ type: TokenType.EOS });\n\n// const isHash = R.whereEq({ type: TokenType.IDENTIFIER, value: '#'});\nconst isLeftSyntax = R.whereEq({ type: LSYNTAX });\nconst isRightSyntax = R.whereEq({ type: RSYNTAX });\n\nconst isLeftDelimiter = R.anyPass([isLeftBracket,\n                                   isLeftBrace,\n                                   isLeftParen,\n                                   isLeftSyntax]);\n\nconst isRightDelimiter = R.anyPass([isRightBracket,\n                                    isRightBrace,\n                                    isRightParen,\n                                    isRightSyntax]);\n\nconst isMatchingDelimiters = R.cond([\n  [isLeftBracket, (_, b) => isRightBracket(b)],\n  [isLeftBrace, (_, b) => isRightBrace(b)],\n  [isLeftParen, (_, b) => isRightParen(b)],\n  [isLeftSyntax, (_, b) => isRightSyntax(b)],\n  [R.T, R.F]\n]);\n\nconst assignOps =  [\"=\", \"+=\", \"-=\", \"*=\", \"/=\", \"%=\", \"<<=\", \">>=\", \">>>=\",\n                  \"&=\", \"|=\", \"^=\", \",\"];\n\nconst binaryOps = [\"+\", \"-\", \"*\", \"/\", \"%\",\"<<\", \">>\", \">>>\", \"&\", \"|\", \"^\",\n                 \"&&\", \"||\", \"?\", \":\",\n                 \"===\", \"==\", \">=\", \"<=\", \"<\", \">\", \"!=\", \"!==\", \"instanceof\"];\n\nconst unaryOps = [\"++\", \"--\", \"~\", \"!\", \"delete\", \"void\", \"typeof\", \"yield\", \"throw\", \"new\"];\n\n// List -> Boolean\nconst isEmpty = R.whereEq({size: 0});\n\n// Syntax -> Boolean\nconst isPunctuator = s => s.match(\"punctuator\");\nconst isKeyword = s => s.match(\"keyword\");\nconst isParens = s => s.match(\"parens\");\nconst isBraces = s => s.match(\"braces\");\nconst isIdentifier = s => s.match(\"identifier\");\n\n// Any -> Syntax -> Boolean\nconst isVal = R.curry((v, s) => s.val() === v);\n\n// Syntax -> Boolean\nconst isDot = R.allPass([isPunctuator, isVal('.')]);\nconst isColon = R.allPass([isPunctuator, isVal(':')]);\nconst isFunctionKeyword = R.allPass([isKeyword, isVal('function')]);\nconst isOperator = s => (s.match(\"punctuator\") || s.match(\"keyword\")) &&\n                          R.any(R.equals(s.val()),\n                                assignOps.concat(binaryOps).concat(unaryOps));\nconst isNonLiteralKeyword = R.allPass([isKeyword,\n                                       s => R.none(R.equals(s.val()), literalKeywords)]);\nconst isKeywordExprPrefix = R.allPass([isKeyword,\n  s => R.any(R.equals(s.val()), ['instanceof', 'typeof', 'delete', 'void',\n                                  'yield', 'throw', 'new', 'case'])]);\n// List a -> a?\nlet last = p => p.last();\n// List a -> Maybe a\nlet safeLast = R.pipe(R.cond([\n  [isEmpty, R.always(Nothing())],\n  [R.T, R.compose(Maybe.of, last)]\n]));\n\n// TODO: better name\n// List -> Boolean -> Maybe List\nlet stuffTrue = R.curry((p, b) => b ? Just(p) : Nothing());\nlet stuffFalse = R.curry((p, b) => !b ? Just(p) : Nothing());\n\n// List a -> Boolean\nlet isTopColon = R.pipe(\n  safeLast,\n  R.map(isColon),\n  Maybe.maybe(false, R.identity)\n);\n// List a -> Boolean\nlet isTopPunctuator = R.pipe(\n  safeLast,\n  R.map(isPunctuator),\n  Maybe.maybe(false, R.identity)\n);\n\n// Number -> List -> Boolean\nlet isExprReturn = R.curry((l, p) => {\n  let retKwd = safeLast(p);\n  let maybeDot = pop(p).chain(safeLast);\n\n  if (maybeDot.map(isDot).getOrElse(false)) {\n    return true;\n  }\n  return retKwd.map(s => {\n    return s.match(\"keyword\") && s.val() === 'return' && s.lineNumber() === l;\n  }).getOrElse(false);\n});\n\nconst isTopOperator = R.pipe(\n  safeLast,\n  R.map(isOperator),\n  Maybe.maybe(false, R.identity)\n);\n\nconst isTopKeywordExprPrefix = R.pipe(\n  safeLast,\n  R.map(isKeywordExprPrefix),\n  Maybe.maybe(false, R.identity)\n);\n\n// Number -> Boolean -> List -> Boolean\nlet isExprPrefix = R.curry((l, b) => R.cond([\n  // ... ({x: 42} /r/i)\n  [isEmpty, R.always(b)],\n  // ... ({x: {x: 42} /r/i })\n  [isTopColon, R.always(b)],\n  // ... throw {x: 42} /r/i\n  [isTopKeywordExprPrefix, R.T],\n  // ... 42 + {x: 42} /r/i\n  [isTopOperator, R.T],\n  // ... for ( ; {x: 42}/r/i)\n  [isTopPunctuator, R.always(b)],\n  // ... return {x: 42} /r /i\n  // ... return\\n{x: 42} /r /i\n  [isExprReturn(l), R.T],\n  [R.T, R.F],\n]));\n\n// List a -> Maybe List a\nlet curly = p => safeLast(p).map(isBraces).chain(stuffTrue(p));\nlet paren = p => safeLast(p).map(isParens).chain(stuffTrue(p));\nlet func = p => safeLast(p).map(isFunctionKeyword).chain(stuffTrue(p));\nlet ident = p => safeLast(p).map(isIdentifier).chain(stuffTrue(p));\nlet nonLiteralKeyword = p => safeLast(p).map(isNonLiteralKeyword).chain(stuffTrue(p));\n\nlet opt = R.curry((a, b, p) => {\n  let result = R.pipeK(a, b)(Maybe.of(p));\n  return Maybe.isJust(result) ? result : Maybe.of(p);\n});\n\nlet notDot = R.ifElse(\n  R.whereEq({size: 0}),\n  Just,\n  p => safeLast(p).map(s => !(s.match(\"punctuator\") && s.val() === '.')).chain(stuffTrue(p))\n);\n\n// List a -> Maybe List a\nlet pop = R.compose(Just, p => p.pop());\n\n// Maybe List a -> Maybe List a\nconst functionPrefix = R.pipeK(\n    curly,\n    pop,\n    paren,\n    pop,\n    opt(ident, pop),\n    func);\n\n// Boolean -> List a -> Boolean\nconst isRegexPrefix = b => R.anyPass([\n  // ε\n  isEmpty,\n  // P . t   where t ∈ Punctuator\n  isTopPunctuator,\n  // P . t . t'  where t \\not = \".\" and t' ∈ (Keyword \\setminus  LiteralKeyword)\n  R.pipe(\n    Maybe.of,\n    R.pipeK(\n      nonLiteralKeyword,\n      pop,\n      notDot\n    ),\n    Maybe.isJust\n  ),\n  // P . t . t' . (T)  where t \\not = \".\" and t' ∈ (Keyword \\setminus LiteralKeyword)\n  R.pipe(\n    Maybe.of,\n    R.pipeK(\n      paren,\n      pop,\n      nonLiteralKeyword,\n      pop,\n      notDot\n    ),\n    Maybe.isJust\n  ),\n  // P . function^l . x? . () . {}     where isExprPrefix(P, b, l) = false\n  R.pipe(\n    Maybe.of,\n    functionPrefix,\n    R.chain(p => {\n        return safeLast(p)\n          .map(s => s.lineNumber())\n          .chain(fnLine => {\n            return pop(p).map(isExprPrefix(fnLine, b));\n          })\n          .chain(stuffFalse(p));\n      }\n    ),\n    Maybe.isJust\n  ),\n  // P . {T}^l  where isExprPrefix(P, b, l) = false\n  p => {\n    let alreadyCheckedFunction = R.pipe(\n      Maybe.of,\n      functionPrefix,\n      Maybe.isJust\n    )(p);\n    if (alreadyCheckedFunction) {\n      return false;\n    }\n    return R.pipe(\n      Maybe.of,\n      R.chain(curly),\n      R.chain(p => {\n        return safeLast(p)\n        .map(s => s.lineNumber())\n        .chain(curlyLine => {\n          return pop(p).map(isExprPrefix(curlyLine, b));\n        })\n        .chain(stuffFalse(p));\n      }),\n      Maybe.isJust\n    )(p);\n  }\n\n\n]);\n\nfunction lastEl(l) {\n  return l[l.length - 1];\n}\n\nexport default class Reader extends Tokenizer {\n  constructor(strings, context, replacements) {\n    super(Array.isArray(strings) ? strings.join('') : strings);\n    this.delimStack = new Map();\n    this.insideSyntaxTemplate = [false];\n    this.context = context;\n\n    // setup splicing replacement array\n    if (Array.isArray(strings)) {\n      let totalIndex = 0;\n      this.replacementIndex = R.reduce((acc, strRep) => {\n        acc.push({\n          index: totalIndex + strRep[0].length,\n          replacement: strRep[1]\n        });\n        totalIndex += strRep[0].length;\n        return acc;\n      }, [], R.zip(strings, replacements));\n    }\n  }\n\n  read(stack = [], b = false, singleDelimiter = false) {\n    let prefix = List();\n    while (true) {\n      let tok = this.advance(prefix, b);\n\n      // splicing allows syntax and terms\n      if (tok.scopesets || tok instanceof Term) {\n        stack.push(tok);\n        continue;\n      }\n      if (Array.isArray(tok)) {\n        Array.prototype.push.apply(stack, tok);\n        continue;\n      }\n      if (List.isList(tok)) {\n        Array.prototype.push.apply(stack, tok.toArray());\n        continue;\n      }\n\n      if (isEOS(tok)) {\n        if (stack[0] && isLeftDelimiter(stack[0].token)) {\n          throw this.createUnexpected(tok);\n        }\n        break;\n      }\n\n      if (isLeftDelimiter(tok)) {\n        if (isLeftSyntax(tok)) {\n          this.insideSyntaxTemplate.push(true);\n        }\n        let line = tok.slice.startLocation.line;\n        let innerB = isLeftBrace(tok) ? isExprPrefix(line, b)(prefix) : true;\n        let inner = this.read([new Syntax(tok, this.context)],\n                              innerB,\n                              false);\n        let stx = new Syntax(inner, this.context);\n        prefix = prefix.concat(stx);\n        stack.push(stx);\n        if (singleDelimiter) {\n          break;\n        }\n      } else if (isRightDelimiter(tok)) {\n        if (stack[0] && !isMatchingDelimiters(stack[0].token, tok)) {\n          throw this.createUnexpected(tok);\n        }\n        let stx = new Syntax(tok, this.context);\n        stack.push(stx);\n        if (lastEl(this.insideSyntaxTemplate) && isRightSyntax(tok)) {\n          this.insideSyntaxTemplate.pop();\n        }\n        break;\n      } else {\n        let stx = new Syntax(tok, this.context);\n        prefix = prefix.concat(stx);\n        stack.push(stx);\n      }\n    }\n    return List(stack);\n  }\n\n  advance(prefix, b) {\n    this.lastIndex = this.index;\n    this.lastLine = this.line;\n    this.lastLineStart = this.lineStart;\n\n    this.skipComment();\n\n    this.startIndex = this.index;\n    this.startLine = this.line;\n    this.startLineStart = this.lineStart;\n\n    if (this.replacementIndex && this.replacementIndex[0] && this.index >= this.replacementIndex[0].index) {\n      let rep = this.replacementIndex[0].replacement;\n      this.replacementIndex.shift();\n      return rep;\n    }\n\n    let charCode = this.source.charCodeAt(this.index);\n\n    if (charCode === 0x60) { // `\n      let element, items = [];\n      let startLocation = this.getLocation();\n      let start = this.index;\n      this.index++;\n      if (lastEl(this.insideSyntaxTemplate)) {\n\n        let slice = this.getSlice(start, startLocation);\n        return {\n          type: RSYNTAX,\n          value: '`',\n          slice: slice\n        };\n      }\n      do {\n        element = this.scanTemplateElement();\n        items.push(element);\n        if (element.interp) {\n          // only read the single delimiter\n          element = this.read([], false, true);\n          assert(element.size === 1, \"should only have read a single delimiter inside a template\");\n          items.push(element.get(0));\n        }\n      } while (!element.tail);\n      return {\n        type: TokenType.TEMPLATE,\n        items: List(items),\n        slice: this.getSlice(start, startLocation)\n      };\n    } else if (charCode === 35) { // #\n      let startLocation = this.getLocation();\n      let start = this.index;\n      let slice = this.getSlice(start, startLocation);\n      this.index++;\n      // TODO: handle ` inside of syntax template interpolations\n      if (this.source.charCodeAt(this.index) === 0x60) { // `\n        this.index++;\n        return {\n          type: LSYNTAX,\n          value: '#`',\n          slice: slice\n        };\n      }\n      return {\n        type: TokenType.IDENTIFIER,\n        value: '#',\n        slice: slice\n      };\n    } else if (charCode === 64) { // @\n      let startLocation = this.getLocation();\n      let start = this.index;\n      let slice = this.getSlice(start, startLocation);\n      this.index++;\n      return {\n        type: AT,\n        value: '@',\n        slice\n      };\n    }\n\n    let lookahead = super.advance();\n    if (lookahead.type === TokenType.DIV && isRegexPrefix(b)(prefix)) {\n      return super.scanRegExp(\"/\");\n    }\n    return lookahead;\n  }\n\n  // need to override how templates are lexed because of delimiters\n  scanTemplateElement() {\n    let startLocation = this.getLocation();\n    let start = this.index;\n    while (this.index < this.source.length) {\n      let ch = this.source.charCodeAt(this.index);\n      switch (ch) {\n        case 0x60: { // `\n          // don't include the traling \"`\"\n          let slice = this.getSlice(start, startLocation);\n          this.index++;\n          return {\n            type: TokenType.TEMPLATE,\n            tail: true,\n            interp: false,\n            slice: slice\n          };\n        }\n        case 0x24:  // $\n          if (this.source.charCodeAt(this.index + 1) === 0x7B) {  // {\n            // don't include the trailing \"$\"\n            let slice = this.getSlice(start, startLocation);\n            this.index += 1;\n            return {\n              type: TokenType.TEMPLATE,\n              tail: false,\n              interp: true,\n              slice: slice\n            };\n          }\n          this.index++;\n          break;\n        case 0x5C:  // \\\\\n        {\n          let octal = this.scanStringEscape(\"\", null)[1];\n          if (octal != null) {\n            throw this.createILLEGAL();\n          }\n          break;\n        }\n        default:\n          this.index++;\n      }\n    }\n\n    throw this.createILLEGAL();\n  }\n}\n"]} /***/ }, -/* 50 */ +/* 43 */ /***/ function(module, exports, __webpack_require__) { "use strict"; @@ -30531,2614 +29014,2416 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack Object.defineProperty(exports, "__esModule", { value: true }); + exports.JsError = exports.TokenType = exports.TokenClass = undefined; - var _immutable = __webpack_require__(11); - - var _enforester = __webpack_require__(51); - - var _termExpander = __webpack_require__(54); - - var _termExpander2 = _interopRequireDefault(_termExpander); - - var _bindingMap = __webpack_require__(14); + var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); - var _bindingMap2 = _interopRequireDefault(_bindingMap); + var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); - var _env = __webpack_require__(31); + var _utils = __webpack_require__(44); - var _env2 = _interopRequireDefault(_env); + var _errors = __webpack_require__(45); - var _shiftReader = __webpack_require__(3); + function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - var _shiftReader2 = _interopRequireDefault(_shiftReader); + function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } - var _terms = __webpack_require__(28); + function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } /** + * Copyright 2014 Shape Security, Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License") + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ - var _terms2 = _interopRequireDefault(_terms); + var TokenClass = exports.TokenClass = { + Eof: { name: "" }, + Ident: { name: "Identifier", isIdentifierName: true }, + Keyword: { name: "Keyword", isIdentifierName: true }, + NumericLiteral: { name: "Numeric" }, + TemplateElement: { name: "Template" }, + Punctuator: { name: "Punctuator" }, + StringLiteral: { name: "String" }, + RegularExpression: { name: "RegularExpression" }, + Illegal: { name: "Illegal" } + }; - var _symbol = __webpack_require__(45); + var TokenType = exports.TokenType = { + EOS: { klass: TokenClass.Eof, name: "EOS" }, + LPAREN: { klass: TokenClass.Punctuator, name: "(" }, + RPAREN: { klass: TokenClass.Punctuator, name: ")" }, + LBRACK: { klass: TokenClass.Punctuator, name: "[" }, + RBRACK: { klass: TokenClass.Punctuator, name: "]" }, + LBRACE: { klass: TokenClass.Punctuator, name: "{" }, + RBRACE: { klass: TokenClass.Punctuator, name: "}" }, + COLON: { klass: TokenClass.Punctuator, name: ":" }, + SEMICOLON: { klass: TokenClass.Punctuator, name: ";" }, + PERIOD: { klass: TokenClass.Punctuator, name: "." }, + ELLIPSIS: { klass: TokenClass.Punctuator, name: "..." }, + ARROW: { klass: TokenClass.Punctuator, name: "=>" }, + CONDITIONAL: { klass: TokenClass.Punctuator, name: "?" }, + INC: { klass: TokenClass.Punctuator, name: "++" }, + DEC: { klass: TokenClass.Punctuator, name: "--" }, + ASSIGN: { klass: TokenClass.Punctuator, name: "=" }, + ASSIGN_BIT_OR: { klass: TokenClass.Punctuator, name: "|=" }, + ASSIGN_BIT_XOR: { klass: TokenClass.Punctuator, name: "^=" }, + ASSIGN_BIT_AND: { klass: TokenClass.Punctuator, name: "&=" }, + ASSIGN_SHL: { klass: TokenClass.Punctuator, name: "<<=" }, + ASSIGN_SHR: { klass: TokenClass.Punctuator, name: ">>=" }, + ASSIGN_SHR_UNSIGNED: { klass: TokenClass.Punctuator, name: ">>>=" }, + ASSIGN_ADD: { klass: TokenClass.Punctuator, name: "+=" }, + ASSIGN_SUB: { klass: TokenClass.Punctuator, name: "-=" }, + ASSIGN_MUL: { klass: TokenClass.Punctuator, name: "*=" }, + ASSIGN_DIV: { klass: TokenClass.Punctuator, name: "/=" }, + ASSIGN_MOD: { klass: TokenClass.Punctuator, name: "%=" }, + COMMA: { klass: TokenClass.Punctuator, name: "," }, + OR: { klass: TokenClass.Punctuator, name: "||" }, + AND: { klass: TokenClass.Punctuator, name: "&&" }, + BIT_OR: { klass: TokenClass.Punctuator, name: "|" }, + BIT_XOR: { klass: TokenClass.Punctuator, name: "^" }, + BIT_AND: { klass: TokenClass.Punctuator, name: "&" }, + SHL: { klass: TokenClass.Punctuator, name: "<<" }, + SHR: { klass: TokenClass.Punctuator, name: ">>" }, + SHR_UNSIGNED: { klass: TokenClass.Punctuator, name: ">>>" }, + ADD: { klass: TokenClass.Punctuator, name: "+" }, + SUB: { klass: TokenClass.Punctuator, name: "-" }, + MUL: { klass: TokenClass.Punctuator, name: "*" }, + DIV: { klass: TokenClass.Punctuator, name: "/" }, + MOD: { klass: TokenClass.Punctuator, name: "%" }, + EQ: { klass: TokenClass.Punctuator, name: "==" }, + NE: { klass: TokenClass.Punctuator, name: "!=" }, + EQ_STRICT: { klass: TokenClass.Punctuator, name: "===" }, + NE_STRICT: { klass: TokenClass.Punctuator, name: "!==" }, + LT: { klass: TokenClass.Punctuator, name: "<" }, + GT: { klass: TokenClass.Punctuator, name: ">" }, + LTE: { klass: TokenClass.Punctuator, name: "<=" }, + GTE: { klass: TokenClass.Punctuator, name: ">=" }, + INSTANCEOF: { klass: TokenClass.Keyword, name: "instanceof" }, + IN: { klass: TokenClass.Keyword, name: "in" }, + NOT: { klass: TokenClass.Punctuator, name: "!" }, + BIT_NOT: { klass: TokenClass.Punctuator, name: "~" }, + AWAIT: { klass: TokenClass.Keyword, name: "await" }, + DELETE: { klass: TokenClass.Keyword, name: "delete" }, + TYPEOF: { klass: TokenClass.Keyword, name: "typeof" }, + VOID: { klass: TokenClass.Keyword, name: "void" }, + BREAK: { klass: TokenClass.Keyword, name: "break" }, + CASE: { klass: TokenClass.Keyword, name: "case" }, + CATCH: { klass: TokenClass.Keyword, name: "catch" }, + CLASS: { klass: TokenClass.Keyword, name: "class" }, + CONTINUE: { klass: TokenClass.Keyword, name: "continue" }, + DEBUGGER: { klass: TokenClass.Keyword, name: "debugger" }, + DEFAULT: { klass: TokenClass.Keyword, name: "default" }, + DO: { klass: TokenClass.Keyword, name: "do" }, + ELSE: { klass: TokenClass.Keyword, name: "else" }, + EXPORT: { klass: TokenClass.Keyword, name: "export" }, + EXTENDS: { klass: TokenClass.Keyword, name: "extends" }, + FINALLY: { klass: TokenClass.Keyword, name: "finally" }, + FOR: { klass: TokenClass.Keyword, name: "for" }, + FUNCTION: { klass: TokenClass.Keyword, name: "function" }, + IF: { klass: TokenClass.Keyword, name: "if" }, + IMPORT: { klass: TokenClass.Keyword, name: "import" }, + LET: { klass: TokenClass.Keyword, name: "let" }, + NEW: { klass: TokenClass.Keyword, name: "new" }, + RETURN: { klass: TokenClass.Keyword, name: "return" }, + SUPER: { klass: TokenClass.Keyword, name: "super" }, + SWITCH: { klass: TokenClass.Keyword, name: "switch" }, + THIS: { klass: TokenClass.Keyword, name: "this" }, + THROW: { klass: TokenClass.Keyword, name: "throw" }, + TRY: { klass: TokenClass.Keyword, name: "try" }, + VAR: { klass: TokenClass.Keyword, name: "var" }, + WHILE: { klass: TokenClass.Keyword, name: "while" }, + WITH: { klass: TokenClass.Keyword, name: "with" }, + NULL: { klass: TokenClass.Keyword, name: "null" }, + TRUE: { klass: TokenClass.Keyword, name: "true" }, + FALSE: { klass: TokenClass.Keyword, name: "false" }, + YIELD: { klass: TokenClass.Keyword, name: "yield" }, + NUMBER: { klass: TokenClass.NumericLiteral, name: "" }, + STRING: { klass: TokenClass.StringLiteral, name: "" }, + REGEXP: { klass: TokenClass.RegularExpression, name: "" }, + IDENTIFIER: { klass: TokenClass.Ident, name: "" }, + CONST: { klass: TokenClass.Keyword, name: "const" }, + TEMPLATE: { klass: TokenClass.TemplateElement, name: "" }, + ILLEGAL: { klass: TokenClass.Illegal, name: "" } + }; - var _transforms = __webpack_require__(32); + var TT = TokenType; + var I = TT.ILLEGAL; + var F = false; + var T = true; - var _errors = __webpack_require__(13); + var ONE_CHAR_PUNCTUATOR = [I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, TT.NOT, I, I, I, TT.MOD, TT.BIT_AND, I, TT.LPAREN, TT.RPAREN, TT.MUL, TT.ADD, TT.COMMA, TT.SUB, TT.PERIOD, TT.DIV, I, I, I, I, I, I, I, I, I, I, TT.COLON, TT.SEMICOLON, TT.LT, TT.ASSIGN, TT.GT, TT.CONDITIONAL, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, TT.LBRACK, I, TT.RBRACK, TT.BIT_XOR, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, I, TT.LBRACE, TT.BIT_OR, TT.RBRACE, TT.BIT_NOT]; - var _loadSyntax = __webpack_require__(53); + var PUNCTUATOR_START = [F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, T, F, F, F, T, T, F, T, T, T, T, T, T, F, T, F, F, F, F, F, F, F, F, F, F, T, T, T, T, T, T, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, T, F, T, T, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, F, T, T, T, T, F]; - var _scope = __webpack_require__(44); + var JsError = exports.JsError = function (_Error) { + _inherits(JsError, _Error); - var _syntax = __webpack_require__(12); + function JsError(index, line, column, msg) { + _classCallCheck(this, JsError); - var _syntax2 = _interopRequireDefault(_syntax); + var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(JsError).call(this, msg)); - var _astDispatcher = __webpack_require__(64); + _this.index = index; + _this.line = line; + _this.column = column; + _this.description = msg; + _this.message = "[" + line + ":" + column + "]: " + msg; + return _this; + } - var _astDispatcher2 = _interopRequireDefault(_astDispatcher); + return JsError; + }(Error); - var _hygieneUtils = __webpack_require__(67); + function fromCodePoint(cp) { + if (cp <= 0xFFFF) return String.fromCharCode(cp); + var cu1 = String.fromCharCode(Math.floor((cp - 0x10000) / 0x400) + 0xD800); + var cu2 = String.fromCharCode((cp - 0x10000) % 0x400 + 0xDC00); + return cu1 + cu2; + } - var _ramda = __webpack_require__(27); + function decodeUtf16(lead, trail) { + return (lead - 0xD800) * 0x400 + (trail - 0xDC00) + 0x10000; + } - var _ = _interopRequireWildcard(_ramda); + var Tokenizer = function () { + function Tokenizer(source) { + _classCallCheck(this, Tokenizer); - function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - - function bindImports_1372(impTerm_1375, exModule_1376, context_1377) { - let names_1378 = []; - let phase_1379 = impTerm_1375.forSyntax ? context_1377.phase + 1 : context_1377.phase; - impTerm_1375.namedImports.forEach(specifier_1380 => { - let name_1381 = specifier_1380.binding.name; - let exportName_1382 = findNameInExports_1373(name_1381, exModule_1376.exportEntries); - if (exportName_1382 != null) { - let newBinding = (0, _symbol.gensym)(name_1381.val()); - context_1377.store.set(newBinding.toString(), new _transforms.VarBindingTransform(name_1381)); - context_1377.bindings.addForward(name_1381, exportName_1382, newBinding, phase_1379); - names_1378.push(name_1381); - } - }); - return (0, _immutable.List)(names_1378); - } - function findNameInExports_1373(name_1383, exp_1384) { - let foundNames_1385 = exp_1384.reduce((acc_1386, e_1387) => { - if ((0, _terms.isExportFrom)(e_1387)) { - return acc_1386.concat(e_1387.namedExports.reduce((acc_1388, specifier_1389) => { - if (specifier_1389.exportedName.val() === name_1383.val()) { - return acc_1388.concat(specifier_1389.exportedName); - } - return acc_1388; - }, (0, _immutable.List)())); - } else if ((0, _terms.isExport)(e_1387)) { - return acc_1386.concat(e_1387.declaration.declarators.reduce((acc_1390, decl_1391) => { - if (decl_1391.binding.name.val() === name_1383.val()) { - return acc_1390.concat(decl_1391.binding.name); - } - return acc_1390; - }, (0, _immutable.List)())); - } - return acc_1386; - }, (0, _immutable.List)()); - (0, _errors.assert)(foundNames_1385.size <= 1, "expecting no more than 1 matching name in exports"); - return foundNames_1385.get(0); - } - function removeNames_1374(impTerm_1392, names_1393) { - let namedImports_1394 = impTerm_1392.namedImports.filter(specifier_1395 => !names_1393.contains(specifier_1395.binding.name)); - return impTerm_1392.extend({ namedImports: namedImports_1394 }); - } - class TokenExpander extends _astDispatcher2.default { - constructor(context_1396) { - super("expand", false); - this.context = context_1396; - } - expand(stxl_1397) { - let result_1398 = []; - if (stxl_1397.size === 0) { - return (0, _immutable.List)(result_1398); - } - let prev_1399 = (0, _immutable.List)(); - let enf_1400 = new _enforester.Enforester(stxl_1397, prev_1399, this.context); - while (!enf_1400.done) { - result_1398.push(this.dispatch(enf_1400.enforest())); - } - return (0, _immutable.List)(result_1398); - } - expandVariableDeclarationStatement(term_1401) { - return term_1401.extend({ declaration: this.registerVariableDeclaration(term_1401.declaration) }); - } - expandFunctionDeclaration(term_1402) { - let registeredTerm_1403 = this.registerFunctionOrClass(term_1402); - let stx_1404 = registeredTerm_1403.name.name; - this.context.env.set(stx_1404.resolve(this.context.phase), new _transforms.VarBindingTransform(stx_1404)); - return registeredTerm_1403; - } - expandImport(term_1405) { - let path_1406 = term_1405.moduleSpecifier.val(); - let mod_1407; - if (term_1405.forSyntax) { - mod_1407 = this.context.modules.getAtPhase(path_1406, this.context.phase + 1, this.context.cwd); - this.context.store = this.context.modules.visit(mod_1407, this.context.phase + 1, this.context.store); - this.context.store = this.context.modules.invoke(mod_1407, this.context.phase + 1, this.context.store); - } else { - mod_1407 = this.context.modules.getAtPhase(path_1406, this.context.phase, this.context.cwd); - this.context.store = this.context.modules.visit(mod_1407, this.context.phase, this.context.store); - } - let boundNames_1408 = bindImports_1372(term_1405, mod_1407, this.context); - return removeNames_1374(term_1405, boundNames_1408); - } - expandExport(term_1409) { - if ((0, _terms.isFunctionDeclaration)(term_1409.declaration) || (0, _terms.isClassDeclaration)(term_1409.declaration)) { - return term_1409.extend({ declaration: this.registerFunctionOrClass(term_1409.declaration) }); - } else if ((0, _terms.isVariableDeclaration)(term_1409.declaration)) { - return term_1409.extend({ declaration: this.registerVariableDeclaration(term_1409.declaration) }); - } - return term_1409; - } - registerFunctionOrClass(term_1410) { - let name_1411 = term_1410.name.removeScope(this.context.useScope, this.context.phase); - (0, _hygieneUtils.collectBindings)(term_1410.name).forEach(stx_1412 => { - let newBinding_1413 = (0, _symbol.gensym)(stx_1412.val()); - this.context.bindings.add(stx_1412, { binding: newBinding_1413, phase: this.context.phase, skipDup: false }); - this.context.env.set(newBinding_1413.toString(), new _transforms.VarBindingTransform(stx_1412)); - }); - return term_1410.extend({ name: name_1411 }); - } - registerVariableDeclaration(term_1414) { - if ((0, _terms.isSyntaxDeclaration)(term_1414) || (0, _terms.isSyntaxrecDeclaration)(term_1414)) { - return this.registerSyntaxDeclaration(term_1414); - } - return term_1414.extend({ declarators: term_1414.declarators.map(decl_1415 => { - let binding_1416 = decl_1415.binding.removeScope(this.context.useScope, this.context.phase); - (0, _hygieneUtils.collectBindings)(binding_1416).forEach(stx_1417 => { - let newBinding_1418 = (0, _symbol.gensym)(stx_1417.val()); - this.context.bindings.add(stx_1417, { binding: newBinding_1418, phase: this.context.phase, skipDup: term_1414.kind === "var" }); - this.context.env.set(newBinding_1418.toString(), new _transforms.VarBindingTransform(stx_1417)); - }); - return decl_1415.extend({ binding: binding_1416 }); - }) }); - } - registerSyntaxDeclaration(term_1419) { - if ((0, _terms.isSyntaxDeclaration)(term_1419)) { - let scope = (0, _scope.freshScope)("nonrec"); - term_1419 = term_1419.extend({ declarators: term_1419.declarators.map(decl_1420 => { - let name_1421 = decl_1420.binding.name; - let nameAdded_1422 = name_1421.addScope(scope, this.context.bindings, _syntax.ALL_PHASES); - let nameRemoved_1423 = name_1421.removeScope(this.context.currentScope[this.context.currentScope.length - 1], this.context.phase); - let newBinding_1424 = (0, _symbol.gensym)(name_1421.val()); - this.context.bindings.addForward(nameAdded_1422, nameRemoved_1423, newBinding_1424, this.context.phase); - return decl_1420.extend({ init: decl_1420.init.addScope(scope, this.context.bindings, _syntax.ALL_PHASES) }); - }) }); - } - return term_1419.extend({ declarators: term_1419.declarators.map(decl_1425 => { - let binding_1426 = decl_1425.binding.removeScope(this.context.useScope, this.context.phase); - let syntaxExpander_1427 = new _termExpander2.default(_.merge(this.context, { phase: this.context.phase + 1, env: new _env2.default(), store: this.context.store })); - let init_1428 = syntaxExpander_1427.expand(decl_1425.init); - let val_1429 = (0, _loadSyntax.evalCompiletimeValue)(init_1428.gen(), _.merge(this.context, { phase: this.context.phase + 1 })); - (0, _hygieneUtils.collectBindings)(binding_1426).forEach(stx_1430 => { - let newBinding_1431 = (0, _symbol.gensym)(stx_1430.val()); - this.context.bindings.add(stx_1430, { binding: newBinding_1431, phase: this.context.phase, skipDup: false }); - let resolvedName_1432 = stx_1430.resolve(this.context.phase); - this.context.env.set(resolvedName_1432, new _transforms.CompiletimeTransform(val_1429)); - }); - return decl_1425.extend({ binding: binding_1426, init: init_1428 }); - }) }); - } - } - exports.default = TokenExpander; - //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/token-expander.js"],"names":[],"mappings":"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","file":"token-expander.js","sourcesContent":["import {List} from \"immutable\";\nimport {enforestExpr, Enforester} from \"./enforester\";\nimport TermExpander from \"./term-expander.js\";\nimport BindingMap from \"./binding-map.js\";\nimport Env from \"./env\";\nimport Reader from \"./shift-reader\";\nimport Term, {isEOF, isBindingIdentifier, isBindingPropertyProperty, isBindingPropertyIdentifier, isObjectBinding, isArrayBinding, isFunctionDeclaration, isFunctionExpression, isFunctionTerm, isFunctionWithName, isSyntaxDeclaration, isSyntaxrecDeclaration, isVariableDeclaration, isVariableDeclarationStatement, isImport, isExport, isExportFrom, isPragma, isExportSyntax, isClassDeclaration} from \"./terms\";\nimport {gensym} from \"./symbol\";\nimport {VarBindingTransform, CompiletimeTransform} from \"./transforms\";\nimport {expect, assert} from \"./errors\";\nimport {evalCompiletimeValue} from \"./load-syntax\";\nimport {Scope, freshScope} from \"./scope\";\nimport Syntax, {ALL_PHASES} from \"./syntax\";\nimport ASTDispatcher from \"./ast-dispatcher\";\nimport {collectBindings} from \"./hygiene-utils\";\nimport  * as _ from \"ramda\";\nfunction bindImports_1372(impTerm_1375, exModule_1376, context_1377) {\n  let names_1378 = [];\n  let phase_1379 = impTerm_1375.forSyntax ? context_1377.phase + 1 : context_1377.phase;\n  impTerm_1375.namedImports.forEach(specifier_1380 => {\n    let name_1381 = specifier_1380.binding.name;\n    let exportName_1382 = findNameInExports_1373(name_1381, exModule_1376.exportEntries);\n    if (exportName_1382 != null) {\n      let newBinding = gensym(name_1381.val());\n      context_1377.store.set(newBinding.toString(), new VarBindingTransform(name_1381));\n      context_1377.bindings.addForward(name_1381, exportName_1382, newBinding, phase_1379);\n      names_1378.push(name_1381);\n    }\n  });\n  return List(names_1378);\n}\nfunction findNameInExports_1373(name_1383, exp_1384) {\n  let foundNames_1385 = exp_1384.reduce((acc_1386, e_1387) => {\n    if (isExportFrom(e_1387)) {\n      return acc_1386.concat(e_1387.namedExports.reduce((acc_1388, specifier_1389) => {\n        if (specifier_1389.exportedName.val() === name_1383.val()) {\n          return acc_1388.concat(specifier_1389.exportedName);\n        }\n        return acc_1388;\n      }, List()));\n    } else if (isExport(e_1387)) {\n      return acc_1386.concat(e_1387.declaration.declarators.reduce((acc_1390, decl_1391) => {\n        if (decl_1391.binding.name.val() === name_1383.val()) {\n          return acc_1390.concat(decl_1391.binding.name);\n        }\n        return acc_1390;\n      }, List()));\n    }\n    return acc_1386;\n  }, List());\n  assert(foundNames_1385.size <= 1, \"expecting no more than 1 matching name in exports\");\n  return foundNames_1385.get(0);\n}\nfunction removeNames_1374(impTerm_1392, names_1393) {\n  let namedImports_1394 = impTerm_1392.namedImports.filter(specifier_1395 => !names_1393.contains(specifier_1395.binding.name));\n  return impTerm_1392.extend({namedImports: namedImports_1394});\n}\nexport default class TokenExpander extends ASTDispatcher {\n  constructor(context_1396) {\n    super(\"expand\", false);\n    this.context = context_1396;\n  }\n  expand(stxl_1397) {\n    let result_1398 = [];\n    if (stxl_1397.size === 0) {\n      return List(result_1398);\n    }\n    let prev_1399 = List();\n    let enf_1400 = new Enforester(stxl_1397, prev_1399, this.context);\n    while (!enf_1400.done) {\n      result_1398.push(this.dispatch(enf_1400.enforest()));\n    }\n    return List(result_1398);\n  }\n  expandVariableDeclarationStatement(term_1401) {\n    return term_1401.extend({declaration: this.registerVariableDeclaration(term_1401.declaration)});\n  }\n  expandFunctionDeclaration(term_1402) {\n    let registeredTerm_1403 = this.registerFunctionOrClass(term_1402);\n    let stx_1404 = registeredTerm_1403.name.name;\n    this.context.env.set(stx_1404.resolve(this.context.phase), new VarBindingTransform(stx_1404));\n    return registeredTerm_1403;\n  }\n  expandImport(term_1405) {\n    let path_1406 = term_1405.moduleSpecifier.val();\n    let mod_1407;\n    if (term_1405.forSyntax) {\n      mod_1407 = this.context.modules.getAtPhase(path_1406, this.context.phase + 1, this.context.cwd);\n      this.context.store = this.context.modules.visit(mod_1407, this.context.phase + 1, this.context.store);\n      this.context.store = this.context.modules.invoke(mod_1407, this.context.phase + 1, this.context.store);\n    } else {\n      mod_1407 = this.context.modules.getAtPhase(path_1406, this.context.phase, this.context.cwd);\n      this.context.store = this.context.modules.visit(mod_1407, this.context.phase, this.context.store);\n    }\n    let boundNames_1408 = bindImports_1372(term_1405, mod_1407, this.context);\n    return removeNames_1374(term_1405, boundNames_1408);\n  }\n  expandExport(term_1409) {\n    if (isFunctionDeclaration(term_1409.declaration) || isClassDeclaration(term_1409.declaration)) {\n      return term_1409.extend({declaration: this.registerFunctionOrClass(term_1409.declaration)});\n    } else if (isVariableDeclaration(term_1409.declaration)) {\n      return term_1409.extend({declaration: this.registerVariableDeclaration(term_1409.declaration)});\n    }\n    return term_1409;\n  }\n  registerFunctionOrClass(term_1410) {\n    let name_1411 = term_1410.name.removeScope(this.context.useScope, this.context.phase);\n    collectBindings(term_1410.name).forEach(stx_1412 => {\n      let newBinding_1413 = gensym(stx_1412.val());\n      this.context.bindings.add(stx_1412, {binding: newBinding_1413, phase: this.context.phase, skipDup: false});\n      this.context.env.set(newBinding_1413.toString(), new VarBindingTransform(stx_1412));\n    });\n    return term_1410.extend({name: name_1411});\n  }\n  registerVariableDeclaration(term_1414) {\n    if (isSyntaxDeclaration(term_1414) || isSyntaxrecDeclaration(term_1414)) {\n      return this.registerSyntaxDeclaration(term_1414);\n    }\n    return term_1414.extend({declarators: term_1414.declarators.map(decl_1415 => {\n      let binding_1416 = decl_1415.binding.removeScope(this.context.useScope, this.context.phase);\n      collectBindings(binding_1416).forEach(stx_1417 => {\n        let newBinding_1418 = gensym(stx_1417.val());\n        this.context.bindings.add(stx_1417, {binding: newBinding_1418, phase: this.context.phase, skipDup: term_1414.kind === \"var\"});\n        this.context.env.set(newBinding_1418.toString(), new VarBindingTransform(stx_1417));\n      });\n      return decl_1415.extend({binding: binding_1416});\n    })});\n  }\n  registerSyntaxDeclaration(term_1419) {\n    if (isSyntaxDeclaration(term_1419)) {\n      let scope = freshScope(\"nonrec\");\n      term_1419 = term_1419.extend({declarators: term_1419.declarators.map(decl_1420 => {\n        let name_1421 = decl_1420.binding.name;\n        let nameAdded_1422 = name_1421.addScope(scope, this.context.bindings, ALL_PHASES);\n        let nameRemoved_1423 = name_1421.removeScope(this.context.currentScope[this.context.currentScope.length - 1], this.context.phase);\n        let newBinding_1424 = gensym(name_1421.val());\n        this.context.bindings.addForward(nameAdded_1422, nameRemoved_1423, newBinding_1424, this.context.phase);\n        return decl_1420.extend({init: decl_1420.init.addScope(scope, this.context.bindings, ALL_PHASES)});\n      })});\n    }\n    return term_1419.extend({declarators: term_1419.declarators.map(decl_1425 => {\n      let binding_1426 = decl_1425.binding.removeScope(this.context.useScope, this.context.phase);\n      let syntaxExpander_1427 = new TermExpander(_.merge(this.context, {phase: this.context.phase + 1, env: new Env, store: this.context.store}));\n      let init_1428 = syntaxExpander_1427.expand(decl_1425.init);\n      let val_1429 = evalCompiletimeValue(init_1428.gen(), _.merge(this.context, {phase: this.context.phase + 1}));\n      collectBindings(binding_1426).forEach(stx_1430 => {\n        let newBinding_1431 = gensym(stx_1430.val());\n        this.context.bindings.add(stx_1430, {binding: newBinding_1431, phase: this.context.phase, skipDup: false});\n        let resolvedName_1432 = stx_1430.resolve(this.context.phase);\n        this.context.env.set(resolvedName_1432, new CompiletimeTransform(val_1429));\n      });\n      return decl_1425.extend({binding: binding_1426, init: init_1428});\n    })});\n  }\n}\n"]} - -/***/ }, -/* 51 */ -/***/ function(module, exports, __webpack_require__) { - - "use strict"; - - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.Enforester = undefined; - - var _terms = __webpack_require__(28); - - var _terms2 = _interopRequireDefault(_terms); - - var _ramdaFantasy = __webpack_require__(15); - - var _transforms = __webpack_require__(32); - - var _immutable = __webpack_require__(11); - - var _errors = __webpack_require__(13); - - var _operators = __webpack_require__(52); - - var _syntax = __webpack_require__(12); - - var _syntax2 = _interopRequireDefault(_syntax); - - var _scope = __webpack_require__(44); - - var _loadSyntax = __webpack_require__(53); - - var _macroContext = __webpack_require__(65); - - var _macroContext2 = _interopRequireDefault(_macroContext); - - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - - const Just_41 = _ramdaFantasy.Maybe.Just; - const Nothing_42 = _ramdaFantasy.Maybe.Nothing; - const EXPR_LOOP_OPERATOR_43 = {}; - const EXPR_LOOP_NO_CHANGE_44 = {}; - const EXPR_LOOP_EXPANSION_45 = {}; - class Enforester_46 { - constructor(stxl_47, prev_48, context_49) { - this.done = false; - (0, _errors.assert)(_immutable.List.isList(stxl_47), "expecting a list of terms to enforest"); - (0, _errors.assert)(_immutable.List.isList(prev_48), "expecting a list of terms to enforest"); - (0, _errors.assert)(context_49, "expecting a context to enforest"); - this.term = null; - this.rest = stxl_47; - this.prev = prev_48; - this.context = context_49; - } - peek() { - let n_50 = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0]; - - return this.rest.get(n_50); - } - advance() { - let ret_51 = this.rest.first(); - this.rest = this.rest.rest(); - return ret_51; + this.source = source; + this.index = 0; + this.line = 0; + this.lineStart = 0; + this.startIndex = 0; + this.startLine = 0; + this.startLineStart = 0; + this.lastIndex = 0; + this.lastLine = 0; + this.lastLineStart = 0; + this.hasLineTerminatorBeforeNext = false; + this.tokenIndex = 0; } - enforest() { - let type_52 = arguments.length <= 0 || arguments[0] === undefined ? "Module" : arguments[0]; - this.term = null; - if (this.rest.size === 0) { - this.done = true; - return this.term; - } - if (this.isEOF(this.peek())) { - this.term = new _terms2.default("EOF", {}); - this.advance(); - return this.term; - } - let result_53; - if (type_52 === "expression") { - result_53 = this.enforestExpressionLoop(); - } else { - result_53 = this.enforestModule(); - } - if (this.rest.size === 0) { - this.done = true; - } - return result_53; - } - enforestModule() { - return this.enforestBody(); - } - enforestBody() { - return this.enforestModuleItem(); - } - enforestModuleItem() { - let lookahead_54 = this.peek(); - if (this.isKeyword(lookahead_54, "import")) { - this.advance(); - return this.enforestImportDeclaration(); - } else if (this.isKeyword(lookahead_54, "export")) { - this.advance(); - return this.enforestExportDeclaration(); - } else if (this.isIdentifier(lookahead_54, "#")) { - return this.enforestLanguagePragma(); - } - return this.enforestStatement(); - } - enforestLanguagePragma() { - this.matchIdentifier("#"); - this.matchIdentifier("lang"); - let path_55 = this.matchStringLiteral(); - this.consumeSemicolon(); - return new _terms2.default("Pragma", { kind: "lang", items: _immutable.List.of(path_55) }); - } - enforestExportDeclaration() { - let lookahead_56 = this.peek(); - if (this.isPunctuator(lookahead_56, "*")) { - this.advance(); - let moduleSpecifier = this.enforestFromClause(); - return new _terms2.default("ExportAllFrom", { moduleSpecifier: moduleSpecifier }); - } else if (this.isBraces(lookahead_56)) { - let namedExports = this.enforestExportClause(); - let moduleSpecifier = null; - if (this.isIdentifier(this.peek(), "from")) { - moduleSpecifier = this.enforestFromClause(); - } - return new _terms2.default("ExportFrom", { namedExports: namedExports, moduleSpecifier: moduleSpecifier }); - } else if (this.isKeyword(lookahead_56, "class")) { - return new _terms2.default("Export", { declaration: this.enforestClass({ isExpr: false }) }); - } else if (this.isFnDeclTransform(lookahead_56)) { - return new _terms2.default("Export", { declaration: this.enforestFunction({ isExpr: false, inDefault: false }) }); - } else if (this.isKeyword(lookahead_56, "default")) { - this.advance(); - if (this.isFnDeclTransform(this.peek())) { - return new _terms2.default("ExportDefault", { body: this.enforestFunction({ isExpr: false, inDefault: true }) }); - } else if (this.isKeyword(this.peek(), "class")) { - return new _terms2.default("ExportDefault", { body: this.enforestClass({ isExpr: false, inDefault: true }) }); - } else { - let body = this.enforestExpressionLoop(); - this.consumeSemicolon(); - return new _terms2.default("ExportDefault", { body: body }); - } - } else if (this.isVarDeclTransform(lookahead_56) || this.isLetDeclTransform(lookahead_56) || this.isConstDeclTransform(lookahead_56) || this.isSyntaxrecDeclTransform(lookahead_56) || this.isSyntaxDeclTransform(lookahead_56)) { - return new _terms2.default("Export", { declaration: this.enforestVariableDeclaration() }); - } - throw this.createError(lookahead_56, "unexpected syntax"); - } - enforestExportClause() { - let enf_57 = new Enforester_46(this.matchCurlies(), (0, _immutable.List)(), this.context); - let result_58 = []; - while (enf_57.rest.size !== 0) { - result_58.push(enf_57.enforestExportSpecifier()); - enf_57.consumeComma(); - } - return (0, _immutable.List)(result_58); - } - enforestExportSpecifier() { - let name_59 = this.enforestIdentifier(); - if (this.isIdentifier(this.peek(), "as")) { - this.advance(); - let exportedName = this.enforestIdentifier(); - return new _terms2.default("ExportSpecifier", { name: name_59, exportedName: exportedName }); - } - return new _terms2.default("ExportSpecifier", { name: null, exportedName: name_59 }); - } - enforestImportDeclaration() { - let lookahead_60 = this.peek(); - let defaultBinding_61 = null; - let namedImports_62 = (0, _immutable.List)(); - let forSyntax_63 = false; - if (this.isStringLiteral(lookahead_60)) { - let moduleSpecifier = this.advance(); - this.consumeSemicolon(); - return new _terms2.default("Import", { defaultBinding: defaultBinding_61, namedImports: namedImports_62, moduleSpecifier: moduleSpecifier }); - } - if (this.isIdentifier(lookahead_60) || this.isKeyword(lookahead_60)) { - defaultBinding_61 = this.enforestBindingIdentifier(); - if (!this.isPunctuator(this.peek(), ",")) { - let moduleSpecifier = this.enforestFromClause(); - if (this.isKeyword(this.peek(), "for") && this.isIdentifier(this.peek(1), "syntax")) { - this.advance(); - this.advance(); - forSyntax_63 = true; - } - return new _terms2.default("Import", { defaultBinding: defaultBinding_61, moduleSpecifier: moduleSpecifier, namedImports: (0, _immutable.List)(), forSyntax: forSyntax_63 }); - } - } - this.consumeComma(); - lookahead_60 = this.peek(); - if (this.isBraces(lookahead_60)) { - let imports = this.enforestNamedImports(); - let fromClause = this.enforestFromClause(); - if (this.isKeyword(this.peek(), "for") && this.isIdentifier(this.peek(1), "syntax")) { - this.advance(); - this.advance(); - forSyntax_63 = true; - } - return new _terms2.default("Import", { defaultBinding: defaultBinding_61, forSyntax: forSyntax_63, namedImports: imports, moduleSpecifier: fromClause }); - } else if (this.isPunctuator(lookahead_60, "*")) { - let namespaceBinding = this.enforestNamespaceBinding(); - let moduleSpecifier = this.enforestFromClause(); - if (this.isKeyword(this.peek(), "for") && this.isIdentifier(this.peek(1), "syntax")) { - this.advance(); - this.advance(); - forSyntax_63 = true; - } - return new _terms2.default("ImportNamespace", { defaultBinding: defaultBinding_61, forSyntax: forSyntax_63, namespaceBinding: namespaceBinding, moduleSpecifier: moduleSpecifier }); - } - throw this.createError(lookahead_60, "unexpected syntax"); - } - enforestNamespaceBinding() { - this.matchPunctuator("*"); - this.matchIdentifier("as"); - return this.enforestBindingIdentifier(); - } - enforestNamedImports() { - let enf_64 = new Enforester_46(this.matchCurlies(), (0, _immutable.List)(), this.context); - let result_65 = []; - while (enf_64.rest.size !== 0) { - result_65.push(enf_64.enforestImportSpecifiers()); - enf_64.consumeComma(); - } - return (0, _immutable.List)(result_65); - } - enforestImportSpecifiers() { - let lookahead_66 = this.peek(); - let name_67; - if (this.isIdentifier(lookahead_66) || this.isKeyword(lookahead_66)) { - name_67 = this.advance(); - if (!this.isIdentifier(this.peek(), "as")) { - return new _terms2.default("ImportSpecifier", { name: null, binding: new _terms2.default("BindingIdentifier", { name: name_67 }) }); - } else { - this.matchIdentifier("as"); - } - } else { - throw this.createError(lookahead_66, "unexpected token in import specifier"); - } - return new _terms2.default("ImportSpecifier", { name: name_67, binding: this.enforestBindingIdentifier() }); - } - enforestFromClause() { - this.matchIdentifier("from"); - let lookahead_68 = this.matchStringLiteral(); - this.consumeSemicolon(); - return lookahead_68; - } - enforestStatementListItem() { - let lookahead_69 = this.peek(); - if (this.isFnDeclTransform(lookahead_69)) { - return this.enforestFunctionDeclaration({ isExpr: false }); - } else if (this.isKeyword(lookahead_69, "class")) { - return this.enforestClass({ isExpr: false }); - } else { - return this.enforestStatement(); - } - } - enforestStatement() { - let lookahead_70 = this.peek(); - if (this.term === null && this.isCompiletimeTransform(lookahead_70)) { - this.expandMacro(); - lookahead_70 = this.peek(); - } - if (this.term === null && this.isTerm(lookahead_70)) { - return this.advance(); - } - if (this.term === null && this.isBraces(lookahead_70)) { - return this.enforestBlockStatement(); - } - if (this.term === null && this.isWhileTransform(lookahead_70)) { - return this.enforestWhileStatement(); - } - if (this.term === null && this.isIfTransform(lookahead_70)) { - return this.enforestIfStatement(); - } - if (this.term === null && this.isForTransform(lookahead_70)) { - return this.enforestForStatement(); - } - if (this.term === null && this.isSwitchTransform(lookahead_70)) { - return this.enforestSwitchStatement(); - } - if (this.term === null && this.isBreakTransform(lookahead_70)) { - return this.enforestBreakStatement(); - } - if (this.term === null && this.isContinueTransform(lookahead_70)) { - return this.enforestContinueStatement(); - } - if (this.term === null && this.isDoTransform(lookahead_70)) { - return this.enforestDoStatement(); - } - if (this.term === null && this.isDebuggerTransform(lookahead_70)) { - return this.enforestDebuggerStatement(); - } - if (this.term === null && this.isWithTransform(lookahead_70)) { - return this.enforestWithStatement(); - } - if (this.term === null && this.isTryTransform(lookahead_70)) { - return this.enforestTryStatement(); - } - if (this.term === null && this.isThrowTransform(lookahead_70)) { - return this.enforestThrowStatement(); - } - if (this.term === null && this.isKeyword(lookahead_70, "class")) { - return this.enforestClass({ isExpr: false }); - } - if (this.term === null && this.isFnDeclTransform(lookahead_70)) { - return this.enforestFunctionDeclaration(); - } - if (this.term === null && this.isIdentifier(lookahead_70) && this.isPunctuator(this.peek(1), ":")) { - return this.enforestLabeledStatement(); - } - if (this.term === null && (this.isVarDeclTransform(lookahead_70) || this.isLetDeclTransform(lookahead_70) || this.isConstDeclTransform(lookahead_70) || this.isSyntaxrecDeclTransform(lookahead_70) || this.isSyntaxDeclTransform(lookahead_70))) { - let stmt = new _terms2.default("VariableDeclarationStatement", { declaration: this.enforestVariableDeclaration() }); - this.consumeSemicolon(); - return stmt; - } - if (this.term === null && this.isReturnStmtTransform(lookahead_70)) { - return this.enforestReturnStatement(); - } - if (this.term === null && this.isPunctuator(lookahead_70, ";")) { - this.advance(); - return new _terms2.default("EmptyStatement", {}); - } - return this.enforestExpressionStatement(); - } - enforestLabeledStatement() { - let label_71 = this.matchIdentifier(); - let punc_72 = this.matchPunctuator(":"); - let stmt_73 = this.enforestStatement(); - return new _terms2.default("LabeledStatement", { label: label_71, body: stmt_73 }); - } - enforestBreakStatement() { - this.matchKeyword("break"); - let lookahead_74 = this.peek(); - let label_75 = null; - if (this.rest.size === 0 || this.isPunctuator(lookahead_74, ";")) { - this.consumeSemicolon(); - return new _terms2.default("BreakStatement", { label: label_75 }); - } - if (this.isIdentifier(lookahead_74) || this.isKeyword(lookahead_74, "yield") || this.isKeyword(lookahead_74, "let")) { - label_75 = this.enforestIdentifier(); - } - this.consumeSemicolon(); - return new _terms2.default("BreakStatement", { label: label_75 }); - } - enforestTryStatement() { - this.matchKeyword("try"); - let body_76 = this.enforestBlock(); - if (this.isKeyword(this.peek(), "catch")) { - let catchClause = this.enforestCatchClause(); - if (this.isKeyword(this.peek(), "finally")) { - this.advance(); - let finalizer = this.enforestBlock(); - return new _terms2.default("TryFinallyStatement", { body: body_76, catchClause: catchClause, finalizer: finalizer }); - } - return new _terms2.default("TryCatchStatement", { body: body_76, catchClause: catchClause }); - } - if (this.isKeyword(this.peek(), "finally")) { - this.advance(); - let finalizer = this.enforestBlock(); - return new _terms2.default("TryFinallyStatement", { body: body_76, catchClause: null, finalizer: finalizer }); - } - throw this.createError(this.peek(), "try with no catch or finally"); - } - enforestCatchClause() { - this.matchKeyword("catch"); - let bindingParens_77 = this.matchParens(); - let enf_78 = new Enforester_46(bindingParens_77, (0, _immutable.List)(), this.context); - let binding_79 = enf_78.enforestBindingTarget(); - let body_80 = this.enforestBlock(); - return new _terms2.default("CatchClause", { binding: binding_79, body: body_80 }); - } - enforestThrowStatement() { - this.matchKeyword("throw"); - let expression_81 = this.enforestExpression(); - this.consumeSemicolon(); - return new _terms2.default("ThrowStatement", { expression: expression_81 }); - } - enforestWithStatement() { - this.matchKeyword("with"); - let objParens_82 = this.matchParens(); - let enf_83 = new Enforester_46(objParens_82, (0, _immutable.List)(), this.context); - let object_84 = enf_83.enforestExpression(); - let body_85 = this.enforestStatement(); - return new _terms2.default("WithStatement", { object: object_84, body: body_85 }); - } - enforestDebuggerStatement() { - this.matchKeyword("debugger"); - return new _terms2.default("DebuggerStatement", {}); - } - enforestDoStatement() { - this.matchKeyword("do"); - let body_86 = this.enforestStatement(); - this.matchKeyword("while"); - let testBody_87 = this.matchParens(); - let enf_88 = new Enforester_46(testBody_87, (0, _immutable.List)(), this.context); - let test_89 = enf_88.enforestExpression(); - this.consumeSemicolon(); - return new _terms2.default("DoWhileStatement", { body: body_86, test: test_89 }); - } - enforestContinueStatement() { - let kwd_90 = this.matchKeyword("continue"); - let lookahead_91 = this.peek(); - let label_92 = null; - if (this.rest.size === 0 || this.isPunctuator(lookahead_91, ";")) { - this.consumeSemicolon(); - return new _terms2.default("ContinueStatement", { label: label_92 }); - } - if (this.lineNumberEq(kwd_90, lookahead_91) && (this.isIdentifier(lookahead_91) || this.isKeyword(lookahead_91, "yield") || this.isKeyword(lookahead_91, "let"))) { - label_92 = this.enforestIdentifier(); - } - this.consumeSemicolon(); - return new _terms2.default("ContinueStatement", { label: label_92 }); - } - enforestSwitchStatement() { - this.matchKeyword("switch"); - let cond_93 = this.matchParens(); - let enf_94 = new Enforester_46(cond_93, (0, _immutable.List)(), this.context); - let discriminant_95 = enf_94.enforestExpression(); - let body_96 = this.matchCurlies(); - if (body_96.size === 0) { - return new _terms2.default("SwitchStatement", { discriminant: discriminant_95, cases: (0, _immutable.List)() }); - } - enf_94 = new Enforester_46(body_96, (0, _immutable.List)(), this.context); - let cases_97 = enf_94.enforestSwitchCases(); - let lookahead_98 = enf_94.peek(); - if (enf_94.isKeyword(lookahead_98, "default")) { - let defaultCase = enf_94.enforestSwitchDefault(); - let postDefaultCases = enf_94.enforestSwitchCases(); - return new _terms2.default("SwitchStatementWithDefault", { discriminant: discriminant_95, preDefaultCases: cases_97, defaultCase: defaultCase, postDefaultCases: postDefaultCases }); - } - return new _terms2.default("SwitchStatement", { discriminant: discriminant_95, cases: cases_97 }); - } - enforestSwitchCases() { - let cases_99 = []; - while (!(this.rest.size === 0 || this.isKeyword(this.peek(), "default"))) { - cases_99.push(this.enforestSwitchCase()); - } - return (0, _immutable.List)(cases_99); - } - enforestSwitchCase() { - this.matchKeyword("case"); - return new _terms2.default("SwitchCase", { test: this.enforestExpression(), consequent: this.enforestSwitchCaseBody() }); - } - enforestSwitchCaseBody() { - this.matchPunctuator(":"); - return this.enforestStatementListInSwitchCaseBody(); - } - enforestStatementListInSwitchCaseBody() { - let result_100 = []; - while (!(this.rest.size === 0 || this.isKeyword(this.peek(), "default") || this.isKeyword(this.peek(), "case"))) { - result_100.push(this.enforestStatementListItem()); - } - return (0, _immutable.List)(result_100); - } - enforestSwitchDefault() { - this.matchKeyword("default"); - return new _terms2.default("SwitchDefault", { consequent: this.enforestSwitchCaseBody() }); - } - enforestForStatement() { - this.matchKeyword("for"); - let cond_101 = this.matchParens(); - let enf_102 = new Enforester_46(cond_101, (0, _immutable.List)(), this.context); - let lookahead_103, test_104, init_105, right_106, type_107, left_108, update_109; - if (enf_102.isPunctuator(enf_102.peek(), ";")) { - enf_102.advance(); - if (!enf_102.isPunctuator(enf_102.peek(), ";")) { - test_104 = enf_102.enforestExpression(); - } - enf_102.matchPunctuator(";"); - if (enf_102.rest.size !== 0) { - right_106 = enf_102.enforestExpression(); - } - return new _terms2.default("ForStatement", { init: null, test: test_104, update: right_106, body: this.enforestStatement() }); - } else { - lookahead_103 = enf_102.peek(); - if (enf_102.isVarDeclTransform(lookahead_103) || enf_102.isLetDeclTransform(lookahead_103) || enf_102.isConstDeclTransform(lookahead_103)) { - init_105 = enf_102.enforestVariableDeclaration(); - lookahead_103 = enf_102.peek(); - if (this.isKeyword(lookahead_103, "in") || this.isIdentifier(lookahead_103, "of")) { - if (this.isKeyword(lookahead_103, "in")) { - enf_102.advance(); - right_106 = enf_102.enforestExpression(); - type_107 = "ForInStatement"; - } else if (this.isIdentifier(lookahead_103, "of")) { - enf_102.advance(); - right_106 = enf_102.enforestExpression(); - type_107 = "ForOfStatement"; - } - return new _terms2.default(type_107, { left: init_105, right: right_106, body: this.enforestStatement() }); - } - enf_102.matchPunctuator(";"); - if (enf_102.isPunctuator(enf_102.peek(), ";")) { - enf_102.advance(); - test_104 = null; - } else { - test_104 = enf_102.enforestExpression(); - enf_102.matchPunctuator(";"); - } - update_109 = enf_102.enforestExpression(); - } else { - if (this.isKeyword(enf_102.peek(1), "in") || this.isIdentifier(enf_102.peek(1), "of")) { - left_108 = enf_102.enforestBindingIdentifier(); - let kind = enf_102.advance(); - if (this.isKeyword(kind, "in")) { - type_107 = "ForInStatement"; - } else { - type_107 = "ForOfStatement"; - } - right_106 = enf_102.enforestExpression(); - return new _terms2.default(type_107, { left: left_108, right: right_106, body: this.enforestStatement() }); - } - init_105 = enf_102.enforestExpression(); - enf_102.matchPunctuator(";"); - if (enf_102.isPunctuator(enf_102.peek(), ";")) { - enf_102.advance(); - test_104 = null; - } else { - test_104 = enf_102.enforestExpression(); - enf_102.matchPunctuator(";"); - } - update_109 = enf_102.enforestExpression(); - } - return new _terms2.default("ForStatement", { init: init_105, test: test_104, update: update_109, body: this.enforestStatement() }); - } - } - enforestIfStatement() { - this.matchKeyword("if"); - let cond_110 = this.matchParens(); - let enf_111 = new Enforester_46(cond_110, (0, _immutable.List)(), this.context); - let lookahead_112 = enf_111.peek(); - let test_113 = enf_111.enforestExpression(); - if (test_113 === null) { - throw enf_111.createError(lookahead_112, "expecting an expression"); - } - let consequent_114 = this.enforestStatement(); - let alternate_115 = null; - if (this.isKeyword(this.peek(), "else")) { - this.advance(); - alternate_115 = this.enforestStatement(); - } - return new _terms2.default("IfStatement", { test: test_113, consequent: consequent_114, alternate: alternate_115 }); - } - enforestWhileStatement() { - this.matchKeyword("while"); - let cond_116 = this.matchParens(); - let enf_117 = new Enforester_46(cond_116, (0, _immutable.List)(), this.context); - let lookahead_118 = enf_117.peek(); - let test_119 = enf_117.enforestExpression(); - if (test_119 === null) { - throw enf_117.createError(lookahead_118, "expecting an expression"); + _createClass(Tokenizer, [{ + key: "saveLexerState", + value: function saveLexerState() { + return { + source: this.source, + index: this.index, + line: this.line, + lineStart: this.lineStart, + startIndex: this.startIndex, + startLine: this.startLine, + startLineStart: this.startLineStart, + lastIndex: this.lastIndex, + lastLine: this.lastLine, + lastLineStart: this.lastLineStart, + lookahead: this.lookahead, + hasLineTerminatorBeforeNext: this.hasLineTerminatorBeforeNext, + tokenIndex: this.tokenIndex + }; } - let body_120 = this.enforestStatement(); - return new _terms2.default("WhileStatement", { test: test_119, body: body_120 }); - } - enforestBlockStatement() { - return new _terms2.default("BlockStatement", { block: this.enforestBlock() }); - } - enforestBlock() { - return new _terms2.default("Block", { statements: this.matchCurlies() }); - } - enforestClass(_ref) { - let isExpr = _ref.isExpr; - let inDefault = _ref.inDefault; - - let kw_121 = this.advance(); - let name_122 = null, - supr_123 = null; - let type_124 = isExpr ? "ClassExpression" : "ClassDeclaration"; - if (this.isIdentifier(this.peek())) { - name_122 = this.enforestBindingIdentifier(); - } else if (!isExpr) { - if (inDefault) { - name_122 = new _terms2.default("BindingIdentifier", { name: _syntax2.default.fromIdentifier("_default", kw_121) }); - } else { - throw this.createError(this.peek(), "unexpected syntax"); - } + }, { + key: "restoreLexerState", + value: function restoreLexerState(state) { + this.source = state.source; + this.index = state.index; + this.line = state.line; + this.lineStart = state.lineStart; + this.startIndex = state.startIndex; + this.startLine = state.startLine; + this.startLineStart = state.startLineStart; + this.lastIndex = state.lastIndex; + this.lastLine = state.lastLine; + this.lastLineStart = state.lastLineStart; + this.lookahead = state.lookahead; + this.hasLineTerminatorBeforeNext = state.hasLineTerminatorBeforeNext; + this.tokenIndex = state.tokenIndex; } - if (this.isKeyword(this.peek(), "extends")) { - this.advance(); - supr_123 = this.enforestExpressionLoop(); + }, { + key: "createILLEGAL", + value: function createILLEGAL() { + this.startIndex = this.index; + this.startLine = this.line; + this.startLineStart = this.lineStart; + return this.index < this.source.length ? this.createError(_errors.ErrorMessages.UNEXPECTED_ILLEGAL_TOKEN, this.source.charAt(this.index)) : this.createError(_errors.ErrorMessages.UNEXPECTED_EOS); } - let elements_125 = []; - let enf_126 = new Enforester_46(this.matchCurlies(), (0, _immutable.List)(), this.context); - while (enf_126.rest.size !== 0) { - if (enf_126.isPunctuator(enf_126.peek(), ";")) { - enf_126.advance(); - continue; - } - let isStatic = false; - - var _enf_126$enforestMeth = enf_126.enforestMethodDefinition(); - - let methodOrKey = _enf_126$enforestMeth.methodOrKey; - let kind = _enf_126$enforestMeth.kind; - - if (kind === "identifier" && methodOrKey.value.val() === "static") { - isStatic = true; - - var _enf_126$enforestMeth2 = enf_126.enforestMethodDefinition(); - - methodOrKey = _enf_126$enforestMeth2.methodOrKey; - kind = _enf_126$enforestMeth2.kind; - } - if (kind === "method") { - elements_125.push(new _terms2.default("ClassElement", { isStatic: isStatic, method: methodOrKey })); - } else { - throw this.createError(enf_126.peek(), "Only methods are allowed in classes"); + }, { + key: "createUnexpected", + value: function createUnexpected(token) { + switch (token.type.klass) { + case TokenClass.Eof: + return this.createError(_errors.ErrorMessages.UNEXPECTED_EOS); + case TokenClass.Ident: + return this.createError(_errors.ErrorMessages.UNEXPECTED_IDENTIFIER); + case TokenClass.Keyword: + return this.createError(_errors.ErrorMessages.UNEXPECTED_TOKEN, token.slice.text); + case TokenClass.NumericLiteral: + return this.createError(_errors.ErrorMessages.UNEXPECTED_NUMBER); + case TokenClass.TemplateElement: + return this.createError(_errors.ErrorMessages.UNEXPECTED_TEMPLATE); + case TokenClass.Punctuator: + return this.createError(_errors.ErrorMessages.UNEXPECTED_TOKEN, token.type.name); + case TokenClass.StringLiteral: + return this.createError(_errors.ErrorMessages.UNEXPECTED_STRING); + // the other token classes are RegularExpression and Illegal, but they cannot reach here } } - return new _terms2.default(type_124, { name: name_122, super: supr_123, elements: (0, _immutable.List)(elements_125) }); - } - enforestBindingTarget() { - var _ref2 = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; - - let allowPunctuator = _ref2.allowPunctuator; + }, { + key: "createError", + value: function createError(message) { + var _arguments = arguments; - let lookahead_127 = this.peek(); - if (this.isIdentifier(lookahead_127) || this.isKeyword(lookahead_127) || allowPunctuator && this.isPunctuator(lookahead_127)) { - return this.enforestBindingIdentifier({ allowPunctuator: allowPunctuator }); - } else if (this.isBrackets(lookahead_127)) { - return this.enforestArrayBinding(); - } else if (this.isBraces(lookahead_127)) { - return this.enforestObjectBinding(); - } - (0, _errors.assert)(false, "not implemented yet"); - } - enforestObjectBinding() { - let enf_128 = new Enforester_46(this.matchCurlies(), (0, _immutable.List)(), this.context); - let properties_129 = []; - while (enf_128.rest.size !== 0) { - properties_129.push(enf_128.enforestBindingProperty()); - enf_128.consumeComma(); + /* istanbul ignore next */ + var msg = message.replace(/\{(\d+)\}/g, function (_, n) { + return JSON.stringify(_arguments[+n + 1]); + }); + return new JsError(this.startIndex, this.startLine + 1, this.startIndex - this.startLineStart + 1, msg); } - return new _terms2.default("ObjectBinding", { properties: (0, _immutable.List)(properties_129) }); - } - enforestBindingProperty() { - let lookahead_130 = this.peek(); - - var _enforestPropertyName = this.enforestPropertyName(); - - let name = _enforestPropertyName.name; - let binding = _enforestPropertyName.binding; + }, { + key: "createErrorWithLocation", + value: function createErrorWithLocation(location, message) { + var _arguments2 = arguments; - if (this.isIdentifier(lookahead_130) || this.isKeyword(lookahead_130, "let") || this.isKeyword(lookahead_130, "yield")) { - if (!this.isPunctuator(this.peek(), ":")) { - let defaultValue = null; - if (this.isAssign(this.peek())) { - this.advance(); - let expr = this.enforestExpressionLoop(); - defaultValue = expr; - } - return new _terms2.default("BindingPropertyIdentifier", { binding: binding, init: defaultValue }); - } - } - this.matchPunctuator(":"); - binding = this.enforestBindingElement(); - return new _terms2.default("BindingPropertyProperty", { name: name, binding: binding }); - } - enforestArrayBinding() { - let bracket_131 = this.matchSquares(); - let enf_132 = new Enforester_46(bracket_131, (0, _immutable.List)(), this.context); - let elements_133 = [], - restElement_134 = null; - while (enf_132.rest.size !== 0) { - let el; - if (enf_132.isPunctuator(enf_132.peek(), ",")) { - enf_132.consumeComma(); - el = null; - } else { - if (enf_132.isPunctuator(enf_132.peek(), "...")) { - enf_132.advance(); - restElement_134 = enf_132.enforestBindingTarget(); - break; - } else { - el = enf_132.enforestBindingElement(); - } - enf_132.consumeComma(); + /* istanbul ignore next */ + var msg = message.replace(/\{(\d+)\}/g, function (_, n) { + return JSON.stringify(_arguments2[+n + 2]); + }); + if (location.slice && location.slice.startLocation) { + location = location.slice.startLocation; } - elements_133.push(el); - } - return new _terms2.default("ArrayBinding", { elements: (0, _immutable.List)(elements_133), restElement: restElement_134 }); - } - enforestBindingElement() { - let binding_135 = this.enforestBindingTarget(); - if (this.isAssign(this.peek())) { - this.advance(); - let init = this.enforestExpressionLoop(); - binding_135 = new _terms2.default("BindingWithDefault", { binding: binding_135, init: init }); - } - return binding_135; - } - enforestBindingIdentifier() { - var _ref3 = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; - - let allowPunctuator = _ref3.allowPunctuator; - - let name_136; - if (allowPunctuator && this.isPunctuator(this.peek())) { - name_136 = this.enforestPunctuator(); - } else { - name_136 = this.enforestIdentifier(); - } - return new _terms2.default("BindingIdentifier", { name: name_136 }); - } - enforestPunctuator() { - let lookahead_137 = this.peek(); - if (this.isPunctuator(lookahead_137)) { - return this.advance(); - } - throw this.createError(lookahead_137, "expecting a punctuator"); - } - enforestIdentifier() { - let lookahead_138 = this.peek(); - if (this.isIdentifier(lookahead_138) || this.isKeyword(lookahead_138)) { - return this.advance(); - } - throw this.createError(lookahead_138, "expecting an identifier"); - } - enforestReturnStatement() { - let kw_139 = this.advance(); - let lookahead_140 = this.peek(); - if (this.rest.size === 0 || lookahead_140 && !this.lineNumberEq(kw_139, lookahead_140)) { - return new _terms2.default("ReturnStatement", { expression: null }); - } - let term_141 = null; - if (!this.isPunctuator(lookahead_140, ";")) { - term_141 = this.enforestExpression(); - (0, _errors.expect)(term_141 != null, "Expecting an expression to follow return keyword", lookahead_140, this.rest); + return new JsError(location.offset, location.line, location.column + 1, msg); } - this.consumeSemicolon(); - return new _terms2.default("ReturnStatement", { expression: term_141 }); - } - enforestVariableDeclaration() { - let kind_142; - let lookahead_143 = this.advance(); - let kindSyn_144 = lookahead_143; - let phase_145 = this.context.phase; - if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === _transforms.VariableDeclTransform) { - kind_142 = "var"; - } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === _transforms.LetDeclTransform) { - kind_142 = "let"; - } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === _transforms.ConstDeclTransform) { - kind_142 = "const"; - } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === _transforms.SyntaxDeclTransform) { - kind_142 = "syntax"; - } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === _transforms.SyntaxrecDeclTransform) { - kind_142 = "syntaxrec"; - } - let decls_146 = (0, _immutable.List)(); - while (true) { - let term = this.enforestVariableDeclarator({ isSyntax: kind_142 === "syntax" || kind_142 === "syntaxrec" }); - let lookahead_143 = this.peek(); - decls_146 = decls_146.concat(term); - if (this.isPunctuator(lookahead_143, ",")) { - this.advance(); - } else { - break; + }, { + key: "getKeyword", + value: function getKeyword(id) { + if (id.length === 1 || id.length > 10) { + return TokenType.IDENTIFIER; } - } - return new _terms2.default("VariableDeclaration", { kind: kind_142, declarators: decls_146 }); - } - enforestVariableDeclarator(_ref4) { - let isSyntax = _ref4.isSyntax; - let id_147 = this.enforestBindingTarget({ allowPunctuator: isSyntax }); - let lookahead_148 = this.peek(); - let init_149, rest_150; - if (this.isPunctuator(lookahead_148, "=")) { - this.advance(); - let enf = new Enforester_46(this.rest, (0, _immutable.List)(), this.context); - init_149 = enf.enforest("expression"); - this.rest = enf.rest; - } else { - init_149 = null; - } - return new _terms2.default("VariableDeclarator", { binding: id_147, init: init_149 }); - } - enforestExpressionStatement() { - let start_151 = this.rest.get(0); - let expr_152 = this.enforestExpression(); - if (expr_152 === null) { - throw this.createError(start_151, "not a valid expression"); - } - this.consumeSemicolon(); - return new _terms2.default("ExpressionStatement", { expression: expr_152 }); - } - enforestExpression() { - let left_153 = this.enforestExpressionLoop(); - let lookahead_154 = this.peek(); - if (this.isPunctuator(lookahead_154, ",")) { - while (this.rest.size !== 0) { - if (!this.isPunctuator(this.peek(), ",")) { + /* istanbul ignore next */ + switch (id.length) { + case 2: + switch (id.charAt(0)) { + case "i": + switch (id.charAt(1)) { + case "f": + return TokenType.IF; + case "n": + return TokenType.IN; + default: + break; + } + break; + case "d": + if (id.charAt(1) === "o") { + return TokenType.DO; + } + break; + } + break; + case 3: + switch (id.charAt(0)) { + case "v": + if (Tokenizer.cse2(id, "a", "r")) { + return TokenType.VAR; + } + break; + case "f": + if (Tokenizer.cse2(id, "o", "r")) { + return TokenType.FOR; + } + break; + case "n": + if (Tokenizer.cse2(id, "e", "w")) { + return TokenType.NEW; + } + break; + case "t": + if (Tokenizer.cse2(id, "r", "y")) { + return TokenType.TRY; + } + break; + case "l": + if (Tokenizer.cse2(id, "e", "t")) { + return TokenType.LET; + } + break; + } + break; + case 4: + switch (id.charAt(0)) { + case "t": + if (Tokenizer.cse3(id, "h", "i", "s")) { + return TokenType.THIS; + } else if (Tokenizer.cse3(id, "r", "u", "e")) { + return TokenType.TRUE; + } + break; + case "n": + if (Tokenizer.cse3(id, "u", "l", "l")) { + return TokenType.NULL; + } + break; + case "e": + if (Tokenizer.cse3(id, "l", "s", "e")) { + return TokenType.ELSE; + } + break; + case "c": + if (Tokenizer.cse3(id, "a", "s", "e")) { + return TokenType.CASE; + } + break; + case "v": + if (Tokenizer.cse3(id, "o", "i", "d")) { + return TokenType.VOID; + } + break; + case "w": + if (Tokenizer.cse3(id, "i", "t", "h")) { + return TokenType.WITH; + } + break; + } + break; + case 5: + switch (id.charAt(0)) { + case "a": + if (this.moduleIsTheGoalSymbol && Tokenizer.cse4(id, "w", "a", "i", "t")) { + return TokenType.AWAIT; + } + break; + case "w": + if (Tokenizer.cse4(id, "h", "i", "l", "e")) { + return TokenType.WHILE; + } + break; + case "b": + if (Tokenizer.cse4(id, "r", "e", "a", "k")) { + return TokenType.BREAK; + } + break; + case "f": + if (Tokenizer.cse4(id, "a", "l", "s", "e")) { + return TokenType.FALSE; + } + break; + case "c": + if (Tokenizer.cse4(id, "a", "t", "c", "h")) { + return TokenType.CATCH; + } else if (Tokenizer.cse4(id, "o", "n", "s", "t")) { + return TokenType.CONST; + } else if (Tokenizer.cse4(id, "l", "a", "s", "s")) { + return TokenType.CLASS; + } + break; + case "t": + if (Tokenizer.cse4(id, "h", "r", "o", "w")) { + return TokenType.THROW; + } + break; + case "y": + if (Tokenizer.cse4(id, "i", "e", "l", "d")) { + return TokenType.YIELD; + } + break; + case "s": + if (Tokenizer.cse4(id, "u", "p", "e", "r")) { + return TokenType.SUPER; + } + break; + } + break; + case 6: + switch (id.charAt(0)) { + case "r": + if (Tokenizer.cse5(id, "e", "t", "u", "r", "n")) { + return TokenType.RETURN; + } + break; + case "t": + if (Tokenizer.cse5(id, "y", "p", "e", "o", "f")) { + return TokenType.TYPEOF; + } + break; + case "d": + if (Tokenizer.cse5(id, "e", "l", "e", "t", "e")) { + return TokenType.DELETE; + } + break; + case "s": + if (Tokenizer.cse5(id, "w", "i", "t", "c", "h")) { + return TokenType.SWITCH; + } + break; + case "e": + if (Tokenizer.cse5(id, "x", "p", "o", "r", "t")) { + return TokenType.EXPORT; + } + break; + case "i": + if (Tokenizer.cse5(id, "m", "p", "o", "r", "t")) { + return TokenType.IMPORT; + } + break; + } + break; + case 7: + switch (id.charAt(0)) { + case "d": + if (Tokenizer.cse6(id, "e", "f", "a", "u", "l", "t")) { + return TokenType.DEFAULT; + } + break; + case "f": + if (Tokenizer.cse6(id, "i", "n", "a", "l", "l", "y")) { + return TokenType.FINALLY; + } + break; + case "e": + if (Tokenizer.cse6(id, "x", "t", "e", "n", "d", "s")) { + return TokenType.EXTENDS; + } + break; + } + break; + case 8: + switch (id.charAt(0)) { + case "f": + if (Tokenizer.cse7(id, "u", "n", "c", "t", "i", "o", "n")) { + return TokenType.FUNCTION; + } + break; + case "c": + if (Tokenizer.cse7(id, "o", "n", "t", "i", "n", "u", "e")) { + return TokenType.CONTINUE; + } + break; + case "d": + if (Tokenizer.cse7(id, "e", "b", "u", "g", "g", "e", "r")) { + return TokenType.DEBUGGER; + } + break; + } + break; + case 10: + if (id === "instanceof") { + return TokenType.INSTANCEOF; + } break; - } - let operator = this.advance(); - let right = this.enforestExpressionLoop(); - left_153 = new _terms2.default("BinaryExpression", { left: left_153, operator: operator, right: right }); - } - } - this.term = null; - return left_153; - } - enforestExpressionLoop() { - this.term = null; - this.opCtx = { prec: 0, combine: x_155 => x_155, stack: (0, _immutable.List)() }; - do { - let term = this.enforestAssignmentExpression(); - if (term === EXPR_LOOP_NO_CHANGE_44 && this.opCtx.stack.size > 0) { - this.term = this.opCtx.combine(this.term); - - var _opCtx$stack$last = this.opCtx.stack.last(); - - let prec = _opCtx$stack$last.prec; - let combine = _opCtx$stack$last.combine; - - this.opCtx.prec = prec; - this.opCtx.combine = combine; - this.opCtx.stack = this.opCtx.stack.pop(); - } else if (term === EXPR_LOOP_NO_CHANGE_44) { - break; - } else if (term === EXPR_LOOP_OPERATOR_43 || term === EXPR_LOOP_EXPANSION_45) { - this.term = null; - } else { - this.term = term; } - } while (true); - return this.term; - } - enforestAssignmentExpression() { - let lookahead_156 = this.peek(); - if (this.term === null && this.isCompiletimeTransform(lookahead_156)) { - this.expandMacro(); - lookahead_156 = this.peek(); - } - if (this.term === null && this.isTerm(lookahead_156)) { - return this.advance(); - } - if (this.term === null && this.isKeyword(lookahead_156, "yield")) { - return this.enforestYieldExpression(); - } - if (this.term === null && this.isKeyword(lookahead_156, "class")) { - return this.enforestClass({ isExpr: true }); - } - if (this.term === null && (this.isIdentifier(lookahead_156) || this.isParens(lookahead_156)) && this.isPunctuator(this.peek(1), "=>") && this.lineNumberEq(lookahead_156, this.peek(1))) { - return this.enforestArrowExpression(); - } - if (this.term === null && this.isSyntaxTemplate(lookahead_156)) { - return this.enforestSyntaxTemplate(); - } - if (this.term === null && this.isSyntaxQuoteTransform(lookahead_156)) { - return this.enforestSyntaxQuote(); - } - if (this.term === null && this.isParens(lookahead_156)) { - return new _terms2.default("ParenthesizedExpression", { inner: this.advance().inner() }); - } - if (this.term === null && (this.isKeyword(lookahead_156, "this") || this.isIdentifier(lookahead_156) || this.isKeyword(lookahead_156, "let") || this.isKeyword(lookahead_156, "yield") || this.isNumericLiteral(lookahead_156) || this.isStringLiteral(lookahead_156) || this.isTemplate(lookahead_156) || this.isBooleanLiteral(lookahead_156) || this.isNullLiteral(lookahead_156) || this.isRegularExpression(lookahead_156) || this.isFnDeclTransform(lookahead_156) || this.isBraces(lookahead_156) || this.isBrackets(lookahead_156))) { - return this.enforestPrimaryExpression(); - } - if (this.term === null && this.isOperator(lookahead_156)) { - return this.enforestUnaryExpression(); + return TokenType.IDENTIFIER; } - if (this.term === null && this.isVarBindingTransform(lookahead_156)) { - let id = this.getFromCompiletimeEnvironment(lookahead_156).id; - if (id !== lookahead_156) { - this.advance(); - this.rest = _immutable.List.of(id).concat(this.rest); - return EXPR_LOOP_EXPANSION_45; + }, { + key: "skipSingleLineComment", + value: function skipSingleLineComment(offset) { + this.index += offset; + while (this.index < this.source.length) { + /** + * @type {Number} + */ + var chCode = this.source.charCodeAt(this.index); + this.index++; + if ((0, _utils.isLineTerminator)(chCode)) { + this.hasLineTerminatorBeforeNext = true; + if (chCode === 0xD /* "\r" */ && this.source.charCodeAt(this.index) === 0xA /*"\n" */) { + this.index++; + } + this.lineStart = this.index; + this.line++; + return; + } } } - if (this.term === null && (this.isNewTransform(lookahead_156) || this.isKeyword(lookahead_156, "super")) || this.term && (this.isPunctuator(lookahead_156, ".") && (this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1))) || this.isBrackets(lookahead_156) || this.isParens(lookahead_156))) { - return this.enforestLeftHandSideExpression({ allowCall: true }); - } - if (this.term && this.isTemplate(lookahead_156)) { - return this.enforestTemplateLiteral(); - } - if (this.term && this.isUpdateOperator(lookahead_156)) { - return this.enforestUpdateExpression(); - } - if (this.term && this.isOperator(lookahead_156)) { - return this.enforestBinaryExpression(); - } - if (this.term && this.isAssign(lookahead_156)) { - let binding = this.transformDestructuring(this.term); - let op = this.advance(); - let enf = new Enforester_46(this.rest, (0, _immutable.List)(), this.context); - let init = enf.enforest("expression"); - this.rest = enf.rest; - if (op.val() === "=") { - return new _terms2.default("AssignmentExpression", { binding: binding, expression: init }); - } else { - return new _terms2.default("CompoundAssignmentExpression", { binding: binding, operator: op.val(), expression: init }); + }, { + key: "skipMultiLineComment", + value: function skipMultiLineComment() { + this.index += 2; + var length = this.source.length; + var isLineStart = false; + while (this.index < length) { + var chCode = this.source.charCodeAt(this.index); + if (chCode < 0x80) { + switch (chCode) { + case 42: + // "*" + // Block comment ends with "*/". + if (this.source.charAt(this.index + 1) === "/") { + this.index = this.index + 2; + return isLineStart; + } + this.index++; + break; + case 10: + // "\n" + isLineStart = true; + this.hasLineTerminatorBeforeNext = true; + this.index++; + this.lineStart = this.index; + this.line++; + break; + case 13: + // "\r": + isLineStart = true; + this.hasLineTerminatorBeforeNext = true; + if (this.source.charAt(this.index + 1) === "\n") { + this.index++; + } + this.index++; + this.lineStart = this.index; + this.line++; + break; + default: + this.index++; + } + } else if (chCode === 0x2028 || chCode === 0x2029) { + isLineStart = true; + this.hasLineTerminatorBeforeNext = true; + this.index++; + this.lineStart = this.index; + this.line++; + } else { + this.index++; + } } + throw this.createILLEGAL(); } - if (this.term && this.isPunctuator(lookahead_156, "?")) { - return this.enforestConditionalExpression(); - } - return EXPR_LOOP_NO_CHANGE_44; - } - enforestPrimaryExpression() { - let lookahead_157 = this.peek(); - if (this.term === null && this.isKeyword(lookahead_157, "this")) { - return this.enforestThisExpression(); - } - if (this.term === null && (this.isIdentifier(lookahead_157) || this.isKeyword(lookahead_157, "let") || this.isKeyword(lookahead_157, "yield"))) { - return this.enforestIdentifierExpression(); - } - if (this.term === null && this.isNumericLiteral(lookahead_157)) { - return this.enforestNumericLiteral(); - } - if (this.term === null && this.isStringLiteral(lookahead_157)) { - return this.enforestStringLiteral(); - } - if (this.term === null && this.isTemplate(lookahead_157)) { - return this.enforestTemplateLiteral(); - } - if (this.term === null && this.isBooleanLiteral(lookahead_157)) { - return this.enforestBooleanLiteral(); - } - if (this.term === null && this.isNullLiteral(lookahead_157)) { - return this.enforestNullLiteral(); - } - if (this.term === null && this.isRegularExpression(lookahead_157)) { - return this.enforestRegularExpressionLiteral(); - } - if (this.term === null && this.isFnDeclTransform(lookahead_157)) { - return this.enforestFunctionExpression(); - } - if (this.term === null && this.isBraces(lookahead_157)) { - return this.enforestObjectExpression(); - } - if (this.term === null && this.isBrackets(lookahead_157)) { - return this.enforestArrayExpression(); - } - (0, _errors.assert)(false, "Not a primary expression"); - } - enforestLeftHandSideExpression(_ref5) { - let allowCall = _ref5.allowCall; + }, { + key: "skipComment", + value: function skipComment() { + this.hasLineTerminatorBeforeNext = false; - let lookahead_158 = this.peek(); - if (this.isKeyword(lookahead_158, "super")) { - this.advance(); - this.term = new _terms2.default("Super", {}); - } else if (this.isNewTransform(lookahead_158)) { - this.term = this.enforestNewExpression(); - } - while (true) { - lookahead_158 = this.peek(); - if (this.isParens(lookahead_158)) { - if (!allowCall) { - if (this.term && (0, _terms.isIdentifierExpression)(this.term)) { - return this.term; + var isLineStart = this.index === 0; + var length = this.source.length; + + while (this.index < length) { + var chCode = this.source.charCodeAt(this.index); + if ((0, _utils.isWhiteSpace)(chCode)) { + this.index++; + } else if ((0, _utils.isLineTerminator)(chCode)) { + this.hasLineTerminatorBeforeNext = true; + this.index++; + if (chCode === 13 /* "\r" */ && this.source.charAt(this.index) === "\n") { + this.index++; } - this.term = this.enforestExpressionLoop(); - } else { - this.term = this.enforestCallExpression(); + this.lineStart = this.index; + this.line++; + isLineStart = true; + } else if (chCode === 47 /* "/" */) { + if (this.index + 1 >= length) { + break; + } + chCode = this.source.charCodeAt(this.index + 1); + if (chCode === 47 /* "/" */) { + this.skipSingleLineComment(2); + isLineStart = true; + } else if (chCode === 42 /* "*" */) { + isLineStart = this.skipMultiLineComment() || isLineStart; + } else { + break; + } + } else if (!this.moduleIsTheGoalSymbol && isLineStart && chCode === 45 /* "-" */) { + if (this.index + 2 >= length) { + break; + } + // U+003E is ">" + if (this.source.charAt(this.index + 1) === "-" && this.source.charAt(this.index + 2) === ">") { + // "-->" is a single-line comment + this.skipSingleLineComment(3); + } else { + break; + } + } else if (!this.moduleIsTheGoalSymbol && chCode === 60 /* "<" */) { + if (this.source.slice(this.index + 1, this.index + 4) === "!--") { + this.skipSingleLineComment(4); + } else { + break; + } + } else { + break; } - } else if (this.isBrackets(lookahead_158)) { - this.term = allowCall ? this.enforestComputedMemberExpression() : this.enforestExpressionLoop(); - } else if (this.isPunctuator(lookahead_158, ".") && (this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1)))) { - this.term = this.enforestStaticMemberExpression(); - } else if (this.isTemplate(lookahead_158)) { - this.term = this.enforestTemplateLiteral(); - } else if (this.isBraces(lookahead_158)) { - this.term = this.enforestPrimaryExpression(); - } else if (this.isIdentifier(lookahead_158)) { - this.term = new _terms2.default("IdentifierExpression", { name: this.enforestIdentifier() }); - } else { - break; } } - return this.term; - } - enforestBooleanLiteral() { - return new _terms2.default("LiteralBooleanExpression", { value: this.advance() }); - } - enforestTemplateLiteral() { - return new _terms2.default("TemplateExpression", { tag: this.term, elements: this.enforestTemplateElements() }); - } - enforestStringLiteral() { - return new _terms2.default("LiteralStringExpression", { value: this.advance() }); - } - enforestNumericLiteral() { - let num_159 = this.advance(); - if (num_159.val() === 1 / 0) { - return new _terms2.default("LiteralInfinityExpression", {}); - } - return new _terms2.default("LiteralNumericExpression", { value: num_159 }); - } - enforestIdentifierExpression() { - return new _terms2.default("IdentifierExpression", { name: this.advance() }); - } - enforestRegularExpressionLiteral() { - let reStx_160 = this.advance(); - let lastSlash_161 = reStx_160.token.value.lastIndexOf("/"); - let pattern_162 = reStx_160.token.value.slice(1, lastSlash_161); - let flags_163 = reStx_160.token.value.slice(lastSlash_161 + 1); - return new _terms2.default("LiteralRegExpExpression", { pattern: pattern_162, flags: flags_163 }); - } - enforestNullLiteral() { - this.advance(); - return new _terms2.default("LiteralNullExpression", {}); - } - enforestThisExpression() { - return new _terms2.default("ThisExpression", { stx: this.advance() }); - } - enforestArgumentList() { - let result_164 = []; - while (this.rest.size > 0) { - let arg; - if (this.isPunctuator(this.peek(), "...")) { - this.advance(); - arg = new _terms2.default("SpreadElement", { expression: this.enforestExpressionLoop() }); - } else { - arg = this.enforestExpressionLoop(); + }, { + key: "scanHexEscape2", + value: function scanHexEscape2() { + if (this.index + 2 > this.source.length) { + return -1; } - if (this.rest.size > 0) { - this.matchPunctuator(","); + var r1 = (0, _utils.getHexValue)(this.source.charAt(this.index)); + if (r1 === -1) { + return -1; } - result_164.push(arg); - } - return (0, _immutable.List)(result_164); - } - enforestNewExpression() { - this.matchKeyword("new"); - if (this.isPunctuator(this.peek(), ".") && this.isIdentifier(this.peek(1), "target")) { - this.advance(); - this.advance(); - return new _terms2.default("NewTargetExpression", {}); - } - let callee_165 = this.enforestLeftHandSideExpression({ allowCall: false }); - let args_166; - if (this.isParens(this.peek())) { - args_166 = this.matchParens(); - } else { - args_166 = (0, _immutable.List)(); - } - return new _terms2.default("NewExpression", { callee: callee_165, arguments: args_166 }); - } - enforestComputedMemberExpression() { - let enf_167 = new Enforester_46(this.matchSquares(), (0, _immutable.List)(), this.context); - return new _terms2.default("ComputedMemberExpression", { object: this.term, expression: enf_167.enforestExpression() }); - } - transformDestructuring(term_168) { - switch (term_168.type) { - case "IdentifierExpression": - return new _terms2.default("BindingIdentifier", { name: term_168.name }); - case "ParenthesizedExpression": - if (term_168.inner.size === 1 && this.isIdentifier(term_168.inner.get(0))) { - return new _terms2.default("BindingIdentifier", { name: term_168.inner.get(0) }); - } - case "DataProperty": - return new _terms2.default("BindingPropertyProperty", { name: term_168.name, binding: this.transformDestructuringWithDefault(term_168.expression) }); - case "ShorthandProperty": - return new _terms2.default("BindingPropertyIdentifier", { binding: new _terms2.default("BindingIdentifier", { name: term_168.name }), init: null }); - case "ObjectExpression": - return new _terms2.default("ObjectBinding", { properties: term_168.properties.map(t_169 => this.transformDestructuring(t_169)) }); - case "ArrayExpression": - let last = term_168.elements.last(); - if (last != null && last.type === "SpreadElement") { - return new _terms2.default("ArrayBinding", { elements: term_168.elements.slice(0, -1).map(t_170 => t_170 && this.transformDestructuringWithDefault(t_170)), restElement: this.transformDestructuringWithDefault(last.expression) }); - } else { - return new _terms2.default("ArrayBinding", { elements: term_168.elements.map(t_171 => t_171 && this.transformDestructuringWithDefault(t_171)), restElement: null }); - } - return new _terms2.default("ArrayBinding", { elements: term_168.elements.map(t_172 => t_172 && this.transformDestructuring(t_172)), restElement: null }); - case "StaticPropertyName": - return new _terms2.default("BindingIdentifier", { name: term_168.value }); - case "ComputedMemberExpression": - case "StaticMemberExpression": - case "ArrayBinding": - case "BindingIdentifier": - case "BindingPropertyIdentifier": - case "BindingPropertyProperty": - case "BindingWithDefault": - case "ObjectBinding": - return term_168; - } - (0, _errors.assert)(false, "not implemented yet for " + term_168.type); - } - transformDestructuringWithDefault(term_173) { - switch (term_173.type) { - case "AssignmentExpression": - return new _terms2.default("BindingWithDefault", { binding: this.transformDestructuring(term_173.binding), init: term_173.expression }); - } - return this.transformDestructuring(term_173); - } - enforestCallExpression() { - let paren_174 = this.advance(); - return new _terms2.default("CallExpression", { callee: this.term, arguments: paren_174.inner() }); - } - enforestArrowExpression() { - let enf_175; - if (this.isIdentifier(this.peek())) { - enf_175 = new Enforester_46(_immutable.List.of(this.advance()), (0, _immutable.List)(), this.context); - } else { - let p = this.matchParens(); - enf_175 = new Enforester_46(p, (0, _immutable.List)(), this.context); - } - let params_176 = enf_175.enforestFormalParameters(); - this.matchPunctuator("=>"); - let body_177; - if (this.isBraces(this.peek())) { - body_177 = this.matchCurlies(); - } else { - enf_175 = new Enforester_46(this.rest, (0, _immutable.List)(), this.context); - body_177 = enf_175.enforestExpressionLoop(); - this.rest = enf_175.rest; - } - return new _terms2.default("ArrowExpression", { params: params_176, body: body_177 }); - } - enforestYieldExpression() { - let kwd_178 = this.matchKeyword("yield"); - let lookahead_179 = this.peek(); - if (this.rest.size === 0 || lookahead_179 && !this.lineNumberEq(kwd_178, lookahead_179)) { - return new _terms2.default("YieldExpression", { expression: null }); - } else { - let isGenerator = false; - if (this.isPunctuator(this.peek(), "*")) { - isGenerator = true; - this.advance(); + var r2 = (0, _utils.getHexValue)(this.source.charAt(this.index + 1)); + if (r2 === -1) { + return -1; } - let expr = this.enforestExpression(); - let type = isGenerator ? "YieldGeneratorExpression" : "YieldExpression"; - return new _terms2.default(type, { expression: expr }); + this.index += 2; + return r1 << 4 | r2; } - } - enforestSyntaxTemplate() { - return new _terms2.default("SyntaxTemplate", { template: this.advance() }); - } - enforestSyntaxQuote() { - let name_180 = this.advance(); - return new _terms2.default("SyntaxQuote", { name: name_180, template: new _terms2.default("TemplateExpression", { tag: new _terms2.default("IdentifierExpression", { name: name_180 }), elements: this.enforestTemplateElements() }) }); - } - enforestStaticMemberExpression() { - let object_181 = this.term; - let dot_182 = this.advance(); - let property_183 = this.advance(); - return new _terms2.default("StaticMemberExpression", { object: object_181, property: property_183 }); - } - enforestArrayExpression() { - let arr_184 = this.advance(); - let elements_185 = []; - let enf_186 = new Enforester_46(arr_184.inner(), (0, _immutable.List)(), this.context); - while (enf_186.rest.size > 0) { - let lookahead = enf_186.peek(); - if (enf_186.isPunctuator(lookahead, ",")) { - enf_186.advance(); - elements_185.push(null); - } else if (enf_186.isPunctuator(lookahead, "...")) { - enf_186.advance(); - let expression = enf_186.enforestExpressionLoop(); - if (expression == null) { - throw enf_186.createError(lookahead, "expecting expression"); - } - elements_185.push(new _terms2.default("SpreadElement", { expression: expression })); - } else { - let term = enf_186.enforestExpressionLoop(); - if (term == null) { - throw enf_186.createError(lookahead, "expected expression"); + }, { + key: "scanUnicode", + value: function scanUnicode() { + if (this.source.charAt(this.index) === "{") { + //\u{HexDigits} + var i = this.index + 1; + var hexDigits = 0, + ch = void 0; + while (i < this.source.length) { + ch = this.source.charAt(i); + var hex = (0, _utils.getHexValue)(ch); + if (hex === -1) { + break; + } + hexDigits = hexDigits << 4 | hex; + if (hexDigits > 0x10FFFF) { + throw this.createILLEGAL(); + } + i++; } - elements_185.push(term); - enf_186.consumeComma(); - } - } - return new _terms2.default("ArrayExpression", { elements: (0, _immutable.List)(elements_185) }); - } - enforestObjectExpression() { - let obj_187 = this.advance(); - let properties_188 = (0, _immutable.List)(); - let enf_189 = new Enforester_46(obj_187.inner(), (0, _immutable.List)(), this.context); - let lastProp_190 = null; - while (enf_189.rest.size > 0) { - let prop = enf_189.enforestPropertyDefinition(); - enf_189.consumeComma(); - properties_188 = properties_188.concat(prop); - if (lastProp_190 === prop) { - throw enf_189.createError(prop, "invalid syntax in object"); + if (ch !== "}") { + throw this.createILLEGAL(); + } + if (i === this.index + 1) { + ++this.index; // This is so that the error is 'Unexpected "}"' instead of 'Unexpected "{"'. + throw this.createILLEGAL(); + } + this.index = i + 1; + return hexDigits; + } else { + //\uHex4Digits + if (this.index + 4 > this.source.length) { + return -1; + } + var r1 = (0, _utils.getHexValue)(this.source.charAt(this.index)); + if (r1 === -1) { + return -1; + } + var r2 = (0, _utils.getHexValue)(this.source.charAt(this.index + 1)); + if (r2 === -1) { + return -1; + } + var r3 = (0, _utils.getHexValue)(this.source.charAt(this.index + 2)); + if (r3 === -1) { + return -1; + } + var r4 = (0, _utils.getHexValue)(this.source.charAt(this.index + 3)); + if (r4 === -1) { + return -1; + } + this.index += 4; + return r1 << 12 | r2 << 8 | r3 << 4 | r4; } - lastProp_190 = prop; } - return new _terms2.default("ObjectExpression", { properties: properties_188 }); - } - enforestPropertyDefinition() { - var _enforestMethodDefini = this.enforestMethodDefinition(); - - let methodOrKey = _enforestMethodDefini.methodOrKey; - let kind = _enforestMethodDefini.kind; + }, { + key: "getEscapedIdentifier", + value: function getEscapedIdentifier() { + var id = ""; + var check = _utils.isIdentifierStart; - switch (kind) { - case "method": - return methodOrKey; - case "identifier": - if (this.isAssign(this.peek())) { - this.advance(); - let init = this.enforestExpressionLoop(); - return new _terms2.default("BindingPropertyIdentifier", { init: init, binding: this.transformDestructuring(methodOrKey) }); - } else if (!this.isPunctuator(this.peek(), ":")) { - return new _terms2.default("ShorthandProperty", { name: methodOrKey.value }); + while (this.index < this.source.length) { + var ch = this.source.charAt(this.index); + var code = ch.charCodeAt(0); + var start = this.index; + ++this.index; + if (ch === "\\") { + if (this.index >= this.source.length) { + throw this.createILLEGAL(); + } + if (this.source.charAt(this.index) !== "u") { + throw this.createILLEGAL(); + } + ++this.index; + code = this.scanUnicode(); + if (code < 0) { + throw this.createILLEGAL(); + } + ch = fromCodePoint(code); + } else if (0xD800 <= code && code <= 0xDBFF) { + if (this.index >= this.source.length) { + throw this.createILLEGAL(); + } + var lowSurrogateCode = this.source.charCodeAt(this.index); + ++this.index; + if (!(0xDC00 <= lowSurrogateCode && lowSurrogateCode <= 0xDFFF)) { + throw this.createILLEGAL(); + } + code = decodeUtf16(code, lowSurrogateCode); + ch = fromCodePoint(code); } + if (!check(code)) { + if (id.length < 1) { + throw this.createILLEGAL(); + } + this.index = start; + return id; + } + check = _utils.isIdentifierPart; + id += ch; + } + return id; } - this.matchPunctuator(":"); - let expr_191 = this.enforestExpressionLoop(); - return new _terms2.default("DataProperty", { name: methodOrKey, expression: expr_191 }); - } - enforestMethodDefinition() { - let lookahead_192 = this.peek(); - let isGenerator_193 = false; - if (this.isPunctuator(lookahead_192, "*")) { - isGenerator_193 = true; - this.advance(); - } - if (this.isIdentifier(lookahead_192, "get") && this.isPropertyName(this.peek(1))) { - this.advance(); - - var _enforestPropertyName2 = this.enforestPropertyName(); - - let name = _enforestPropertyName2.name; - - this.matchParens(); - let body = this.matchCurlies(); - return { methodOrKey: new _terms2.default("Getter", { name: name, body: body }), kind: "method" }; - } else if (this.isIdentifier(lookahead_192, "set") && this.isPropertyName(this.peek(1))) { - this.advance(); - - var _enforestPropertyName3 = this.enforestPropertyName(); - - let name = _enforestPropertyName3.name; - - let enf = new Enforester_46(this.matchParens(), (0, _immutable.List)(), this.context); - let param = enf.enforestBindingElement(); - let body = this.matchCurlies(); - return { methodOrKey: new _terms2.default("Setter", { name: name, param: param, body: body }), kind: "method" }; + }, { + key: "getIdentifier", + value: function getIdentifier() { + var start = this.index; + var l = this.source.length; + var i = this.index; + var check = _utils.isIdentifierStart; + while (i < l) { + var ch = this.source.charAt(i); + var code = ch.charCodeAt(0); + if (ch === "\\" || 0xD800 <= code && code <= 0xDBFF) { + // Go back and try the hard one. + this.index = start; + return this.getEscapedIdentifier(); + } + if (!check(code)) { + this.index = i; + return this.source.slice(start, i); + } + ++i; + check = _utils.isIdentifierPart; + } + this.index = i; + return this.source.slice(start, i); } + }, { + key: "scanIdentifier", + value: function scanIdentifier() { + var startLocation = this.getLocation(); + var start = this.index; - var _enforestPropertyName4 = this.enforestPropertyName(); + // Backslash (U+005C) starts an escaped character. + var id = this.source.charAt(this.index) === "\\" ? this.getEscapedIdentifier() : this.getIdentifier(); - let name = _enforestPropertyName4.name; + // There is no keyword or literal with only one character. + // Thus, it must be an identifier. + var slice = this.getSlice(start, startLocation); + slice.text = id; - if (this.isParens(this.peek())) { - let params = this.matchParens(); - let enf = new Enforester_46(params, (0, _immutable.List)(), this.context); - let formalParams = enf.enforestFormalParameters(); - let body = this.matchCurlies(); - return { methodOrKey: new _terms2.default("Method", { isGenerator: isGenerator_193, name: name, params: formalParams, body: body }), kind: "method" }; - } - return { methodOrKey: name, kind: this.isIdentifier(lookahead_192) || this.isKeyword(lookahead_192) ? "identifier" : "property" }; - } - enforestPropertyName() { - let lookahead_194 = this.peek(); - if (this.isStringLiteral(lookahead_194) || this.isNumericLiteral(lookahead_194)) { - return { name: new _terms2.default("StaticPropertyName", { value: this.advance() }), binding: null }; - } else if (this.isBrackets(lookahead_194)) { - let enf = new Enforester_46(this.matchSquares(), (0, _immutable.List)(), this.context); - let expr = enf.enforestExpressionLoop(); - return { name: new _terms2.default("ComputedPropertyName", { expression: expr }), binding: null }; - } - let name_195 = this.advance(); - return { name: new _terms2.default("StaticPropertyName", { value: name_195 }), binding: new _terms2.default("BindingIdentifier", { name: name_195 }) }; - } - enforestFunction(_ref6) { - let isExpr = _ref6.isExpr; - let inDefault = _ref6.inDefault; - let allowGenerator = _ref6.allowGenerator; - - let name_196 = null, - params_197, - body_198, - rest_199; - let isGenerator_200 = false; - let fnKeyword_201 = this.advance(); - let lookahead_202 = this.peek(); - let type_203 = isExpr ? "FunctionExpression" : "FunctionDeclaration"; - if (this.isPunctuator(lookahead_202, "*")) { - isGenerator_200 = true; - this.advance(); - lookahead_202 = this.peek(); - } - if (!this.isParens(lookahead_202)) { - name_196 = this.enforestBindingIdentifier(); - } else if (inDefault) { - name_196 = new _terms2.default("BindingIdentifier", { name: _syntax2.default.fromIdentifier("*default*", fnKeyword_201) }); - } - params_197 = this.matchParens(); - body_198 = this.matchCurlies(); - let enf_204 = new Enforester_46(params_197, (0, _immutable.List)(), this.context); - let formalParams_205 = enf_204.enforestFormalParameters(); - return new _terms2.default(type_203, { name: name_196, isGenerator: isGenerator_200, params: formalParams_205, body: body_198 }); - } - enforestFunctionExpression() { - let name_206 = null, - params_207, - body_208, - rest_209; - let isGenerator_210 = false; - this.advance(); - let lookahead_211 = this.peek(); - if (this.isPunctuator(lookahead_211, "*")) { - isGenerator_210 = true; - this.advance(); - lookahead_211 = this.peek(); - } - if (!this.isParens(lookahead_211)) { - name_206 = this.enforestBindingIdentifier(); + return { type: this.getKeyword(id), value: id, slice: slice }; } - params_207 = this.matchParens(); - body_208 = this.matchCurlies(); - let enf_212 = new Enforester_46(params_207, (0, _immutable.List)(), this.context); - let formalParams_213 = enf_212.enforestFormalParameters(); - return new _terms2.default("FunctionExpression", { name: name_206, isGenerator: isGenerator_210, params: formalParams_213, body: body_208 }); - } - enforestFunctionDeclaration() { - let name_214, params_215, body_216, rest_217; - let isGenerator_218 = false; - this.advance(); - let lookahead_219 = this.peek(); - if (this.isPunctuator(lookahead_219, "*")) { - isGenerator_218 = true; - this.advance(); + }, { + key: "getLocation", + value: function getLocation() { + return { + line: this.startLine + 1, + column: this.startIndex - this.startLineStart, + offset: this.startIndex + }; } - name_214 = this.enforestBindingIdentifier(); - params_215 = this.matchParens(); - body_216 = this.matchCurlies(); - let enf_220 = new Enforester_46(params_215, (0, _immutable.List)(), this.context); - let formalParams_221 = enf_220.enforestFormalParameters(); - return new _terms2.default("FunctionDeclaration", { name: name_214, isGenerator: isGenerator_218, params: formalParams_221, body: body_216 }); - } - enforestFormalParameters() { - let items_222 = []; - let rest_223 = null; - while (this.rest.size !== 0) { - let lookahead = this.peek(); - if (this.isPunctuator(lookahead, "...")) { - this.matchPunctuator("..."); - rest_223 = this.enforestBindingIdentifier(); - break; - } - items_222.push(this.enforestParam()); - this.consumeComma(); + }, { + key: "getSlice", + value: function getSlice(start, startLocation) { + return { text: this.source.slice(start, this.index), start: start, startLocation: startLocation, end: this.index }; } - return new _terms2.default("FormalParameters", { items: (0, _immutable.List)(items_222), rest: rest_223 }); - } - enforestParam() { - return this.enforestBindingElement(); - } - enforestUpdateExpression() { - let operator_224 = this.matchUnaryOperator(); - return new _terms2.default("UpdateExpression", { isPrefix: false, operator: operator_224.val(), operand: this.transformDestructuring(this.term) }); - } - enforestUnaryExpression() { - let operator_225 = this.matchUnaryOperator(); - this.opCtx.stack = this.opCtx.stack.push({ prec: this.opCtx.prec, combine: this.opCtx.combine }); - this.opCtx.prec = 14; - this.opCtx.combine = rightTerm_226 => { - let type_227, term_228, isPrefix_229; - if (operator_225.val() === "++" || operator_225.val() === "--") { - type_227 = "UpdateExpression"; - term_228 = this.transformDestructuring(rightTerm_226); - isPrefix_229 = true; - } else { - type_227 = "UnaryExpression"; - isPrefix_229 = undefined; - term_228 = rightTerm_226; + }, { + key: "scanPunctuatorHelper", + value: function scanPunctuatorHelper() { + var ch1 = this.source.charAt(this.index); + + switch (ch1) { + // Check for most common single-character punctuators. + case ".": + var ch2 = this.source.charAt(this.index + 1); + if (ch2 !== ".") return TokenType.PERIOD; + var ch3 = this.source.charAt(this.index + 2); + if (ch3 !== ".") return TokenType.PERIOD; + return TokenType.ELLIPSIS; + case "(": + return TokenType.LPAREN; + case ")": + case ";": + case ",": + return ONE_CHAR_PUNCTUATOR[ch1.charCodeAt(0)]; + case "{": + return TokenType.LBRACE; + case "}": + case "[": + case "]": + case ":": + case "?": + case "~": + return ONE_CHAR_PUNCTUATOR[ch1.charCodeAt(0)]; + default: + // "=" (U+003D) marks an assignment or comparison operator. + if (this.index + 1 < this.source.length && this.source.charAt(this.index + 1) === "=") { + switch (ch1) { + case "=": + if (this.index + 2 < this.source.length && this.source.charAt(this.index + 2) === "=") { + return TokenType.EQ_STRICT; + } + return TokenType.EQ; + case "!": + if (this.index + 2 < this.source.length && this.source.charAt(this.index + 2) === "=") { + return TokenType.NE_STRICT; + } + return TokenType.NE; + case "|": + return TokenType.ASSIGN_BIT_OR; + case "+": + return TokenType.ASSIGN_ADD; + case "-": + return TokenType.ASSIGN_SUB; + case "*": + return TokenType.ASSIGN_MUL; + case "<": + return TokenType.LTE; + case ">": + return TokenType.GTE; + case "/": + return TokenType.ASSIGN_DIV; + case "%": + return TokenType.ASSIGN_MOD; + case "^": + return TokenType.ASSIGN_BIT_XOR; + case "&": + return TokenType.ASSIGN_BIT_AND; + // istanbul ignore next + default: + break; //failed + } + } } - return new _terms2.default(type_227, { operator: operator_225.val(), operand: term_228, isPrefix: isPrefix_229 }); - }; - return EXPR_LOOP_OPERATOR_43; - } - enforestConditionalExpression() { - let test_230 = this.opCtx.combine(this.term); - if (this.opCtx.stack.size > 0) { - var _opCtx$stack$last2 = this.opCtx.stack.last(); - let prec = _opCtx$stack$last2.prec; - let combine = _opCtx$stack$last2.combine; + if (this.index + 1 < this.source.length) { + var _ch = this.source.charAt(this.index + 1); + if (ch1 === _ch) { + if (this.index + 2 < this.source.length) { + var _ch2 = this.source.charAt(this.index + 2); + if (ch1 === ">" && _ch2 === ">") { + // 4-character punctuator: >>>= + if (this.index + 3 < this.source.length && this.source.charAt(this.index + 3) === "=") { + return TokenType.ASSIGN_SHR_UNSIGNED; + } + return TokenType.SHR_UNSIGNED; + } - this.opCtx.stack = this.opCtx.stack.pop(); - this.opCtx.prec = prec; - this.opCtx.combine = combine; - } - this.matchPunctuator("?"); - let enf_231 = new Enforester_46(this.rest, (0, _immutable.List)(), this.context); - let consequent_232 = enf_231.enforestExpressionLoop(); - enf_231.matchPunctuator(":"); - enf_231 = new Enforester_46(enf_231.rest, (0, _immutable.List)(), this.context); - let alternate_233 = enf_231.enforestExpressionLoop(); - this.rest = enf_231.rest; - return new _terms2.default("ConditionalExpression", { test: test_230, consequent: consequent_232, alternate: alternate_233 }); - } - enforestBinaryExpression() { - let leftTerm_234 = this.term; - let opStx_235 = this.peek(); - let op_236 = opStx_235.val(); - let opPrec_237 = (0, _operators.getOperatorPrec)(op_236); - let opAssoc_238 = (0, _operators.getOperatorAssoc)(op_236); - if ((0, _operators.operatorLt)(this.opCtx.prec, opPrec_237, opAssoc_238)) { - this.opCtx.stack = this.opCtx.stack.push({ prec: this.opCtx.prec, combine: this.opCtx.combine }); - this.opCtx.prec = opPrec_237; - this.opCtx.combine = rightTerm_239 => { - return new _terms2.default("BinaryExpression", { left: leftTerm_234, operator: opStx_235, right: rightTerm_239 }); - }; - this.advance(); - return EXPR_LOOP_OPERATOR_43; - } else { - let term = this.opCtx.combine(leftTerm_234); + if (ch1 === "<" && _ch2 === "=") { + return TokenType.ASSIGN_SHL; + } - var _opCtx$stack$last3 = this.opCtx.stack.last(); + if (ch1 === ">" && _ch2 === "=") { + return TokenType.ASSIGN_SHR; + } + } + // Other 2-character punctuators: ++ -- << >> && || + switch (ch1) { + case "+": + return TokenType.INC; + case "-": + return TokenType.DEC; + case "<": + return TokenType.SHL; + case ">": + return TokenType.SHR; + case "&": + return TokenType.AND; + case "|": + return TokenType.OR; + // istanbul ignore next + default: + break; //failed + } + } else if (ch1 === "=" && _ch === ">") { + return TokenType.ARROW; + } + } - let prec = _opCtx$stack$last3.prec; - let combine = _opCtx$stack$last3.combine; + return ONE_CHAR_PUNCTUATOR[ch1.charCodeAt(0)]; + } - this.opCtx.stack = this.opCtx.stack.pop(); - this.opCtx.prec = prec; - this.opCtx.combine = combine; - return term; + // 7.7 Punctuators + + }, { + key: "scanPunctuator", + value: function scanPunctuator() { + var startLocation = this.getLocation(); + var start = this.index; + var subType = this.scanPunctuatorHelper(); + this.index += subType.name.length; + return { type: subType, value: subType.name, slice: this.getSlice(start, startLocation) }; } - } - enforestTemplateElements() { - let lookahead_240 = this.matchTemplate(); - let elements_241 = lookahead_240.token.items.map(it_242 => { - if (this.isDelimiter(it_242)) { - let enf = new Enforester_46(it_242.inner(), (0, _immutable.List)(), this.context); - return enf.enforest("expression"); + }, { + key: "scanHexLiteral", + value: function scanHexLiteral(start, startLocation) { + var i = this.index; + while (i < this.source.length) { + var ch = this.source.charAt(i); + var hex = (0, _utils.getHexValue)(ch); + if (hex === -1) { + break; + } + i++; } - return new _terms2.default("TemplateElement", { rawValue: it_242.slice.text }); - }); - return elements_241; - } - expandMacro() { - let lookahead_243 = this.peek(); - while (this.isCompiletimeTransform(lookahead_243)) { - let name = this.advance(); - let syntaxTransform = this.getFromCompiletimeEnvironment(name); - if (syntaxTransform == null || typeof syntaxTransform.value !== "function") { - throw this.createError(name, "the macro name was not bound to a value that could be invoked"); + + if (this.index === i) { + throw this.createILLEGAL(); } - let useSiteScope = (0, _scope.freshScope)("u"); - let introducedScope = (0, _scope.freshScope)("i"); - this.context.useScope = useSiteScope; - let ctx = new _macroContext2.default(this, name, this.context, useSiteScope, introducedScope); - let result = (0, _loadSyntax.sanitizeReplacementValues)(syntaxTransform.value.call(null, ctx)); - if (!_immutable.List.isList(result)) { - throw this.createError(name, "macro must return a list but got: " + result); + + if (i < this.source.length && (0, _utils.isIdentifierStart)(this.source.charCodeAt(i))) { + throw this.createILLEGAL(); } - result = result.map(stx_244 => { - if (!(stx_244 && typeof stx_244.addScope === "function")) { - throw this.createError(name, "macro must return syntax objects or terms but got: " + stx_244); - } - return stx_244.addScope(introducedScope, this.context.bindings, _syntax.ALL_PHASES, { flip: true }); - }); - this.rest = result.concat(ctx._rest(this)); - lookahead_243 = this.peek(); - } - } - consumeSemicolon() { - let lookahead_245 = this.peek(); - if (lookahead_245 && this.isPunctuator(lookahead_245, ";")) { - this.advance(); - } - } - consumeComma() { - let lookahead_246 = this.peek(); - if (lookahead_246 && this.isPunctuator(lookahead_246, ",")) { - this.advance(); - } - } - safeCheck(obj_247, type_248) { - let val_249 = arguments.length <= 2 || arguments[2] === undefined ? null : arguments[2]; - return obj_247 && (typeof obj_247.match === "function" ? obj_247.match(type_248, val_249) : false); - } - isTerm(term_250) { - return term_250 && term_250 instanceof _terms2.default; - } - isEOF(obj_251) { - return this.safeCheck(obj_251, "eof"); - } - isIdentifier(obj_252) { - let val_253 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + this.index = i; - return this.safeCheck(obj_252, "identifier", val_253); - } - isPropertyName(obj_254) { - return this.isIdentifier(obj_254) || this.isKeyword(obj_254) || this.isNumericLiteral(obj_254) || this.isStringLiteral(obj_254) || this.isBrackets(obj_254); - } - isNumericLiteral(obj_255) { - let val_256 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + var slice = this.getSlice(start, startLocation); + return { type: TokenType.NUMBER, value: parseInt(slice.text.substr(2), 16), slice: slice }; + } + }, { + key: "scanBinaryLiteral", + value: function scanBinaryLiteral(start, startLocation) { + var offset = this.index - start; - return this.safeCheck(obj_255, "number", val_256); - } - isStringLiteral(obj_257) { - let val_258 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + while (this.index < this.source.length) { + var ch = this.source.charAt(this.index); + if (ch !== "0" && ch !== "1") { + break; + } + this.index++; + } - return this.safeCheck(obj_257, "string", val_258); - } - isTemplate(obj_259) { - let val_260 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + if (this.index - start <= offset) { + throw this.createILLEGAL(); + } - return this.safeCheck(obj_259, "template", val_260); - } - isSyntaxTemplate(obj_261) { - return this.safeCheck(obj_261, "syntaxTemplate"); - } - isBooleanLiteral(obj_262) { - let val_263 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + if (this.index < this.source.length && ((0, _utils.isIdentifierStart)(this.source.charCodeAt(this.index)) || (0, _utils.isDecimalDigit)(this.source.charCodeAt(this.index)))) { + throw this.createILLEGAL(); + } - return this.safeCheck(obj_262, "boolean", val_263); - } - isNullLiteral(obj_264) { - let val_265 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + return { + type: TokenType.NUMBER, + value: parseInt(this.getSlice(start, startLocation).text.substr(offset), 2), + slice: this.getSlice(start, startLocation), + octal: false, + noctal: false + }; + } + }, { + key: "scanOctalLiteral", + value: function scanOctalLiteral(start, startLocation) { + while (this.index < this.source.length) { + var ch = this.source.charAt(this.index); + if ("0" <= ch && ch <= "7") { + this.index++; + } else if ((0, _utils.isIdentifierPart)(ch.charCodeAt(0))) { + throw this.createILLEGAL(); + } else { + break; + } + } - return this.safeCheck(obj_264, "null", val_265); - } - isRegularExpression(obj_266) { - let val_267 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + if (this.index - start === 2) { + throw this.createILLEGAL(); + } - return this.safeCheck(obj_266, "regularExpression", val_267); - } - isDelimiter(obj_268) { - return this.safeCheck(obj_268, "delimiter"); - } - isParens(obj_269) { - return this.safeCheck(obj_269, "parens"); - } - isBraces(obj_270) { - return this.safeCheck(obj_270, "braces"); - } - isBrackets(obj_271) { - return this.safeCheck(obj_271, "brackets"); - } - isAssign(obj_272) { - let val_273 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + return { + type: TokenType.NUMBER, + value: parseInt(this.getSlice(start, startLocation).text.substr(2), 8), + slice: this.getSlice(start, startLocation), + octal: false, + noctal: false + }; + } + }, { + key: "scanLegacyOctalLiteral", + value: function scanLegacyOctalLiteral(start, startLocation) { + var isOctal = true; - return this.safeCheck(obj_272, "assign", val_273); - } - isKeyword(obj_274) { - let val_275 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + while (this.index < this.source.length) { + var ch = this.source.charAt(this.index); + if ("0" <= ch && ch <= "7") { + this.index++; + } else if (ch === "8" || ch === "9") { + isOctal = false; + this.index++; + } else if ((0, _utils.isIdentifierPart)(ch.charCodeAt(0))) { + throw this.createILLEGAL(); + } else { + break; + } + } - return this.safeCheck(obj_274, "keyword", val_275); - } - isPunctuator(obj_276) { - let val_277 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + var slice = this.getSlice(start, startLocation); + if (!isOctal) { + this.eatDecimalLiteralSuffix(); + return { + type: TokenType.NUMBER, + slice: slice, + value: +slice.text, + octal: true, + noctal: !isOctal + }; + } - return this.safeCheck(obj_276, "punctuator", val_277); - } - isOperator(obj_278) { - return (this.safeCheck(obj_278, "punctuator") || this.safeCheck(obj_278, "identifier") || this.safeCheck(obj_278, "keyword")) && (0, _operators.isOperator)(obj_278); - } - isUpdateOperator(obj_279) { - return this.safeCheck(obj_279, "punctuator", "++") || this.safeCheck(obj_279, "punctuator", "--"); - } - safeResolve(obj_280, phase_281) { - return obj_280 && typeof obj_280.resolve === "function" ? Just_41(obj_280.resolve(phase_281)) : Nothing_42(); - } - isTransform(obj_282, trans_283) { - return this.safeResolve(obj_282, this.context.phase).map(name_284 => this.context.env.get(name_284) === trans_283 || this.context.store.get(name_284) === trans_283).getOrElse(false); - } - isTransformInstance(obj_285, trans_286) { - return this.safeResolve(obj_285, this.context.phase).map(name_287 => this.context.env.get(name_287) instanceof trans_286 || this.context.store.get(name_287) instanceof trans_286).getOrElse(false); - } - isFnDeclTransform(obj_288) { - return this.isTransform(obj_288, _transforms.FunctionDeclTransform); - } - isVarDeclTransform(obj_289) { - return this.isTransform(obj_289, _transforms.VariableDeclTransform); - } - isLetDeclTransform(obj_290) { - return this.isTransform(obj_290, _transforms.LetDeclTransform); - } - isConstDeclTransform(obj_291) { - return this.isTransform(obj_291, _transforms.ConstDeclTransform); - } - isSyntaxDeclTransform(obj_292) { - return this.isTransform(obj_292, _transforms.SyntaxDeclTransform); - } - isSyntaxrecDeclTransform(obj_293) { - return this.isTransform(obj_293, _transforms.SyntaxrecDeclTransform); - } - isSyntaxQuoteTransform(obj_294) { - return this.isTransform(obj_294, _transforms.SyntaxQuoteTransform); - } - isReturnStmtTransform(obj_295) { - return this.isTransform(obj_295, _transforms.ReturnStatementTransform); - } - isWhileTransform(obj_296) { - return this.isTransform(obj_296, _transforms.WhileTransform); - } - isForTransform(obj_297) { - return this.isTransform(obj_297, _transforms.ForTransform); - } - isSwitchTransform(obj_298) { - return this.isTransform(obj_298, _transforms.SwitchTransform); - } - isBreakTransform(obj_299) { - return this.isTransform(obj_299, _transforms.BreakTransform); - } - isContinueTransform(obj_300) { - return this.isTransform(obj_300, _transforms.ContinueTransform); - } - isDoTransform(obj_301) { - return this.isTransform(obj_301, _transforms.DoTransform); - } - isDebuggerTransform(obj_302) { - return this.isTransform(obj_302, _transforms.DebuggerTransform); - } - isWithTransform(obj_303) { - return this.isTransform(obj_303, _transforms.WithTransform); - } - isTryTransform(obj_304) { - return this.isTransform(obj_304, _transforms.TryTransform); - } - isThrowTransform(obj_305) { - return this.isTransform(obj_305, _transforms.ThrowTransform); - } - isIfTransform(obj_306) { - return this.isTransform(obj_306, _transforms.IfTransform); - } - isNewTransform(obj_307) { - return this.isTransform(obj_307, _transforms.NewTransform); - } - isCompiletimeTransform(obj_308) { - return this.isTransformInstance(obj_308, _transforms.CompiletimeTransform); - } - isVarBindingTransform(obj_309) { - return this.isTransformInstance(obj_309, _transforms.VarBindingTransform); - } - getFromCompiletimeEnvironment(term_310) { - if (this.context.env.has(term_310.resolve(this.context.phase))) { - return this.context.env.get(term_310.resolve(this.context.phase)); - } - return this.context.store.get(term_310.resolve(this.context.phase)); - } - lineNumberEq(a_311, b_312) { - if (!(a_311 && b_312)) { - return false; - } - return a_311.lineNumber() === b_312.lineNumber(); - } - matchIdentifier(val_313) { - let lookahead_314 = this.advance(); - if (this.isIdentifier(lookahead_314)) { - return lookahead_314; - } - throw this.createError(lookahead_314, "expecting an identifier"); - } - matchKeyword(val_315) { - let lookahead_316 = this.advance(); - if (this.isKeyword(lookahead_316, val_315)) { - return lookahead_316; - } - throw this.createError(lookahead_316, "expecting " + val_315); - } - matchLiteral() { - let lookahead_317 = this.advance(); - if (this.isNumericLiteral(lookahead_317) || this.isStringLiteral(lookahead_317) || this.isBooleanLiteral(lookahead_317) || this.isNullLiteral(lookahead_317) || this.isTemplate(lookahead_317) || this.isRegularExpression(lookahead_317)) { - return lookahead_317; - } - throw this.createError(lookahead_317, "expecting a literal"); - } - matchStringLiteral() { - let lookahead_318 = this.advance(); - if (this.isStringLiteral(lookahead_318)) { - return lookahead_318; - } - throw this.createError(lookahead_318, "expecting a string literal"); - } - matchTemplate() { - let lookahead_319 = this.advance(); - if (this.isTemplate(lookahead_319)) { - return lookahead_319; - } - throw this.createError(lookahead_319, "expecting a template literal"); - } - matchParens() { - let lookahead_320 = this.advance(); - if (this.isParens(lookahead_320)) { - return lookahead_320.inner(); - } - throw this.createError(lookahead_320, "expecting parens"); - } - matchCurlies() { - let lookahead_321 = this.advance(); - if (this.isBraces(lookahead_321)) { - return lookahead_321.inner(); - } - throw this.createError(lookahead_321, "expecting curly braces"); - } - matchSquares() { - let lookahead_322 = this.advance(); - if (this.isBrackets(lookahead_322)) { - return lookahead_322.inner(); + return { + type: TokenType.NUMBER, + slice: slice, + value: parseInt(slice.text.substr(1), 8), + octal: true, + noctal: !isOctal + }; } - throw this.createError(lookahead_322, "expecting sqaure braces"); - } - matchUnaryOperator() { - let lookahead_323 = this.advance(); - if ((0, _operators.isUnaryOperator)(lookahead_323)) { - return lookahead_323; - } - throw this.createError(lookahead_323, "expecting a unary operator"); - } - matchPunctuator(val_324) { - let lookahead_325 = this.advance(); - if (this.isPunctuator(lookahead_325)) { - if (typeof val_324 !== "undefined") { - if (lookahead_325.val() === val_324) { - return lookahead_325; + }, { + key: "scanNumericLiteral", + value: function scanNumericLiteral() { + var ch = this.source.charAt(this.index); + // assert(ch === "." || "0" <= ch && ch <= "9") + var startLocation = this.getLocation(); + var start = this.index; + + if (ch === "0") { + this.index++; + if (this.index < this.source.length) { + ch = this.source.charAt(this.index); + if (ch === "x" || ch === "X") { + this.index++; + return this.scanHexLiteral(start, startLocation); + } else if (ch === "b" || ch === "B") { + this.index++; + return this.scanBinaryLiteral(start, startLocation); + } else if (ch === "o" || ch === "O") { + this.index++; + return this.scanOctalLiteral(start, startLocation); + } else if ("0" <= ch && ch <= "9") { + return this.scanLegacyOctalLiteral(start, startLocation); + } } else { - throw this.createError(lookahead_325, "expecting a " + val_324 + " punctuator"); - } - } - return lookahead_325; - } - throw this.createError(lookahead_325, "expecting a punctuator"); - } - createError(stx_326, message_327) { - let ctx_328 = ""; - let offending_329 = stx_326; - if (this.rest.size > 0) { - ctx_328 = this.rest.slice(0, 20).map(term_330 => { - if (this.isDelimiter(term_330)) { - return term_330.inner(); + var _slice = this.getSlice(start, startLocation); + return { + type: TokenType.NUMBER, + value: +_slice.text, + slice: _slice, + octal: false, + noctal: false + }; } - return _immutable.List.of(term_330); - }).flatten().map(s_331 => { - if (s_331 === offending_329) { - return "__" + s_331.val() + "__"; + } else if (ch !== ".") { + // Must be "1".."9" + ch = this.source.charAt(this.index); + while ("0" <= ch && ch <= "9") { + this.index++; + if (this.index === this.source.length) { + var _slice2 = this.getSlice(start, startLocation); + return { + type: TokenType.NUMBER, + value: +_slice2.text, + slice: _slice2, + octal: false, + noctal: false + }; + } + ch = this.source.charAt(this.index); } - return s_331.val(); - }).join(" "); - } else { - ctx_328 = offending_329.toString(); - } - return new Error(message_327 + "\n" + ctx_328); - } - } - exports.Enforester = Enforester_46; - //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/enforester.js"],"names":[],"mappings":"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","file":"enforester.js","sourcesContent":["import Term, {isIdentifierExpression} from \"./terms\";\nimport {Maybe} from \"ramda-fantasy\";\nimport {FunctionDeclTransform, VariableDeclTransform, NewTransform, LetDeclTransform, ConstDeclTransform, SyntaxDeclTransform, SyntaxrecDeclTransform, SyntaxQuoteTransform, ReturnStatementTransform, WhileTransform, IfTransform, ForTransform, SwitchTransform, BreakTransform, ContinueTransform, DoTransform, DebuggerTransform, WithTransform, TryTransform, ThrowTransform, CompiletimeTransform, VarBindingTransform} from \"./transforms\";\nimport {List} from \"immutable\";\nimport {expect, assert} from \"./errors\";\nimport {isOperator, isUnaryOperator, getOperatorAssoc, getOperatorPrec, operatorLt} from \"./operators\";\nimport Syntax, {ALL_PHASES} from \"./syntax\";\nimport {freshScope} from \"./scope\";\nimport {sanitizeReplacementValues} from \"./load-syntax\";\nimport MacroContext from \"./macro-context\";\nconst Just_41 = Maybe.Just;\nconst Nothing_42 = Maybe.Nothing;\nconst EXPR_LOOP_OPERATOR_43 = {};\nconst EXPR_LOOP_NO_CHANGE_44 = {};\nconst EXPR_LOOP_EXPANSION_45 = {};\nclass Enforester_46 {\n  constructor(stxl_47, prev_48, context_49) {\n    this.done = false;\n    assert(List.isList(stxl_47), \"expecting a list of terms to enforest\");\n    assert(List.isList(prev_48), \"expecting a list of terms to enforest\");\n    assert(context_49, \"expecting a context to enforest\");\n    this.term = null;\n    this.rest = stxl_47;\n    this.prev = prev_48;\n    this.context = context_49;\n  }\n  peek(n_50 = 0) {\n    return this.rest.get(n_50);\n  }\n  advance() {\n    let ret_51 = this.rest.first();\n    this.rest = this.rest.rest();\n    return ret_51;\n  }\n  enforest(type_52 = \"Module\") {\n    this.term = null;\n    if (this.rest.size === 0) {\n      this.done = true;\n      return this.term;\n    }\n    if (this.isEOF(this.peek())) {\n      this.term = new Term(\"EOF\", {});\n      this.advance();\n      return this.term;\n    }\n    let result_53;\n    if (type_52 === \"expression\") {\n      result_53 = this.enforestExpressionLoop();\n    } else {\n      result_53 = this.enforestModule();\n    }\n    if (this.rest.size === 0) {\n      this.done = true;\n    }\n    return result_53;\n  }\n  enforestModule() {\n    return this.enforestBody();\n  }\n  enforestBody() {\n    return this.enforestModuleItem();\n  }\n  enforestModuleItem() {\n    let lookahead_54 = this.peek();\n    if (this.isKeyword(lookahead_54, \"import\")) {\n      this.advance();\n      return this.enforestImportDeclaration();\n    } else if (this.isKeyword(lookahead_54, \"export\")) {\n      this.advance();\n      return this.enforestExportDeclaration();\n    } else if (this.isIdentifier(lookahead_54, \"#\")) {\n      return this.enforestLanguagePragma();\n    }\n    return this.enforestStatement();\n  }\n  enforestLanguagePragma() {\n    this.matchIdentifier(\"#\");\n    this.matchIdentifier(\"lang\");\n    let path_55 = this.matchStringLiteral();\n    this.consumeSemicolon();\n    return new Term(\"Pragma\", {kind: \"lang\", items: List.of(path_55)});\n  }\n  enforestExportDeclaration() {\n    let lookahead_56 = this.peek();\n    if (this.isPunctuator(lookahead_56, \"*\")) {\n      this.advance();\n      let moduleSpecifier = this.enforestFromClause();\n      return new Term(\"ExportAllFrom\", {moduleSpecifier: moduleSpecifier});\n    } else if (this.isBraces(lookahead_56)) {\n      let namedExports = this.enforestExportClause();\n      let moduleSpecifier = null;\n      if (this.isIdentifier(this.peek(), \"from\")) {\n        moduleSpecifier = this.enforestFromClause();\n      }\n      return new Term(\"ExportFrom\", {namedExports: namedExports, moduleSpecifier: moduleSpecifier});\n    } else if (this.isKeyword(lookahead_56, \"class\")) {\n      return new Term(\"Export\", {declaration: this.enforestClass({isExpr: false})});\n    } else if (this.isFnDeclTransform(lookahead_56)) {\n      return new Term(\"Export\", {declaration: this.enforestFunction({isExpr: false, inDefault: false})});\n    } else if (this.isKeyword(lookahead_56, \"default\")) {\n      this.advance();\n      if (this.isFnDeclTransform(this.peek())) {\n        return new Term(\"ExportDefault\", {body: this.enforestFunction({isExpr: false, inDefault: true})});\n      } else if (this.isKeyword(this.peek(), \"class\")) {\n        return new Term(\"ExportDefault\", {body: this.enforestClass({isExpr: false, inDefault: true})});\n      } else {\n        let body = this.enforestExpressionLoop();\n        this.consumeSemicolon();\n        return new Term(\"ExportDefault\", {body: body});\n      }\n    } else if (this.isVarDeclTransform(lookahead_56) || this.isLetDeclTransform(lookahead_56) || this.isConstDeclTransform(lookahead_56) || this.isSyntaxrecDeclTransform(lookahead_56) || this.isSyntaxDeclTransform(lookahead_56)) {\n      return new Term(\"Export\", {declaration: this.enforestVariableDeclaration()});\n    }\n    throw this.createError(lookahead_56, \"unexpected syntax\");\n  }\n  enforestExportClause() {\n    let enf_57 = new Enforester_46(this.matchCurlies(), List(), this.context);\n    let result_58 = [];\n    while (enf_57.rest.size !== 0) {\n      result_58.push(enf_57.enforestExportSpecifier());\n      enf_57.consumeComma();\n    }\n    return List(result_58);\n  }\n  enforestExportSpecifier() {\n    let name_59 = this.enforestIdentifier();\n    if (this.isIdentifier(this.peek(), \"as\")) {\n      this.advance();\n      let exportedName = this.enforestIdentifier();\n      return new Term(\"ExportSpecifier\", {name: name_59, exportedName: exportedName});\n    }\n    return new Term(\"ExportSpecifier\", {name: null, exportedName: name_59});\n  }\n  enforestImportDeclaration() {\n    let lookahead_60 = this.peek();\n    let defaultBinding_61 = null;\n    let namedImports_62 = List();\n    let forSyntax_63 = false;\n    if (this.isStringLiteral(lookahead_60)) {\n      let moduleSpecifier = this.advance();\n      this.consumeSemicolon();\n      return new Term(\"Import\", {defaultBinding: defaultBinding_61, namedImports: namedImports_62, moduleSpecifier: moduleSpecifier});\n    }\n    if (this.isIdentifier(lookahead_60) || this.isKeyword(lookahead_60)) {\n      defaultBinding_61 = this.enforestBindingIdentifier();\n      if (!this.isPunctuator(this.peek(), \",\")) {\n        let moduleSpecifier = this.enforestFromClause();\n        if (this.isKeyword(this.peek(), \"for\") && this.isIdentifier(this.peek(1), \"syntax\")) {\n          this.advance();\n          this.advance();\n          forSyntax_63 = true;\n        }\n        return new Term(\"Import\", {defaultBinding: defaultBinding_61, moduleSpecifier: moduleSpecifier, namedImports: List(), forSyntax: forSyntax_63});\n      }\n    }\n    this.consumeComma();\n    lookahead_60 = this.peek();\n    if (this.isBraces(lookahead_60)) {\n      let imports = this.enforestNamedImports();\n      let fromClause = this.enforestFromClause();\n      if (this.isKeyword(this.peek(), \"for\") && this.isIdentifier(this.peek(1), \"syntax\")) {\n        this.advance();\n        this.advance();\n        forSyntax_63 = true;\n      }\n      return new Term(\"Import\", {defaultBinding: defaultBinding_61, forSyntax: forSyntax_63, namedImports: imports, moduleSpecifier: fromClause});\n    } else if (this.isPunctuator(lookahead_60, \"*\")) {\n      let namespaceBinding = this.enforestNamespaceBinding();\n      let moduleSpecifier = this.enforestFromClause();\n      if (this.isKeyword(this.peek(), \"for\") && this.isIdentifier(this.peek(1), \"syntax\")) {\n        this.advance();\n        this.advance();\n        forSyntax_63 = true;\n      }\n      return new Term(\"ImportNamespace\", {defaultBinding: defaultBinding_61, forSyntax: forSyntax_63, namespaceBinding: namespaceBinding, moduleSpecifier: moduleSpecifier});\n    }\n    throw this.createError(lookahead_60, \"unexpected syntax\");\n  }\n  enforestNamespaceBinding() {\n    this.matchPunctuator(\"*\");\n    this.matchIdentifier(\"as\");\n    return this.enforestBindingIdentifier();\n  }\n  enforestNamedImports() {\n    let enf_64 = new Enforester_46(this.matchCurlies(), List(), this.context);\n    let result_65 = [];\n    while (enf_64.rest.size !== 0) {\n      result_65.push(enf_64.enforestImportSpecifiers());\n      enf_64.consumeComma();\n    }\n    return List(result_65);\n  }\n  enforestImportSpecifiers() {\n    let lookahead_66 = this.peek();\n    let name_67;\n    if (this.isIdentifier(lookahead_66) || this.isKeyword(lookahead_66)) {\n      name_67 = this.advance();\n      if (!this.isIdentifier(this.peek(), \"as\")) {\n        return new Term(\"ImportSpecifier\", {name: null, binding: new Term(\"BindingIdentifier\", {name: name_67})});\n      } else {\n        this.matchIdentifier(\"as\");\n      }\n    } else {\n      throw this.createError(lookahead_66, \"unexpected token in import specifier\");\n    }\n    return new Term(\"ImportSpecifier\", {name: name_67, binding: this.enforestBindingIdentifier()});\n  }\n  enforestFromClause() {\n    this.matchIdentifier(\"from\");\n    let lookahead_68 = this.matchStringLiteral();\n    this.consumeSemicolon();\n    return lookahead_68;\n  }\n  enforestStatementListItem() {\n    let lookahead_69 = this.peek();\n    if (this.isFnDeclTransform(lookahead_69)) {\n      return this.enforestFunctionDeclaration({isExpr: false});\n    } else if (this.isKeyword(lookahead_69, \"class\")) {\n      return this.enforestClass({isExpr: false});\n    } else {\n      return this.enforestStatement();\n    }\n  }\n  enforestStatement() {\n    let lookahead_70 = this.peek();\n    if (this.term === null && this.isCompiletimeTransform(lookahead_70)) {\n      this.expandMacro();\n      lookahead_70 = this.peek();\n    }\n    if (this.term === null && this.isTerm(lookahead_70)) {\n      return this.advance();\n    }\n    if (this.term === null && this.isBraces(lookahead_70)) {\n      return this.enforestBlockStatement();\n    }\n    if (this.term === null && this.isWhileTransform(lookahead_70)) {\n      return this.enforestWhileStatement();\n    }\n    if (this.term === null && this.isIfTransform(lookahead_70)) {\n      return this.enforestIfStatement();\n    }\n    if (this.term === null && this.isForTransform(lookahead_70)) {\n      return this.enforestForStatement();\n    }\n    if (this.term === null && this.isSwitchTransform(lookahead_70)) {\n      return this.enforestSwitchStatement();\n    }\n    if (this.term === null && this.isBreakTransform(lookahead_70)) {\n      return this.enforestBreakStatement();\n    }\n    if (this.term === null && this.isContinueTransform(lookahead_70)) {\n      return this.enforestContinueStatement();\n    }\n    if (this.term === null && this.isDoTransform(lookahead_70)) {\n      return this.enforestDoStatement();\n    }\n    if (this.term === null && this.isDebuggerTransform(lookahead_70)) {\n      return this.enforestDebuggerStatement();\n    }\n    if (this.term === null && this.isWithTransform(lookahead_70)) {\n      return this.enforestWithStatement();\n    }\n    if (this.term === null && this.isTryTransform(lookahead_70)) {\n      return this.enforestTryStatement();\n    }\n    if (this.term === null && this.isThrowTransform(lookahead_70)) {\n      return this.enforestThrowStatement();\n    }\n    if (this.term === null && this.isKeyword(lookahead_70, \"class\")) {\n      return this.enforestClass({isExpr: false});\n    }\n    if (this.term === null && this.isFnDeclTransform(lookahead_70)) {\n      return this.enforestFunctionDeclaration();\n    }\n    if (this.term === null && this.isIdentifier(lookahead_70) && this.isPunctuator(this.peek(1), \":\")) {\n      return this.enforestLabeledStatement();\n    }\n    if (this.term === null && (this.isVarDeclTransform(lookahead_70) || this.isLetDeclTransform(lookahead_70) || this.isConstDeclTransform(lookahead_70) || this.isSyntaxrecDeclTransform(lookahead_70) || this.isSyntaxDeclTransform(lookahead_70))) {\n      let stmt = new Term(\"VariableDeclarationStatement\", {declaration: this.enforestVariableDeclaration()});\n      this.consumeSemicolon();\n      return stmt;\n    }\n    if (this.term === null && this.isReturnStmtTransform(lookahead_70)) {\n      return this.enforestReturnStatement();\n    }\n    if (this.term === null && this.isPunctuator(lookahead_70, \";\")) {\n      this.advance();\n      return new Term(\"EmptyStatement\", {});\n    }\n    return this.enforestExpressionStatement();\n  }\n  enforestLabeledStatement() {\n    let label_71 = this.matchIdentifier();\n    let punc_72 = this.matchPunctuator(\":\");\n    let stmt_73 = this.enforestStatement();\n    return new Term(\"LabeledStatement\", {label: label_71, body: stmt_73});\n  }\n  enforestBreakStatement() {\n    this.matchKeyword(\"break\");\n    let lookahead_74 = this.peek();\n    let label_75 = null;\n    if (this.rest.size === 0 || this.isPunctuator(lookahead_74, \";\")) {\n      this.consumeSemicolon();\n      return new Term(\"BreakStatement\", {label: label_75});\n    }\n    if (this.isIdentifier(lookahead_74) || this.isKeyword(lookahead_74, \"yield\") || this.isKeyword(lookahead_74, \"let\")) {\n      label_75 = this.enforestIdentifier();\n    }\n    this.consumeSemicolon();\n    return new Term(\"BreakStatement\", {label: label_75});\n  }\n  enforestTryStatement() {\n    this.matchKeyword(\"try\");\n    let body_76 = this.enforestBlock();\n    if (this.isKeyword(this.peek(), \"catch\")) {\n      let catchClause = this.enforestCatchClause();\n      if (this.isKeyword(this.peek(), \"finally\")) {\n        this.advance();\n        let finalizer = this.enforestBlock();\n        return new Term(\"TryFinallyStatement\", {body: body_76, catchClause: catchClause, finalizer: finalizer});\n      }\n      return new Term(\"TryCatchStatement\", {body: body_76, catchClause: catchClause});\n    }\n    if (this.isKeyword(this.peek(), \"finally\")) {\n      this.advance();\n      let finalizer = this.enforestBlock();\n      return new Term(\"TryFinallyStatement\", {body: body_76, catchClause: null, finalizer: finalizer});\n    }\n    throw this.createError(this.peek(), \"try with no catch or finally\");\n  }\n  enforestCatchClause() {\n    this.matchKeyword(\"catch\");\n    let bindingParens_77 = this.matchParens();\n    let enf_78 = new Enforester_46(bindingParens_77, List(), this.context);\n    let binding_79 = enf_78.enforestBindingTarget();\n    let body_80 = this.enforestBlock();\n    return new Term(\"CatchClause\", {binding: binding_79, body: body_80});\n  }\n  enforestThrowStatement() {\n    this.matchKeyword(\"throw\");\n    let expression_81 = this.enforestExpression();\n    this.consumeSemicolon();\n    return new Term(\"ThrowStatement\", {expression: expression_81});\n  }\n  enforestWithStatement() {\n    this.matchKeyword(\"with\");\n    let objParens_82 = this.matchParens();\n    let enf_83 = new Enforester_46(objParens_82, List(), this.context);\n    let object_84 = enf_83.enforestExpression();\n    let body_85 = this.enforestStatement();\n    return new Term(\"WithStatement\", {object: object_84, body: body_85});\n  }\n  enforestDebuggerStatement() {\n    this.matchKeyword(\"debugger\");\n    return new Term(\"DebuggerStatement\", {});\n  }\n  enforestDoStatement() {\n    this.matchKeyword(\"do\");\n    let body_86 = this.enforestStatement();\n    this.matchKeyword(\"while\");\n    let testBody_87 = this.matchParens();\n    let enf_88 = new Enforester_46(testBody_87, List(), this.context);\n    let test_89 = enf_88.enforestExpression();\n    this.consumeSemicolon();\n    return new Term(\"DoWhileStatement\", {body: body_86, test: test_89});\n  }\n  enforestContinueStatement() {\n    let kwd_90 = this.matchKeyword(\"continue\");\n    let lookahead_91 = this.peek();\n    let label_92 = null;\n    if (this.rest.size === 0 || this.isPunctuator(lookahead_91, \";\")) {\n      this.consumeSemicolon();\n      return new Term(\"ContinueStatement\", {label: label_92});\n    }\n    if (this.lineNumberEq(kwd_90, lookahead_91) && (this.isIdentifier(lookahead_91) || this.isKeyword(lookahead_91, \"yield\") || this.isKeyword(lookahead_91, \"let\"))) {\n      label_92 = this.enforestIdentifier();\n    }\n    this.consumeSemicolon();\n    return new Term(\"ContinueStatement\", {label: label_92});\n  }\n  enforestSwitchStatement() {\n    this.matchKeyword(\"switch\");\n    let cond_93 = this.matchParens();\n    let enf_94 = new Enforester_46(cond_93, List(), this.context);\n    let discriminant_95 = enf_94.enforestExpression();\n    let body_96 = this.matchCurlies();\n    if (body_96.size === 0) {\n      return new Term(\"SwitchStatement\", {discriminant: discriminant_95, cases: List()});\n    }\n    enf_94 = new Enforester_46(body_96, List(), this.context);\n    let cases_97 = enf_94.enforestSwitchCases();\n    let lookahead_98 = enf_94.peek();\n    if (enf_94.isKeyword(lookahead_98, \"default\")) {\n      let defaultCase = enf_94.enforestSwitchDefault();\n      let postDefaultCases = enf_94.enforestSwitchCases();\n      return new Term(\"SwitchStatementWithDefault\", {discriminant: discriminant_95, preDefaultCases: cases_97, defaultCase: defaultCase, postDefaultCases: postDefaultCases});\n    }\n    return new Term(\"SwitchStatement\", {discriminant: discriminant_95, cases: cases_97});\n  }\n  enforestSwitchCases() {\n    let cases_99 = [];\n    while (!(this.rest.size === 0 || this.isKeyword(this.peek(), \"default\"))) {\n      cases_99.push(this.enforestSwitchCase());\n    }\n    return List(cases_99);\n  }\n  enforestSwitchCase() {\n    this.matchKeyword(\"case\");\n    return new Term(\"SwitchCase\", {test: this.enforestExpression(), consequent: this.enforestSwitchCaseBody()});\n  }\n  enforestSwitchCaseBody() {\n    this.matchPunctuator(\":\");\n    return this.enforestStatementListInSwitchCaseBody();\n  }\n  enforestStatementListInSwitchCaseBody() {\n    let result_100 = [];\n    while (!(this.rest.size === 0 || this.isKeyword(this.peek(), \"default\") || this.isKeyword(this.peek(), \"case\"))) {\n      result_100.push(this.enforestStatementListItem());\n    }\n    return List(result_100);\n  }\n  enforestSwitchDefault() {\n    this.matchKeyword(\"default\");\n    return new Term(\"SwitchDefault\", {consequent: this.enforestSwitchCaseBody()});\n  }\n  enforestForStatement() {\n    this.matchKeyword(\"for\");\n    let cond_101 = this.matchParens();\n    let enf_102 = new Enforester_46(cond_101, List(), this.context);\n    let lookahead_103, test_104, init_105, right_106, type_107, left_108, update_109;\n    if (enf_102.isPunctuator(enf_102.peek(), \";\")) {\n      enf_102.advance();\n      if (!enf_102.isPunctuator(enf_102.peek(), \";\")) {\n        test_104 = enf_102.enforestExpression();\n      }\n      enf_102.matchPunctuator(\";\");\n      if (enf_102.rest.size !== 0) {\n        right_106 = enf_102.enforestExpression();\n      }\n      return new Term(\"ForStatement\", {init: null, test: test_104, update: right_106, body: this.enforestStatement()});\n    } else {\n      lookahead_103 = enf_102.peek();\n      if (enf_102.isVarDeclTransform(lookahead_103) || enf_102.isLetDeclTransform(lookahead_103) || enf_102.isConstDeclTransform(lookahead_103)) {\n        init_105 = enf_102.enforestVariableDeclaration();\n        lookahead_103 = enf_102.peek();\n        if (this.isKeyword(lookahead_103, \"in\") || this.isIdentifier(lookahead_103, \"of\")) {\n          if (this.isKeyword(lookahead_103, \"in\")) {\n            enf_102.advance();\n            right_106 = enf_102.enforestExpression();\n            type_107 = \"ForInStatement\";\n          } else if (this.isIdentifier(lookahead_103, \"of\")) {\n            enf_102.advance();\n            right_106 = enf_102.enforestExpression();\n            type_107 = \"ForOfStatement\";\n          }\n          return new Term(type_107, {left: init_105, right: right_106, body: this.enforestStatement()});\n        }\n        enf_102.matchPunctuator(\";\");\n        if (enf_102.isPunctuator(enf_102.peek(), \";\")) {\n          enf_102.advance();\n          test_104 = null;\n        } else {\n          test_104 = enf_102.enforestExpression();\n          enf_102.matchPunctuator(\";\");\n        }\n        update_109 = enf_102.enforestExpression();\n      } else {\n        if (this.isKeyword(enf_102.peek(1), \"in\") || this.isIdentifier(enf_102.peek(1), \"of\")) {\n          left_108 = enf_102.enforestBindingIdentifier();\n          let kind = enf_102.advance();\n          if (this.isKeyword(kind, \"in\")) {\n            type_107 = \"ForInStatement\";\n          } else {\n            type_107 = \"ForOfStatement\";\n          }\n          right_106 = enf_102.enforestExpression();\n          return new Term(type_107, {left: left_108, right: right_106, body: this.enforestStatement()});\n        }\n        init_105 = enf_102.enforestExpression();\n        enf_102.matchPunctuator(\";\");\n        if (enf_102.isPunctuator(enf_102.peek(), \";\")) {\n          enf_102.advance();\n          test_104 = null;\n        } else {\n          test_104 = enf_102.enforestExpression();\n          enf_102.matchPunctuator(\";\");\n        }\n        update_109 = enf_102.enforestExpression();\n      }\n      return new Term(\"ForStatement\", {init: init_105, test: test_104, update: update_109, body: this.enforestStatement()});\n    }\n  }\n  enforestIfStatement() {\n    this.matchKeyword(\"if\");\n    let cond_110 = this.matchParens();\n    let enf_111 = new Enforester_46(cond_110, List(), this.context);\n    let lookahead_112 = enf_111.peek();\n    let test_113 = enf_111.enforestExpression();\n    if (test_113 === null) {\n      throw enf_111.createError(lookahead_112, \"expecting an expression\");\n    }\n    let consequent_114 = this.enforestStatement();\n    let alternate_115 = null;\n    if (this.isKeyword(this.peek(), \"else\")) {\n      this.advance();\n      alternate_115 = this.enforestStatement();\n    }\n    return new Term(\"IfStatement\", {test: test_113, consequent: consequent_114, alternate: alternate_115});\n  }\n  enforestWhileStatement() {\n    this.matchKeyword(\"while\");\n    let cond_116 = this.matchParens();\n    let enf_117 = new Enforester_46(cond_116, List(), this.context);\n    let lookahead_118 = enf_117.peek();\n    let test_119 = enf_117.enforestExpression();\n    if (test_119 === null) {\n      throw enf_117.createError(lookahead_118, \"expecting an expression\");\n    }\n    let body_120 = this.enforestStatement();\n    return new Term(\"WhileStatement\", {test: test_119, body: body_120});\n  }\n  enforestBlockStatement() {\n    return new Term(\"BlockStatement\", {block: this.enforestBlock()});\n  }\n  enforestBlock() {\n    return new Term(\"Block\", {statements: this.matchCurlies()});\n  }\n  enforestClass({isExpr, inDefault}) {\n    let kw_121 = this.advance();\n    let name_122 = null, supr_123 = null;\n    let type_124 = isExpr ? \"ClassExpression\" : \"ClassDeclaration\";\n    if (this.isIdentifier(this.peek())) {\n      name_122 = this.enforestBindingIdentifier();\n    } else if (!isExpr) {\n      if (inDefault) {\n        name_122 = new Term(\"BindingIdentifier\", {name: Syntax.fromIdentifier(\"_default\", kw_121)});\n      } else {\n        throw this.createError(this.peek(), \"unexpected syntax\");\n      }\n    }\n    if (this.isKeyword(this.peek(), \"extends\")) {\n      this.advance();\n      supr_123 = this.enforestExpressionLoop();\n    }\n    let elements_125 = [];\n    let enf_126 = new Enforester_46(this.matchCurlies(), List(), this.context);\n    while (enf_126.rest.size !== 0) {\n      if (enf_126.isPunctuator(enf_126.peek(), \";\")) {\n        enf_126.advance();\n        continue;\n      }\n      let isStatic = false;\n      let {methodOrKey, kind} = enf_126.enforestMethodDefinition();\n      if (kind === \"identifier\" && methodOrKey.value.val() === \"static\") {\n        isStatic = true;\n        ({methodOrKey, kind} = enf_126.enforestMethodDefinition());\n      }\n      if (kind === \"method\") {\n        elements_125.push(new Term(\"ClassElement\", {isStatic: isStatic, method: methodOrKey}));\n      } else {\n        throw this.createError(enf_126.peek(), \"Only methods are allowed in classes\");\n      }\n    }\n    return new Term(type_124, {name: name_122, super: supr_123, elements: List(elements_125)});\n  }\n  enforestBindingTarget({allowPunctuator} = {}) {\n    let lookahead_127 = this.peek();\n    if (this.isIdentifier(lookahead_127) || this.isKeyword(lookahead_127) || allowPunctuator && this.isPunctuator(lookahead_127)) {\n      return this.enforestBindingIdentifier({allowPunctuator: allowPunctuator});\n    } else if (this.isBrackets(lookahead_127)) {\n      return this.enforestArrayBinding();\n    } else if (this.isBraces(lookahead_127)) {\n      return this.enforestObjectBinding();\n    }\n    assert(false, \"not implemented yet\");\n  }\n  enforestObjectBinding() {\n    let enf_128 = new Enforester_46(this.matchCurlies(), List(), this.context);\n    let properties_129 = [];\n    while (enf_128.rest.size !== 0) {\n      properties_129.push(enf_128.enforestBindingProperty());\n      enf_128.consumeComma();\n    }\n    return new Term(\"ObjectBinding\", {properties: List(properties_129)});\n  }\n  enforestBindingProperty() {\n    let lookahead_130 = this.peek();\n    let {name, binding} = this.enforestPropertyName();\n    if (this.isIdentifier(lookahead_130) || this.isKeyword(lookahead_130, \"let\") || this.isKeyword(lookahead_130, \"yield\")) {\n      if (!this.isPunctuator(this.peek(), \":\")) {\n        let defaultValue = null;\n        if (this.isAssign(this.peek())) {\n          this.advance();\n          let expr = this.enforestExpressionLoop();\n          defaultValue = expr;\n        }\n        return new Term(\"BindingPropertyIdentifier\", {binding: binding, init: defaultValue});\n      }\n    }\n    this.matchPunctuator(\":\");\n    binding = this.enforestBindingElement();\n    return new Term(\"BindingPropertyProperty\", {name: name, binding: binding});\n  }\n  enforestArrayBinding() {\n    let bracket_131 = this.matchSquares();\n    let enf_132 = new Enforester_46(bracket_131, List(), this.context);\n    let elements_133 = [], restElement_134 = null;\n    while (enf_132.rest.size !== 0) {\n      let el;\n      if (enf_132.isPunctuator(enf_132.peek(), \",\")) {\n        enf_132.consumeComma();\n        el = null;\n      } else {\n        if (enf_132.isPunctuator(enf_132.peek(), \"...\")) {\n          enf_132.advance();\n          restElement_134 = enf_132.enforestBindingTarget();\n          break;\n        } else {\n          el = enf_132.enforestBindingElement();\n        }\n        enf_132.consumeComma();\n      }\n      elements_133.push(el);\n    }\n    return new Term(\"ArrayBinding\", {elements: List(elements_133), restElement: restElement_134});\n  }\n  enforestBindingElement() {\n    let binding_135 = this.enforestBindingTarget();\n    if (this.isAssign(this.peek())) {\n      this.advance();\n      let init = this.enforestExpressionLoop();\n      binding_135 = new Term(\"BindingWithDefault\", {binding: binding_135, init: init});\n    }\n    return binding_135;\n  }\n  enforestBindingIdentifier({allowPunctuator} = {}) {\n    let name_136;\n    if (allowPunctuator && this.isPunctuator(this.peek())) {\n      name_136 = this.enforestPunctuator();\n    } else {\n      name_136 = this.enforestIdentifier();\n    }\n    return new Term(\"BindingIdentifier\", {name: name_136});\n  }\n  enforestPunctuator() {\n    let lookahead_137 = this.peek();\n    if (this.isPunctuator(lookahead_137)) {\n      return this.advance();\n    }\n    throw this.createError(lookahead_137, \"expecting a punctuator\");\n  }\n  enforestIdentifier() {\n    let lookahead_138 = this.peek();\n    if (this.isIdentifier(lookahead_138) || this.isKeyword(lookahead_138)) {\n      return this.advance();\n    }\n    throw this.createError(lookahead_138, \"expecting an identifier\");\n  }\n  enforestReturnStatement() {\n    let kw_139 = this.advance();\n    let lookahead_140 = this.peek();\n    if (this.rest.size === 0 || lookahead_140 && !this.lineNumberEq(kw_139, lookahead_140)) {\n      return new Term(\"ReturnStatement\", {expression: null});\n    }\n    let term_141 = null;\n    if (!this.isPunctuator(lookahead_140, \";\")) {\n      term_141 = this.enforestExpression();\n      expect(term_141 != null, \"Expecting an expression to follow return keyword\", lookahead_140, this.rest);\n    }\n    this.consumeSemicolon();\n    return new Term(\"ReturnStatement\", {expression: term_141});\n  }\n  enforestVariableDeclaration() {\n    let kind_142;\n    let lookahead_143 = this.advance();\n    let kindSyn_144 = lookahead_143;\n    let phase_145 = this.context.phase;\n    if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === VariableDeclTransform) {\n      kind_142 = \"var\";\n    } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === LetDeclTransform) {\n      kind_142 = \"let\";\n    } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === ConstDeclTransform) {\n      kind_142 = \"const\";\n    } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === SyntaxDeclTransform) {\n      kind_142 = \"syntax\";\n    } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === SyntaxrecDeclTransform) {\n      kind_142 = \"syntaxrec\";\n    }\n    let decls_146 = List();\n    while (true) {\n      let term = this.enforestVariableDeclarator({isSyntax: kind_142 === \"syntax\" || kind_142 === \"syntaxrec\"});\n      let lookahead_143 = this.peek();\n      decls_146 = decls_146.concat(term);\n      if (this.isPunctuator(lookahead_143, \",\")) {\n        this.advance();\n      } else {\n        break;\n      }\n    }\n    return new Term(\"VariableDeclaration\", {kind: kind_142, declarators: decls_146});\n  }\n  enforestVariableDeclarator({isSyntax}) {\n    let id_147 = this.enforestBindingTarget({allowPunctuator: isSyntax});\n    let lookahead_148 = this.peek();\n    let init_149, rest_150;\n    if (this.isPunctuator(lookahead_148, \"=\")) {\n      this.advance();\n      let enf = new Enforester_46(this.rest, List(), this.context);\n      init_149 = enf.enforest(\"expression\");\n      this.rest = enf.rest;\n    } else {\n      init_149 = null;\n    }\n    return new Term(\"VariableDeclarator\", {binding: id_147, init: init_149});\n  }\n  enforestExpressionStatement() {\n    let start_151 = this.rest.get(0);\n    let expr_152 = this.enforestExpression();\n    if (expr_152 === null) {\n      throw this.createError(start_151, \"not a valid expression\");\n    }\n    this.consumeSemicolon();\n    return new Term(\"ExpressionStatement\", {expression: expr_152});\n  }\n  enforestExpression() {\n    let left_153 = this.enforestExpressionLoop();\n    let lookahead_154 = this.peek();\n    if (this.isPunctuator(lookahead_154, \",\")) {\n      while (this.rest.size !== 0) {\n        if (!this.isPunctuator(this.peek(), \",\")) {\n          break;\n        }\n        let operator = this.advance();\n        let right = this.enforestExpressionLoop();\n        left_153 = new Term(\"BinaryExpression\", {left: left_153, operator: operator, right: right});\n      }\n    }\n    this.term = null;\n    return left_153;\n  }\n  enforestExpressionLoop() {\n    this.term = null;\n    this.opCtx = {prec: 0, combine: x_155 => x_155, stack: List()};\n    do {\n      let term = this.enforestAssignmentExpression();\n      if (term === EXPR_LOOP_NO_CHANGE_44 && this.opCtx.stack.size > 0) {\n        this.term = this.opCtx.combine(this.term);\n        let {prec, combine} = this.opCtx.stack.last();\n        this.opCtx.prec = prec;\n        this.opCtx.combine = combine;\n        this.opCtx.stack = this.opCtx.stack.pop();\n      } else if (term === EXPR_LOOP_NO_CHANGE_44) {\n        break;\n      } else if (term === EXPR_LOOP_OPERATOR_43 || term === EXPR_LOOP_EXPANSION_45) {\n        this.term = null;\n      } else {\n        this.term = term;\n      }\n    } while (true);\n    return this.term;\n  }\n  enforestAssignmentExpression() {\n    let lookahead_156 = this.peek();\n    if (this.term === null && this.isCompiletimeTransform(lookahead_156)) {\n      this.expandMacro();\n      lookahead_156 = this.peek();\n    }\n    if (this.term === null && this.isTerm(lookahead_156)) {\n      return this.advance();\n    }\n    if (this.term === null && this.isKeyword(lookahead_156, \"yield\")) {\n      return this.enforestYieldExpression();\n    }\n    if (this.term === null && this.isKeyword(lookahead_156, \"class\")) {\n      return this.enforestClass({isExpr: true});\n    }\n    if (this.term === null && (this.isIdentifier(lookahead_156) || this.isParens(lookahead_156)) && this.isPunctuator(this.peek(1), \"=>\") && this.lineNumberEq(lookahead_156, this.peek(1))) {\n      return this.enforestArrowExpression();\n    }\n    if (this.term === null && this.isSyntaxTemplate(lookahead_156)) {\n      return this.enforestSyntaxTemplate();\n    }\n    if (this.term === null && this.isSyntaxQuoteTransform(lookahead_156)) {\n      return this.enforestSyntaxQuote();\n    }\n    if (this.term === null && this.isParens(lookahead_156)) {\n      return new Term(\"ParenthesizedExpression\", {inner: this.advance().inner()});\n    }\n    if (this.term === null && (this.isKeyword(lookahead_156, \"this\") || this.isIdentifier(lookahead_156) || this.isKeyword(lookahead_156, \"let\") || this.isKeyword(lookahead_156, \"yield\") || this.isNumericLiteral(lookahead_156) || this.isStringLiteral(lookahead_156) || this.isTemplate(lookahead_156) || this.isBooleanLiteral(lookahead_156) || this.isNullLiteral(lookahead_156) || this.isRegularExpression(lookahead_156) || this.isFnDeclTransform(lookahead_156) || this.isBraces(lookahead_156) || this.isBrackets(lookahead_156))) {\n      return this.enforestPrimaryExpression();\n    }\n    if (this.term === null && this.isOperator(lookahead_156)) {\n      return this.enforestUnaryExpression();\n    }\n    if (this.term === null && this.isVarBindingTransform(lookahead_156)) {\n      let id = this.getFromCompiletimeEnvironment(lookahead_156).id;\n      if (id !== lookahead_156) {\n        this.advance();\n        this.rest = List.of(id).concat(this.rest);\n        return EXPR_LOOP_EXPANSION_45;\n      }\n    }\n    if (this.term === null && (this.isNewTransform(lookahead_156) || this.isKeyword(lookahead_156, \"super\")) || this.term && (this.isPunctuator(lookahead_156, \".\") && (this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1))) || this.isBrackets(lookahead_156) || this.isParens(lookahead_156))) {\n      return this.enforestLeftHandSideExpression({allowCall: true});\n    }\n    if (this.term && this.isTemplate(lookahead_156)) {\n      return this.enforestTemplateLiteral();\n    }\n    if (this.term && this.isUpdateOperator(lookahead_156)) {\n      return this.enforestUpdateExpression();\n    }\n    if (this.term && this.isOperator(lookahead_156)) {\n      return this.enforestBinaryExpression();\n    }\n    if (this.term && this.isAssign(lookahead_156)) {\n      let binding = this.transformDestructuring(this.term);\n      let op = this.advance();\n      let enf = new Enforester_46(this.rest, List(), this.context);\n      let init = enf.enforest(\"expression\");\n      this.rest = enf.rest;\n      if (op.val() === \"=\") {\n        return new Term(\"AssignmentExpression\", {binding: binding, expression: init});\n      } else {\n        return new Term(\"CompoundAssignmentExpression\", {binding: binding, operator: op.val(), expression: init});\n      }\n    }\n    if (this.term && this.isPunctuator(lookahead_156, \"?\")) {\n      return this.enforestConditionalExpression();\n    }\n    return EXPR_LOOP_NO_CHANGE_44;\n  }\n  enforestPrimaryExpression() {\n    let lookahead_157 = this.peek();\n    if (this.term === null && this.isKeyword(lookahead_157, \"this\")) {\n      return this.enforestThisExpression();\n    }\n    if (this.term === null && (this.isIdentifier(lookahead_157) || this.isKeyword(lookahead_157, \"let\") || this.isKeyword(lookahead_157, \"yield\"))) {\n      return this.enforestIdentifierExpression();\n    }\n    if (this.term === null && this.isNumericLiteral(lookahead_157)) {\n      return this.enforestNumericLiteral();\n    }\n    if (this.term === null && this.isStringLiteral(lookahead_157)) {\n      return this.enforestStringLiteral();\n    }\n    if (this.term === null && this.isTemplate(lookahead_157)) {\n      return this.enforestTemplateLiteral();\n    }\n    if (this.term === null && this.isBooleanLiteral(lookahead_157)) {\n      return this.enforestBooleanLiteral();\n    }\n    if (this.term === null && this.isNullLiteral(lookahead_157)) {\n      return this.enforestNullLiteral();\n    }\n    if (this.term === null && this.isRegularExpression(lookahead_157)) {\n      return this.enforestRegularExpressionLiteral();\n    }\n    if (this.term === null && this.isFnDeclTransform(lookahead_157)) {\n      return this.enforestFunctionExpression();\n    }\n    if (this.term === null && this.isBraces(lookahead_157)) {\n      return this.enforestObjectExpression();\n    }\n    if (this.term === null && this.isBrackets(lookahead_157)) {\n      return this.enforestArrayExpression();\n    }\n    assert(false, \"Not a primary expression\");\n  }\n  enforestLeftHandSideExpression({allowCall}) {\n    let lookahead_158 = this.peek();\n    if (this.isKeyword(lookahead_158, \"super\")) {\n      this.advance();\n      this.term = new Term(\"Super\", {});\n    } else if (this.isNewTransform(lookahead_158)) {\n      this.term = this.enforestNewExpression();\n    }\n    while (true) {\n      lookahead_158 = this.peek();\n      if (this.isParens(lookahead_158)) {\n        if (!allowCall) {\n          if (this.term && isIdentifierExpression(this.term)) {\n            return this.term;\n          }\n          this.term = this.enforestExpressionLoop();\n        } else {\n          this.term = this.enforestCallExpression();\n        }\n      } else if (this.isBrackets(lookahead_158)) {\n        this.term = allowCall ? this.enforestComputedMemberExpression() : this.enforestExpressionLoop();\n      } else if (this.isPunctuator(lookahead_158, \".\") && (this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1)))) {\n        this.term = this.enforestStaticMemberExpression();\n      } else if (this.isTemplate(lookahead_158)) {\n        this.term = this.enforestTemplateLiteral();\n      } else if (this.isBraces(lookahead_158)) {\n        this.term = this.enforestPrimaryExpression();\n      } else if (this.isIdentifier(lookahead_158)) {\n        this.term = new Term(\"IdentifierExpression\", {name: this.enforestIdentifier()});\n      } else {\n        break;\n      }\n    }\n    return this.term;\n  }\n  enforestBooleanLiteral() {\n    return new Term(\"LiteralBooleanExpression\", {value: this.advance()});\n  }\n  enforestTemplateLiteral() {\n    return new Term(\"TemplateExpression\", {tag: this.term, elements: this.enforestTemplateElements()});\n  }\n  enforestStringLiteral() {\n    return new Term(\"LiteralStringExpression\", {value: this.advance()});\n  }\n  enforestNumericLiteral() {\n    let num_159 = this.advance();\n    if (num_159.val() === 1 / 0) {\n      return new Term(\"LiteralInfinityExpression\", {});\n    }\n    return new Term(\"LiteralNumericExpression\", {value: num_159});\n  }\n  enforestIdentifierExpression() {\n    return new Term(\"IdentifierExpression\", {name: this.advance()});\n  }\n  enforestRegularExpressionLiteral() {\n    let reStx_160 = this.advance();\n    let lastSlash_161 = reStx_160.token.value.lastIndexOf(\"/\");\n    let pattern_162 = reStx_160.token.value.slice(1, lastSlash_161);\n    let flags_163 = reStx_160.token.value.slice(lastSlash_161 + 1);\n    return new Term(\"LiteralRegExpExpression\", {pattern: pattern_162, flags: flags_163});\n  }\n  enforestNullLiteral() {\n    this.advance();\n    return new Term(\"LiteralNullExpression\", {});\n  }\n  enforestThisExpression() {\n    return new Term(\"ThisExpression\", {stx: this.advance()});\n  }\n  enforestArgumentList() {\n    let result_164 = [];\n    while (this.rest.size > 0) {\n      let arg;\n      if (this.isPunctuator(this.peek(), \"...\")) {\n        this.advance();\n        arg = new Term(\"SpreadElement\", {expression: this.enforestExpressionLoop()});\n      } else {\n        arg = this.enforestExpressionLoop();\n      }\n      if (this.rest.size > 0) {\n        this.matchPunctuator(\",\");\n      }\n      result_164.push(arg);\n    }\n    return List(result_164);\n  }\n  enforestNewExpression() {\n    this.matchKeyword(\"new\");\n    if (this.isPunctuator(this.peek(), \".\") && this.isIdentifier(this.peek(1), \"target\")) {\n      this.advance();\n      this.advance();\n      return new Term(\"NewTargetExpression\", {});\n    }\n    let callee_165 = this.enforestLeftHandSideExpression({allowCall: false});\n    let args_166;\n    if (this.isParens(this.peek())) {\n      args_166 = this.matchParens();\n    } else {\n      args_166 = List();\n    }\n    return new Term(\"NewExpression\", {callee: callee_165, arguments: args_166});\n  }\n  enforestComputedMemberExpression() {\n    let enf_167 = new Enforester_46(this.matchSquares(), List(), this.context);\n    return new Term(\"ComputedMemberExpression\", {object: this.term, expression: enf_167.enforestExpression()});\n  }\n  transformDestructuring(term_168) {\n    switch (term_168.type) {\n      case \"IdentifierExpression\":\n        return new Term(\"BindingIdentifier\", {name: term_168.name});\n      case \"ParenthesizedExpression\":\n        if (term_168.inner.size === 1 && this.isIdentifier(term_168.inner.get(0))) {\n          return new Term(\"BindingIdentifier\", {name: term_168.inner.get(0)});\n        }\n      case \"DataProperty\":\n        return new Term(\"BindingPropertyProperty\", {name: term_168.name, binding: this.transformDestructuringWithDefault(term_168.expression)});\n      case \"ShorthandProperty\":\n        return new Term(\"BindingPropertyIdentifier\", {binding: new Term(\"BindingIdentifier\", {name: term_168.name}), init: null});\n      case \"ObjectExpression\":\n        return new Term(\"ObjectBinding\", {properties: term_168.properties.map(t_169 => this.transformDestructuring(t_169))});\n      case \"ArrayExpression\":\n        let last = term_168.elements.last();\n        if (last != null && last.type === \"SpreadElement\") {\n          return new Term(\"ArrayBinding\", {elements: term_168.elements.slice(0, -1).map(t_170 => t_170 && this.transformDestructuringWithDefault(t_170)), restElement: this.transformDestructuringWithDefault(last.expression)});\n        } else {\n          return new Term(\"ArrayBinding\", {elements: term_168.elements.map(t_171 => t_171 && this.transformDestructuringWithDefault(t_171)), restElement: null});\n        }\n        return new Term(\"ArrayBinding\", {elements: term_168.elements.map(t_172 => t_172 && this.transformDestructuring(t_172)), restElement: null});\n      case \"StaticPropertyName\":\n        return new Term(\"BindingIdentifier\", {name: term_168.value});\n      case \"ComputedMemberExpression\":\n      case \"StaticMemberExpression\":\n      case \"ArrayBinding\":\n      case \"BindingIdentifier\":\n      case \"BindingPropertyIdentifier\":\n      case \"BindingPropertyProperty\":\n      case \"BindingWithDefault\":\n      case \"ObjectBinding\":\n        return term_168;\n    }\n    assert(false, \"not implemented yet for \" + term_168.type);\n  }\n  transformDestructuringWithDefault(term_173) {\n    switch (term_173.type) {\n      case \"AssignmentExpression\":\n        return new Term(\"BindingWithDefault\", {binding: this.transformDestructuring(term_173.binding), init: term_173.expression});\n    }\n    return this.transformDestructuring(term_173);\n  }\n  enforestCallExpression() {\n    let paren_174 = this.advance();\n    return new Term(\"CallExpression\", {callee: this.term, arguments: paren_174.inner()});\n  }\n  enforestArrowExpression() {\n    let enf_175;\n    if (this.isIdentifier(this.peek())) {\n      enf_175 = new Enforester_46(List.of(this.advance()), List(), this.context);\n    } else {\n      let p = this.matchParens();\n      enf_175 = new Enforester_46(p, List(), this.context);\n    }\n    let params_176 = enf_175.enforestFormalParameters();\n    this.matchPunctuator(\"=>\");\n    let body_177;\n    if (this.isBraces(this.peek())) {\n      body_177 = this.matchCurlies();\n    } else {\n      enf_175 = new Enforester_46(this.rest, List(), this.context);\n      body_177 = enf_175.enforestExpressionLoop();\n      this.rest = enf_175.rest;\n    }\n    return new Term(\"ArrowExpression\", {params: params_176, body: body_177});\n  }\n  enforestYieldExpression() {\n    let kwd_178 = this.matchKeyword(\"yield\");\n    let lookahead_179 = this.peek();\n    if (this.rest.size === 0 || lookahead_179 && !this.lineNumberEq(kwd_178, lookahead_179)) {\n      return new Term(\"YieldExpression\", {expression: null});\n    } else {\n      let isGenerator = false;\n      if (this.isPunctuator(this.peek(), \"*\")) {\n        isGenerator = true;\n        this.advance();\n      }\n      let expr = this.enforestExpression();\n      let type = isGenerator ? \"YieldGeneratorExpression\" : \"YieldExpression\";\n      return new Term(type, {expression: expr});\n    }\n  }\n  enforestSyntaxTemplate() {\n    return new Term(\"SyntaxTemplate\", {template: this.advance()});\n  }\n  enforestSyntaxQuote() {\n    let name_180 = this.advance();\n    return new Term(\"SyntaxQuote\", {name: name_180, template: new Term(\"TemplateExpression\", {tag: new Term(\"IdentifierExpression\", {name: name_180}), elements: this.enforestTemplateElements()})});\n  }\n  enforestStaticMemberExpression() {\n    let object_181 = this.term;\n    let dot_182 = this.advance();\n    let property_183 = this.advance();\n    return new Term(\"StaticMemberExpression\", {object: object_181, property: property_183});\n  }\n  enforestArrayExpression() {\n    let arr_184 = this.advance();\n    let elements_185 = [];\n    let enf_186 = new Enforester_46(arr_184.inner(), List(), this.context);\n    while (enf_186.rest.size > 0) {\n      let lookahead = enf_186.peek();\n      if (enf_186.isPunctuator(lookahead, \",\")) {\n        enf_186.advance();\n        elements_185.push(null);\n      } else if (enf_186.isPunctuator(lookahead, \"...\")) {\n        enf_186.advance();\n        let expression = enf_186.enforestExpressionLoop();\n        if (expression == null) {\n          throw enf_186.createError(lookahead, \"expecting expression\");\n        }\n        elements_185.push(new Term(\"SpreadElement\", {expression: expression}));\n      } else {\n        let term = enf_186.enforestExpressionLoop();\n        if (term == null) {\n          throw enf_186.createError(lookahead, \"expected expression\");\n        }\n        elements_185.push(term);\n        enf_186.consumeComma();\n      }\n    }\n    return new Term(\"ArrayExpression\", {elements: List(elements_185)});\n  }\n  enforestObjectExpression() {\n    let obj_187 = this.advance();\n    let properties_188 = List();\n    let enf_189 = new Enforester_46(obj_187.inner(), List(), this.context);\n    let lastProp_190 = null;\n    while (enf_189.rest.size > 0) {\n      let prop = enf_189.enforestPropertyDefinition();\n      enf_189.consumeComma();\n      properties_188 = properties_188.concat(prop);\n      if (lastProp_190 === prop) {\n        throw enf_189.createError(prop, \"invalid syntax in object\");\n      }\n      lastProp_190 = prop;\n    }\n    return new Term(\"ObjectExpression\", {properties: properties_188});\n  }\n  enforestPropertyDefinition() {\n    let {methodOrKey, kind} = this.enforestMethodDefinition();\n    switch (kind) {\n      case \"method\":\n        return methodOrKey;\n      case \"identifier\":\n        if (this.isAssign(this.peek())) {\n          this.advance();\n          let init = this.enforestExpressionLoop();\n          return new Term(\"BindingPropertyIdentifier\", {init: init, binding: this.transformDestructuring(methodOrKey)});\n        } else if (!this.isPunctuator(this.peek(), \":\")) {\n          return new Term(\"ShorthandProperty\", {name: methodOrKey.value});\n        }\n    }\n    this.matchPunctuator(\":\");\n    let expr_191 = this.enforestExpressionLoop();\n    return new Term(\"DataProperty\", {name: methodOrKey, expression: expr_191});\n  }\n  enforestMethodDefinition() {\n    let lookahead_192 = this.peek();\n    let isGenerator_193 = false;\n    if (this.isPunctuator(lookahead_192, \"*\")) {\n      isGenerator_193 = true;\n      this.advance();\n    }\n    if (this.isIdentifier(lookahead_192, \"get\") && this.isPropertyName(this.peek(1))) {\n      this.advance();\n      let {name} = this.enforestPropertyName();\n      this.matchParens();\n      let body = this.matchCurlies();\n      return {methodOrKey: new Term(\"Getter\", {name: name, body: body}), kind: \"method\"};\n    } else if (this.isIdentifier(lookahead_192, \"set\") && this.isPropertyName(this.peek(1))) {\n      this.advance();\n      let {name} = this.enforestPropertyName();\n      let enf = new Enforester_46(this.matchParens(), List(), this.context);\n      let param = enf.enforestBindingElement();\n      let body = this.matchCurlies();\n      return {methodOrKey: new Term(\"Setter\", {name: name, param: param, body: body}), kind: \"method\"};\n    }\n    let {name} = this.enforestPropertyName();\n    if (this.isParens(this.peek())) {\n      let params = this.matchParens();\n      let enf = new Enforester_46(params, List(), this.context);\n      let formalParams = enf.enforestFormalParameters();\n      let body = this.matchCurlies();\n      return {methodOrKey: new Term(\"Method\", {isGenerator: isGenerator_193, name: name, params: formalParams, body: body}), kind: \"method\"};\n    }\n    return {methodOrKey: name, kind: this.isIdentifier(lookahead_192) || this.isKeyword(lookahead_192) ? \"identifier\" : \"property\"};\n  }\n  enforestPropertyName() {\n    let lookahead_194 = this.peek();\n    if (this.isStringLiteral(lookahead_194) || this.isNumericLiteral(lookahead_194)) {\n      return {name: new Term(\"StaticPropertyName\", {value: this.advance()}), binding: null};\n    } else if (this.isBrackets(lookahead_194)) {\n      let enf = new Enforester_46(this.matchSquares(), List(), this.context);\n      let expr = enf.enforestExpressionLoop();\n      return {name: new Term(\"ComputedPropertyName\", {expression: expr}), binding: null};\n    }\n    let name_195 = this.advance();\n    return {name: new Term(\"StaticPropertyName\", {value: name_195}), binding: new Term(\"BindingIdentifier\", {name: name_195})};\n  }\n  enforestFunction({isExpr, inDefault, allowGenerator}) {\n    let name_196 = null, params_197, body_198, rest_199;\n    let isGenerator_200 = false;\n    let fnKeyword_201 = this.advance();\n    let lookahead_202 = this.peek();\n    let type_203 = isExpr ? \"FunctionExpression\" : \"FunctionDeclaration\";\n    if (this.isPunctuator(lookahead_202, \"*\")) {\n      isGenerator_200 = true;\n      this.advance();\n      lookahead_202 = this.peek();\n    }\n    if (!this.isParens(lookahead_202)) {\n      name_196 = this.enforestBindingIdentifier();\n    } else if (inDefault) {\n      name_196 = new Term(\"BindingIdentifier\", {name: Syntax.fromIdentifier(\"*default*\", fnKeyword_201)});\n    }\n    params_197 = this.matchParens();\n    body_198 = this.matchCurlies();\n    let enf_204 = new Enforester_46(params_197, List(), this.context);\n    let formalParams_205 = enf_204.enforestFormalParameters();\n    return new Term(type_203, {name: name_196, isGenerator: isGenerator_200, params: formalParams_205, body: body_198});\n  }\n  enforestFunctionExpression() {\n    let name_206 = null, params_207, body_208, rest_209;\n    let isGenerator_210 = false;\n    this.advance();\n    let lookahead_211 = this.peek();\n    if (this.isPunctuator(lookahead_211, \"*\")) {\n      isGenerator_210 = true;\n      this.advance();\n      lookahead_211 = this.peek();\n    }\n    if (!this.isParens(lookahead_211)) {\n      name_206 = this.enforestBindingIdentifier();\n    }\n    params_207 = this.matchParens();\n    body_208 = this.matchCurlies();\n    let enf_212 = new Enforester_46(params_207, List(), this.context);\n    let formalParams_213 = enf_212.enforestFormalParameters();\n    return new Term(\"FunctionExpression\", {name: name_206, isGenerator: isGenerator_210, params: formalParams_213, body: body_208});\n  }\n  enforestFunctionDeclaration() {\n    let name_214, params_215, body_216, rest_217;\n    let isGenerator_218 = false;\n    this.advance();\n    let lookahead_219 = this.peek();\n    if (this.isPunctuator(lookahead_219, \"*\")) {\n      isGenerator_218 = true;\n      this.advance();\n    }\n    name_214 = this.enforestBindingIdentifier();\n    params_215 = this.matchParens();\n    body_216 = this.matchCurlies();\n    let enf_220 = new Enforester_46(params_215, List(), this.context);\n    let formalParams_221 = enf_220.enforestFormalParameters();\n    return new Term(\"FunctionDeclaration\", {name: name_214, isGenerator: isGenerator_218, params: formalParams_221, body: body_216});\n  }\n  enforestFormalParameters() {\n    let items_222 = [];\n    let rest_223 = null;\n    while (this.rest.size !== 0) {\n      let lookahead = this.peek();\n      if (this.isPunctuator(lookahead, \"...\")) {\n        this.matchPunctuator(\"...\");\n        rest_223 = this.enforestBindingIdentifier();\n        break;\n      }\n      items_222.push(this.enforestParam());\n      this.consumeComma();\n    }\n    return new Term(\"FormalParameters\", {items: List(items_222), rest: rest_223});\n  }\n  enforestParam() {\n    return this.enforestBindingElement();\n  }\n  enforestUpdateExpression() {\n    let operator_224 = this.matchUnaryOperator();\n    return new Term(\"UpdateExpression\", {isPrefix: false, operator: operator_224.val(), operand: this.transformDestructuring(this.term)});\n  }\n  enforestUnaryExpression() {\n    let operator_225 = this.matchUnaryOperator();\n    this.opCtx.stack = this.opCtx.stack.push({prec: this.opCtx.prec, combine: this.opCtx.combine});\n    this.opCtx.prec = 14;\n    this.opCtx.combine = rightTerm_226 => {\n      let type_227, term_228, isPrefix_229;\n      if (operator_225.val() === \"++\" || operator_225.val() === \"--\") {\n        type_227 = \"UpdateExpression\";\n        term_228 = this.transformDestructuring(rightTerm_226);\n        isPrefix_229 = true;\n      } else {\n        type_227 = \"UnaryExpression\";\n        isPrefix_229 = undefined;\n        term_228 = rightTerm_226;\n      }\n      return new Term(type_227, {operator: operator_225.val(), operand: term_228, isPrefix: isPrefix_229});\n    };\n    return EXPR_LOOP_OPERATOR_43;\n  }\n  enforestConditionalExpression() {\n    let test_230 = this.opCtx.combine(this.term);\n    if (this.opCtx.stack.size > 0) {\n      let {prec, combine} = this.opCtx.stack.last();\n      this.opCtx.stack = this.opCtx.stack.pop();\n      this.opCtx.prec = prec;\n      this.opCtx.combine = combine;\n    }\n    this.matchPunctuator(\"?\");\n    let enf_231 = new Enforester_46(this.rest, List(), this.context);\n    let consequent_232 = enf_231.enforestExpressionLoop();\n    enf_231.matchPunctuator(\":\");\n    enf_231 = new Enforester_46(enf_231.rest, List(), this.context);\n    let alternate_233 = enf_231.enforestExpressionLoop();\n    this.rest = enf_231.rest;\n    return new Term(\"ConditionalExpression\", {test: test_230, consequent: consequent_232, alternate: alternate_233});\n  }\n  enforestBinaryExpression() {\n    let leftTerm_234 = this.term;\n    let opStx_235 = this.peek();\n    let op_236 = opStx_235.val();\n    let opPrec_237 = getOperatorPrec(op_236);\n    let opAssoc_238 = getOperatorAssoc(op_236);\n    if (operatorLt(this.opCtx.prec, opPrec_237, opAssoc_238)) {\n      this.opCtx.stack = this.opCtx.stack.push({prec: this.opCtx.prec, combine: this.opCtx.combine});\n      this.opCtx.prec = opPrec_237;\n      this.opCtx.combine = rightTerm_239 => {\n        return new Term(\"BinaryExpression\", {left: leftTerm_234, operator: opStx_235, right: rightTerm_239});\n      };\n      this.advance();\n      return EXPR_LOOP_OPERATOR_43;\n    } else {\n      let term = this.opCtx.combine(leftTerm_234);\n      let {prec, combine} = this.opCtx.stack.last();\n      this.opCtx.stack = this.opCtx.stack.pop();\n      this.opCtx.prec = prec;\n      this.opCtx.combine = combine;\n      return term;\n    }\n  }\n  enforestTemplateElements() {\n    let lookahead_240 = this.matchTemplate();\n    let elements_241 = lookahead_240.token.items.map(it_242 => {\n      if (this.isDelimiter(it_242)) {\n        let enf = new Enforester_46(it_242.inner(), List(), this.context);\n        return enf.enforest(\"expression\");\n      }\n      return new Term(\"TemplateElement\", {rawValue: it_242.slice.text});\n    });\n    return elements_241;\n  }\n  expandMacro() {\n    let lookahead_243 = this.peek();\n    while (this.isCompiletimeTransform(lookahead_243)) {\n      let name = this.advance();\n      let syntaxTransform = this.getFromCompiletimeEnvironment(name);\n      if (syntaxTransform == null || typeof syntaxTransform.value !== \"function\") {\n        throw this.createError(name, \"the macro name was not bound to a value that could be invoked\");\n      }\n      let useSiteScope = freshScope(\"u\");\n      let introducedScope = freshScope(\"i\");\n      this.context.useScope = useSiteScope;\n      let ctx = new MacroContext(this, name, this.context, useSiteScope, introducedScope);\n      let result = sanitizeReplacementValues(syntaxTransform.value.call(null, ctx));\n      if (!List.isList(result)) {\n        throw this.createError(name, \"macro must return a list but got: \" + result);\n      }\n      result = result.map(stx_244 => {\n        if (!(stx_244 && typeof stx_244.addScope === \"function\")) {\n          throw this.createError(name, \"macro must return syntax objects or terms but got: \" + stx_244);\n        }\n        return stx_244.addScope(introducedScope, this.context.bindings, ALL_PHASES, {flip: true});\n      });\n      this.rest = result.concat(ctx._rest(this));\n      lookahead_243 = this.peek();\n    }\n  }\n  consumeSemicolon() {\n    let lookahead_245 = this.peek();\n    if (lookahead_245 && this.isPunctuator(lookahead_245, \";\")) {\n      this.advance();\n    }\n  }\n  consumeComma() {\n    let lookahead_246 = this.peek();\n    if (lookahead_246 && this.isPunctuator(lookahead_246, \",\")) {\n      this.advance();\n    }\n  }\n  safeCheck(obj_247, type_248, val_249 = null) {\n    return obj_247 && (typeof obj_247.match === \"function\" ? obj_247.match(type_248, val_249) : false);\n  }\n  isTerm(term_250) {\n    return term_250 && term_250 instanceof Term;\n  }\n  isEOF(obj_251) {\n    return this.safeCheck(obj_251, \"eof\");\n  }\n  isIdentifier(obj_252, val_253 = null) {\n    return this.safeCheck(obj_252, \"identifier\", val_253);\n  }\n  isPropertyName(obj_254) {\n    return this.isIdentifier(obj_254) || this.isKeyword(obj_254) || this.isNumericLiteral(obj_254) || this.isStringLiteral(obj_254) || this.isBrackets(obj_254);\n  }\n  isNumericLiteral(obj_255, val_256 = null) {\n    return this.safeCheck(obj_255, \"number\", val_256);\n  }\n  isStringLiteral(obj_257, val_258 = null) {\n    return this.safeCheck(obj_257, \"string\", val_258);\n  }\n  isTemplate(obj_259, val_260 = null) {\n    return this.safeCheck(obj_259, \"template\", val_260);\n  }\n  isSyntaxTemplate(obj_261) {\n    return this.safeCheck(obj_261, \"syntaxTemplate\");\n  }\n  isBooleanLiteral(obj_262, val_263 = null) {\n    return this.safeCheck(obj_262, \"boolean\", val_263);\n  }\n  isNullLiteral(obj_264, val_265 = null) {\n    return this.safeCheck(obj_264, \"null\", val_265);\n  }\n  isRegularExpression(obj_266, val_267 = null) {\n    return this.safeCheck(obj_266, \"regularExpression\", val_267);\n  }\n  isDelimiter(obj_268) {\n    return this.safeCheck(obj_268, \"delimiter\");\n  }\n  isParens(obj_269) {\n    return this.safeCheck(obj_269, \"parens\");\n  }\n  isBraces(obj_270) {\n    return this.safeCheck(obj_270, \"braces\");\n  }\n  isBrackets(obj_271) {\n    return this.safeCheck(obj_271, \"brackets\");\n  }\n  isAssign(obj_272, val_273 = null) {\n    return this.safeCheck(obj_272, \"assign\", val_273);\n  }\n  isKeyword(obj_274, val_275 = null) {\n    return this.safeCheck(obj_274, \"keyword\", val_275);\n  }\n  isPunctuator(obj_276, val_277 = null) {\n    return this.safeCheck(obj_276, \"punctuator\", val_277);\n  }\n  isOperator(obj_278) {\n    return (this.safeCheck(obj_278, \"punctuator\") || this.safeCheck(obj_278, \"identifier\") || this.safeCheck(obj_278, \"keyword\")) && isOperator(obj_278);\n  }\n  isUpdateOperator(obj_279) {\n    return this.safeCheck(obj_279, \"punctuator\", \"++\") || this.safeCheck(obj_279, \"punctuator\", \"--\");\n  }\n  safeResolve(obj_280, phase_281) {\n    return obj_280 && typeof obj_280.resolve === \"function\" ? Just_41(obj_280.resolve(phase_281)) : Nothing_42();\n  }\n  isTransform(obj_282, trans_283) {\n    return this.safeResolve(obj_282, this.context.phase).map(name_284 => this.context.env.get(name_284) === trans_283 || this.context.store.get(name_284) === trans_283).getOrElse(false);\n  }\n  isTransformInstance(obj_285, trans_286) {\n    return this.safeResolve(obj_285, this.context.phase).map(name_287 => this.context.env.get(name_287) instanceof trans_286 || this.context.store.get(name_287) instanceof trans_286).getOrElse(false);\n  }\n  isFnDeclTransform(obj_288) {\n    return this.isTransform(obj_288, FunctionDeclTransform);\n  }\n  isVarDeclTransform(obj_289) {\n    return this.isTransform(obj_289, VariableDeclTransform);\n  }\n  isLetDeclTransform(obj_290) {\n    return this.isTransform(obj_290, LetDeclTransform);\n  }\n  isConstDeclTransform(obj_291) {\n    return this.isTransform(obj_291, ConstDeclTransform);\n  }\n  isSyntaxDeclTransform(obj_292) {\n    return this.isTransform(obj_292, SyntaxDeclTransform);\n  }\n  isSyntaxrecDeclTransform(obj_293) {\n    return this.isTransform(obj_293, SyntaxrecDeclTransform);\n  }\n  isSyntaxQuoteTransform(obj_294) {\n    return this.isTransform(obj_294, SyntaxQuoteTransform);\n  }\n  isReturnStmtTransform(obj_295) {\n    return this.isTransform(obj_295, ReturnStatementTransform);\n  }\n  isWhileTransform(obj_296) {\n    return this.isTransform(obj_296, WhileTransform);\n  }\n  isForTransform(obj_297) {\n    return this.isTransform(obj_297, ForTransform);\n  }\n  isSwitchTransform(obj_298) {\n    return this.isTransform(obj_298, SwitchTransform);\n  }\n  isBreakTransform(obj_299) {\n    return this.isTransform(obj_299, BreakTransform);\n  }\n  isContinueTransform(obj_300) {\n    return this.isTransform(obj_300, ContinueTransform);\n  }\n  isDoTransform(obj_301) {\n    return this.isTransform(obj_301, DoTransform);\n  }\n  isDebuggerTransform(obj_302) {\n    return this.isTransform(obj_302, DebuggerTransform);\n  }\n  isWithTransform(obj_303) {\n    return this.isTransform(obj_303, WithTransform);\n  }\n  isTryTransform(obj_304) {\n    return this.isTransform(obj_304, TryTransform);\n  }\n  isThrowTransform(obj_305) {\n    return this.isTransform(obj_305, ThrowTransform);\n  }\n  isIfTransform(obj_306) {\n    return this.isTransform(obj_306, IfTransform);\n  }\n  isNewTransform(obj_307) {\n    return this.isTransform(obj_307, NewTransform);\n  }\n  isCompiletimeTransform(obj_308) {\n    return this.isTransformInstance(obj_308, CompiletimeTransform);\n  }\n  isVarBindingTransform(obj_309) {\n    return this.isTransformInstance(obj_309, VarBindingTransform);\n  }\n  getFromCompiletimeEnvironment(term_310) {\n    if (this.context.env.has(term_310.resolve(this.context.phase))) {\n      return this.context.env.get(term_310.resolve(this.context.phase));\n    }\n    return this.context.store.get(term_310.resolve(this.context.phase));\n  }\n  lineNumberEq(a_311, b_312) {\n    if (!(a_311 && b_312)) {\n      return false;\n    }\n    return a_311.lineNumber() === b_312.lineNumber();\n  }\n  matchIdentifier(val_313) {\n    let lookahead_314 = this.advance();\n    if (this.isIdentifier(lookahead_314)) {\n      return lookahead_314;\n    }\n    throw this.createError(lookahead_314, \"expecting an identifier\");\n  }\n  matchKeyword(val_315) {\n    let lookahead_316 = this.advance();\n    if (this.isKeyword(lookahead_316, val_315)) {\n      return lookahead_316;\n    }\n    throw this.createError(lookahead_316, \"expecting \" + val_315);\n  }\n  matchLiteral() {\n    let lookahead_317 = this.advance();\n    if (this.isNumericLiteral(lookahead_317) || this.isStringLiteral(lookahead_317) || this.isBooleanLiteral(lookahead_317) || this.isNullLiteral(lookahead_317) || this.isTemplate(lookahead_317) || this.isRegularExpression(lookahead_317)) {\n      return lookahead_317;\n    }\n    throw this.createError(lookahead_317, \"expecting a literal\");\n  }\n  matchStringLiteral() {\n    let lookahead_318 = this.advance();\n    if (this.isStringLiteral(lookahead_318)) {\n      return lookahead_318;\n    }\n    throw this.createError(lookahead_318, \"expecting a string literal\");\n  }\n  matchTemplate() {\n    let lookahead_319 = this.advance();\n    if (this.isTemplate(lookahead_319)) {\n      return lookahead_319;\n    }\n    throw this.createError(lookahead_319, \"expecting a template literal\");\n  }\n  matchParens() {\n    let lookahead_320 = this.advance();\n    if (this.isParens(lookahead_320)) {\n      return lookahead_320.inner();\n    }\n    throw this.createError(lookahead_320, \"expecting parens\");\n  }\n  matchCurlies() {\n    let lookahead_321 = this.advance();\n    if (this.isBraces(lookahead_321)) {\n      return lookahead_321.inner();\n    }\n    throw this.createError(lookahead_321, \"expecting curly braces\");\n  }\n  matchSquares() {\n    let lookahead_322 = this.advance();\n    if (this.isBrackets(lookahead_322)) {\n      return lookahead_322.inner();\n    }\n    throw this.createError(lookahead_322, \"expecting sqaure braces\");\n  }\n  matchUnaryOperator() {\n    let lookahead_323 = this.advance();\n    if (isUnaryOperator(lookahead_323)) {\n      return lookahead_323;\n    }\n    throw this.createError(lookahead_323, \"expecting a unary operator\");\n  }\n  matchPunctuator(val_324) {\n    let lookahead_325 = this.advance();\n    if (this.isPunctuator(lookahead_325)) {\n      if (typeof val_324 !== \"undefined\") {\n        if (lookahead_325.val() === val_324) {\n          return lookahead_325;\n        } else {\n          throw this.createError(lookahead_325, \"expecting a \" + val_324 + \" punctuator\");\n        }\n      }\n      return lookahead_325;\n    }\n    throw this.createError(lookahead_325, \"expecting a punctuator\");\n  }\n  createError(stx_326, message_327) {\n    let ctx_328 = \"\";\n    let offending_329 = stx_326;\n    if (this.rest.size > 0) {\n      ctx_328 = this.rest.slice(0, 20).map(term_330 => {\n        if (this.isDelimiter(term_330)) {\n          return term_330.inner();\n        }\n        return List.of(term_330);\n      }).flatten().map(s_331 => {\n        if (s_331 === offending_329) {\n          return \"__\" + s_331.val() + \"__\";\n        }\n        return s_331.val();\n      }).join(\" \");\n    } else {\n      ctx_328 = offending_329.toString();\n    }\n    return new Error(message_327 + \"\\n\" + ctx_328);\n  }\n}\nexport {Enforester_46 as Enforester}"]} + } -/***/ }, -/* 52 */ -/***/ function(module, exports) { + this.eatDecimalLiteralSuffix(); - "use strict"; + if (this.index !== this.source.length && (0, _utils.isIdentifierStart)(this.source.charCodeAt(this.index))) { + throw this.createILLEGAL(); + } - Object.defineProperty(exports, "__esModule", { - value: true - }); - const unaryOperators_558 = { "+": true, "-": true, "!": true, "~": true, "++": true, "--": true, typeof: true, void: true, delete: true }; - const binaryOperatorPrecedence_559 = { "*": 13, "/": 13, "%": 13, "+": 12, "-": 12, ">>": 11, "<<": 11, ">>>": 11, "<": 10, "<=": 10, ">": 10, ">=": 10, in: 10, instanceof: 10, "==": 9, "!=": 9, "===": 9, "!==": 9, "&": 8, "^": 7, "|": 6, "&&": 5, "||": 4 }; - var operatorAssoc_560 = { "*": "left", "/": "left", "%": "left", "+": "left", "-": "left", ">>": "left", "<<": "left", ">>>": "left", "<": "left", "<=": "left", ">": "left", ">=": "left", in: "left", instanceof: "left", "==": "left", "!=": "left", "===": "left", "!==": "left", "&": "left", "^": "left", "|": "left", "&&": "left", "||": "left" }; - function operatorLt_561(left_566, right_567, assoc_568) { - if (assoc_568 === "left") { - return left_566 < right_567; - } else { - return left_566 <= right_567; - } - } - function getOperatorPrec_562(op_569) { - return binaryOperatorPrecedence_559[op_569]; - } - function getOperatorAssoc_563(op_570) { - return operatorAssoc_560[op_570]; - } - function isUnaryOperator_564(op_571) { - return (op_571.match("punctuator") || op_571.match("identifier") || op_571.match("keyword")) && unaryOperators_558.hasOwnProperty(op_571.val()); - } - function isOperator_565(op_572) { - if (op_572.match("punctuator") || op_572.match("identifier") || op_572.match("keyword")) { - return binaryOperatorPrecedence_559.hasOwnProperty(op_572) || unaryOperators_558.hasOwnProperty(op_572.val()); - } - return false; - } - exports.operatorLt = operatorLt_561; - exports.getOperatorPrec = getOperatorPrec_562; - exports.getOperatorAssoc = getOperatorAssoc_563; - exports.isUnaryOperator = isUnaryOperator_564; - exports.isOperator = isOperator_565; - //# sourceMappingURL=data:application/json;base64,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QixjO1FBQ3VCLGUsR0FBdkIsbUI7UUFDd0IsZ0IsR0FBeEIsb0I7UUFDdUIsZSxHQUF2QixtQjtRQUNrQixVLEdBQWxCLGMiLCJmaWxlIjoib3BlcmF0b3JzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgdW5hcnlPcGVyYXRvcnNfNTU4ID0ge1wiK1wiOiB0cnVlLCBcIi1cIjogdHJ1ZSwgXCIhXCI6IHRydWUsIFwiflwiOiB0cnVlLCBcIisrXCI6IHRydWUsIFwiLS1cIjogdHJ1ZSwgdHlwZW9mOiB0cnVlLCB2b2lkOiB0cnVlLCBkZWxldGU6IHRydWV9O1xuY29uc3QgYmluYXJ5T3BlcmF0b3JQcmVjZWRlbmNlXzU1OSA9IHtcIipcIjogMTMsIFwiL1wiOiAxMywgXCIlXCI6IDEzLCBcIitcIjogMTIsIFwiLVwiOiAxMiwgXCI+PlwiOiAxMSwgXCI8PFwiOiAxMSwgXCI+Pj5cIjogMTEsIFwiPFwiOiAxMCwgXCI8PVwiOiAxMCwgXCI+XCI6IDEwLCBcIj49XCI6IDEwLCBpbjogMTAsIGluc3RhbmNlb2Y6IDEwLCBcIj09XCI6IDksIFwiIT1cIjogOSwgXCI9PT1cIjogOSwgXCIhPT1cIjogOSwgXCImXCI6IDgsIFwiXlwiOiA3LCBcInxcIjogNiwgXCImJlwiOiA1LCBcInx8XCI6IDR9O1xudmFyIG9wZXJhdG9yQXNzb2NfNTYwID0ge1wiKlwiOiBcImxlZnRcIiwgXCIvXCI6IFwibGVmdFwiLCBcIiVcIjogXCJsZWZ0XCIsIFwiK1wiOiBcImxlZnRcIiwgXCItXCI6IFwibGVmdFwiLCBcIj4+XCI6IFwibGVmdFwiLCBcIjw8XCI6IFwibGVmdFwiLCBcIj4+PlwiOiBcImxlZnRcIiwgXCI8XCI6IFwibGVmdFwiLCBcIjw9XCI6IFwibGVmdFwiLCBcIj5cIjogXCJsZWZ0XCIsIFwiPj1cIjogXCJsZWZ0XCIsIGluOiBcImxlZnRcIiwgaW5zdGFuY2VvZjogXCJsZWZ0XCIsIFwiPT1cIjogXCJsZWZ0XCIsIFwiIT1cIjogXCJsZWZ0XCIsIFwiPT09XCI6IFwibGVmdFwiLCBcIiE9PVwiOiBcImxlZnRcIiwgXCImXCI6IFwibGVmdFwiLCBcIl5cIjogXCJsZWZ0XCIsIFwifFwiOiBcImxlZnRcIiwgXCImJlwiOiBcImxlZnRcIiwgXCJ8fFwiOiBcImxlZnRcIn07XG5mdW5jdGlvbiBvcGVyYXRvckx0XzU2MShsZWZ0XzU2NiwgcmlnaHRfNTY3LCBhc3NvY181NjgpIHtcbiAgaWYgKGFzc29jXzU2OCA9PT0gXCJsZWZ0XCIpIHtcbiAgICByZXR1cm4gbGVmdF81NjYgPCByaWdodF81Njc7XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIGxlZnRfNTY2IDw9IHJpZ2h0XzU2NztcbiAgfVxufVxuZnVuY3Rpb24gZ2V0T3BlcmF0b3JQcmVjXzU2MihvcF81NjkpIHtcbiAgcmV0dXJuIGJpbmFyeU9wZXJhdG9yUHJlY2VkZW5jZV81NTlbb3BfNTY5XTtcbn1cbmZ1bmN0aW9uIGdldE9wZXJhdG9yQXNzb2NfNTYzKG9wXzU3MCkge1xuICByZXR1cm4gb3BlcmF0b3JBc3NvY181NjBbb3BfNTcwXTtcbn1cbmZ1bmN0aW9uIGlzVW5hcnlPcGVyYXRvcl81NjQob3BfNTcxKSB7XG4gIHJldHVybiAob3BfNTcxLm1hdGNoKFwicHVuY3R1YXRvclwiKSB8fCBvcF81NzEubWF0Y2goXCJpZGVudGlmaWVyXCIpIHx8IG9wXzU3MS5tYXRjaChcImtleXdvcmRcIikpICYmIHVuYXJ5T3BlcmF0b3JzXzU1OC5oYXNPd25Qcm9wZXJ0eShvcF81NzEudmFsKCkpO1xufVxuZnVuY3Rpb24gaXNPcGVyYXRvcl81NjUob3BfNTcyKSB7XG4gIGlmIChvcF81NzIubWF0Y2goXCJwdW5jdHVhdG9yXCIpIHx8IG9wXzU3Mi5tYXRjaChcImlkZW50aWZpZXJcIikgfHwgb3BfNTcyLm1hdGNoKFwia2V5d29yZFwiKSkge1xuICAgIHJldHVybiBiaW5hcnlPcGVyYXRvclByZWNlZGVuY2VfNTU5Lmhhc093blByb3BlcnR5KG9wXzU3MikgfHwgdW5hcnlPcGVyYXRvcnNfNTU4Lmhhc093blByb3BlcnR5KG9wXzU3Mi52YWwoKSk7XG4gIH1cbiAgcmV0dXJuIGZhbHNlO1xufVxuZXhwb3J0IHtvcGVyYXRvckx0XzU2MSBhcyBvcGVyYXRvckx0fTtcbmV4cG9ydCB7Z2V0T3BlcmF0b3JQcmVjXzU2MiBhcyBnZXRPcGVyYXRvclByZWN9O1xuZXhwb3J0IHtnZXRPcGVyYXRvckFzc29jXzU2MyBhcyBnZXRPcGVyYXRvckFzc29jfTtcbmV4cG9ydCB7aXNVbmFyeU9wZXJhdG9yXzU2NCBhcyBpc1VuYXJ5T3BlcmF0b3J9O1xuZXhwb3J0IHtpc09wZXJhdG9yXzU2NSBhcyBpc09wZXJhdG9yfSJdfQ== + var slice = this.getSlice(start, startLocation); + return { + type: TokenType.NUMBER, + value: +slice.text, + slice: slice, + octal: false, + noctal: false + }; + } + }, { + key: "eatDecimalLiteralSuffix", + value: function eatDecimalLiteralSuffix() { + var ch = this.source.charAt(this.index); + if (ch === ".") { + this.index++; + if (this.index === this.source.length) { + return; + } -/***/ }, -/* 53 */ -/***/ function(module, exports, __webpack_require__) { + ch = this.source.charAt(this.index); + while ("0" <= ch && ch <= "9") { + this.index++; + if (this.index === this.source.length) { + return; + } + ch = this.source.charAt(this.index); + } + } - "use strict"; + // EOF not reached here + if (ch === "e" || ch === "E") { + this.index++; + if (this.index === this.source.length) { + throw this.createILLEGAL(); + } - Object.defineProperty(exports, "__esModule", { - value: true - }); - exports.evalCompiletimeValue = exports.evalRuntimeValues = exports.sanitizeReplacementValues = undefined; + ch = this.source.charAt(this.index); + if (ch === "+" || ch === "-") { + this.index++; + if (this.index === this.source.length) { + throw this.createILLEGAL(); + } + ch = this.source.charAt(this.index); + } - var _termExpander = __webpack_require__(54); + if ("0" <= ch && ch <= "9") { + while ("0" <= ch && ch <= "9") { + this.index++; + if (this.index === this.source.length) { + break; + } + ch = this.source.charAt(this.index); + } + } else { + throw this.createILLEGAL(); + } + } + } + }, { + key: "scanStringEscape", + value: function scanStringEscape(str, octal) { + this.index++; + if (this.index === this.source.length) { + throw this.createILLEGAL(); + } + var ch = this.source.charAt(this.index); + if (!(0, _utils.isLineTerminator)(ch.charCodeAt(0))) { + switch (ch) { + case "n": + str += "\n"; + this.index++; + break; + case "r": + str += "\r"; + this.index++; + break; + case "t": + str += "\t"; + this.index++; + break; + case "u": + case "x": + var unescaped = void 0; + this.index++; + if (this.index >= this.source.length) { + throw this.createILLEGAL(); + } + unescaped = ch === "u" ? this.scanUnicode() : this.scanHexEscape2(); + if (unescaped < 0) { + throw this.createILLEGAL(); + } + str += fromCodePoint(unescaped); + break; + case "b": + str += "\b"; + this.index++; + break; + case "f": + str += "\f"; + this.index++; + break; + case "v": + str += "\u000b"; + this.index++; + break; + default: + if ("0" <= ch && ch <= "7") { + var octalStart = this.index; + var octLen = 1; + // 3 digits are only allowed when string starts + // with 0, 1, 2, 3 + if ("0" <= ch && ch <= "3") { + octLen = 0; + } + var code = 0; + while (octLen < 3 && "0" <= ch && ch <= "7") { + this.index++; + if (octLen > 0 || ch !== "0") { + octal = this.source.slice(octalStart, this.index); + } + code *= 8; + code += ch - "0"; + octLen++; + if (this.index === this.source.length) { + throw this.createILLEGAL(); + } + ch = this.source.charAt(this.index); + } + str += String.fromCharCode(code); + } else if (ch === "8" || ch === "9") { + throw this.createILLEGAL(); + } else { + str += ch; + this.index++; + } + } + } else { + this.index++; + if (ch === "\r" && this.source.charAt(this.index) === "\n") { + this.index++; + } + this.lineStart = this.index; + this.line++; + } + return [str, octal]; + } + // 7.8.4 String Literals - var _termExpander2 = _interopRequireDefault(_termExpander); + }, { + key: "scanStringLiteral", + value: function scanStringLiteral() { + var str = ""; - var _immutable = __webpack_require__(11); + var quote = this.source.charAt(this.index); + // assert((quote === "\"" || quote === """), "String literal must starts with a quote") - var _parseReducer = __webpack_require__(37); + var startLocation = this.getLocation(); + var start = this.index; + this.index++; - var _parseReducer2 = _interopRequireDefault(_parseReducer); + var octal = null; + while (this.index < this.source.length) { + var ch = this.source.charAt(this.index); + if (ch === quote) { + this.index++; + return { type: TokenType.STRING, slice: this.getSlice(start, startLocation), str: str, octal: octal }; + } else if (ch === "\\") { + var _scanStringEscape = this.scanStringEscape(str, octal); - var _shiftReducer = __webpack_require__(33); + var _scanStringEscape2 = _slicedToArray(_scanStringEscape, 2); - var _shiftReducer2 = _interopRequireDefault(_shiftReducer); + str = _scanStringEscape2[0]; + octal = _scanStringEscape2[1]; + } else if ((0, _utils.isLineTerminator)(ch.charCodeAt(0))) { + throw this.createILLEGAL(); + } else { + str += ch; + this.index++; + } + } - var _serializer = __webpack_require__(57); + throw this.createILLEGAL(); + } + }, { + key: "scanTemplateElement", + value: function scanTemplateElement() { + var startLocation = this.getLocation(); + var start = this.index; + this.index++; + while (this.index < this.source.length) { + var ch = this.source.charCodeAt(this.index); + switch (ch) { + case 0x60: + // ` + this.index++; + return { type: TokenType.TEMPLATE, tail: true, slice: this.getSlice(start, startLocation) }; + case 0x24: + // $ + if (this.source.charCodeAt(this.index + 1) === 0x7B) { + // { + this.index += 2; + return { type: TokenType.TEMPLATE, tail: false, slice: this.getSlice(start, startLocation) }; + } + this.index++; + break; + case 0x5C: + // \\ + { + var octal = this.scanStringEscape("", null)[1]; + if (octal != null) { + throw this.createILLEGAL(); + } + break; + } + default: + this.index++; + } + } - var _syntax = __webpack_require__(12); + throw this.createILLEGAL(); + } + }, { + key: "scanRegExp", + value: function scanRegExp(str) { + var startLocation = this.getLocation(); + var start = this.index; - var _syntax2 = _interopRequireDefault(_syntax); + var terminated = false; + var classMarker = false; + while (this.index < this.source.length) { + var ch = this.source.charAt(this.index); + if (ch === "\\") { + str += ch; + this.index++; + ch = this.source.charAt(this.index); + // ECMA-262 7.8.5 + if ((0, _utils.isLineTerminator)(ch.charCodeAt(0))) { + throw this.createError(_errors.ErrorMessages.UNTERMINATED_REGEXP); + } + str += ch; + this.index++; + } else if ((0, _utils.isLineTerminator)(ch.charCodeAt(0))) { + throw this.createError(_errors.ErrorMessages.UNTERMINATED_REGEXP); + } else { + if (classMarker) { + if (ch === "]") { + classMarker = false; + } + } else { + if (ch === "/") { + terminated = true; + str += ch; + this.index++; + break; + } else if (ch === "[") { + classMarker = true; + } + } + str += ch; + this.index++; + } + } - var _shiftCodegen = __webpack_require__(38); + if (!terminated) { + throw this.createError(_errors.ErrorMessages.UNTERMINATED_REGEXP); + } - var _shiftCodegen2 = _interopRequireDefault(_shiftCodegen); + while (this.index < this.source.length) { + var _ch3 = this.source.charAt(this.index); + if (_ch3 === "\\") { + throw this.createError(_errors.ErrorMessages.INVALID_REGEXP_FLAGS); + } + if (!(0, _utils.isIdentifierPart)(_ch3.charCodeAt(0))) { + break; + } + this.index++; + str += _ch3; + } + return { type: TokenType.REGEXP, value: str, slice: this.getSlice(start, startLocation) }; + } + }, { + key: "advance", + value: function advance() { + var startLocation = this.getLocation(); - var _transforms = __webpack_require__(32); + this.lastIndex = this.index; + this.lastLine = this.line; + this.lastLineStart = this.lineStart; - var _terms = __webpack_require__(28); + this.skipComment(); - var _terms2 = _interopRequireDefault(_terms); + this.startIndex = this.index; + this.startLine = this.line; + this.startLineStart = this.lineStart; - var _shiftReader = __webpack_require__(3); + if (this.lastIndex === 0) { + this.lastIndex = this.index; + this.lastLine = this.line; + this.lastLineStart = this.lineStart; + } - var _shiftReader2 = _interopRequireDefault(_shiftReader); + if (this.index >= this.source.length) { + return { type: TokenType.EOS, slice: this.getSlice(this.index, startLocation) }; + } - var _macroContext = __webpack_require__(65); + var charCode = this.source.charCodeAt(this.index); - var _templateProcessor = __webpack_require__(63); + if (charCode < 0x80) { + if (PUNCTUATOR_START[charCode]) { + return this.scanPunctuator(); + } - var _vm = __webpack_require__(48); + if ((0, _utils.isIdentifierStart)(charCode) || charCode === 0x5C /* backslash (\) */) { + return this.scanIdentifier(); + } - var _vm2 = _interopRequireDefault(_vm); + // Dot (.) U+002E can also start a floating-point number, hence the need + // to check the next character. + if (charCode === 0x2E) { + if (this.index + 1 < this.source.length && (0, _utils.isDecimalDigit)(this.source.charCodeAt(this.index + 1))) { + return this.scanNumericLiteral(); + } + return this.scanPunctuator(); + } - var _ramda = __webpack_require__(27); + // String literal starts with single quote (U+0027) or double quote (U+0022). + if (charCode === 0x27 || charCode === 0x22) { + return this.scanStringLiteral(); + } - var _ = _interopRequireWildcard(_ramda); + // Template literal starts with back quote (U+0060) + if (charCode === 0x60) { + return this.scanTemplateElement(); + } - function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + if (0x30 /* "0" */ <= charCode && charCode <= 0x39 /* "9" */) { + return this.scanNumericLiteral(); + } - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + // Slash (/) U+002F can also start a regex. + throw this.createILLEGAL(); + } else { + if ((0, _utils.isIdentifierStart)(charCode) || 0xD800 <= charCode && charCode <= 0xDBFF) { + return this.scanIdentifier(); + } - let geval_361 = eval; - function sanitizeReplacementValues_362(values_365) { - if (Array.isArray(values_365)) { - return sanitizeReplacementValues_362((0, _immutable.List)(values_365)); - } else if (_immutable.List.isList(values_365)) { - return values_365.map(sanitizeReplacementValues_362); - } else if (values_365 == null) { - throw new Error("replacement values for syntax template must not be null or undefined"); - } else if (typeof values_365.next === "function") { - return sanitizeReplacementValues_362((0, _immutable.List)(values_365)); - } - return (0, _macroContext.unwrap)(values_365); - } - function evalRuntimeValues_363(terms_366, context_367) { - let prepped_368 = terms_366.reduce((acc_374, term_375) => { - let result_376 = (0, _immutable.List)(); - if ((0, _terms.isExport)(term_375)) { - if ((0, _terms.isVariableDeclaration)(term_375.declaration)) { - return acc_374.concat(new _terms2.default("VariableDeclarationStatement", { declaration: term_375.declaration })).concat(term_375.declaration.declarators.map(decl_377 => { - return new _terms2.default("ExpressionStatement", { expression: new _terms2.default("AssignmentExpression", { binding: new _terms2.default("StaticMemberExpression", { object: new _terms2.default("IdentifierExpression", { name: _syntax2.default.fromIdentifier("exports") }), property: decl_377.binding.name }), expression: new _terms2.default("IdentifierExpression", { name: decl_377.binding.name }) }) }); - })); + throw this.createILLEGAL(); } - } else if ((0, _terms.isImport)(term_375)) { - return acc_374; } - return acc_374.concat(term_375); - }, (0, _immutable.List)()); - let parsed_369 = (0, _shiftReducer2.default)(new _parseReducer2.default(context_367, false), new _terms2.default("Module", { directives: (0, _immutable.List)(), items: prepped_368 }).gen({ includeImports: false })); - let gen_370 = (0, _shiftCodegen2.default)(parsed_369, new _shiftCodegen.FormattedCodeGen()); - let result_371 = context_367.transform(gen_370, { babelrc: true, filename: context_367.filename }); - let exportsObj_372 = {}; - context_367.store.set("exports", exportsObj_372); - let val_373 = _vm2.default.runInContext(result_371.code, context_367.store.getNodeContext()); - return exportsObj_372; - } - function evalCompiletimeValue_364(expr_378, context_379) { - let deserializer_380 = (0, _serializer.makeDeserializer)(context_379.bindings); - let sandbox_381 = { syntaxQuote: function syntaxQuote(strings_389) { - for (var _len = arguments.length, values_388 = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - values_388[_key - 1] = arguments[_key]; - } - - let ctx_390 = deserializer_380.read(_.last(values_388)); - let reader_391 = new _shiftReader2.default(strings_389, ctx_390, _.take(values_388.length - 1, values_388)); - return reader_391.read(); - }, syntaxTemplate: function syntaxTemplate(str_393) { - for (var _len2 = arguments.length, values_392 = Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { - values_392[_key2 - 1] = arguments[_key2]; - } - - return (0, _templateProcessor.replaceTemplate)(deserializer_380.read(str_393), sanitizeReplacementValues_362(values_392)); - } }; - let sandboxKeys_382 = (0, _immutable.List)(Object.keys(sandbox_381)); - let sandboxVals_383 = sandboxKeys_382.map(k_394 => sandbox_381[k_394]).toArray(); - let parsed_384 = (0, _shiftReducer2.default)(new _parseReducer2.default(context_379), new _terms2.default("Module", { directives: (0, _immutable.List)(), items: _immutable.List.of(new _terms2.default("ExpressionStatement", { expression: new _terms2.default("FunctionExpression", { isGenerator: false, name: null, params: new _terms2.default("FormalParameters", { items: sandboxKeys_382.map(param_395 => { - return new _terms2.default("BindingIdentifier", { name: _syntax2.default.from("identifier", param_395) }); - }), rest: null }), body: new _terms2.default("FunctionBody", { directives: _immutable.List.of(new _terms2.default("Directive", { rawValue: "use strict" })), statements: _immutable.List.of(new _terms2.default("ReturnStatement", { expression: expr_378 })) }) }) })) })); - let gen_385 = (0, _shiftCodegen2.default)(parsed_384, new _shiftCodegen.FormattedCodeGen()); - let result_386 = context_379.transform(gen_385, { babelrc: true, filename: context_379.filename }); - let val_387 = _vm2.default.runInContext(result_386.code, context_379.store.getNodeContext()); - return val_387.apply(undefined, sandboxVals_383); - } - exports.sanitizeReplacementValues = sanitizeReplacementValues_362; - exports.evalRuntimeValues = evalRuntimeValues_363; - exports.evalCompiletimeValue = evalCompiletimeValue_364; - //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/load-syntax.js"],"names":[],"mappings":"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","file":"load-syntax.js","sourcesContent":["import TermExpander from \"./term-expander\";\nimport {List} from \"immutable\";\nimport ParseReducer from \"./parse-reducer.js\";\nimport reducer, {MonoidalReducer} from \"shift-reducer\";\nimport {makeDeserializer} from \"./serializer\";\nimport Syntax from \"./syntax\";\nimport codegen, {FormattedCodeGen} from \"shift-codegen\";\nimport {VarBindingTransform, CompiletimeTransform} from \"./transforms\";\nimport Term, {isEOF, isBindingIdentifier, isFunctionDeclaration, isFunctionExpression, isFunctionTerm, isFunctionWithName, isSyntaxDeclaration, isVariableDeclaration, isVariableDeclarationStatement, isImport, isExport} from \"./terms\";\nimport Reader from \"./shift-reader\";\nimport {unwrap} from \"./macro-context\";\nimport {replaceTemplate} from \"./template-processor\";\nimport vm from \"vm\";\nimport  * as _ from \"ramda\";\nlet geval_361 = eval;\nfunction sanitizeReplacementValues_362(values_365) {\n  if (Array.isArray(values_365)) {\n    return sanitizeReplacementValues_362(List(values_365));\n  } else if (List.isList(values_365)) {\n    return values_365.map(sanitizeReplacementValues_362);\n  } else if (values_365 == null) {\n    throw new Error(\"replacement values for syntax template must not be null or undefined\");\n  } else if (typeof values_365.next === \"function\") {\n    return sanitizeReplacementValues_362(List(values_365));\n  }\n  return unwrap(values_365);\n}\nfunction evalRuntimeValues_363(terms_366, context_367) {\n  let prepped_368 = terms_366.reduce((acc_374, term_375) => {\n    let result_376 = List();\n    if (isExport(term_375)) {\n      if (isVariableDeclaration(term_375.declaration)) {\n        return acc_374.concat(new Term(\"VariableDeclarationStatement\", {declaration: term_375.declaration})).concat(term_375.declaration.declarators.map(decl_377 => {\n          return new Term(\"ExpressionStatement\", {expression: new Term(\"AssignmentExpression\", {binding: new Term(\"StaticMemberExpression\", {object: new Term(\"IdentifierExpression\", {name: Syntax.fromIdentifier(\"exports\")}), property: decl_377.binding.name}), expression: new Term(\"IdentifierExpression\", {name: decl_377.binding.name})})});\n        }));\n      }\n    } else if (isImport(term_375)) {\n      return acc_374;\n    }\n    return acc_374.concat(term_375);\n  }, List());\n  let parsed_369 = reducer(new ParseReducer(context_367, false), new Term(\"Module\", {directives: List(), items: prepped_368}).gen({includeImports: false}));\n  let gen_370 = codegen(parsed_369, new FormattedCodeGen);\n  let result_371 = context_367.transform(gen_370, {babelrc: true, filename: context_367.filename});\n  let exportsObj_372 = {};\n  context_367.store.set(\"exports\", exportsObj_372);\n  let val_373 = vm.runInContext(result_371.code, context_367.store.getNodeContext());\n  return exportsObj_372;\n}\nfunction evalCompiletimeValue_364(expr_378, context_379) {\n  let deserializer_380 = makeDeserializer(context_379.bindings);\n  let sandbox_381 = {syntaxQuote: function (strings_389, ...values_388) {\n    let ctx_390 = deserializer_380.read(_.last(values_388));\n    let reader_391 = new Reader(strings_389, ctx_390, _.take(values_388.length - 1, values_388));\n    return reader_391.read();\n  }, syntaxTemplate: function (str_393, ...values_392) {\n    return replaceTemplate(deserializer_380.read(str_393), sanitizeReplacementValues_362(values_392));\n  }};\n  let sandboxKeys_382 = List(Object.keys(sandbox_381));\n  let sandboxVals_383 = sandboxKeys_382.map(k_394 => sandbox_381[k_394]).toArray();\n  let parsed_384 = reducer(new ParseReducer(context_379), new Term(\"Module\", {directives: List(), items: List.of(new Term(\"ExpressionStatement\", {expression: new Term(\"FunctionExpression\", {isGenerator: false, name: null, params: new Term(\"FormalParameters\", {items: sandboxKeys_382.map(param_395 => {\n    return new Term(\"BindingIdentifier\", {name: Syntax.from(\"identifier\", param_395)});\n  }), rest: null}), body: new Term(\"FunctionBody\", {directives: List.of(new Term(\"Directive\", {rawValue: \"use strict\"})), statements: List.of(new Term(\"ReturnStatement\", {expression: expr_378}))})})}))}));\n  let gen_385 = codegen(parsed_384, new FormattedCodeGen);\n  let result_386 = context_379.transform(gen_385, {babelrc: true, filename: context_379.filename});\n  let val_387 = vm.runInContext(result_386.code, context_379.store.getNodeContext());\n  return val_387.apply(undefined, sandboxVals_383);\n}\nexport {sanitizeReplacementValues_362 as sanitizeReplacementValues};\nexport {evalRuntimeValues_363 as evalRuntimeValues};\nexport {evalCompiletimeValue_364 as evalCompiletimeValue}"]} + }, { + key: "eof", + value: function eof() { + return this.lookahead.type === TokenType.EOS; + } + }, { + key: "lex", + value: function lex() { + var prevToken = this.lookahead; + this.lookahead = this.advance(); + this.tokenIndex++; + return prevToken; + } + }], [{ + key: "cse2", + value: function cse2(id, ch1, ch2) { + return id.charAt(1) === ch1 && id.charAt(2) === ch2; + } + }, { + key: "cse3", + value: function cse3(id, ch1, ch2, ch3) { + return id.charAt(1) === ch1 && id.charAt(2) === ch2 && id.charAt(3) === ch3; + } + }, { + key: "cse4", + value: function cse4(id, ch1, ch2, ch3, ch4) { + return id.charAt(1) === ch1 && id.charAt(2) === ch2 && id.charAt(3) === ch3 && id.charAt(4) === ch4; + } + }, { + key: "cse5", + value: function cse5(id, ch1, ch2, ch3, ch4, ch5) { + return id.charAt(1) === ch1 && id.charAt(2) === ch2 && id.charAt(3) === ch3 && id.charAt(4) === ch4 && id.charAt(5) === ch5; + } + }, { + key: "cse6", + value: function cse6(id, ch1, ch2, ch3, ch4, ch5, ch6) { + return id.charAt(1) === ch1 && id.charAt(2) === ch2 && id.charAt(3) === ch3 && id.charAt(4) === ch4 && id.charAt(5) === ch5 && id.charAt(6) === ch6; + } + }, { + key: "cse7", + value: function cse7(id, ch1, ch2, ch3, ch4, ch5, ch6, ch7) { + return id.charAt(1) === ch1 && id.charAt(2) === ch2 && id.charAt(3) === ch3 && id.charAt(4) === ch4 && id.charAt(5) === ch5 && id.charAt(6) === ch6 && id.charAt(7) === ch7; + } + }]); -/***/ }, -/* 54 */ -/***/ function(module, exports, __webpack_require__) { + return Tokenizer; + }(); + + exports.default = Tokenizer; + +/***/ }, +/* 44 */ +/***/ function(module, exports, __webpack_require__) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); + exports.isDecimalDigit = exports.isLineTerminator = exports.isWhiteSpace = exports.isIdentifierPart = exports.isIdentifierStart = exports.isRestrictedWord = undefined; + exports.isStrictModeReservedWord = isStrictModeReservedWord; + exports.getHexValue = getHexValue; - var _immutable = __webpack_require__(11); + var _esutils = __webpack_require__(15); - var _terms = __webpack_require__(28); + var isReservedWordES6 = _esutils.keyword.isReservedWordES6; /** + * Copyright 2014 Shape Security, Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License") + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ - var _terms2 = _interopRequireDefault(_terms); + var isRestrictedWord = _esutils.keyword.isRestrictedWord; + var isIdentifierStartES6 = _esutils.code.isIdentifierStartES6; + var isIdentifierPartES6 = _esutils.code.isIdentifierPartES6; + var isWhiteSpace = _esutils.code.isWhiteSpace; + var isLineTerminator = _esutils.code.isLineTerminator; + var isDecimalDigit = _esutils.code.isDecimalDigit; + exports.isRestrictedWord = isRestrictedWord; + exports.isIdentifierStart = isIdentifierStartES6; + exports.isIdentifierPart = isIdentifierPartES6; + exports.isWhiteSpace = isWhiteSpace; + exports.isLineTerminator = isLineTerminator; + exports.isDecimalDigit = isDecimalDigit; + function isStrictModeReservedWord(id) { + return isReservedWordES6(id, true); + } + + function getHexValue(rune) { + if ("0" <= rune && rune <= "9") { + return rune.charCodeAt(0) - 48; + } + if ("a" <= rune && rune <= "f") { + return rune.charCodeAt(0) - 87; + } + if ("A" <= rune && rune <= "F") { + return rune.charCodeAt(0) - 55; + } + return -1; + } - var _scope = __webpack_require__(44); +/***/ }, +/* 45 */ +/***/ function(module, exports) { - var _applyScopeInParamsReducer = __webpack_require__(55); + "use strict"; - var _applyScopeInParamsReducer2 = _interopRequireDefault(_applyScopeInParamsReducer); + Object.defineProperty(exports, "__esModule", { + value: true + }); + /** + * Copyright 2014 Shape Security, Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License") + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + + var ErrorMessages = exports.ErrorMessages = { + UNEXPECTED_TOKEN: "Unexpected token {0}", + UNEXPECTED_ILLEGAL_TOKEN: "Unexpected {0}", + UNEXPECTED_NUMBER: "Unexpected number", + UNEXPECTED_STRING: "Unexpected string", + UNEXPECTED_IDENTIFIER: "Unexpected identifier", + UNEXPECTED_RESERVED_WORD: "Unexpected reserved word", + UNEXPECTED_TEMPLATE: "Unexpected template", + UNEXPECTED_EOS: "Unexpected end of input", + UNEXPECTED_LINE_TERMINATOR: "Unexpected line terminator", + NEWLINE_AFTER_THROW: "Illegal newline after throw", + UNTERMINATED_REGEXP: "Invalid regular expression: missing /", + INVALID_REGEXP_FLAGS: "Invalid regular expression flags", + INVALID_LHS_IN_ASSIGNMENT: "Invalid left-hand side in assignment", + INVALID_LHS_IN_FOR_IN: "Invalid left-hand side in for-in", + INVALID_LHS_IN_FOR_OF: "Invalid left-hand side in for-of", + INVALID_UPDATE_OPERAND: "Increment/decrement target must be an identifier or member expression", + MULTIPLE_DEFAULTS_IN_SWITCH: "More than one default clause in switch statement", + NO_CATCH_OR_FINALLY: "Missing catch or finally after try", + ILLEGAL_RETURN: "Illegal return statement", + ILLEGAL_ARROW_FUNCTION_PARAMS: "Illegal arrow function parameter list", + INVALID_VAR_INIT_FOR_IN: "Invalid variable declaration in for-in statement", + INVALID_VAR_INIT_FOR_OF: "Invalid variable declaration in for-of statement", + ILLEGAL_PROPERTY: "Illegal property initializer" + }; - var _shiftReducer = __webpack_require__(33); +/***/ }, +/* 46 */ +/***/ function(module, exports, __webpack_require__) { - var _shiftReducer2 = _interopRequireDefault(_shiftReducer); + "use strict"; - var _compiler = __webpack_require__(56); + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.ALL_PHASES = exports.Types = undefined; - var _compiler2 = _interopRequireDefault(_compiler); + var _immutable = __webpack_require__(3); - var _syntax = __webpack_require__(12); + var _errors = __webpack_require__(23); - var _syntax2 = _interopRequireDefault(_syntax); + var _bindingMap = __webpack_require__(22); - var _serializer = __webpack_require__(57); + var _bindingMap2 = _interopRequireDefault(_bindingMap); - var _enforester = __webpack_require__(51); + var _ramdaFantasy = __webpack_require__(24); - var _errors = __webpack_require__(13); + var _ramda = __webpack_require__(10); - var _templateProcessor = __webpack_require__(63); + var _ = _interopRequireWildcard(_ramda); - var _astDispatcher = __webpack_require__(64); + var _tokenizer = __webpack_require__(43); - var _astDispatcher2 = _interopRequireDefault(_astDispatcher); + function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - class TermExpander extends _astDispatcher2.default { - constructor(context_999) { - super("expand", true); - this.context = context_999; - } - expand(term_1000) { - return this.dispatch(term_1000); - } - expandPragma(term_1001) { - return term_1001; - } - expandTemplateExpression(term_1002) { - return new _terms2.default("TemplateExpression", { tag: term_1002.tag == null ? null : this.expand(term_1002.tag), elements: term_1002.elements.toArray() }); - } - expandBreakStatement(term_1003) { - return new _terms2.default("BreakStatement", { label: term_1003.label ? term_1003.label.val() : null }); - } - expandDoWhileStatement(term_1004) { - return new _terms2.default("DoWhileStatement", { body: this.expand(term_1004.body), test: this.expand(term_1004.test) }); - } - expandWithStatement(term_1005) { - return new _terms2.default("WithStatement", { body: this.expand(term_1005.body), object: this.expand(term_1005.object) }); - } - expandDebuggerStatement(term_1006) { - return term_1006; - } - expandContinueStatement(term_1007) { - return new _terms2.default("ContinueStatement", { label: term_1007.label ? term_1007.label.val() : null }); + function getFirstSlice(stx) { + if (!stx || typeof stx.isDelimiter !== 'function') return null; // TODO: should not have to do this + if (!stx.isDelimiter()) { + return stx.token.slice; } - expandSwitchStatementWithDefault(term_1008) { - return new _terms2.default("SwitchStatementWithDefault", { discriminant: this.expand(term_1008.discriminant), preDefaultCases: term_1008.preDefaultCases.map(c_1009 => this.expand(c_1009)).toArray(), defaultCase: this.expand(term_1008.defaultCase), postDefaultCases: term_1008.postDefaultCases.map(c_1010 => this.expand(c_1010)).toArray() }); + return stx.token.get(0).token.slice; + } + + function sizeDecending(a, b) { + if (a.scopes.size > b.scopes.size) { + return -1; + } else if (b.scopes.size > a.scopes.size) { + return 1; + } else { + return 0; } - expandComputedMemberExpression(term_1011) { - return new _terms2.default("ComputedMemberExpression", { object: this.expand(term_1011.object), expression: this.expand(term_1011.expression) }); + } + + let Types = exports.Types = { + null: { + match: token => !Types.delimiter.match(token) && token.type === _tokenizer.TokenType.NULL, + create: (value, stx) => new Syntax({ + type: _tokenizer.TokenType.NULL, + value: null + }, stx) + }, + number: { + match: token => !Types.delimiter.match(token) && token.type.klass === _tokenizer.TokenClass.NumericLiteral, + create: (value, stx) => new Syntax({ + type: _tokenizer.TokenType.NUMBER, + value: value + }, stx) + }, + string: { + match: token => !Types.delimiter.match(token) && token.type.klass === _tokenizer.TokenClass.StringLiteral, + create: (value, stx) => new Syntax({ + type: _tokenizer.TokenType.STRING, + str: value + }, stx) + }, + punctuator: { + match: token => !Types.delimiter.match(token) && token.type.klass === _tokenizer.TokenClass.Punctuator, + create: (value, stx) => new Syntax({ + type: { + klass: _tokenizer.TokenClass.Punctuator, + name: value + }, + value: value + }, stx) + }, + keyword: { + match: token => !Types.delimiter.match(token) && token.type.klass === _tokenizer.TokenClass.Keyword, + create: (value, stx) => new Syntax({ + type: { + klass: _tokenizer.TokenClass.Keyword, + name: value + }, + value: value + }, stx) + }, + identifier: { + match: token => !Types.delimiter.match(token) && token.type.klass === _tokenizer.TokenClass.Ident, + create: (value, stx) => new Syntax({ + type: _tokenizer.TokenType.IDENTIFIER, + value: value + }, stx) + }, + regularExpression: { + match: token => !Types.delimiter.match(token) && token.type.klass === _tokenizer.TokenClass.RegularExpression, + create: (value, stx) => new Syntax({ + type: _tokenizer.TokenType.REGEXP, + value: value + }, stx) + }, + braces: { + match: token => Types.delimiter.match(token) && token.get(0).token.type === _tokenizer.TokenType.LBRACE, + create: (inner, stx) => { + let left = new Syntax({ + type: _tokenizer.TokenType.LBRACE, + value: "{", + slice: getFirstSlice(stx) + }); + let right = new Syntax({ + type: _tokenizer.TokenType.RBRACE, + value: "}", + slice: getFirstSlice(stx) + }); + return new Syntax(_immutable.List.of(left).concat(inner).push(right), stx); + } + }, + brackets: { + match: token => Types.delimiter.match(token) && token.get(0).token.type === _tokenizer.TokenType.LBRACK, + create: (inner, stx) => { + let left = new Syntax({ + type: _tokenizer.TokenType.LBRACK, + value: "[", + slice: getFirstSlice(stx) + }); + let right = new Syntax({ + type: _tokenizer.TokenType.RBRACK, + value: "]", + slice: getFirstSlice(stx) + }); + return new Syntax(_immutable.List.of(left).concat(inner).push(right), stx); + } + }, + parens: { + match: token => Types.delimiter.match(token) && token.get(0).token.type === _tokenizer.TokenType.LPAREN, + create: (inner, stx) => { + let left = new Syntax({ + type: _tokenizer.TokenType.LPAREN, + value: "(", + slice: getFirstSlice(stx) + }); + let right = new Syntax({ + type: _tokenizer.TokenType.RPAREN, + value: ")", + slice: getFirstSlice(stx) + }); + return new Syntax(_immutable.List.of(left).concat(inner).push(right), stx); + } + }, + + assign: { + match: token => { + if (Types.punctuator.match(token)) { + switch (token.value) { + case "=": + case "|=": + case "^=": + case "&=": + case "<<=": + case ">>=": + case ">>>=": + case "+=": + case "-=": + case "*=": + case "/=": + case "%=": + return true; + default: + return false; + } + } + return false; + } + }, + + boolean: { + match: token => !Types.delimiter.match(token) && token.type === _tokenizer.TokenType.TRUE || token.type === _tokenizer.TokenType.FALSE + }, + + template: { + match: token => !Types.delimiter.match(token) && token.type === _tokenizer.TokenType.TEMPLATE + }, + + delimiter: { + match: token => _immutable.List.isList(token) + }, + + syntaxTemplate: { + match: token => Types.delimiter.match(token) && token.get(0).val() === '#`' + }, + + eof: { + match: token => !Types.delimiter.match(token) && token.type === _tokenizer.TokenType.EOS } - expandSwitchStatement(term_1012) { - return new _terms2.default("SwitchStatement", { discriminant: this.expand(term_1012.discriminant), cases: term_1012.cases.map(c_1013 => this.expand(c_1013)).toArray() }); + }; + const ALL_PHASES = exports.ALL_PHASES = {}; + + class Syntax { + + constructor(token, oldstx) { + this.token = token; + this.bindings = oldstx && oldstx.bindings != null ? oldstx.bindings : new _bindingMap2.default(); + this.scopesets = oldstx && oldstx.scopesets != null ? oldstx.scopesets : { + all: (0, _immutable.List)(), + phase: (0, _immutable.Map)() + }; + Object.freeze(this); } - expandFormalParameters(term_1014) { - let rest_1015 = term_1014.rest == null ? null : this.expand(term_1014.rest); - return new _terms2.default("FormalParameters", { items: term_1014.items.map(i_1016 => this.expand(i_1016)), rest: rest_1015 }); + // token: Token | List; + + + static of(token, stx) { + return new Syntax(token, stx); } - expandArrowExpression(term_1017) { - return this.doFunctionExpansion(term_1017, "ArrowExpression"); + + static from(type, value, stx) { + if (!Types[type]) { + throw new Error(type + " is not a valid type"); + } else if (!Types[type].create) { + throw new Error("Cannot create a syntax from type " + type); + } + let newstx = Types[type].create(value, stx); + let slice = getFirstSlice(stx); + if (slice != null) { + newstx.token.slice = slice; + } + return newstx; } - expandSwitchDefault(term_1018) { - return new _terms2.default("SwitchDefault", { consequent: term_1018.consequent.map(c_1019 => this.expand(c_1019)).toArray() }); + + from(type, value) { + return Syntax.from(type, value, this); } - expandSwitchCase(term_1020) { - return new _terms2.default("SwitchCase", { test: this.expand(term_1020.test), consequent: term_1020.consequent.map(c_1021 => this.expand(c_1021)).toArray() }); + + fromNull() { + return this.from("null", null); } - expandForInStatement(term_1022) { - return new _terms2.default("ForInStatement", { left: this.expand(term_1022.left), right: this.expand(term_1022.right), body: this.expand(term_1022.body) }); + + fromNumber(value) { + return this.from('number', value); } - expandTryCatchStatement(term_1023) { - return new _terms2.default("TryCatchStatement", { body: this.expand(term_1023.body), catchClause: this.expand(term_1023.catchClause) }); + + fromString(value) { + return this.from("string", value); } - expandTryFinallyStatement(term_1024) { - let catchClause_1025 = term_1024.catchClause == null ? null : this.expand(term_1024.catchClause); - return new _terms2.default("TryFinallyStatement", { body: this.expand(term_1024.body), catchClause: catchClause_1025, finalizer: this.expand(term_1024.finalizer) }); + + fromPunctuator(value) { + return this.from("punctuator", value); } - expandCatchClause(term_1026) { - return new _terms2.default("CatchClause", { binding: this.expand(term_1026.binding), body: this.expand(term_1026.body) }); + + fromKeyword(value) { + return this.from("keyword", value); } - expandThrowStatement(term_1027) { - return new _terms2.default("ThrowStatement", { expression: this.expand(term_1027.expression) }); + + fromIdentifier(value) { + return this.from("identifier", value); } - expandForOfStatement(term_1028) { - return new _terms2.default("ForOfStatement", { left: this.expand(term_1028.left), right: this.expand(term_1028.right), body: this.expand(term_1028.body) }); + + fromRegularExpression(value) { + return this.from("regularExpression", value); } - expandBindingIdentifier(term_1029) { - return term_1029; + + fromBraces(inner) { + return this.from("braces", inner); } - expandBindingPropertyIdentifier(term_1030) { - return term_1030; + + fromBrackets(inner) { + return this.from("brackets", inner); } - expandBindingPropertyProperty(term_1031) { - return new _terms2.default("BindingPropertyProperty", { name: this.expand(term_1031.name), binding: this.expand(term_1031.binding) }); + + fromParens(inner) { + return this.from("parens", inner); } - expandComputedPropertyName(term_1032) { - return new _terms2.default("ComputedPropertyName", { expression: this.expand(term_1032.expression) }); + + static fromNull(stx) { + return Syntax.from("null", null, stx); } - expandObjectBinding(term_1033) { - return new _terms2.default("ObjectBinding", { properties: term_1033.properties.map(t_1034 => this.expand(t_1034)).toArray() }); + + static fromNumber(value, stx) { + return Syntax.from("number", value, stx); } - expandArrayBinding(term_1035) { - let restElement_1036 = term_1035.restElement == null ? null : this.expand(term_1035.restElement); - return new _terms2.default("ArrayBinding", { elements: term_1035.elements.map(t_1037 => t_1037 == null ? null : this.expand(t_1037)).toArray(), restElement: restElement_1036 }); + + static fromString(value, stx) { + return Syntax.from("string", value, stx); } - expandBindingWithDefault(term_1038) { - return new _terms2.default("BindingWithDefault", { binding: this.expand(term_1038.binding), init: this.expand(term_1038.init) }); + + static fromPunctuator(value, stx) { + return Syntax.from("punctuator", value, stx); } - expandShorthandProperty(term_1039) { - return new _terms2.default("DataProperty", { name: new _terms2.default("StaticPropertyName", { value: term_1039.name }), expression: new _terms2.default("IdentifierExpression", { name: term_1039.name }) }); + + static fromKeyword(value, stx) { + return Syntax.from("keyword", value, stx); } - expandForStatement(term_1040) { - let init_1041 = term_1040.init == null ? null : this.expand(term_1040.init); - let test_1042 = term_1040.test == null ? null : this.expand(term_1040.test); - let update_1043 = term_1040.update == null ? null : this.expand(term_1040.update); - let body_1044 = this.expand(term_1040.body); - return new _terms2.default("ForStatement", { init: init_1041, test: test_1042, update: update_1043, body: body_1044 }); + + static fromIdentifier(value, stx) { + return Syntax.from("identifier", value, stx); } - expandYieldExpression(term_1045) { - let expr_1046 = term_1045.expression == null ? null : this.expand(term_1045.expression); - return new _terms2.default("YieldExpression", { expression: expr_1046 }); + + static fromRegularExpression(value, stx) { + return Syntax.from("regularExpression", value, stx); } - expandYieldGeneratorExpression(term_1047) { - let expr_1048 = term_1047.expression == null ? null : this.expand(term_1047.expression); - return new _terms2.default("YieldGeneratorExpression", { expression: expr_1048 }); + + static fromBraces(inner, stx) { + return Syntax.from("braces", inner, stx); } - expandWhileStatement(term_1049) { - return new _terms2.default("WhileStatement", { test: this.expand(term_1049.test), body: this.expand(term_1049.body) }); + + static fromBrackets(inner, stx) { + return Syntax.from("brackets", inner, stx); } - expandIfStatement(term_1050) { - let consequent_1051 = term_1050.consequent == null ? null : this.expand(term_1050.consequent); - let alternate_1052 = term_1050.alternate == null ? null : this.expand(term_1050.alternate); - return new _terms2.default("IfStatement", { test: this.expand(term_1050.test), consequent: consequent_1051, alternate: alternate_1052 }); + + static fromParens(inner, stx) { + return Syntax.from("parens", inner, stx); } - expandBlockStatement(term_1053) { - return new _terms2.default("BlockStatement", { block: this.expand(term_1053.block) }); + + // () -> string + resolve(phase) { + (0, _errors.assert)(phase != null, "must provide a phase to resolve"); + let allScopes = this.scopesets.all; + let stxScopes = this.scopesets.phase.has(phase) ? this.scopesets.phase.get(phase) : (0, _immutable.List)(); + stxScopes = allScopes.concat(stxScopes); + if (stxScopes.size === 0 || !(this.match('identifier') || this.match('keyword'))) { + return this.token.value; + } + let scope = stxScopes.last(); + let bindings = this.bindings; + if (scope) { + // List<{ scopes: List, binding: Symbol }> + let scopesetBindingList = bindings.get(this); + + if (scopesetBindingList) { + // { scopes: List, binding: Symbol } + let biggestBindingPair = scopesetBindingList.filter(_ref => { + let scopes = _ref.scopes; + + return scopes.isSubset(stxScopes); + }).sort(sizeDecending); + + if (biggestBindingPair.size >= 2 && biggestBindingPair.get(0).scopes.size === biggestBindingPair.get(1).scopes.size) { + let debugBase = '{' + stxScopes.map(s => s.toString()).join(', ') + '}'; + let debugAmbigousScopesets = biggestBindingPair.map(_ref2 => { + let scopes = _ref2.scopes; + + return '{' + scopes.map(s => s.toString()).join(', ') + '}'; + }).join(', '); + throw new Error('Scopeset ' + debugBase + ' has ambiguous subsets ' + debugAmbigousScopesets); + } else if (biggestBindingPair.size !== 0) { + let bindingStr = biggestBindingPair.get(0).binding.toString(); + if (_ramdaFantasy.Maybe.isJust(biggestBindingPair.get(0).alias)) { + // null never happens because we just checked if it is a Just + return biggestBindingPair.get(0).alias.getOrElse(null).resolve(phase); + } + return bindingStr; + } + } + } + return this.token.value; } - expandBlock(term_1054) { - let scope_1055 = (0, _scope.freshScope)("block"); - this.context.currentScope.push(scope_1055); - let compiler_1056 = new _compiler2.default(this.context.phase, this.context.env, this.context.store, this.context); - let markedBody_1057, bodyTerm_1058; - markedBody_1057 = term_1054.statements.map(b_1059 => b_1059.addScope(scope_1055, this.context.bindings, _syntax.ALL_PHASES)); - bodyTerm_1058 = new _terms2.default("Block", { statements: compiler_1056.compile(markedBody_1057) }); - this.context.currentScope.pop(); - return bodyTerm_1058; + + val() { + (0, _errors.assert)(!this.match("delimiter"), "cannot get the val of a delimiter"); + if (this.match("string")) { + return this.token.str; + } + if (this.match("template")) { + return this.token.items.map(el => { + if (typeof el.match === 'function' && el.match("delimiter")) { + return '${...}'; + } + return el.slice.text; + }).join(''); + } + return this.token.value; } - expandVariableDeclarationStatement(term_1060) { - return new _terms2.default("VariableDeclarationStatement", { declaration: this.expand(term_1060.declaration) }); + + lineNumber() { + if (!this.match("delimiter")) { + return this.token.slice.startLocation.line; + } else { + return this.token.get(0).lineNumber(); + } } - expandReturnStatement(term_1061) { - if (term_1061.expression == null) { - return term_1061; + + setLineNumber(line) { + let newTok = {}; + if (this.isDelimiter()) { + newTok = this.token.map(s => s.setLineNumber(line)); + } else { + for (let key of Object.keys(this.token)) { + newTok[key] = this.token[key]; + } + (0, _errors.assert)(newTok.slice && newTok.slice.startLocation, 'all tokens must have line info'); + newTok.slice.startLocation.line = line; } - return new _terms2.default("ReturnStatement", { expression: this.expand(term_1061.expression) }); + return new Syntax(newTok, this); } - expandClassDeclaration(term_1062) { - return new _terms2.default("ClassDeclaration", { name: term_1062.name == null ? null : this.expand(term_1062.name), super: term_1062.super == null ? null : this.expand(term_1062.super), elements: term_1062.elements.map(el_1063 => this.expand(el_1063)).toArray() }); + + // () -> List + inner() { + (0, _errors.assert)(this.match("delimiter"), "can only get the inner of a delimiter"); + return this.token.slice(1, this.token.size - 1); } - expandClassExpression(term_1064) { - return new _terms2.default("ClassExpression", { name: term_1064.name == null ? null : this.expand(term_1064.name), super: term_1064.super == null ? null : this.expand(term_1064.super), elements: term_1064.elements.map(el_1065 => this.expand(el_1065)).toArray() }); + + addScope(scope, bindings, phase) { + let options = arguments.length <= 3 || arguments[3] === undefined ? { flip: false } : arguments[3]; + + let token = this.match('delimiter') ? this.token.map(s => s.addScope(scope, bindings, phase, options)) : this.token; + if (this.match('template')) { + token = _.merge(token, { + items: token.items.map(it => { + if (it instanceof Syntax && it.match('delimiter')) { + return it.addScope(scope, bindings, phase, options); + } + return it; + }) + }); + } + let oldScopeset; + if (phase === ALL_PHASES) { + oldScopeset = this.scopesets.all; + } else { + oldScopeset = this.scopesets.phase.has(phase) ? this.scopesets.phase.get(phase) : (0, _immutable.List)(); + } + let newScopeset; + if (options.flip) { + let index = oldScopeset.indexOf(scope); + if (index !== -1) { + newScopeset = oldScopeset.remove(index); + } else { + newScopeset = oldScopeset.push(scope); + } + } else { + newScopeset = oldScopeset.push(scope); + } + let newstx = { + bindings: bindings, + scopesets: { + all: this.scopesets.all, + phase: this.scopesets.phase + } + }; + + if (phase === ALL_PHASES) { + newstx.scopesets.all = newScopeset; + } else { + newstx.scopesets.phase = newstx.scopesets.phase.set(phase, newScopeset); + } + return new Syntax(token, newstx); } - expandClassElement(term_1066) { - return new _terms2.default("ClassElement", { isStatic: term_1066.isStatic, method: this.expand(term_1066.method) }); + + removeScope(scope, phase) { + let token = this.match('delimiter') ? this.token.map(s => s.removeScope(scope, phase)) : this.token; + let phaseScopeset = this.scopesets.phase.has(phase) ? this.scopesets.phase.get(phase) : (0, _immutable.List)(); + let allScopeset = this.scopesets.all; + let newstx = { + bindings: this.bindings, + scopesets: { + all: this.scopesets.all, + phase: this.scopesets.phase + } + }; + + let phaseIndex = phaseScopeset.indexOf(scope); + let allIndex = allScopeset.indexOf(scope); + if (phaseIndex !== -1) { + newstx.scopesets.phase = this.scopesets.phase.set(phase, phaseScopeset.remove(phaseIndex)); + } else if (allIndex !== -1) { + newstx.scopesets.all = allScopeset.remove(allIndex); + } + return new Syntax(token, newstx); } - expandThisExpression(term_1067) { - return term_1067; + + match(type, value) { + if (!Types[type]) { + throw new Error(type + " is an invalid type"); + } + return Types[type].match(this.token) && (value == null || (value instanceof RegExp ? value.test(this.val()) : this.val() == value)); } - expandSyntaxTemplate(term_1068) { - let r_1069 = (0, _templateProcessor.processTemplate)(term_1068.template.inner()); - let str_1070 = _syntax2.default.from("string", _serializer.serializer.write(r_1069.template)); - let callee_1071 = new _terms2.default("IdentifierExpression", { name: _syntax2.default.from("identifier", "syntaxTemplate") }); - let expandedInterps_1072 = r_1069.interp.map(i_1074 => { - let enf_1075 = new _enforester.Enforester(i_1074, (0, _immutable.List)(), this.context); - return this.expand(enf_1075.enforest("expression")); - }); - let args_1073 = _immutable.List.of(new _terms2.default("LiteralStringExpression", { value: str_1070 })).concat(expandedInterps_1072); - return new _terms2.default("CallExpression", { callee: callee_1071, arguments: args_1073 }); + + isIdentifier(value) { + return this.match("identifier", value); } - expandSyntaxQuote(term_1076) { - let str_1077 = new _terms2.default("LiteralStringExpression", { value: _syntax2.default.from("string", _serializer.serializer.write(term_1076.name)) }); - return new _terms2.default("TemplateExpression", { tag: term_1076.template.tag, elements: term_1076.template.elements.push(str_1077).push(new _terms2.default("TemplateElement", { rawValue: "" })).toArray() }); + + isAssign(value) { + return this.match("assign", value); } - expandStaticMemberExpression(term_1078) { - return new _terms2.default("StaticMemberExpression", { object: this.expand(term_1078.object), property: term_1078.property }); + + isBooleanLiteral(value) { + return this.match("boolean", value); } - expandArrayExpression(term_1079) { - return new _terms2.default("ArrayExpression", { elements: term_1079.elements.map(t_1080 => t_1080 == null ? t_1080 : this.expand(t_1080)) }); + + isKeyword(value) { + return this.match("keyword", value); } - expandImport(term_1081) { - return term_1081; + + isNullLiteral(value) { + return this.match("null", value); } - expandImportNamespace(term_1082) { - return term_1082; + + isNumericLiteral(value) { + return this.match("number", value); } - expandExport(term_1083) { - return new _terms2.default("Export", { declaration: this.expand(term_1083.declaration) }); + + isPunctuator(value) { + return this.match("punctuator", value); } - expandExportDefault(term_1084) { - return new _terms2.default("ExportDefault", { body: this.expand(term_1084.body) }); + + isStringLiteral(value) { + return this.match("string", value); } - expandExportFrom(term_1085) { - return term_1085; + + isRegularExpression(value) { + return this.match("regularExpression", value); } - expandExportAllFrom(term_1086) { - return term_1086; + + isTemplate(value) { + return this.match("template", value); } - expandExportSpecifier(term_1087) { - return term_1087; + + isDelimiter(value) { + return this.match("delimiter", value); } - expandStaticPropertyName(term_1088) { - return term_1088; + + isParens(value) { + return this.match("parens", value); } - expandDataProperty(term_1089) { - return new _terms2.default("DataProperty", { name: this.expand(term_1089.name), expression: this.expand(term_1089.expression) }); + + isBraces(value) { + return this.match("braces", value); } - expandObjectExpression(term_1090) { - return new _terms2.default("ObjectExpression", { properties: term_1090.properties.map(t_1091 => this.expand(t_1091)) }); + + isBrackets(value) { + return this.match("brackets", value); } - expandVariableDeclarator(term_1092) { - let init_1093 = term_1092.init == null ? null : this.expand(term_1092.init); - return new _terms2.default("VariableDeclarator", { binding: this.expand(term_1092.binding), init: init_1093 }); + + isSyntaxTemplate(value) { + return this.match("syntaxTemplate", value); } - expandVariableDeclaration(term_1094) { - if (term_1094.kind === "syntax" || term_1094.kind === "syntaxrec") { - return term_1094; - } - return new _terms2.default("VariableDeclaration", { kind: term_1094.kind, declarators: term_1094.declarators.map(d_1095 => this.expand(d_1095)) }); + + isEOF(value) { + return this.match("eof", value); } - expandParenthesizedExpression(term_1096) { - if (term_1096.inner.size === 0) { - throw new Error("unexpected end of input"); - } - let enf_1097 = new _enforester.Enforester(term_1096.inner, (0, _immutable.List)(), this.context); - let lookahead_1098 = enf_1097.peek(); - let t_1099 = enf_1097.enforestExpression(); - if (t_1099 == null || enf_1097.rest.size > 0) { - throw enf_1097.createError(lookahead_1098, "unexpected syntax"); - } - return this.expand(t_1099); - } - expandUnaryExpression(term_1100) { - return new _terms2.default("UnaryExpression", { operator: term_1100.operator, operand: this.expand(term_1100.operand) }); - } - expandUpdateExpression(term_1101) { - return new _terms2.default("UpdateExpression", { isPrefix: term_1101.isPrefix, operator: term_1101.operator, operand: this.expand(term_1101.operand) }); - } - expandBinaryExpression(term_1102) { - let left_1103 = this.expand(term_1102.left); - let right_1104 = this.expand(term_1102.right); - return new _terms2.default("BinaryExpression", { left: left_1103, operator: term_1102.operator, right: right_1104 }); - } - expandConditionalExpression(term_1105) { - return new _terms2.default("ConditionalExpression", { test: this.expand(term_1105.test), consequent: this.expand(term_1105.consequent), alternate: this.expand(term_1105.alternate) }); - } - expandNewTargetExpression(term_1106) { - return term_1106; - } - expandNewExpression(term_1107) { - let callee_1108 = this.expand(term_1107.callee); - let enf_1109 = new _enforester.Enforester(term_1107.arguments, (0, _immutable.List)(), this.context); - let args_1110 = enf_1109.enforestArgumentList().map(arg_1111 => this.expand(arg_1111)); - return new _terms2.default("NewExpression", { callee: callee_1108, arguments: args_1110.toArray() }); - } - expandSuper(term_1112) { - return term_1112; - } - expandCallExpression(term_1113) { - let callee_1114 = this.expand(term_1113.callee); - let enf_1115 = new _enforester.Enforester(term_1113.arguments, (0, _immutable.List)(), this.context); - let args_1116 = enf_1115.enforestArgumentList().map(arg_1117 => this.expand(arg_1117)); - return new _terms2.default("CallExpression", { callee: callee_1114, arguments: args_1116 }); - } - expandSpreadElement(term_1118) { - return new _terms2.default("SpreadElement", { expression: this.expand(term_1118.expression) }); - } - expandExpressionStatement(term_1119) { - let child_1120 = this.expand(term_1119.expression); - return new _terms2.default("ExpressionStatement", { expression: child_1120 }); - } - expandLabeledStatement(term_1121) { - return new _terms2.default("LabeledStatement", { label: term_1121.label.val(), body: this.expand(term_1121.body) }); - } - doFunctionExpansion(term_1122, type_1123) { - let scope_1124 = (0, _scope.freshScope)("fun"); - let red_1125 = new _applyScopeInParamsReducer2.default(scope_1124, this.context); - let params_1126; - if (type_1123 !== "Getter" && type_1123 !== "Setter") { - params_1126 = red_1125.transform(term_1122.params); - params_1126 = this.expand(params_1126); - } - this.context.currentScope.push(scope_1124); - let compiler_1127 = new _compiler2.default(this.context.phase, this.context.env, this.context.store, this.context); - let markedBody_1128, bodyTerm_1129; - if (term_1122.body instanceof _terms2.default) { - bodyTerm_1129 = this.expand(term_1122.body.addScope(scope_1124, this.context.bindings, _syntax.ALL_PHASES)); - } else { - markedBody_1128 = term_1122.body.map(b_1130 => b_1130.addScope(scope_1124, this.context.bindings, _syntax.ALL_PHASES)); - bodyTerm_1129 = new _terms2.default("FunctionBody", { directives: (0, _immutable.List)(), statements: compiler_1127.compile(markedBody_1128) }); + + toString() { + if (this.match("delimiter")) { + return this.token.map(s => s.toString()).join(" "); } - this.context.currentScope.pop(); - if (type_1123 === "Getter") { - return new _terms2.default(type_1123, { name: this.expand(term_1122.name), body: bodyTerm_1129 }); - } else if (type_1123 === "Setter") { - return new _terms2.default(type_1123, { name: this.expand(term_1122.name), param: term_1122.param, body: bodyTerm_1129 }); + if (this.match("string")) { + return "'" + this.token.str; } - return new _terms2.default(type_1123, { name: term_1122.name, isGenerator: term_1122.isGenerator, params: params_1126, body: bodyTerm_1129 }); - } - expandMethod(term_1131) { - return this.doFunctionExpansion(term_1131, "Method"); - } - expandSetter(term_1132) { - return this.doFunctionExpansion(term_1132, "Setter"); - } - expandGetter(term_1133) { - return this.doFunctionExpansion(term_1133, "Getter"); - } - expandFunctionDeclaration(term_1134) { - return this.doFunctionExpansion(term_1134, "FunctionDeclaration"); - } - expandFunctionExpression(term_1135) { - return this.doFunctionExpansion(term_1135, "FunctionExpression"); - } - expandCompoundAssignmentExpression(term_1136) { - return new _terms2.default("CompoundAssignmentExpression", { binding: this.expand(term_1136.binding), operator: term_1136.operator, expression: this.expand(term_1136.expression) }); - } - expandAssignmentExpression(term_1137) { - return new _terms2.default("AssignmentExpression", { binding: this.expand(term_1137.binding), expression: this.expand(term_1137.expression) }); - } - expandEmptyStatement(term_1138) { - return term_1138; - } - expandLiteralBooleanExpression(term_1139) { - return term_1139; - } - expandLiteralNumericExpression(term_1140) { - return term_1140; - } - expandLiteralInfinityExpression(term_1141) { - return term_1141; - } - expandIdentifierExpression(term_1142) { - let trans_1143 = this.context.env.get(term_1142.name.resolve(this.context.phase)); - if (trans_1143) { - return new _terms2.default("IdentifierExpression", { name: trans_1143.id }); + if (this.match("template")) { + return this.val(); } - return term_1142; - } - expandLiteralNullExpression(term_1144) { - return term_1144; - } - expandLiteralStringExpression(term_1145) { - return term_1145; - } - expandLiteralRegExpExpression(term_1146) { - return term_1146; + return this.token.value; } } - exports.default = TermExpander; - //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/term-expander.js"],"names":[],"mappings":"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","file":"term-expander.js","sourcesContent":["import {List} from \"immutable\";\nimport Term, {isEOF, isBindingIdentifier, isFunctionDeclaration, isFunctionExpression, isFunctionTerm, isFunctionWithName, isSyntaxDeclaration, isVariableDeclaration, isVariableDeclarationStatement, isImport, isExport} from \"./terms\";\nimport {Scope, freshScope} from \"./scope\";\nimport ApplyScopeInParamsReducer from \"./apply-scope-in-params-reducer\";\nimport reducer, {MonoidalReducer} from \"shift-reducer\";\nimport Compiler from \"./compiler\";\nimport Syntax, {ALL_PHASES} from \"./syntax\";\nimport {serializer, makeDeserializer} from \"./serializer\";\nimport {enforestExpr, Enforester} from \"./enforester\";\nimport {assert} from \"./errors\";\nimport {processTemplate} from \"./template-processor.js\";\nimport ASTDispatcher from \"./ast-dispatcher\";\nexport default class TermExpander extends ASTDispatcher {\n  constructor(context_999) {\n    super(\"expand\", true);\n    this.context = context_999;\n  }\n  expand(term_1000) {\n    return this.dispatch(term_1000);\n  }\n  expandPragma(term_1001) {\n    return term_1001;\n  }\n  expandTemplateExpression(term_1002) {\n    return new Term(\"TemplateExpression\", {tag: term_1002.tag == null ? null : this.expand(term_1002.tag), elements: term_1002.elements.toArray()});\n  }\n  expandBreakStatement(term_1003) {\n    return new Term(\"BreakStatement\", {label: term_1003.label ? term_1003.label.val() : null});\n  }\n  expandDoWhileStatement(term_1004) {\n    return new Term(\"DoWhileStatement\", {body: this.expand(term_1004.body), test: this.expand(term_1004.test)});\n  }\n  expandWithStatement(term_1005) {\n    return new Term(\"WithStatement\", {body: this.expand(term_1005.body), object: this.expand(term_1005.object)});\n  }\n  expandDebuggerStatement(term_1006) {\n    return term_1006;\n  }\n  expandContinueStatement(term_1007) {\n    return new Term(\"ContinueStatement\", {label: term_1007.label ? term_1007.label.val() : null});\n  }\n  expandSwitchStatementWithDefault(term_1008) {\n    return new Term(\"SwitchStatementWithDefault\", {discriminant: this.expand(term_1008.discriminant), preDefaultCases: term_1008.preDefaultCases.map(c_1009 => this.expand(c_1009)).toArray(), defaultCase: this.expand(term_1008.defaultCase), postDefaultCases: term_1008.postDefaultCases.map(c_1010 => this.expand(c_1010)).toArray()});\n  }\n  expandComputedMemberExpression(term_1011) {\n    return new Term(\"ComputedMemberExpression\", {object: this.expand(term_1011.object), expression: this.expand(term_1011.expression)});\n  }\n  expandSwitchStatement(term_1012) {\n    return new Term(\"SwitchStatement\", {discriminant: this.expand(term_1012.discriminant), cases: term_1012.cases.map(c_1013 => this.expand(c_1013)).toArray()});\n  }\n  expandFormalParameters(term_1014) {\n    let rest_1015 = term_1014.rest == null ? null : this.expand(term_1014.rest);\n    return new Term(\"FormalParameters\", {items: term_1014.items.map(i_1016 => this.expand(i_1016)), rest: rest_1015});\n  }\n  expandArrowExpression(term_1017) {\n    return this.doFunctionExpansion(term_1017, \"ArrowExpression\");\n  }\n  expandSwitchDefault(term_1018) {\n    return new Term(\"SwitchDefault\", {consequent: term_1018.consequent.map(c_1019 => this.expand(c_1019)).toArray()});\n  }\n  expandSwitchCase(term_1020) {\n    return new Term(\"SwitchCase\", {test: this.expand(term_1020.test), consequent: term_1020.consequent.map(c_1021 => this.expand(c_1021)).toArray()});\n  }\n  expandForInStatement(term_1022) {\n    return new Term(\"ForInStatement\", {left: this.expand(term_1022.left), right: this.expand(term_1022.right), body: this.expand(term_1022.body)});\n  }\n  expandTryCatchStatement(term_1023) {\n    return new Term(\"TryCatchStatement\", {body: this.expand(term_1023.body), catchClause: this.expand(term_1023.catchClause)});\n  }\n  expandTryFinallyStatement(term_1024) {\n    let catchClause_1025 = term_1024.catchClause == null ? null : this.expand(term_1024.catchClause);\n    return new Term(\"TryFinallyStatement\", {body: this.expand(term_1024.body), catchClause: catchClause_1025, finalizer: this.expand(term_1024.finalizer)});\n  }\n  expandCatchClause(term_1026) {\n    return new Term(\"CatchClause\", {binding: this.expand(term_1026.binding), body: this.expand(term_1026.body)});\n  }\n  expandThrowStatement(term_1027) {\n    return new Term(\"ThrowStatement\", {expression: this.expand(term_1027.expression)});\n  }\n  expandForOfStatement(term_1028) {\n    return new Term(\"ForOfStatement\", {left: this.expand(term_1028.left), right: this.expand(term_1028.right), body: this.expand(term_1028.body)});\n  }\n  expandBindingIdentifier(term_1029) {\n    return term_1029;\n  }\n  expandBindingPropertyIdentifier(term_1030) {\n    return term_1030;\n  }\n  expandBindingPropertyProperty(term_1031) {\n    return new Term(\"BindingPropertyProperty\", {name: this.expand(term_1031.name), binding: this.expand(term_1031.binding)});\n  }\n  expandComputedPropertyName(term_1032) {\n    return new Term(\"ComputedPropertyName\", {expression: this.expand(term_1032.expression)});\n  }\n  expandObjectBinding(term_1033) {\n    return new Term(\"ObjectBinding\", {properties: term_1033.properties.map(t_1034 => this.expand(t_1034)).toArray()});\n  }\n  expandArrayBinding(term_1035) {\n    let restElement_1036 = term_1035.restElement == null ? null : this.expand(term_1035.restElement);\n    return new Term(\"ArrayBinding\", {elements: term_1035.elements.map(t_1037 => t_1037 == null ? null : this.expand(t_1037)).toArray(), restElement: restElement_1036});\n  }\n  expandBindingWithDefault(term_1038) {\n    return new Term(\"BindingWithDefault\", {binding: this.expand(term_1038.binding), init: this.expand(term_1038.init)});\n  }\n  expandShorthandProperty(term_1039) {\n    return new Term(\"DataProperty\", {name: new Term(\"StaticPropertyName\", {value: term_1039.name}), expression: new Term(\"IdentifierExpression\", {name: term_1039.name})});\n  }\n  expandForStatement(term_1040) {\n    let init_1041 = term_1040.init == null ? null : this.expand(term_1040.init);\n    let test_1042 = term_1040.test == null ? null : this.expand(term_1040.test);\n    let update_1043 = term_1040.update == null ? null : this.expand(term_1040.update);\n    let body_1044 = this.expand(term_1040.body);\n    return new Term(\"ForStatement\", {init: init_1041, test: test_1042, update: update_1043, body: body_1044});\n  }\n  expandYieldExpression(term_1045) {\n    let expr_1046 = term_1045.expression == null ? null : this.expand(term_1045.expression);\n    return new Term(\"YieldExpression\", {expression: expr_1046});\n  }\n  expandYieldGeneratorExpression(term_1047) {\n    let expr_1048 = term_1047.expression == null ? null : this.expand(term_1047.expression);\n    return new Term(\"YieldGeneratorExpression\", {expression: expr_1048});\n  }\n  expandWhileStatement(term_1049) {\n    return new Term(\"WhileStatement\", {test: this.expand(term_1049.test), body: this.expand(term_1049.body)});\n  }\n  expandIfStatement(term_1050) {\n    let consequent_1051 = term_1050.consequent == null ? null : this.expand(term_1050.consequent);\n    let alternate_1052 = term_1050.alternate == null ? null : this.expand(term_1050.alternate);\n    return new Term(\"IfStatement\", {test: this.expand(term_1050.test), consequent: consequent_1051, alternate: alternate_1052});\n  }\n  expandBlockStatement(term_1053) {\n    return new Term(\"BlockStatement\", {block: this.expand(term_1053.block)});\n  }\n  expandBlock(term_1054) {\n    let scope_1055 = freshScope(\"block\");\n    this.context.currentScope.push(scope_1055);\n    let compiler_1056 = new Compiler(this.context.phase, this.context.env, this.context.store, this.context);\n    let markedBody_1057, bodyTerm_1058;\n    markedBody_1057 = term_1054.statements.map(b_1059 => b_1059.addScope(scope_1055, this.context.bindings, ALL_PHASES));\n    bodyTerm_1058 = new Term(\"Block\", {statements: compiler_1056.compile(markedBody_1057)});\n    this.context.currentScope.pop();\n    return bodyTerm_1058;\n  }\n  expandVariableDeclarationStatement(term_1060) {\n    return new Term(\"VariableDeclarationStatement\", {declaration: this.expand(term_1060.declaration)});\n  }\n  expandReturnStatement(term_1061) {\n    if (term_1061.expression == null) {\n      return term_1061;\n    }\n    return new Term(\"ReturnStatement\", {expression: this.expand(term_1061.expression)});\n  }\n  expandClassDeclaration(term_1062) {\n    return new Term(\"ClassDeclaration\", {name: term_1062.name == null ? null : this.expand(term_1062.name), super: term_1062.super == null ? null : this.expand(term_1062.super), elements: term_1062.elements.map(el_1063 => this.expand(el_1063)).toArray()});\n  }\n  expandClassExpression(term_1064) {\n    return new Term(\"ClassExpression\", {name: term_1064.name == null ? null : this.expand(term_1064.name), super: term_1064.super == null ? null : this.expand(term_1064.super), elements: term_1064.elements.map(el_1065 => this.expand(el_1065)).toArray()});\n  }\n  expandClassElement(term_1066) {\n    return new Term(\"ClassElement\", {isStatic: term_1066.isStatic, method: this.expand(term_1066.method)});\n  }\n  expandThisExpression(term_1067) {\n    return term_1067;\n  }\n  expandSyntaxTemplate(term_1068) {\n    let r_1069 = processTemplate(term_1068.template.inner());\n    let str_1070 = Syntax.from(\"string\", serializer.write(r_1069.template));\n    let callee_1071 = new Term(\"IdentifierExpression\", {name: Syntax.from(\"identifier\", \"syntaxTemplate\")});\n    let expandedInterps_1072 = r_1069.interp.map(i_1074 => {\n      let enf_1075 = new Enforester(i_1074, List(), this.context);\n      return this.expand(enf_1075.enforest(\"expression\"));\n    });\n    let args_1073 = List.of(new Term(\"LiteralStringExpression\", {value: str_1070})).concat(expandedInterps_1072);\n    return new Term(\"CallExpression\", {callee: callee_1071, arguments: args_1073});\n  }\n  expandSyntaxQuote(term_1076) {\n    let str_1077 = new Term(\"LiteralStringExpression\", {value: Syntax.from(\"string\", serializer.write(term_1076.name))});\n    return new Term(\"TemplateExpression\", {tag: term_1076.template.tag, elements: term_1076.template.elements.push(str_1077).push(new Term(\"TemplateElement\", {rawValue: \"\"})).toArray()});\n  }\n  expandStaticMemberExpression(term_1078) {\n    return new Term(\"StaticMemberExpression\", {object: this.expand(term_1078.object), property: term_1078.property});\n  }\n  expandArrayExpression(term_1079) {\n    return new Term(\"ArrayExpression\", {elements: term_1079.elements.map(t_1080 => t_1080 == null ? t_1080 : this.expand(t_1080))});\n  }\n  expandImport(term_1081) {\n    return term_1081;\n  }\n  expandImportNamespace(term_1082) {\n    return term_1082;\n  }\n  expandExport(term_1083) {\n    return new Term(\"Export\", {declaration: this.expand(term_1083.declaration)});\n  }\n  expandExportDefault(term_1084) {\n    return new Term(\"ExportDefault\", {body: this.expand(term_1084.body)});\n  }\n  expandExportFrom(term_1085) {\n    return term_1085;\n  }\n  expandExportAllFrom(term_1086) {\n    return term_1086;\n  }\n  expandExportSpecifier(term_1087) {\n    return term_1087;\n  }\n  expandStaticPropertyName(term_1088) {\n    return term_1088;\n  }\n  expandDataProperty(term_1089) {\n    return new Term(\"DataProperty\", {name: this.expand(term_1089.name), expression: this.expand(term_1089.expression)});\n  }\n  expandObjectExpression(term_1090) {\n    return new Term(\"ObjectExpression\", {properties: term_1090.properties.map(t_1091 => this.expand(t_1091))});\n  }\n  expandVariableDeclarator(term_1092) {\n    let init_1093 = term_1092.init == null ? null : this.expand(term_1092.init);\n    return new Term(\"VariableDeclarator\", {binding: this.expand(term_1092.binding), init: init_1093});\n  }\n  expandVariableDeclaration(term_1094) {\n    if (term_1094.kind === \"syntax\" || term_1094.kind === \"syntaxrec\") {\n      return term_1094;\n    }\n    return new Term(\"VariableDeclaration\", {kind: term_1094.kind, declarators: term_1094.declarators.map(d_1095 => this.expand(d_1095))});\n  }\n  expandParenthesizedExpression(term_1096) {\n    if (term_1096.inner.size === 0) {\n      throw new Error(\"unexpected end of input\");\n    }\n    let enf_1097 = new Enforester(term_1096.inner, List(), this.context);\n    let lookahead_1098 = enf_1097.peek();\n    let t_1099 = enf_1097.enforestExpression();\n    if (t_1099 == null || enf_1097.rest.size > 0) {\n      throw enf_1097.createError(lookahead_1098, \"unexpected syntax\");\n    }\n    return this.expand(t_1099);\n  }\n  expandUnaryExpression(term_1100) {\n    return new Term(\"UnaryExpression\", {operator: term_1100.operator, operand: this.expand(term_1100.operand)});\n  }\n  expandUpdateExpression(term_1101) {\n    return new Term(\"UpdateExpression\", {isPrefix: term_1101.isPrefix, operator: term_1101.operator, operand: this.expand(term_1101.operand)});\n  }\n  expandBinaryExpression(term_1102) {\n    let left_1103 = this.expand(term_1102.left);\n    let right_1104 = this.expand(term_1102.right);\n    return new Term(\"BinaryExpression\", {left: left_1103, operator: term_1102.operator, right: right_1104});\n  }\n  expandConditionalExpression(term_1105) {\n    return new Term(\"ConditionalExpression\", {test: this.expand(term_1105.test), consequent: this.expand(term_1105.consequent), alternate: this.expand(term_1105.alternate)});\n  }\n  expandNewTargetExpression(term_1106) {\n    return term_1106;\n  }\n  expandNewExpression(term_1107) {\n    let callee_1108 = this.expand(term_1107.callee);\n    let enf_1109 = new Enforester(term_1107.arguments, List(), this.context);\n    let args_1110 = enf_1109.enforestArgumentList().map(arg_1111 => this.expand(arg_1111));\n    return new Term(\"NewExpression\", {callee: callee_1108, arguments: args_1110.toArray()});\n  }\n  expandSuper(term_1112) {\n    return term_1112;\n  }\n  expandCallExpression(term_1113) {\n    let callee_1114 = this.expand(term_1113.callee);\n    let enf_1115 = new Enforester(term_1113.arguments, List(), this.context);\n    let args_1116 = enf_1115.enforestArgumentList().map(arg_1117 => this.expand(arg_1117));\n    return new Term(\"CallExpression\", {callee: callee_1114, arguments: args_1116});\n  }\n  expandSpreadElement(term_1118) {\n    return new Term(\"SpreadElement\", {expression: this.expand(term_1118.expression)});\n  }\n  expandExpressionStatement(term_1119) {\n    let child_1120 = this.expand(term_1119.expression);\n    return new Term(\"ExpressionStatement\", {expression: child_1120});\n  }\n  expandLabeledStatement(term_1121) {\n    return new Term(\"LabeledStatement\", {label: term_1121.label.val(), body: this.expand(term_1121.body)});\n  }\n  doFunctionExpansion(term_1122, type_1123) {\n    let scope_1124 = freshScope(\"fun\");\n    let red_1125 = new ApplyScopeInParamsReducer(scope_1124, this.context);\n    let params_1126;\n    if (type_1123 !== \"Getter\" && type_1123 !== \"Setter\") {\n      params_1126 = red_1125.transform(term_1122.params);\n      params_1126 = this.expand(params_1126);\n    }\n    this.context.currentScope.push(scope_1124);\n    let compiler_1127 = new Compiler(this.context.phase, this.context.env, this.context.store, this.context);\n    let markedBody_1128, bodyTerm_1129;\n    if (term_1122.body instanceof Term) {\n      bodyTerm_1129 = this.expand(term_1122.body.addScope(scope_1124, this.context.bindings, ALL_PHASES));\n    } else {\n      markedBody_1128 = term_1122.body.map(b_1130 => b_1130.addScope(scope_1124, this.context.bindings, ALL_PHASES));\n      bodyTerm_1129 = new Term(\"FunctionBody\", {directives: List(), statements: compiler_1127.compile(markedBody_1128)});\n    }\n    this.context.currentScope.pop();\n    if (type_1123 === \"Getter\") {\n      return new Term(type_1123, {name: this.expand(term_1122.name), body: bodyTerm_1129});\n    } else if (type_1123 === \"Setter\") {\n      return new Term(type_1123, {name: this.expand(term_1122.name), param: term_1122.param, body: bodyTerm_1129});\n    }\n    return new Term(type_1123, {name: term_1122.name, isGenerator: term_1122.isGenerator, params: params_1126, body: bodyTerm_1129});\n  }\n  expandMethod(term_1131) {\n    return this.doFunctionExpansion(term_1131, \"Method\");\n  }\n  expandSetter(term_1132) {\n    return this.doFunctionExpansion(term_1132, \"Setter\");\n  }\n  expandGetter(term_1133) {\n    return this.doFunctionExpansion(term_1133, \"Getter\");\n  }\n  expandFunctionDeclaration(term_1134) {\n    return this.doFunctionExpansion(term_1134, \"FunctionDeclaration\");\n  }\n  expandFunctionExpression(term_1135) {\n    return this.doFunctionExpansion(term_1135, \"FunctionExpression\");\n  }\n  expandCompoundAssignmentExpression(term_1136) {\n    return new Term(\"CompoundAssignmentExpression\", {binding: this.expand(term_1136.binding), operator: term_1136.operator, expression: this.expand(term_1136.expression)});\n  }\n  expandAssignmentExpression(term_1137) {\n    return new Term(\"AssignmentExpression\", {binding: this.expand(term_1137.binding), expression: this.expand(term_1137.expression)});\n  }\n  expandEmptyStatement(term_1138) {\n    return term_1138;\n  }\n  expandLiteralBooleanExpression(term_1139) {\n    return term_1139;\n  }\n  expandLiteralNumericExpression(term_1140) {\n    return term_1140;\n  }\n  expandLiteralInfinityExpression(term_1141) {\n    return term_1141;\n  }\n  expandIdentifierExpression(term_1142) {\n    let trans_1143 = this.context.env.get(term_1142.name.resolve(this.context.phase));\n    if (trans_1143) {\n      return new Term(\"IdentifierExpression\", {name: trans_1143.id});\n    }\n    return term_1142;\n  }\n  expandLiteralNullExpression(term_1144) {\n    return term_1144;\n  }\n  expandLiteralStringExpression(term_1145) {\n    return term_1145;\n  }\n  expandLiteralRegExpExpression(term_1146) {\n    return term_1146;\n  }\n}\n"]} + exports.default = Syntax; + //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/syntax.js"],"names":[],"mappings":"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","file":"syntax.js","sourcesContent":["// @flow\nimport { List, Map } from \"immutable\";\nimport { assert } from \"./errors\";\nimport BindingMap from \"./binding-map\";\nimport { Maybe } from \"ramda-fantasy\";\nimport * as _ from 'ramda';\n\nimport { TokenType, TokenClass } from \"shift-parser/dist/tokenizer\";\n\ntype Token = {\n  type: any;\n  value: any;\n  slice: any;\n};\n\ntype TokenTag =\n  'null' |\n  'number' |\n  'string' |\n  'punctuator' |\n  'keyword' |\n  'identifier' |\n  'regularExpression' |\n  'boolean' |\n  'braces' |\n  'parens' |\n  'delimiter' |\n  'eof' |\n  'template' |\n  'assign' |\n  'syntaxTemplate' |\n  'brackets'\n\nfunction getFirstSlice(stx: ?Syntax) {\n  if ((!stx) || typeof stx.isDelimiter !== 'function') return null; // TODO: should not have to do this\n  if (!stx.isDelimiter()) {\n    return stx.token.slice;\n  }\n  return stx.token.get(0).token.slice;\n}\n\nfunction sizeDecending(a, b) {\n  if (a.scopes.size > b.scopes.size) {\n    return -1;\n  } else if (b.scopes.size > a.scopes.size) {\n    return 1;\n  } else {\n    return 0;\n  }\n}\n\ntype TypesHelper = {\n  [key: TokenTag]: {\n    match(token: any): boolean;\n    create?: (value: any, stx: ?Syntax) => Syntax;\n  }\n}\n\nexport let Types: TypesHelper = {\n  null: {\n    match: token => !Types.delimiter.match(token) && token.type === TokenType.NULL,\n    create: (value, stx) => new Syntax({\n      type: TokenType.NULL,\n      value: null\n    }, stx)\n  },\n  number: {\n    match: token => !Types.delimiter.match(token) && token.type.klass === TokenClass.NumericLiteral,\n    create: (value, stx) => new Syntax({\n      type: TokenType.NUMBER,\n      value\n    }, stx)\n  },\n  string: {\n\t\tmatch: token => !Types.delimiter.match(token) && token.type.klass === TokenClass.StringLiteral,\n    create: (value, stx) => new Syntax({\n      type: TokenType.STRING,\n      str: value\n    }, stx)\n  },\n  punctuator: {\n\t\tmatch: token => !Types.delimiter.match(token) && token.type.klass === TokenClass.Punctuator,\n    create: (value, stx) => new Syntax({\n      type: {\n        klass: TokenClass.Punctuator,\n        name: value\n      },\n      value\n    }, stx)\n  },\n  keyword: {\n\t\tmatch: token => !Types.delimiter.match(token) && token.type.klass === TokenClass.Keyword,\n    create: (value, stx) => new Syntax({\n      type: {\n        klass: TokenClass.Keyword,\n        name: value\n      },\n      value\n    }, stx)\n  },\n  identifier: {\n\t\tmatch: token => !Types.delimiter.match(token) && token.type.klass === TokenClass.Ident,\n    create: (value, stx) => new Syntax({\n      type: TokenType.IDENTIFIER,\n      value\n    }, stx)\n  },\n  regularExpression: {\n\t\tmatch: token => !Types.delimiter.match(token) && token.type.klass === TokenClass.RegularExpression,\n    create: (value, stx) => new Syntax({\n      type: TokenType.REGEXP,\n      value\n    }, stx)\n  },\n  braces: {\n\t\tmatch: token => Types.delimiter.match(token) &&\n           token.get(0).token.type === TokenType.LBRACE,\n    create: (inner, stx) => {\n      let left = new Syntax({\n        type: TokenType.LBRACE,\n        value: \"{\",\n        slice: getFirstSlice(stx)\n      });\n      let right = new Syntax({\n        type: TokenType.RBRACE,\n        value: \"}\",\n        slice: getFirstSlice(stx)\n      });\n      return new Syntax(List.of(left).concat(inner).push(right), stx);\n    }\n  },\n  brackets: {\n\t\tmatch: token => Types.delimiter.match(token) &&\n           token.get(0).token.type === TokenType.LBRACK,\n    create: (inner, stx) => {\n      let left = new Syntax({\n        type: TokenType.LBRACK,\n        value: \"[\",\n        slice: getFirstSlice(stx)\n      });\n      let right = new Syntax({\n        type: TokenType.RBRACK,\n        value: \"]\",\n        slice: getFirstSlice(stx)\n      });\n      return new Syntax(List.of(left).concat(inner).push(right), stx);\n    }\n  },\n  parens: {\n\t\tmatch: token => Types.delimiter.match(token) &&\n           token.get(0).token.type === TokenType.LPAREN,\n    create: (inner, stx) => {\n      let left = new Syntax({\n        type: TokenType.LPAREN,\n        value: \"(\",\n        slice: getFirstSlice(stx)\n      });\n      let right = new Syntax({\n        type: TokenType.RPAREN,\n        value: \")\",\n        slice: getFirstSlice(stx)\n      });\n      return new Syntax(List.of(left).concat(inner).push(right), stx);\n    }\n  },\n\n  assign: {\n    match: token => {\n      if (Types.punctuator.match(token)) {\n        switch (token.value) {\n          case \"=\":\n          case \"|=\":\n          case \"^=\":\n          case \"&=\":\n          case \"<<=\":\n          case \">>=\":\n          case \">>>=\":\n          case \"+=\":\n          case \"-=\":\n          case \"*=\":\n          case \"/=\":\n          case \"%=\":\n            return true;\n          default:\n            return false;\n        }\n      }\n      return false;\n    }\n  },\n\n  boolean: {\n    match: token => !Types.delimiter.match(token) && token.type === TokenType.TRUE ||\n           token.type === TokenType.FALSE\n  },\n\n  template: {\n    match: token => !Types.delimiter.match(token) && token.type === TokenType.TEMPLATE\n  },\n\n  delimiter: {\n    match: token => List.isList(token)\n  },\n\n  syntaxTemplate: {\n    match: token => Types.delimiter.match(token) && token.get(0).val() === '#`'\n  },\n\n  eof: {\n    match: token => !Types.delimiter.match(token) && token.type === TokenType.EOS\n  },\n};\nexport const ALL_PHASES = {};\n\ntype Scopeset = {\n  all: List<any>;\n  phase: Map<number, any>;\n}\n\nexport default class Syntax {\n  // token: Token | List<Token>;\n  token: any;\n  bindings: BindingMap;\n  scopesets: Scopeset;\n\n  constructor(token: any, oldstx: ?{ bindings: any; scopesets: any}) {\n    this.token = token;\n    this.bindings = oldstx && (oldstx.bindings != null) ? oldstx.bindings : new BindingMap();\n    this.scopesets = oldstx && (oldstx.scopesets != null) ? oldstx.scopesets : {\n      all: List(),\n      phase: Map()\n    };\n    Object.freeze(this);\n  }\n\n  static of(token: Token, stx: ?Syntax) {\n    return new Syntax(token, stx);\n  }\n\n  static from(type, value, stx: ?Syntax) {\n    if (!Types[type]) {\n      throw new Error(type + \" is not a valid type\");\n    }\n    else if (!Types[type].create) {\n      throw new Error(\"Cannot create a syntax from type \" + type);\n    }\n    let newstx = Types[type].create(value, stx);\n    let slice = getFirstSlice(stx);\n    if (slice != null) {\n      newstx.token.slice = slice;\n    }\n    return newstx;\n  }\n\n  from(type: TokenTag, value: any) {\n    return Syntax.from(type, value, this);\n  }\n\n  fromNull() {\n    return this.from(\"null\", null);\n  }\n\n  fromNumber(value: number) {\n    return this.from('number', value);\n  }\n\n  fromString(value: string) {\n    return this.from(\"string\", value);\n  }\n\n  fromPunctuator(value: string) {\n    return this.from(\"punctuator\", value);\n  }\n\n  fromKeyword(value: string) {\n    return this.from(\"keyword\", value);\n  }\n\n  fromIdentifier(value: string) {\n    return this.from(\"identifier\", value);\n  }\n\n  fromRegularExpression(value: any) {\n    return this.from(\"regularExpression\", value);\n  }\n\n  fromBraces(inner: List<Syntax>) {\n    return this.from(\"braces\", inner);\n  }\n\n  fromBrackets(inner: List<Syntax>) {\n    return this.from(\"brackets\", inner);\n  }\n\n  fromParens(inner: List<Syntax>) {\n    return this.from(\"parens\", inner);\n  }\n\n  static fromNull(stx: Syntax) {\n    return Syntax.from(\"null\", null, stx);\n  }\n\n  static fromNumber(value, stx) {\n    return Syntax.from(\"number\", value, stx);\n  }\n\n  static fromString(value, stx) {\n    return Syntax.from(\"string\", value, stx);\n  }\n\n  static fromPunctuator(value, stx) {\n    return Syntax.from(\"punctuator\", value, stx);\n  }\n\n  static fromKeyword(value, stx) {\n    return Syntax.from(\"keyword\", value, stx);\n  }\n\n  static fromIdentifier(value, stx) {\n    return Syntax.from(\"identifier\", value, stx);\n  }\n\n  static fromRegularExpression(value, stx) {\n    return Syntax.from(\"regularExpression\", value, stx);\n  }\n\n  static fromBraces(inner, stx) {\n    return Syntax.from(\"braces\", inner, stx);\n  }\n\n  static fromBrackets(inner, stx) {\n    return Syntax.from(\"brackets\", inner, stx);\n  }\n\n  static fromParens(inner, stx) {\n    return Syntax.from(\"parens\", inner, stx);\n  }\n\n  // () -> string\n  resolve(phase: any) {\n    assert(phase != null, \"must provide a phase to resolve\");\n    let allScopes = this.scopesets.all;\n    let stxScopes = this.scopesets.phase.has(phase) ? this.scopesets.phase.get(phase) : List();\n    stxScopes = allScopes.concat(stxScopes);\n    if (stxScopes.size === 0 || !(this.match('identifier') || this.match('keyword'))) {\n      return this.token.value;\n    }\n    let scope = stxScopes.last();\n    let bindings = this.bindings;\n    if (scope) {\n      // List<{ scopes: List<Scope>, binding: Symbol }>\n      let scopesetBindingList = bindings.get(this);\n\n      if (scopesetBindingList) {\n        // { scopes: List<Scope>, binding: Symbol }\n        let biggestBindingPair = scopesetBindingList.filter(({scopes}) => {\n          return scopes.isSubset(stxScopes);\n        }).sort(sizeDecending);\n\n        if (biggestBindingPair.size >= 2 &&\n            biggestBindingPair.get(0).scopes.size === biggestBindingPair.get(1).scopes.size) {\n          let debugBase = '{' + stxScopes.map(s => s.toString()).join(', ') + '}';\n          let debugAmbigousScopesets = biggestBindingPair.map(({scopes}) => {\n            return '{' + scopes.map(s => s.toString()).join(', ') + '}';\n          }).join(', ');\n          throw new Error('Scopeset ' + debugBase + ' has ambiguous subsets ' + debugAmbigousScopesets);\n        } else if (biggestBindingPair.size !== 0) {\n          let bindingStr = biggestBindingPair.get(0).binding.toString();\n          if (Maybe.isJust(biggestBindingPair.get(0).alias)) {\n            // null never happens because we just checked if it is a Just\n            return biggestBindingPair.get(0).alias.getOrElse(null).resolve(phase);\n          }\n          return bindingStr;\n        }\n      }\n    }\n    return this.token.value;\n  }\n\n  val() {\n    assert(!this.match(\"delimiter\"), \"cannot get the val of a delimiter\");\n    if (this.match(\"string\")) {\n      return this.token.str;\n    }\n    if (this.match(\"template\")) {\n      return this.token.items.map(el => {\n        if (typeof el.match === 'function' && el.match(\"delimiter\")) {\n          return '${...}';\n        }\n        return el.slice.text;\n      }).join('');\n    }\n    return this.token.value;\n  }\n\n  lineNumber() {\n    if (!this.match(\"delimiter\")) {\n      return this.token.slice.startLocation.line;\n    } else {\n      return this.token.get(0).lineNumber();\n    }\n  }\n\n  setLineNumber(line: number) {\n    let newTok = {};\n    if (this.isDelimiter()) {\n      newTok = this.token.map(s => s.setLineNumber(line));\n    } else {\n      for (let key of Object.keys(this.token)) {\n        newTok[key] = this.token[key];\n      }\n      assert(newTok.slice && newTok.slice.startLocation, 'all tokens must have line info');\n      newTok.slice.startLocation.line = line;\n    }\n    return new Syntax(newTok, this);\n  }\n\n  // () -> List<Syntax>\n  inner() {\n    assert(this.match(\"delimiter\"), \"can only get the inner of a delimiter\");\n    return this.token.slice(1, this.token.size - 1);\n  }\n\n  addScope(scope: any, bindings: any, phase: number, options: any = { flip: false }) {\n    let token = this.match('delimiter') ? this.token.map(s => s.addScope(scope, bindings, phase, options)) : this.token;\n    if (this.match('template')) {\n      token = _.merge(token, {\n        items: token.items.map(it => {\n          if (it instanceof Syntax && it.match('delimiter')) {\n            return it.addScope(scope, bindings, phase, options);\n          }\n          return it;\n        })\n      });\n    }\n    let oldScopeset;\n    if (phase === ALL_PHASES) {\n      oldScopeset = this.scopesets.all;\n    } else {\n      oldScopeset = this.scopesets.phase.has(phase) ? this.scopesets.phase.get(phase) : List();\n    }\n    let newScopeset;\n    if (options.flip) {\n      let index = oldScopeset.indexOf(scope);\n      if (index !== -1) {\n        newScopeset = oldScopeset.remove(index);\n      } else {\n        newScopeset = oldScopeset.push(scope);\n      }\n    } else {\n      newScopeset = oldScopeset.push(scope);\n    }\n    let newstx = {\n      bindings,\n      scopesets: {\n        all: this.scopesets.all,\n        phase: this.scopesets.phase\n      }\n    };\n\n    if (phase === ALL_PHASES) {\n      newstx.scopesets.all = newScopeset;\n    } else {\n      newstx.scopesets.phase = newstx.scopesets.phase.set(phase, newScopeset);\n    }\n    return new Syntax(token, newstx);\n  }\n\n  removeScope(scope: any, phase: number) {\n    let token = this.match('delimiter') ? this.token.map(s => s.removeScope(scope, phase)) : this.token;\n    let phaseScopeset = this.scopesets.phase.has(phase) ? this.scopesets.phase.get(phase) : List();\n    let allScopeset = this.scopesets.all;\n    let newstx = {\n      bindings: this.bindings,\n      scopesets: {\n        all: this.scopesets.all,\n        phase: this.scopesets.phase\n      }\n    };\n\n    let phaseIndex = phaseScopeset.indexOf(scope);\n    let allIndex = allScopeset.indexOf(scope);\n    if (phaseIndex !== -1) {\n      newstx.scopesets.phase = this.scopesets.phase.set(phase, phaseScopeset.remove(phaseIndex));\n    } else if (allIndex !== -1) {\n      newstx.scopesets.all = allScopeset.remove(allIndex);\n    }\n    return new Syntax(token, newstx);\n  }\n\n  match(type: TokenTag, value: any) {\n    if (!Types[type]) {\n      throw new Error(type + \" is an invalid type\");\n    }\n    return Types[type].match(this.token) && (value == null ||\n      (value instanceof RegExp ? value.test(this.val()) : this.val() == value));\n  }\n\n  isIdentifier(value: string) {\n    return this.match(\"identifier\", value);\n  }\n\n  isAssign(value: string) {\n    return this.match(\"assign\", value);\n  }\n\n  isBooleanLiteral(value: boolean) {\n    return this.match(\"boolean\", value);\n  }\n\n  isKeyword(value: string) {\n    return this.match(\"keyword\", value);\n  }\n\n  isNullLiteral(value: any) {\n    return this.match(\"null\", value);\n  }\n\n  isNumericLiteral(value: number) {\n    return this.match(\"number\", value);\n  }\n\n  isPunctuator(value: string) {\n    return this.match(\"punctuator\", value);\n  }\n\n  isStringLiteral(value: string) {\n    return this.match(\"string\", value);\n  }\n\n  isRegularExpression(value: any) {\n    return this.match(\"regularExpression\", value);\n  }\n\n  isTemplate(value: any) {\n    return this.match(\"template\", value);\n  }\n\n  isDelimiter(value: any) {\n    return this.match(\"delimiter\", value);\n  }\n\n  isParens(value: any) {\n    return this.match(\"parens\", value);\n  }\n\n  isBraces(value: any) {\n    return this.match(\"braces\", value);\n  }\n\n  isBrackets(value: any) {\n    return this.match(\"brackets\", value);\n  }\n\n  isSyntaxTemplate(value: any) {\n    return this.match(\"syntaxTemplate\", value);\n  }\n\n  isEOF(value: any) {\n    return this.match(\"eof\", value);\n  }\n\n  toString() {\n    if (this.match(\"delimiter\")) {\n      return this.token.map(s => s.toString()).join(\" \");\n    }\n    if (this.match(\"string\")) {\n      return \"'\" + this.token.str;\n    }\n    if (this.match(\"template\")) {\n      return this.val();\n    }\n    return this.token.value;\n  }\n}\n"]} /***/ }, -/* 55 */ -/***/ function(module, exports, __webpack_require__) { +/* 47 */ +/***/ function(module, exports) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); + exports.gensym = gensym; + let internedMap = new Map(); - var _terms = __webpack_require__(28); - - var _terms2 = _interopRequireDefault(_terms); - - var _symbol = __webpack_require__(45); + let counter = 0; - var _transforms = __webpack_require__(32); - - var _errors = __webpack_require__(13); - - var _syntax = __webpack_require__(12); + function gensym(name) { + let prefix = name == null ? "s_" : name + "_"; + let sym = new Symbol(prefix + counter); + counter++; + return sym; + } - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + function Symbol(name) { + this.name = name; + } + Symbol.prototype.toString = function () { + return this.name; + }; - class ScopeApplyingReducer { - constructor(scope_0, context_1) { - this.context = context_1; - this.scope = scope_0; - } - transform(term_2) { - let field_3 = "transform" + term_2.type; - if (typeof this[field_3] === "function") { - return this[field_3](term_2); - } - (0, _errors.assert)(false, "transform not implemented yet for: " + term_2.type); - } - transformFormalParameters(term_4) { - let rest_5 = term_4.rest == null ? null : this.transform(term_4.rest); - return new _terms2.default("FormalParameters", { items: term_4.items.map(it_6 => this.transform(it_6)), rest: rest_5 }); - } - transformBindingWithDefault(term_7) { - return new _terms2.default("BindingWithDefault", { binding: this.transform(term_7.binding), init: term_7.init }); - } - transformObjectBinding(term_8) { - return term_8; - } - transformBindingPropertyIdentifier(term_9) { - return new _terms2.default("BindingPropertyIdentifier", { binding: this.transform(term_9.binding), init: term_9.init }); - } - transformBindingPropertyProperty(term_10) { - return new _terms2.default("BindingPropertyProperty", { name: term_10.name, binding: this.transform(term_10.binding) }); - } - transformArrayBinding(term_11) { - return new _terms2.default("ArrayBinding", { elements: term_11.elements.map(el_12 => this.transform(el_12)), restElement: term_11.restElement == null ? null : this.transform(term_11.restElement) }); - } - transformBindingIdentifier(term_13) { - let name_14 = term_13.name.addScope(this.scope, this.context.bindings, _syntax.ALL_PHASES); - let newBinding_15 = (0, _symbol.gensym)(name_14.val()); - this.context.env.set(newBinding_15.toString(), new _transforms.VarBindingTransform(name_14)); - this.context.bindings.add(name_14, { binding: newBinding_15, phase: this.context.phase, skipDup: true }); - return new _terms2.default("BindingIdentifier", { name: name_14 }); + function makeSymbol(name) { + if (internedMap.has(name)) { + return internedMap.get(name); + } else { + let sym = new Symbol(name); + internedMap.set(name, sym); + return sym; } } - exports.default = ScopeApplyingReducer; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2FwcGx5LXNjb3BlLWluLXBhcmFtcy1yZWR1Y2VyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOzs7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7QUFDZSxNQUFNLG9CQUFOLENBQTJCO0FBQ3hDLGNBQVksT0FBWixFQUFxQixTQUFyQixFQUFnQztBQUM5QixTQUFLLE9BQUwsR0FBZSxTQUFmO0FBQ0EsU0FBSyxLQUFMLEdBQWEsT0FBYjtBQUNEO0FBQ0QsWUFBVSxNQUFWLEVBQWtCO0FBQ2hCLFFBQUksVUFBVSxjQUFjLE9BQU8sSUFBbkM7QUFDQSxRQUFJLE9BQU8sS0FBSyxPQUFMLENBQVAsS0FBeUIsVUFBN0IsRUFBeUM7QUFDdkMsYUFBTyxLQUFLLE9BQUwsRUFBYyxNQUFkLENBQVA7QUFDRDtBQUNELHdCQUFPLEtBQVAsRUFBYyx3Q0FBd0MsT0FBTyxJQUE3RDtBQUNEO0FBQ0QsNEJBQTBCLE1BQTFCLEVBQWtDO0FBQ2hDLFFBQUksU0FBUyxPQUFPLElBQVAsSUFBZSxJQUFmLEdBQXNCLElBQXRCLEdBQTZCLEtBQUssU0FBTCxDQUFlLE9BQU8sSUFBdEIsQ0FBMUM7QUFDQSxXQUFPLG9CQUFTLGtCQUFULEVBQTZCLEVBQUMsT0FBTyxPQUFPLEtBQVAsQ0FBYSxHQUFiLENBQWlCLFFBQVEsS0FBSyxTQUFMLENBQWUsSUFBZixDQUF6QixDQUFSLEVBQXdELE1BQU0sTUFBOUQsRUFBN0IsQ0FBUDtBQUNEO0FBQ0QsOEJBQTRCLE1BQTVCLEVBQW9DO0FBQ2xDLFdBQU8sb0JBQVMsb0JBQVQsRUFBK0IsRUFBQyxTQUFTLEtBQUssU0FBTCxDQUFlLE9BQU8sT0FBdEIsQ0FBVixFQUEwQyxNQUFNLE9BQU8sSUFBdkQsRUFBL0IsQ0FBUDtBQUNEO0FBQ0QseUJBQXVCLE1BQXZCLEVBQStCO0FBQzdCLFdBQU8sTUFBUDtBQUNEO0FBQ0QscUNBQW1DLE1BQW5DLEVBQTJDO0FBQ3pDLFdBQU8sb0JBQVMsMkJBQVQsRUFBc0MsRUFBQyxTQUFTLEtBQUssU0FBTCxDQUFlLE9BQU8sT0FBdEIsQ0FBVixFQUEwQyxNQUFNLE9BQU8sSUFBdkQsRUFBdEMsQ0FBUDtBQUNEO0FBQ0QsbUNBQWlDLE9BQWpDLEVBQTBDO0FBQ3hDLFdBQU8sb0JBQVMseUJBQVQsRUFBb0MsRUFBQyxNQUFNLFFBQVEsSUFBZixFQUFxQixTQUFTLEtBQUssU0FBTCxDQUFlLFFBQVEsT0FBdkIsQ0FBOUIsRUFBcEMsQ0FBUDtBQUNEO0FBQ0Qsd0JBQXNCLE9BQXRCLEVBQStCO0FBQzdCLFdBQU8sb0JBQVMsY0FBVCxFQUF5QixFQUFDLFVBQVUsUUFBUSxRQUFSLENBQWlCLEdBQWpCLENBQXFCLFNBQVMsS0FBSyxTQUFMLENBQWUsS0FBZixDQUE5QixDQUFYLEVBQWlFLGFBQWEsUUFBUSxXQUFSLElBQXVCLElBQXZCLEdBQThCLElBQTlCLEdBQXFDLEtBQUssU0FBTCxDQUFlLFFBQVEsV0FBdkIsQ0FBbkgsRUFBekIsQ0FBUDtBQUNEO0FBQ0QsNkJBQTJCLE9BQTNCLEVBQW9DO0FBQ2xDLFFBQUksVUFBVSxRQUFRLElBQVIsQ0FBYSxRQUFiLENBQXNCLEtBQUssS0FBM0IsRUFBa0MsS0FBSyxPQUFMLENBQWEsUUFBL0MscUJBQWQ7QUFDQSxRQUFJLGdCQUFnQixvQkFBTyxRQUFRLEdBQVIsRUFBUCxDQUFwQjtBQUNBLFNBQUssT0FBTCxDQUFhLEdBQWIsQ0FBaUIsR0FBakIsQ0FBcUIsY0FBYyxRQUFkLEVBQXJCLEVBQStDLG9DQUF3QixPQUF4QixDQUEvQztBQUNBLFNBQUssT0FBTCxDQUFhLFFBQWIsQ0FBc0IsR0FBdEIsQ0FBMEIsT0FBMUIsRUFBbUMsRUFBQyxTQUFTLGFBQVYsRUFBeUIsT0FBTyxLQUFLLE9BQUwsQ0FBYSxLQUE3QyxFQUFvRCxTQUFTLElBQTdELEVBQW5DO0FBQ0EsV0FBTyxvQkFBUyxtQkFBVCxFQUE4QixFQUFDLE1BQU0sT0FBUCxFQUE5QixDQUFQO0FBQ0Q7QUFyQ3VDO2tCQUFyQixvQiIsImZpbGUiOiJhcHBseS1zY29wZS1pbi1wYXJhbXMtcmVkdWNlci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBUZXJtIGZyb20gXCIuL3Rlcm1zXCI7XG5pbXBvcnQge2dlbnN5bX0gZnJvbSBcIi4vc3ltYm9sXCI7XG5pbXBvcnQge1ZhckJpbmRpbmdUcmFuc2Zvcm19IGZyb20gXCIuL3RyYW5zZm9ybXNcIjtcbmltcG9ydCB7YXNzZXJ0fSBmcm9tIFwiLi9lcnJvcnNcIjtcbmltcG9ydCB7QUxMX1BIQVNFU30gZnJvbSBcIi4vc3ludGF4XCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBTY29wZUFwcGx5aW5nUmVkdWNlciB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlXzAsIGNvbnRleHRfMSkge1xuICAgIHRoaXMuY29udGV4dCA9IGNvbnRleHRfMTtcbiAgICB0aGlzLnNjb3BlID0gc2NvcGVfMDtcbiAgfVxuICB0cmFuc2Zvcm0odGVybV8yKSB7XG4gICAgbGV0IGZpZWxkXzMgPSBcInRyYW5zZm9ybVwiICsgdGVybV8yLnR5cGU7XG4gICAgaWYgKHR5cGVvZiB0aGlzW2ZpZWxkXzNdID09PSBcImZ1bmN0aW9uXCIpIHtcbiAgICAgIHJldHVybiB0aGlzW2ZpZWxkXzNdKHRlcm1fMik7XG4gICAgfVxuICAgIGFzc2VydChmYWxzZSwgXCJ0cmFuc2Zvcm0gbm90IGltcGxlbWVudGVkIHlldCBmb3I6IFwiICsgdGVybV8yLnR5cGUpO1xuICB9XG4gIHRyYW5zZm9ybUZvcm1hbFBhcmFtZXRlcnModGVybV80KSB7XG4gICAgbGV0IHJlc3RfNSA9IHRlcm1fNC5yZXN0ID09IG51bGwgPyBudWxsIDogdGhpcy50cmFuc2Zvcm0odGVybV80LnJlc3QpO1xuICAgIHJldHVybiBuZXcgVGVybShcIkZvcm1hbFBhcmFtZXRlcnNcIiwge2l0ZW1zOiB0ZXJtXzQuaXRlbXMubWFwKGl0XzYgPT4gdGhpcy50cmFuc2Zvcm0oaXRfNikpLCByZXN0OiByZXN0XzV9KTtcbiAgfVxuICB0cmFuc2Zvcm1CaW5kaW5nV2l0aERlZmF1bHQodGVybV83KSB7XG4gICAgcmV0dXJuIG5ldyBUZXJtKFwiQmluZGluZ1dpdGhEZWZhdWx0XCIsIHtiaW5kaW5nOiB0aGlzLnRyYW5zZm9ybSh0ZXJtXzcuYmluZGluZyksIGluaXQ6IHRlcm1fNy5pbml0fSk7XG4gIH1cbiAgdHJhbnNmb3JtT2JqZWN0QmluZGluZyh0ZXJtXzgpIHtcbiAgICByZXR1cm4gdGVybV84O1xuICB9XG4gIHRyYW5zZm9ybUJpbmRpbmdQcm9wZXJ0eUlkZW50aWZpZXIodGVybV85KSB7XG4gICAgcmV0dXJuIG5ldyBUZXJtKFwiQmluZGluZ1Byb3BlcnR5SWRlbnRpZmllclwiLCB7YmluZGluZzogdGhpcy50cmFuc2Zvcm0odGVybV85LmJpbmRpbmcpLCBpbml0OiB0ZXJtXzkuaW5pdH0pO1xuICB9XG4gIHRyYW5zZm9ybUJpbmRpbmdQcm9wZXJ0eVByb3BlcnR5KHRlcm1fMTApIHtcbiAgICByZXR1cm4gbmV3IFRlcm0oXCJCaW5kaW5nUHJvcGVydHlQcm9wZXJ0eVwiLCB7bmFtZTogdGVybV8xMC5uYW1lLCBiaW5kaW5nOiB0aGlzLnRyYW5zZm9ybSh0ZXJtXzEwLmJpbmRpbmcpfSk7XG4gIH1cbiAgdHJhbnNmb3JtQXJyYXlCaW5kaW5nKHRlcm1fMTEpIHtcbiAgICByZXR1cm4gbmV3IFRlcm0oXCJBcnJheUJpbmRpbmdcIiwge2VsZW1lbnRzOiB0ZXJtXzExLmVsZW1lbnRzLm1hcChlbF8xMiA9PiB0aGlzLnRyYW5zZm9ybShlbF8xMikpLCByZXN0RWxlbWVudDogdGVybV8xMS5yZXN0RWxlbWVudCA9PSBudWxsID8gbnVsbCA6IHRoaXMudHJhbnNmb3JtKHRlcm1fMTEucmVzdEVsZW1lbnQpfSk7XG4gIH1cbiAgdHJhbnNmb3JtQmluZGluZ0lkZW50aWZpZXIodGVybV8xMykge1xuICAgIGxldCBuYW1lXzE0ID0gdGVybV8xMy5uYW1lLmFkZFNjb3BlKHRoaXMuc2NvcGUsIHRoaXMuY29udGV4dC5iaW5kaW5ncywgQUxMX1BIQVNFUyk7XG4gICAgbGV0IG5ld0JpbmRpbmdfMTUgPSBnZW5zeW0obmFtZV8xNC52YWwoKSk7XG4gICAgdGhpcy5jb250ZXh0LmVudi5zZXQobmV3QmluZGluZ18xNS50b1N0cmluZygpLCBuZXcgVmFyQmluZGluZ1RyYW5zZm9ybShuYW1lXzE0KSk7XG4gICAgdGhpcy5jb250ZXh0LmJpbmRpbmdzLmFkZChuYW1lXzE0LCB7YmluZGluZzogbmV3QmluZGluZ18xNSwgcGhhc2U6IHRoaXMuY29udGV4dC5waGFzZSwgc2tpcER1cDogdHJ1ZX0pO1xuICAgIHJldHVybiBuZXcgVGVybShcIkJpbmRpbmdJZGVudGlmaWVyXCIsIHtuYW1lOiBuYW1lXzE0fSk7XG4gIH1cbn1cbiJdfQ== + + exports.Symbol = makeSymbol; + exports.SymbolClass = Symbol; + //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zeW1ib2wuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7UUFJZ0IsTSxHQUFBLE07QUFKaEIsSUFBSSxjQUFjLElBQUksR0FBSixFQUFsQjs7QUFFQSxJQUFJLFVBQVUsQ0FBZDs7QUFFTyxTQUFTLE1BQVQsQ0FBZ0IsSUFBaEIsRUFBc0I7QUFDM0IsTUFBSSxTQUFTLFFBQVEsSUFBUixHQUFlLElBQWYsR0FBc0IsT0FBTyxHQUExQztBQUNBLE1BQUksTUFBTSxJQUFJLE1BQUosQ0FBVyxTQUFTLE9BQXBCLENBQVY7QUFDQTtBQUNBLFNBQU8sR0FBUDtBQUNEOztBQUVELFNBQVMsTUFBVCxDQUFnQixJQUFoQixFQUFzQjtBQUNwQixPQUFLLElBQUwsR0FBWSxJQUFaO0FBQ0Q7QUFDRCxPQUFPLFNBQVAsQ0FBaUIsUUFBakIsR0FBNEIsWUFBWTtBQUN0QyxTQUFPLEtBQUssSUFBWjtBQUNELENBRkQ7O0FBSUEsU0FBUyxVQUFULENBQW9CLElBQXBCLEVBQTBCO0FBQ3hCLE1BQUksWUFBWSxHQUFaLENBQWdCLElBQWhCLENBQUosRUFBMkI7QUFDekIsV0FBTyxZQUFZLEdBQVosQ0FBZ0IsSUFBaEIsQ0FBUDtBQUNELEdBRkQsTUFFTztBQUNMLFFBQUksTUFBTSxJQUFJLE1BQUosQ0FBVyxJQUFYLENBQVY7QUFDQSxnQkFBWSxHQUFaLENBQWdCLElBQWhCLEVBQXNCLEdBQXRCO0FBQ0EsV0FBTyxHQUFQO0FBQ0Q7QUFDRjs7UUFHZSxNLEdBQWQsVTtRQUNVLFcsR0FBVixNIiwiZmlsZSI6InN5bWJvbC5qcyIsInNvdXJjZXNDb250ZW50IjpbImxldCBpbnRlcm5lZE1hcCA9IG5ldyBNYXAoKTtcblxubGV0IGNvdW50ZXIgPSAwO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2Vuc3ltKG5hbWUpIHtcbiAgbGV0IHByZWZpeCA9IG5hbWUgPT0gbnVsbCA/IFwic19cIiA6IG5hbWUgKyBcIl9cIjtcbiAgbGV0IHN5bSA9IG5ldyBTeW1ib2wocHJlZml4ICsgY291bnRlcik7XG4gIGNvdW50ZXIrKztcbiAgcmV0dXJuIHN5bTtcbn1cblxuZnVuY3Rpb24gU3ltYm9sKG5hbWUpIHtcbiAgdGhpcy5uYW1lID0gbmFtZTtcbn1cblN5bWJvbC5wcm90b3R5cGUudG9TdHJpbmcgPSBmdW5jdGlvbiAoKSB7XG4gIHJldHVybiB0aGlzLm5hbWU7XG59O1xuXG5mdW5jdGlvbiBtYWtlU3ltYm9sKG5hbWUpIHtcbiAgaWYgKGludGVybmVkTWFwLmhhcyhuYW1lKSkge1xuICAgIHJldHVybiBpbnRlcm5lZE1hcC5nZXQobmFtZSk7XG4gIH0gZWxzZSB7XG4gICAgbGV0IHN5bSA9IG5ldyBTeW1ib2wobmFtZSk7XG4gICAgaW50ZXJuZWRNYXAuc2V0KG5hbWUsIHN5bSk7XG4gICAgcmV0dXJuIHN5bTtcbiAgfVxufVxuXG5leHBvcnQge1xuICBtYWtlU3ltYm9sIGFzIFN5bWJvbCxcbiAgU3ltYm9sIGFzIFN5bWJvbENsYXNzXG59O1xuIl19 /***/ }, -/* 56 */ +/* 48 */ /***/ function(module, exports, __webpack_require__) { - "use strict"; + 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); + exports.sanitizeReplacementValues = sanitizeReplacementValues; + exports.evalRuntimeValues = evalRuntimeValues; + exports.evalCompiletimeValue = evalCompiletimeValue; - var _immutable = __webpack_require__(11); + var _ramda = __webpack_require__(10); - var _termExpander = __webpack_require__(54); + var _ = _interopRequireWildcard(_ramda); - var _termExpander2 = _interopRequireDefault(_termExpander); + var _immutable = __webpack_require__(3); - var _tokenExpander = __webpack_require__(50); + var _parseReducer = __webpack_require__(8); - var _tokenExpander2 = _interopRequireDefault(_tokenExpander); + var _parseReducer2 = _interopRequireDefault(_parseReducer); - var _scope = __webpack_require__(44); + var _shiftReducer = __webpack_require__(4); - var _ramda = __webpack_require__(27); + var _shiftReducer2 = _interopRequireDefault(_shiftReducer); - var _ = _interopRequireWildcard(_ramda); + var _serializer = __webpack_require__(49); - function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + var _syntax = __webpack_require__(46); + + var _syntax2 = _interopRequireDefault(_syntax); + + var _shiftCodegen = __webpack_require__(12); + + var _shiftCodegen2 = _interopRequireDefault(_shiftCodegen); + + var _terms = __webpack_require__(9); + + var _terms2 = _interopRequireDefault(_terms); + + var _shiftReader = __webpack_require__(42); + + var _shiftReader2 = _interopRequireDefault(_shiftReader); + + var _macroContext = __webpack_require__(55); + + var _templateProcessor = __webpack_require__(59); + + var _vm = __webpack_require__(40); + + var _vm2 = _interopRequireDefault(_vm); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - class Compiler { - constructor(phase_33, env_34, store_35, context_36) { - this.phase = phase_33; - this.env = env_34; - this.store = store_35; - this.context = context_36; - } - compile(stxl_37) { - let tokenExpander_38 = new _tokenExpander2.default(_.merge(this.context, { phase: this.phase, env: this.env, store: this.store })); - let termExpander_39 = new _termExpander2.default(_.merge(this.context, { phase: this.phase, env: this.env, store: this.store })); - return _.pipe(_.bind(tokenExpander_38.expand, tokenExpander_38), _.map(t_40 => termExpander_39.expand(t_40)))(stxl_37); + function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + + function sanitizeReplacementValues(values) { + if (Array.isArray(values)) { + return sanitizeReplacementValues((0, _immutable.List)(values)); + } else if (_immutable.List.isList(values)) { + return values.map(sanitizeReplacementValues); + } else if (values == null) { + throw new Error("replacement values for syntax template must not be null or undefined"); + } else if (typeof values.next === 'function') { + return sanitizeReplacementValues((0, _immutable.List)(values)); } + return (0, _macroContext.unwrap)(values); } - exports.default = Compiler; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2NvbXBpbGVyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOztBQUNBOzs7O0FBQ0E7Ozs7QUFDQTs7QUFDQTs7SUFBYSxDOzs7Ozs7QUFDRSxNQUFNLFFBQU4sQ0FBZTtBQUM1QixjQUFZLFFBQVosRUFBc0IsTUFBdEIsRUFBOEIsUUFBOUIsRUFBd0MsVUFBeEMsRUFBb0Q7QUFDbEQsU0FBSyxLQUFMLEdBQWEsUUFBYjtBQUNBLFNBQUssR0FBTCxHQUFXLE1BQVg7QUFDQSxTQUFLLEtBQUwsR0FBYSxRQUFiO0FBQ0EsU0FBSyxPQUFMLEdBQWUsVUFBZjtBQUNEO0FBQ0QsVUFBUSxPQUFSLEVBQWlCO0FBQ2YsUUFBSSxtQkFBbUIsNEJBQWtCLEVBQUUsS0FBRixDQUFRLEtBQUssT0FBYixFQUFzQixFQUFDLE9BQU8sS0FBSyxLQUFiLEVBQW9CLEtBQUssS0FBSyxHQUE5QixFQUFtQyxPQUFPLEtBQUssS0FBL0MsRUFBdEIsQ0FBbEIsQ0FBdkI7QUFDQSxRQUFJLGtCQUFrQiwyQkFBaUIsRUFBRSxLQUFGLENBQVEsS0FBSyxPQUFiLEVBQXNCLEVBQUMsT0FBTyxLQUFLLEtBQWIsRUFBb0IsS0FBSyxLQUFLLEdBQTlCLEVBQW1DLE9BQU8sS0FBSyxLQUEvQyxFQUF0QixDQUFqQixDQUF0QjtBQUNBLFdBQU8sRUFBRSxJQUFGLENBQU8sRUFBRSxJQUFGLENBQU8saUJBQWlCLE1BQXhCLEVBQWdDLGdCQUFoQyxDQUFQLEVBQTBELEVBQUUsR0FBRixDQUFNLFFBQVEsZ0JBQWdCLE1BQWhCLENBQXVCLElBQXZCLENBQWQsQ0FBMUQsRUFBdUcsT0FBdkcsQ0FBUDtBQUNEO0FBWDJCO2tCQUFULFEiLCJmaWxlIjoiY29tcGlsZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0xpc3R9IGZyb20gXCJpbW11dGFibGVcIjtcbmltcG9ydCBUZXJtRXhwYW5kZXIgZnJvbSBcIi4vdGVybS1leHBhbmRlci5qc1wiO1xuaW1wb3J0IFRva2VuRXhwYW5kZXIgZnJvbSBcIi4vdG9rZW4tZXhwYW5kZXJcIjtcbmltcG9ydCB7U2NvcGUsIGZyZXNoU2NvcGV9IGZyb20gXCIuL3Njb3BlXCI7XG5pbXBvcnQgICogYXMgXyBmcm9tIFwicmFtZGFcIjtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENvbXBpbGVyIHtcbiAgY29uc3RydWN0b3IocGhhc2VfMzMsIGVudl8zNCwgc3RvcmVfMzUsIGNvbnRleHRfMzYpIHtcbiAgICB0aGlzLnBoYXNlID0gcGhhc2VfMzM7XG4gICAgdGhpcy5lbnYgPSBlbnZfMzQ7XG4gICAgdGhpcy5zdG9yZSA9IHN0b3JlXzM1O1xuICAgIHRoaXMuY29udGV4dCA9IGNvbnRleHRfMzY7XG4gIH1cbiAgY29tcGlsZShzdHhsXzM3KSB7XG4gICAgbGV0IHRva2VuRXhwYW5kZXJfMzggPSBuZXcgVG9rZW5FeHBhbmRlcihfLm1lcmdlKHRoaXMuY29udGV4dCwge3BoYXNlOiB0aGlzLnBoYXNlLCBlbnY6IHRoaXMuZW52LCBzdG9yZTogdGhpcy5zdG9yZX0pKTtcbiAgICBsZXQgdGVybUV4cGFuZGVyXzM5ID0gbmV3IFRlcm1FeHBhbmRlcihfLm1lcmdlKHRoaXMuY29udGV4dCwge3BoYXNlOiB0aGlzLnBoYXNlLCBlbnY6IHRoaXMuZW52LCBzdG9yZTogdGhpcy5zdG9yZX0pKTtcbiAgICByZXR1cm4gXy5waXBlKF8uYmluZCh0b2tlbkV4cGFuZGVyXzM4LmV4cGFuZCwgdG9rZW5FeHBhbmRlcl8zOCksIF8ubWFwKHRfNDAgPT4gdGVybUV4cGFuZGVyXzM5LmV4cGFuZCh0XzQwKSkpKHN0eGxfMzcpO1xuICB9XG59XG4iXX0= + + function evalRuntimeValues(terms, context) { + let prepped = terms.reduce((acc, term) => { + if ((0, _terms.isExport)(term)) { + if ((0, _terms.isVariableDeclaration)(term.declaration)) { + return acc.concat(new _terms2.default('VariableDeclarationStatement', { + declaration: term.declaration + })).concat(term.declaration.declarators.map(decl => { + return new _terms2.default('ExpressionStatement', { + expression: new _terms2.default('AssignmentExpression', { + binding: new _terms2.default('StaticMemberExpression', { + object: new _terms2.default('IdentifierExpression', { + name: _syntax2.default.fromIdentifier('exports') + }), + property: decl.binding.name + }), + expression: new _terms2.default('IdentifierExpression', { + name: decl.binding.name + }) + }) + }); + })); + } + } else if ((0, _terms.isImport)(term)) { + return acc; + } + return acc.concat(term); + }, (0, _immutable.List)()); + let parsed = (0, _shiftReducer2.default)(new _parseReducer2.default(context, false), new _terms2.default('Module', { + directives: (0, _immutable.List)(), + items: prepped + }).gen(false)); + + let gen = (0, _shiftCodegen2.default)(parsed, new _shiftCodegen.FormattedCodeGen()); + let result = context.transform(gen, { + babelrc: true, + filename: context.filename + }); + + let exportsObj = {}; + context.store.set('exports', exportsObj); + + _vm2.default.runInContext(result.code, context.store.getNodeContext()); + return exportsObj; + } + + // (Expression, Context) -> [function] + function evalCompiletimeValue(expr, context) { + let deserializer = (0, _serializer.makeDeserializer)(context.bindings); + let sandbox = { + syntaxQuote: function syntaxQuote(strings) { + for (var _len = arguments.length, values = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + values[_key - 1] = arguments[_key]; + } + + let ctx = deserializer.read(_.last(values)); + let reader = new _shiftReader2.default(strings, ctx, _.take(values.length - 1, values)); + return reader.read(); + }, + syntaxTemplate: function syntaxTemplate(str) { + for (var _len2 = arguments.length, values = Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { + values[_key2 - 1] = arguments[_key2]; + } + + return (0, _templateProcessor.replaceTemplate)(deserializer.read(str), sanitizeReplacementValues(values)); + } + }; + + let sandboxKeys = (0, _immutable.List)(Object.keys(sandbox)); + let sandboxVals = sandboxKeys.map(k => sandbox[k]).toArray(); + + let parsed = (0, _shiftReducer2.default)(new _parseReducer2.default(context), new _terms2.default("Module", { + directives: (0, _immutable.List)(), + items: _immutable.List.of(new _terms2.default("ExpressionStatement", { + expression: new _terms2.default("FunctionExpression", { + isGenerator: false, + name: null, + params: new _terms2.default("FormalParameters", { + items: sandboxKeys.map(param => { + return new _terms2.default("BindingIdentifier", { + name: _syntax2.default.from("identifier", param) + }); + }), + rest: null + }), + body: new _terms2.default("FunctionBody", { + directives: _immutable.List.of(new _terms2.default('Directive', { + rawValue: 'use strict' + })), + statements: _immutable.List.of(new _terms2.default("ReturnStatement", { + expression: expr + })) + }) + }) + })) + })); + + let gen = (0, _shiftCodegen2.default)(parsed, new _shiftCodegen.FormattedCodeGen()); + let result = context.transform(gen, { + babelrc: true, + filename: context.filename + }); + + let val = _vm2.default.runInContext(result.code, context.store.getNodeContext()); + return val.apply(undefined, sandboxVals); + } + //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/load-syntax.js"],"names":[],"mappings":"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","file":"load-syntax.js","sourcesContent":["import * as _ from 'ramda';\nimport { List } from 'immutable';\nimport ParseReducer from './parse-reducer.js';\nimport reducer from \"shift-reducer\";\nimport { makeDeserializer } from './serializer';\nimport Syntax from \"./syntax\";\nimport codegen, { FormattedCodeGen } from 'shift-codegen';\nimport Term, { isVariableDeclaration, isImport, isExport } from \"./terms\";\nimport Reader from './shift-reader';\n\nimport { unwrap } from './macro-context';\n\nimport { replaceTemplate } from './template-processor';\n\nimport vm from \"vm\";\n\nexport function sanitizeReplacementValues(values) {\n  if (Array.isArray(values)) {\n    return sanitizeReplacementValues(List(values));\n  } else if (List.isList(values)) {\n    return values.map(sanitizeReplacementValues);\n  } else if (values == null) {\n    throw new Error(\"replacement values for syntax template must not be null or undefined\");\n  } else if (typeof values.next === 'function') {\n    return sanitizeReplacementValues(List(values));\n  }\n  return unwrap(values);\n}\n\nexport function evalRuntimeValues(terms, context) {\n  let prepped = terms.reduce((acc, term) => {\n    if (isExport(term)) {\n      if (isVariableDeclaration(term.declaration)) {\n        return acc.concat(new Term('VariableDeclarationStatement', {\n          declaration: term.declaration\n        })).concat(term.declaration.declarators.map(decl => {\n          return new Term('ExpressionStatement', {\n            expression: new Term('AssignmentExpression', {\n              binding: new Term('StaticMemberExpression', {\n                object: new Term('IdentifierExpression', {\n                  name: Syntax.fromIdentifier('exports')\n                }),\n                property: decl.binding.name\n              }),\n              expression: new Term('IdentifierExpression', {\n                name: decl.binding.name\n              })\n            })\n          });\n        }));\n      }\n    } else if (isImport(term)) {\n      return acc;\n    }\n    return acc.concat(term);\n  }, List());\n  let parsed = reducer(new ParseReducer(context, false), new Term('Module', {\n    directives: List(),\n    items: prepped\n  }).gen(false));\n\n  let gen = codegen(parsed, new FormattedCodeGen);\n  let result = context.transform(gen, {\n    babelrc: true,\n    filename: context.filename\n  });\n\n  let exportsObj = {};\n  context.store.set('exports', exportsObj);\n\n  vm.runInContext(result.code, context.store.getNodeContext());\n  return exportsObj;\n}\n\n// (Expression, Context) -> [function]\nexport function evalCompiletimeValue(expr, context) {\n  let deserializer = makeDeserializer(context.bindings);\n  let sandbox = {\n    syntaxQuote: function (strings, ...values) {\n      let ctx = deserializer.read(_.last(values));\n      let reader = new Reader(strings, ctx, _.take(values.length - 1, values));\n      return reader.read();\n    },\n    syntaxTemplate: function(str, ...values) {\n      return replaceTemplate(deserializer.read(str), sanitizeReplacementValues(values));\n    }\n  };\n\n  let sandboxKeys = List(Object.keys(sandbox));\n  let sandboxVals = sandboxKeys.map(k => sandbox[k]).toArray();\n\n  let parsed = reducer(new ParseReducer(context), new Term(\"Module\", {\n    directives: List(),\n    items: List.of(new Term(\"ExpressionStatement\", {\n      expression: new Term(\"FunctionExpression\", {\n        isGenerator: false,\n        name: null,\n        params: new Term(\"FormalParameters\", {\n          items: sandboxKeys.map(param => {\n            return new Term(\"BindingIdentifier\", {\n              name: Syntax.from(\"identifier\", param)\n            });\n          }),\n          rest: null\n        }),\n        body: new Term(\"FunctionBody\", {\n          directives: List.of(new Term('Directive', {\n            rawValue: 'use strict'\n          })),\n          statements: List.of(new Term(\"ReturnStatement\", {\n            expression: expr\n          }))\n        })\n      })\n    }))\n  }));\n\n  let gen = codegen(parsed, new FormattedCodeGen);\n  let result = context.transform(gen, {\n    babelrc: true,\n    filename: context.filename\n  });\n\n  let val = vm.runInContext(result.code, context.store.getNodeContext());\n  return val.apply(undefined, sandboxVals);\n}\n"]} /***/ }, -/* 57 */ +/* 49 */ /***/ function(module, exports, __webpack_require__) { "use strict"; @@ -33148,73 +31433,110 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack }); exports.serializer = exports.makeDeserializer = undefined; - var _transitJs = __webpack_require__(58); + var _transitJs = __webpack_require__(50); var _transitJs2 = _interopRequireDefault(_transitJs); - var _immutable = __webpack_require__(11); + var _immutable = __webpack_require__(3); - var _syntax = __webpack_require__(12); + var _syntax = __webpack_require__(46); var _syntax2 = _interopRequireDefault(_syntax); - var _symbol = __webpack_require__(45); + var _symbol = __webpack_require__(47); - var _tokenizer = __webpack_require__(4); + var _tokenizer = __webpack_require__(43); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - let typeMap_630 = [_tokenizer.TokenType.STRING, _tokenizer.TokenType.EOS, _tokenizer.TokenType.LPAREN, _tokenizer.TokenType.RPAREN, _tokenizer.TokenType.LBRACK, _tokenizer.TokenType.RBRACK, _tokenizer.TokenType.LBRACE, _tokenizer.TokenType.RBRACE, _tokenizer.TokenType.COLON, _tokenizer.TokenType.SEMICOLON, _tokenizer.TokenType.PERIOD, _tokenizer.TokenType.ELLIPSIS, _tokenizer.TokenType.ARROW, _tokenizer.TokenType.CONDITIONAL, _tokenizer.TokenType.INC, _tokenizer.TokenType.DEC, _tokenizer.TokenType.ASSIGN, _tokenizer.TokenType.ASSIGN_BIT_OR, _tokenizer.TokenType.ASSIGN_BIT_XOR, _tokenizer.TokenType.ASSIGN_BIT_AND, _tokenizer.TokenType.ASSIGN_SHL, _tokenizer.TokenType.ASSIGN_SHR, _tokenizer.TokenType.ASSIGN_SHR_UNSIGNED, _tokenizer.TokenType.ASSIGN_ADD, _tokenizer.TokenType.ASSIGN_SUB, _tokenizer.TokenType.ASSIGN_MUL, _tokenizer.TokenType.ASSIGN_DIV, _tokenizer.TokenType.ASSIGN_MOD, _tokenizer.TokenType.COMMA, _tokenizer.TokenType.OR, _tokenizer.TokenType.AND, _tokenizer.TokenType.BIT_OR, _tokenizer.TokenType.BIT_XOR, _tokenizer.TokenType.BIT_AND, _tokenizer.TokenType.SHL, _tokenizer.TokenType.SHR, _tokenizer.TokenType.SHR_UNSIGNED, _tokenizer.TokenType.ADD, _tokenizer.TokenType.SUB, _tokenizer.TokenType.MUL, _tokenizer.TokenType.DIV, _tokenizer.TokenType.MOD, _tokenizer.TokenType.EQ, _tokenizer.TokenType.NE, _tokenizer.TokenType.EQ_STRICT, _tokenizer.TokenType.NE_STRICT, _tokenizer.TokenType.LT, _tokenizer.TokenType.GT, _tokenizer.TokenType.LTE, _tokenizer.TokenType.GTE, _tokenizer.TokenType.INSTANCEOF, _tokenizer.TokenType.IN, _tokenizer.TokenType.NOT, _tokenizer.TokenType.BIT_NOT, _tokenizer.TokenType.AWAIT, _tokenizer.TokenType.DELETE, _tokenizer.TokenType.TYPEOF, _tokenizer.TokenType.VOID, _tokenizer.TokenType.BREAK, _tokenizer.TokenType.CASE, _tokenizer.TokenType.CATCH, _tokenizer.TokenType.CLASS, _tokenizer.TokenType.CONTINUE, _tokenizer.TokenType.DEBUGGER, _tokenizer.TokenType.DEFAULT, _tokenizer.TokenType.DO, _tokenizer.TokenType.ELSE, _tokenizer.TokenType.EXPORT, _tokenizer.TokenType.EXTENDS, _tokenizer.TokenType.FINALLY, _tokenizer.TokenType.FOR, _tokenizer.TokenType.FUNCTION, _tokenizer.TokenType.IF, _tokenizer.TokenType.IMPORT, _tokenizer.TokenType.LET, _tokenizer.TokenType.NEW, _tokenizer.TokenType.RETURN, _tokenizer.TokenType.SUPER, _tokenizer.TokenType.SWITCH, _tokenizer.TokenType.THIS, _tokenizer.TokenType.THROW, _tokenizer.TokenType.TRY, _tokenizer.TokenType.VAR, _tokenizer.TokenType.WHILE, _tokenizer.TokenType.WITH, _tokenizer.TokenType.NULL, _tokenizer.TokenType.TRUE, _tokenizer.TokenType.FALSE, _tokenizer.TokenType.YIELD, _tokenizer.TokenType.NUMBER, _tokenizer.TokenType.STRING, _tokenizer.TokenType.REGEXP, _tokenizer.TokenType.IDENTIFIER, _tokenizer.TokenType.CONST, _tokenizer.TokenType.TEMPLATE, _tokenizer.TokenType.ILLEGAL]; - let ListHandler_631 = _transitJs2.default.makeWriteHandler({ tag: () => "array", rep: v_637 => v_637 }); - let MapHandler_632 = _transitJs2.default.makeWriteHandler({ tag: function tag(v_638) { + let typeMap = [_tokenizer.TokenType.STRING, _tokenizer.TokenType.EOS, _tokenizer.TokenType.LPAREN, _tokenizer.TokenType.RPAREN, _tokenizer.TokenType.LBRACK, _tokenizer.TokenType.RBRACK, _tokenizer.TokenType.LBRACE, _tokenizer.TokenType.RBRACE, _tokenizer.TokenType.COLON, _tokenizer.TokenType.SEMICOLON, _tokenizer.TokenType.PERIOD, _tokenizer.TokenType.ELLIPSIS, _tokenizer.TokenType.ARROW, _tokenizer.TokenType.CONDITIONAL, _tokenizer.TokenType.INC, _tokenizer.TokenType.DEC, _tokenizer.TokenType.ASSIGN, _tokenizer.TokenType.ASSIGN_BIT_OR, _tokenizer.TokenType.ASSIGN_BIT_XOR, _tokenizer.TokenType.ASSIGN_BIT_AND, _tokenizer.TokenType.ASSIGN_SHL, _tokenizer.TokenType.ASSIGN_SHR, _tokenizer.TokenType.ASSIGN_SHR_UNSIGNED, _tokenizer.TokenType.ASSIGN_ADD, _tokenizer.TokenType.ASSIGN_SUB, _tokenizer.TokenType.ASSIGN_MUL, _tokenizer.TokenType.ASSIGN_DIV, _tokenizer.TokenType.ASSIGN_MOD, _tokenizer.TokenType.COMMA, _tokenizer.TokenType.OR, _tokenizer.TokenType.AND, _tokenizer.TokenType.BIT_OR, _tokenizer.TokenType.BIT_XOR, _tokenizer.TokenType.BIT_AND, _tokenizer.TokenType.SHL, _tokenizer.TokenType.SHR, _tokenizer.TokenType.SHR_UNSIGNED, _tokenizer.TokenType.ADD, _tokenizer.TokenType.SUB, _tokenizer.TokenType.MUL, _tokenizer.TokenType.DIV, _tokenizer.TokenType.MOD, _tokenizer.TokenType.EQ, _tokenizer.TokenType.NE, _tokenizer.TokenType.EQ_STRICT, _tokenizer.TokenType.NE_STRICT, _tokenizer.TokenType.LT, _tokenizer.TokenType.GT, _tokenizer.TokenType.LTE, _tokenizer.TokenType.GTE, _tokenizer.TokenType.INSTANCEOF, _tokenizer.TokenType.IN, _tokenizer.TokenType.NOT, _tokenizer.TokenType.BIT_NOT, _tokenizer.TokenType.AWAIT, _tokenizer.TokenType.DELETE, _tokenizer.TokenType.TYPEOF, _tokenizer.TokenType.VOID, _tokenizer.TokenType.BREAK, _tokenizer.TokenType.CASE, _tokenizer.TokenType.CATCH, _tokenizer.TokenType.CLASS, _tokenizer.TokenType.CONTINUE, _tokenizer.TokenType.DEBUGGER, _tokenizer.TokenType.DEFAULT, _tokenizer.TokenType.DO, _tokenizer.TokenType.ELSE, _tokenizer.TokenType.EXPORT, _tokenizer.TokenType.EXTENDS, _tokenizer.TokenType.FINALLY, _tokenizer.TokenType.FOR, _tokenizer.TokenType.FUNCTION, _tokenizer.TokenType.IF, _tokenizer.TokenType.IMPORT, _tokenizer.TokenType.LET, _tokenizer.TokenType.NEW, _tokenizer.TokenType.RETURN, _tokenizer.TokenType.SUPER, _tokenizer.TokenType.SWITCH, _tokenizer.TokenType.THIS, _tokenizer.TokenType.THROW, _tokenizer.TokenType.TRY, _tokenizer.TokenType.VAR, _tokenizer.TokenType.WHILE, _tokenizer.TokenType.WITH, _tokenizer.TokenType.NULL, _tokenizer.TokenType.TRUE, _tokenizer.TokenType.FALSE, _tokenizer.TokenType.YIELD, _tokenizer.TokenType.NUMBER, _tokenizer.TokenType.STRING, _tokenizer.TokenType.REGEXP, _tokenizer.TokenType.IDENTIFIER, _tokenizer.TokenType.CONST, _tokenizer.TokenType.TEMPLATE, _tokenizer.TokenType.ILLEGAL]; + + let ListHandler = _transitJs2.default.makeWriteHandler({ + tag: () => "array", + rep: v => v + }); + + let MapHandler = _transitJs2.default.makeWriteHandler({ + tag: function tag() { return "map"; - }, rep: function rep(v_639) { - return v_639; - }, stringRep: function stringRep(v_640) { + }, + rep: function rep(v) { + return v; + }, + stringRep: function stringRep() { return null; - } }); - let SyntaxHandler_633 = _transitJs2.default.makeWriteHandler({ tag: () => "stx", rep: v_641 => { - if (_immutable.List.isList(v_641.token)) { - return [v_641.token, v_641.scopesets]; + } + }); + + let SyntaxHandler = _transitJs2.default.makeWriteHandler({ + tag: () => "stx", + rep: v => { + if (_immutable.List.isList(v.token)) { + return [v.token, v.scopesets]; } else { - let t = _transitJs2.default.objectToMap(v_641.token); - t.set("type", typeMap_630.indexOf(v_641.token.type)); - return [t, v_641.scopesets]; - } - } }); - let SymbolHandler_634 = _transitJs2.default.makeWriteHandler({ tag: () => "symb", rep: v_642 => [v_642.name] }); - let writer_635 = _transitJs2.default.writer("json", { handlers: _transitJs2.default.map([_immutable.List, ListHandler_631, _immutable.Map, MapHandler_632, _syntax2.default, SyntaxHandler_633, _symbol.SymbolClass, SymbolHandler_634]) }); - function makeReader_636(bindings_643) { - return _transitJs2.default.reader("json", { arrayBuilder: { init: node_644 => (0, _immutable.List)().asMutable(), add: (ret_645, val_646, node_647) => ret_645.push(val_646), finalize: (ret_648, node_649) => ret_648.asImmutable(), fromArray: (arr_650, node_651) => (0, _immutable.List)(arr_650) }, mapBuilder: { init: function init(node_652) { + let t = _transitJs2.default.objectToMap(v.token); + t.set("type", typeMap.indexOf(v.token.type)); + return [t, v.scopesets]; + } + } + }); + let SymbolHandler = _transitJs2.default.makeWriteHandler({ + tag: () => "symb", + rep: v => [v.name] + }); + + let writer = _transitJs2.default.writer("json", { + handlers: _transitJs2.default.map([_immutable.List, ListHandler, _immutable.Map, MapHandler, _syntax2.default, SyntaxHandler, _symbol.SymbolClass, SymbolHandler]) + }); + + function makeReader(bindings) { + return _transitJs2.default.reader("json", { + arrayBuilder: { + init: () => (0, _immutable.List)().asMutable(), + add: (ret, val) => ret.push(val), + finalize: ret => ret.asImmutable(), + fromArray: arr => (0, _immutable.List)(arr) + }, + mapBuilder: { + init: function init() { return (0, _immutable.Map)().asMutable(); - }, add: function add(ret_653, key_654, val_655, node_656) { - return ret_653.set(key_654, val_655); - }, finalize: function finalize(ret_657, node_658) { - return ret_657.asImmutable(); - } }, handlers: { stx: rep_659 => { - let scopesets_660 = _transitJs2.default.mapToObject(rep_659[1]); - if (_immutable.List.isList(rep_659[0])) { - let token = rep_659[0]; - return new _syntax2.default(token, { bindings: bindings_643, scopesets: scopesets_660 }); + }, + add: function add(ret, key, val) { + return ret.set(key, val); + }, + finalize: function finalize(ret) { + return ret.asImmutable(); + } + }, + handlers: { + "stx": rep => { + let scopesets = _transitJs2.default.mapToObject(rep[1]); + if (_immutable.List.isList(rep[0])) { + let token = rep[0]; + return new _syntax2.default(token, { bindings: bindings, scopesets: scopesets }); } else { - let token = _transitJs2.default.mapToObject(rep_659[0]); - token.type = typeMap_630[rep_659[0].get("type")]; - token.slice = rep_659[0].has("slice") ? _transitJs2.default.mapToObject(rep_659[0].get("slice")) : undefined; + let token = _transitJs2.default.mapToObject(rep[0]); + token.type = typeMap[rep[0].get("type")]; + token.slice = rep[0].has("slice") ? _transitJs2.default.mapToObject(rep[0].get("slice")) : undefined; if (token.slice) { token.slice.startLocation = _transitJs2.default.mapToObject(token.slice.startLocation); } - return new _syntax2.default(token, { bindings: bindings_643, scopesets: scopesets_660 }); + return new _syntax2.default(token, { bindings: bindings, scopesets: scopesets }); } - }, symb: rep_661 => { - return (0, _symbol.Symbol)(rep_661[0]); - } } }); + }, + "symb": rep => { + return (0, _symbol.Symbol)(rep[0]); + } + } + }); } - exports.makeDeserializer = makeReader_636; - exports.serializer = writer_635; - //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/serializer.js"],"names":[],"mappings":"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","file":"serializer.js","sourcesContent":["import transit from \"transit-js\";\nimport {List, Map} from \"immutable\";\nimport Syntax from \"./syntax\";\nimport {Symbol, gensym, SymbolClass} from \"./symbol\";\nimport {TokenClass, TokenType} from \"shift-parser/dist/tokenizer\";\nlet typeMap_630 = [TokenType.STRING, TokenType.EOS, TokenType.LPAREN, TokenType.RPAREN, TokenType.LBRACK, TokenType.RBRACK, TokenType.LBRACE, TokenType.RBRACE, TokenType.COLON, TokenType.SEMICOLON, TokenType.PERIOD, TokenType.ELLIPSIS, TokenType.ARROW, TokenType.CONDITIONAL, TokenType.INC, TokenType.DEC, TokenType.ASSIGN, TokenType.ASSIGN_BIT_OR, TokenType.ASSIGN_BIT_XOR, TokenType.ASSIGN_BIT_AND, TokenType.ASSIGN_SHL, TokenType.ASSIGN_SHR, TokenType.ASSIGN_SHR_UNSIGNED, TokenType.ASSIGN_ADD, TokenType.ASSIGN_SUB, TokenType.ASSIGN_MUL, TokenType.ASSIGN_DIV, TokenType.ASSIGN_MOD, TokenType.COMMA, TokenType.OR, TokenType.AND, TokenType.BIT_OR, TokenType.BIT_XOR, TokenType.BIT_AND, TokenType.SHL, TokenType.SHR, TokenType.SHR_UNSIGNED, TokenType.ADD, TokenType.SUB, TokenType.MUL, TokenType.DIV, TokenType.MOD, TokenType.EQ, TokenType.NE, TokenType.EQ_STRICT, TokenType.NE_STRICT, TokenType.LT, TokenType.GT, TokenType.LTE, TokenType.GTE, TokenType.INSTANCEOF, TokenType.IN, TokenType.NOT, TokenType.BIT_NOT, TokenType.AWAIT, TokenType.DELETE, TokenType.TYPEOF, TokenType.VOID, TokenType.BREAK, TokenType.CASE, TokenType.CATCH, TokenType.CLASS, TokenType.CONTINUE, TokenType.DEBUGGER, TokenType.DEFAULT, TokenType.DO, TokenType.ELSE, TokenType.EXPORT, TokenType.EXTENDS, TokenType.FINALLY, TokenType.FOR, TokenType.FUNCTION, TokenType.IF, TokenType.IMPORT, TokenType.LET, TokenType.NEW, TokenType.RETURN, TokenType.SUPER, TokenType.SWITCH, TokenType.THIS, TokenType.THROW, TokenType.TRY, TokenType.VAR, TokenType.WHILE, TokenType.WITH, TokenType.NULL, TokenType.TRUE, TokenType.FALSE, TokenType.YIELD, TokenType.NUMBER, TokenType.STRING, TokenType.REGEXP, TokenType.IDENTIFIER, TokenType.CONST, TokenType.TEMPLATE, TokenType.ILLEGAL];\nlet ListHandler_631 = transit.makeWriteHandler({tag: () => \"array\", rep: v_637 => v_637});\nlet MapHandler_632 = transit.makeWriteHandler({tag: function (v_638) {\n  return \"map\";\n}, rep: function (v_639) {\n  return v_639;\n}, stringRep: function (v_640) {\n  return null;\n}});\nlet SyntaxHandler_633 = transit.makeWriteHandler({tag: () => \"stx\", rep: v_641 => {\n  if (List.isList(v_641.token)) {\n    return [v_641.token, v_641.scopesets];\n  } else {\n    let t = transit.objectToMap(v_641.token);\n    t.set(\"type\", typeMap_630.indexOf(v_641.token.type));\n    return [t, v_641.scopesets];\n  }\n}});\nlet SymbolHandler_634 = transit.makeWriteHandler({tag: () => \"symb\", rep: v_642 => [v_642.name]});\nlet writer_635 = transit.writer(\"json\", {handlers: transit.map([List, ListHandler_631, Map, MapHandler_632, Syntax, SyntaxHandler_633, SymbolClass, SymbolHandler_634])});\nfunction makeReader_636(bindings_643) {\n  return transit.reader(\"json\", {arrayBuilder: {init: node_644 => List().asMutable(), add: (ret_645, val_646, node_647) => ret_645.push(val_646), finalize: (ret_648, node_649) => ret_648.asImmutable(), fromArray: (arr_650, node_651) => List(arr_650)}, mapBuilder: {init: function (node_652) {\n    return Map().asMutable();\n  }, add: function (ret_653, key_654, val_655, node_656) {\n    return ret_653.set(key_654, val_655);\n  }, finalize: function (ret_657, node_658) {\n    return ret_657.asImmutable();\n  }}, handlers: {stx: rep_659 => {\n    let scopesets_660 = transit.mapToObject(rep_659[1]);\n    if (List.isList(rep_659[0])) {\n      let token = rep_659[0];\n      return new Syntax(token, {bindings: bindings_643, scopesets: scopesets_660});\n    } else {\n      let token = transit.mapToObject(rep_659[0]);\n      token.type = typeMap_630[rep_659[0].get(\"type\")];\n      token.slice = rep_659[0].has(\"slice\") ? transit.mapToObject(rep_659[0].get(\"slice\")) : undefined;\n      if (token.slice) {\n        token.slice.startLocation = transit.mapToObject(token.slice.startLocation);\n      }\n      return new Syntax(token, {bindings: bindings_643, scopesets: scopesets_660});\n    }\n  }, symb: rep_661 => {\n    return Symbol(rep_661[0]);\n  }}});\n}\nexport {makeReader_636 as makeDeserializer, writer_635 as serializer};\n"]} + + exports.makeDeserializer = makeReader; + exports.serializer = writer; + //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/serializer.js"],"names":[],"mappings":"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","file":"serializer.js","sourcesContent":["import transit from \"transit-js\";\nimport { List, Map } from \"immutable\";\nimport Syntax from \"./syntax\";\nimport { Symbol,  SymbolClass } from \"./symbol\";\nimport { TokenType } from \"shift-parser/dist/tokenizer\";\n\nlet typeMap = [TokenType.STRING, TokenType.EOS, TokenType.LPAREN, TokenType.RPAREN,\n               TokenType.LBRACK, TokenType.RBRACK, TokenType.LBRACE, TokenType.RBRACE,\n               TokenType.COLON, TokenType.SEMICOLON, TokenType.PERIOD, TokenType.ELLIPSIS,\n               TokenType.ARROW, TokenType.CONDITIONAL, TokenType.INC, TokenType.DEC,\n               TokenType.ASSIGN, TokenType.ASSIGN_BIT_OR, TokenType.ASSIGN_BIT_XOR,\n               TokenType.ASSIGN_BIT_AND, TokenType.ASSIGN_SHL, TokenType.ASSIGN_SHR,\n               TokenType.ASSIGN_SHR_UNSIGNED, TokenType.ASSIGN_ADD, TokenType.ASSIGN_SUB,\n               TokenType.ASSIGN_MUL, TokenType.ASSIGN_DIV, TokenType.ASSIGN_MOD,\n               TokenType.COMMA, TokenType.OR, TokenType.AND, TokenType.BIT_OR,\n               TokenType.BIT_XOR, TokenType.BIT_AND, TokenType.SHL, TokenType.SHR,\n               TokenType.SHR_UNSIGNED, TokenType.ADD, TokenType.SUB, TokenType.MUL,\n               TokenType.DIV, TokenType.MOD, TokenType.EQ, TokenType.NE,\n               TokenType.EQ_STRICT, TokenType.NE_STRICT, TokenType.LT, TokenType.GT,\n               TokenType.LTE, TokenType.GTE, TokenType.INSTANCEOF, TokenType.IN,\n               TokenType.NOT, TokenType.BIT_NOT, TokenType.AWAIT, TokenType.DELETE,\n               TokenType.TYPEOF, TokenType.VOID, TokenType.BREAK, TokenType.CASE,\n               TokenType.CATCH, TokenType.CLASS, TokenType.CONTINUE, TokenType.DEBUGGER,\n               TokenType.DEFAULT, TokenType.DO, TokenType.ELSE, TokenType.EXPORT,\n               TokenType.EXTENDS, TokenType.FINALLY, TokenType.FOR, TokenType.FUNCTION,\n               TokenType.IF, TokenType.IMPORT, TokenType.LET, TokenType.NEW,\n               TokenType.RETURN, TokenType.SUPER, TokenType.SWITCH, TokenType.THIS,\n               TokenType.THROW, TokenType.TRY, TokenType.VAR, TokenType.WHILE,\n               TokenType.WITH, TokenType.NULL, TokenType.TRUE, TokenType.FALSE,\n               TokenType.YIELD, TokenType.NUMBER, TokenType.STRING, TokenType.REGEXP,\n               TokenType.IDENTIFIER, TokenType.CONST, TokenType.TEMPLATE,\n               TokenType.ILLEGAL];\n\nlet ListHandler = transit.makeWriteHandler({\n  tag: () => \"array\",\n  rep: (v) => v\n});\n\nlet MapHandler = transit.makeWriteHandler({\n  tag: function() { return \"map\"; },\n  rep: function(v) { return v; },\n  stringRep: function() { return null; }\n});\n\nlet SyntaxHandler = transit.makeWriteHandler({\n  tag: () => \"stx\",\n  rep: (v) => {\n    if (List.isList(v.token)) {\n      return [v.token, v.scopesets];\n    } else {\n      let t = transit.objectToMap(v.token);\n      t.set(\"type\", typeMap.indexOf(v.token.type));\n      return [t, v.scopesets];\n    }\n  }\n});\nlet SymbolHandler = transit.makeWriteHandler({\n  tag: () => \"symb\",\n  rep: (v) =>  [v.name]\n});\n\nlet writer = transit.writer(\"json\", {\n  handlers: transit.map([\n    List, ListHandler,\n    Map, MapHandler,\n    Syntax, SyntaxHandler,\n    SymbolClass, SymbolHandler\n  ])\n});\n\nfunction makeReader(bindings) {\n  return transit.reader(\"json\", {\n    arrayBuilder: {\n      init: () => List().asMutable(),\n      add: (ret, val) => ret.push(val),\n      finalize: (ret) => ret.asImmutable(),\n      fromArray: (arr) => List(arr)\n    },\n    mapBuilder: {\n      init: function() { return Map().asMutable(); },\n      add: function(ret, key, val) { return ret.set(key, val); },\n      finalize: function(ret) { return ret.asImmutable(); }\n    },\n    handlers: {\n      \"stx\": (rep) => {\n        let scopesets = transit.mapToObject(rep[1]);\n        if (List.isList(rep[0])) {\n          let token = rep[0];\n          return new Syntax(token, {bindings, scopesets: scopesets});\n        } else {\n          let token = transit.mapToObject(rep[0]);\n          token.type = typeMap[rep[0].get(\"type\")];\n          token.slice = rep[0].has(\"slice\") ? transit.mapToObject(rep[0].get(\"slice\")) : undefined;\n          if (token.slice) {\n            token.slice.startLocation = transit.mapToObject(token.slice.startLocation);\n          }\n          return new Syntax(token, {bindings, scopesets: scopesets});\n        }\n      },\n      \"symb\": (rep) => {\n        return Symbol(rep[0]);\n      }\n    }\n  });\n}\n\nexport {\n  makeReader as makeDeserializer, writer as serializer\n};\n"]} /***/ }, -/* 58 */ +/* 50 */ /***/ function(module, exports, __webpack_require__) { /* WEBPACK VAR INJECTION */(function(Buffer) {// transit-js 0.8.847 @@ -35713,2484 +34035,5387 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack for (var b in this.defaults.handlers) { this.handlers[b] = this.defaults.handlers[b]; } - for (b in this.options.handlers) { - if (com.cognitect.transit.impl.decoder.isGroundHandler(b)) { - throw Error('Cannot override handler for ground type "' + b + '"'); + for (b in this.options.handlers) { + if (com.cognitect.transit.impl.decoder.isGroundHandler(b)) { + throw Error('Cannot override handler for ground type "' + b + '"'); + } + this.handlers[b] = this.options.handlers[b]; + } + this.preferStrings = null != this.options.preferStrings ? this.options.preferStrings : this.defaults.preferStrings; + this.preferBuffers = null != this.options.preferBuffers ? this.options.preferBuffers : this.defaults.preferBuffers; + this.defaultHandler = this.options.defaultHandler || this.defaults.defaultHandler; + this.mapBuilder = this.options.mapBuilder; + this.arrayBuilder = this.options.arrayBuilder; + }; + com.cognitect.transit.impl.decoder.Decoder.prototype.defaults = {handlers:{_:function(a, b) { + return com.cognitect.transit.types.nullValue(); + }, "?":function(a, b) { + return com.cognitect.transit.types.boolValue(a); + }, b:function(a, b) { + return com.cognitect.transit.types.binary(a, b); + }, i:function(a, b) { + return com.cognitect.transit.types.intValue(a); + }, n:function(a, b) { + return com.cognitect.transit.types.bigInteger(a); + }, d:function(a, b) { + return com.cognitect.transit.types.floatValue(a); + }, f:function(a, b) { + return com.cognitect.transit.types.bigDecimalValue(a); + }, c:function(a, b) { + return com.cognitect.transit.types.charValue(a); + }, ":":function(a, b) { + return com.cognitect.transit.types.keyword(a); + }, $:function(a, b) { + return com.cognitect.transit.types.symbol(a); + }, r:function(a, b) { + return com.cognitect.transit.types.uri(a); + }, z:function(a, b) { + return com.cognitect.transit.types.specialDouble(a); + }, "'":function(a, b) { + return a; + }, m:function(a, b) { + return com.cognitect.transit.types.date(a); + }, t:function(a, b) { + return com.cognitect.transit.types.verboseDate(a); + }, u:function(a, b) { + return com.cognitect.transit.types.uuid(a); + }, set:function(a, b) { + return com.cognitect.transit.types.set(a); + }, list:function(a, b) { + return com.cognitect.transit.types.list(a); + }, link:function(a, b) { + return com.cognitect.transit.types.link(a); + }, cmap:function(a, b) { + return com.cognitect.transit.types.map(a, !1); + }}, defaultHandler:function(a, b) { + return com.cognitect.transit.types.taggedValue(a, b); + }, preferStrings:!0, preferBuffers:!0}; + com.cognitect.transit.impl.decoder.Decoder.prototype.decode = function(a, b, c, d) { + if (null == a) { + return null; + } + switch(typeof a) { + case "string": + return this.decodeString(a, b, c, d); + case "object": + return com.cognitect.transit.util.isArray(a) ? "^ " === a[0] ? this.decodeArrayHash(a, b, c, d) : this.decodeArray(a, b, c, d) : this.decodeHash(a, b, c, d); + } + return a; + }; + com.cognitect.transit.impl.decoder.Decoder.prototype.decode = com.cognitect.transit.impl.decoder.Decoder.prototype.decode; + com.cognitect.transit.impl.decoder.Decoder.prototype.decodeString = function(a, b, c, d) { + return com.cognitect.transit.caching.isCacheable(a, c) ? (a = this.parseString(a, b, !1), b && b.write(a, c), a) : com.cognitect.transit.caching.isCacheCode(a) ? b.read(a, c) : this.parseString(a, b, c); + }; + com.cognitect.transit.impl.decoder.Decoder.prototype.decodeHash = function(a, b, c, d) { + c = com.cognitect.transit.util.objectKeys(a); + var e = c[0]; + d = 1 == c.length ? this.decode(e, b, !1, !1) : null; + if (com.cognitect.transit.impl.decoder.isTag(d)) { + return a = a[e], c = this.handlers[d.str], null != c ? c(this.decode(a, b, !1, !0), this) : com.cognitect.transit.types.taggedValue(d.str, this.decode(a, b, !1, !1)); + } + if (this.mapBuilder) { + if (c.length < 2 * com.cognitect.transit.types.SMALL_ARRAY_MAP_THRESHOLD && this.mapBuilder.fromArray) { + var f = []; + for (d = 0;d < c.length;d++) { + e = c[d], f.push(this.decode(e, b, !0, !1)), f.push(this.decode(a[e], b, !1, !1)); + } + return this.mapBuilder.fromArray(f, a); + } + f = this.mapBuilder.init(a); + for (d = 0;d < c.length;d++) { + e = c[d], f = this.mapBuilder.add(f, this.decode(e, b, !0, !1), this.decode(a[e], b, !1, !1), a); + } + return this.mapBuilder.finalize(f, a); + } + f = []; + for (d = 0;d < c.length;d++) { + e = c[d], f.push(this.decode(e, b, !0, !1)), f.push(this.decode(a[e], b, !1, !1)); + } + return com.cognitect.transit.types.map(f, !1); + }; + com.cognitect.transit.impl.decoder.Decoder.prototype.decodeArrayHash = function(a, b, c, d) { + if (this.mapBuilder) { + if (a.length < 2 * com.cognitect.transit.types.SMALL_ARRAY_MAP_THRESHOLD + 1 && this.mapBuilder.fromArray) { + d = []; + for (c = 1;c < a.length;c += 2) { + d.push(this.decode(a[c], b, !0, !1)), d.push(this.decode(a[c + 1], b, !1, !1)); + } + return this.mapBuilder.fromArray(d, a); + } + d = this.mapBuilder.init(a); + for (c = 1;c < a.length;c += 2) { + d = this.mapBuilder.add(d, this.decode(a[c], b, !0, !1), this.decode(a[c + 1], b, !1, !1), a); + } + return this.mapBuilder.finalize(d, a); + } + d = []; + for (c = 1;c < a.length;c += 2) { + d.push(this.decode(a[c], b, !0, !1)), d.push(this.decode(a[c + 1], b, !1, !1)); + } + return com.cognitect.transit.types.map(d, !1); + }; + com.cognitect.transit.impl.decoder.Decoder.prototype.decodeArray = function(a, b, c, d) { + if (d) { + var e = []; + for (d = 0;d < a.length;d++) { + e.push(this.decode(a[d], b, c, !1)); + } + return e; + } + e = b && b.idx; + if (2 === a.length && "string" === typeof a[0] && (d = this.decode(a[0], b, !1, !1), com.cognitect.transit.impl.decoder.isTag(d))) { + return a = a[1], e = this.handlers[d.str], null != e ? e = e(this.decode(a, b, c, !0), this) : com.cognitect.transit.types.taggedValue(d.str, this.decode(a, b, c, !1)); + } + b && e != b.idx && (b.idx = e); + if (this.arrayBuilder) { + if (32 >= a.length && this.arrayBuilder.fromArray) { + e = []; + for (d = 0;d < a.length;d++) { + e.push(this.decode(a[d], b, c, !1)); + } + return this.arrayBuilder.fromArray(e, a); + } + e = this.arrayBuilder.init(a); + for (d = 0;d < a.length;d++) { + e = this.arrayBuilder.add(e, this.decode(a[d], b, c, !1), a); + } + return this.arrayBuilder.finalize(e, a); + } + e = []; + for (d = 0;d < a.length;d++) { + e.push(this.decode(a[d], b, c, !1)); + } + return e; + }; + com.cognitect.transit.impl.decoder.Decoder.prototype.parseString = function(a, b, c) { + if (a.charAt(0) === com.cognitect.transit.delimiters.ESC) { + b = a.charAt(1); + if (b === com.cognitect.transit.delimiters.ESC || b === com.cognitect.transit.delimiters.SUB || b === com.cognitect.transit.delimiters.RES) { + return a.substring(1); + } + if (b === com.cognitect.transit.delimiters.TAG) { + return com.cognitect.transit.impl.decoder.tag(a.substring(2)); + } + c = this.handlers[b]; + return null == c ? this.defaultHandler(b, a.substring(2)) : c(a.substring(2), this); + } + return a; + }; + com.cognitect.transit.impl.decoder.decoder = function(a) { + return new com.cognitect.transit.impl.decoder.Decoder(a); + }; + com.cognitect.transit.impl.reader = {}; + com.cognitect.transit.impl.reader.JSONUnmarshaller = function(a) { + this.decoder = new com.cognitect.transit.impl.decoder.Decoder(a); + }; + com.cognitect.transit.impl.reader.JSONUnmarshaller.prototype.unmarshal = function(a, b) { + return this.decoder.decode(JSON.parse(a), b); + }; + com.cognitect.transit.impl.reader.Reader = function(a, b) { + this.unmarshaller = a; + this.options = b || {}; + this.cache = this.options.cache ? this.options.cache : new com.cognitect.transit.caching.ReadCache; + }; + com.cognitect.transit.impl.reader.Reader.prototype.read = function(a) { + a = this.unmarshaller.unmarshal(a, this.cache); + this.cache.clear(); + return a; + }; + com.cognitect.transit.impl.reader.Reader.prototype.read = com.cognitect.transit.impl.reader.Reader.prototype.read; + com.cognitect.transit.impl.writer = {}; + com.cognitect.transit.impl.writer.escape = function(a) { + if (0 < a.length) { + var b = a.charAt(0); + return b === com.cognitect.transit.delimiters.ESC || b === com.cognitect.transit.delimiters.SUB || b === com.cognitect.transit.delimiters.RES ? com.cognitect.transit.delimiters.ESC + a : a; + } + return a; + }; + com.cognitect.transit.impl.writer.JSONMarshaller = function(a) { + this.opts = a || {}; + this.preferStrings = null != this.opts.preferStrings ? this.opts.preferStrings : !0; + this.objectBuilder = this.opts.objectBuilder || null; + this.handlers = new com.cognitect.transit.handlers.Handlers; + if (a = this.opts.handlers) { + if (com.cognitect.transit.util.isArray(a) || !a.forEach) { + throw Error('transit writer "handlers" option must be a map'); + } + var b = this; + a.forEach(function(a, d) { + if (void 0 !== d) { + b.handlers.set(d, a); + } else { + throw Error("Cannot create handler for JavaScript undefined"); + } + }); + } + this.handlerForForeign = this.opts.handlerForForeign; + this.unpack = this.opts.unpack || function(a) { + return com.cognitect.transit.types.isArrayMap(a) && null === a.backingMap ? a._entries : !1; + }; + this.verbose = this.opts && this.opts.verbose || !1; + }; + com.cognitect.transit.impl.writer.JSONMarshaller.prototype.handler = function(a) { + var b = this.handlers.get(com.cognitect.transit.handlers.constructor(a)); + return null != b ? b : (a = a && a.transitTag) ? this.handlers.get(a) : null; + }; + com.cognitect.transit.impl.writer.JSONMarshaller.prototype.registerHandler = function(a, b) { + this.handlers.set(a, b); + }; + com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitNil = function(a, b) { + return a ? this.emitString(com.cognitect.transit.delimiters.ESC, "_", "", a, b) : null; + }; + com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitString = function(a, b, c, d, e) { + a = a + b + c; + return e ? e.write(a, d) : a; + }; + com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitBoolean = function(a, b, c) { + return b ? this.emitString(com.cognitect.transit.delimiters.ESC, "?", a.toString()[0], b, c) : a; + }; + com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitInteger = function(a, b, c) { + return Infinity === a ? this.emitString(com.cognitect.transit.delimiters.ESC, "z", "INF", b, c) : -Infinity === a ? this.emitString(com.cognitect.transit.delimiters.ESC, "z", "-INF", b, c) : isNaN(a) ? this.emitString(com.cognitect.transit.delimiters.ESC, "z", "NaN", b, c) : b || "string" === typeof a || a instanceof goog.math.Long ? this.emitString(com.cognitect.transit.delimiters.ESC, "i", a.toString(), b, c) : a; + }; + com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitDouble = function(a, b, c) { + return b ? this.emitString(a.ESC, "d", a, b, c) : a; + }; + com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitBinary = function(a, b, c) { + return this.emitString(com.cognitect.transit.delimiters.ESC, "b", a, b, c); + }; + com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitQuoted = function(a, b, c) { + if (a.verbose) { + a = {}; + var d = this.emitString(com.cognitect.transit.delimiters.ESC_TAG, "'", "", !0, c); + a[d] = com.cognitect.transit.impl.writer.marshal(this, b, !1, c); + return a; + } + return [this.emitString(com.cognitect.transit.delimiters.ESC_TAG, "'", "", !0, c), com.cognitect.transit.impl.writer.marshal(this, b, !1, c)]; + }; + com.cognitect.transit.impl.writer.emitObjects = function(a, b, c) { + var d = []; + if (com.cognitect.transit.util.isArray(b)) { + for (var e = 0;e < b.length;e++) { + d.push(com.cognitect.transit.impl.writer.marshal(a, b[e], !1, c)); + } + } else { + b.forEach(function(b, e) { + d.push(com.cognitect.transit.impl.writer.marshal(a, b, !1, c)); + }); + } + return d; + }; + com.cognitect.transit.impl.writer.emitArray = function(a, b, c, d) { + return com.cognitect.transit.impl.writer.emitObjects(a, b, d); + }; + com.cognitect.transit.impl.writer.isStringableKey = function(a, b) { + if ("string" !== typeof b) { + var c = a.handler(b); + return c && 1 === c.tag(b).length; + } + return !0; + }; + com.cognitect.transit.impl.writer.stringableKeys = function(a, b) { + var c = a.unpack(b), d = !0; + if (c) { + for (var e = 0;e < c.length && (d = com.cognitect.transit.impl.writer.isStringableKey(a, c[e]), d);e += 2) { + } + return d; + } + if (b.keys && (c = b.keys(), e = null, c.next)) { + for (e = c.next();!e.done;) { + d = com.cognitect.transit.impl.writer.isStringableKey(a, e.value); + if (!d) { + break; + } + e = c.next(); + } + return d; + } + if (b.forEach) { + return b.forEach(function(b, c) { + d = d && com.cognitect.transit.impl.writer.isStringableKey(a, c); + }), d; + } + throw Error("Cannot walk keys of object type " + com.cognitect.transit.handlers.constructor(b).name); + }; + com.cognitect.transit.impl.writer.isForeignObject = function(a) { + if (a.constructor.transit$isObject) { + return !0; + } + var b = a.constructor.toString(), b = b.substr(9), b = b.substr(0, b.indexOf("(")); + isObject = "Object" == b; + "undefined" != typeof Object.defineProperty ? Object.defineProperty(a.constructor, "transit$isObject", {value:isObject, enumerable:!1}) : a.constructor.transit$isObject = isObject; + return isObject; + }; + com.cognitect.transit.impl.writer.emitMap = function(a, b, c, d) { + var e = null, f = null, g = null, e = null; + c = 0; + if (b.constructor === Object || null != b.forEach || a.handlerForForeign && com.cognitect.transit.impl.writer.isForeignObject(b)) { + if (a.verbose) { + if (null != b.forEach) { + if (com.cognitect.transit.impl.writer.stringableKeys(a, b)) { + var h = {}; + b.forEach(function(b, c) { + h[com.cognitect.transit.impl.writer.marshal(a, c, !0, !1)] = com.cognitect.transit.impl.writer.marshal(a, b, !1, d); + }); + } else { + e = a.unpack(b); + f = []; + g = a.emitString(com.cognitect.transit.delimiters.ESC_TAG, "cmap", "", !0, d); + if (e) { + for (;c < e.length;c += 2) { + f.push(com.cognitect.transit.impl.writer.marshal(a, e[c], !1, !1)), f.push(com.cognitect.transit.impl.writer.marshal(a, e[c + 1], !1, d)); + } + } else { + b.forEach(function(b, c) { + f.push(com.cognitect.transit.impl.writer.marshal(a, c, !1, !1)); + f.push(com.cognitect.transit.impl.writer.marshal(a, b, !1, d)); + }); + } + h = {}; + h[g] = f; + } + } else { + for (e = com.cognitect.transit.util.objectKeys(b), h = {};c < e.length;c++) { + h[com.cognitect.transit.impl.writer.marshal(a, e[c], !0, !1)] = com.cognitect.transit.impl.writer.marshal(a, b[e[c]], !1, d); + } + } + return h; + } + if (null != b.forEach) { + if (com.cognitect.transit.impl.writer.stringableKeys(a, b)) { + e = a.unpack(b); + h = ["^ "]; + if (e) { + for (;c < e.length;c += 2) { + h.push(com.cognitect.transit.impl.writer.marshal(a, e[c], !0, d)), h.push(com.cognitect.transit.impl.writer.marshal(a, e[c + 1], !1, d)); + } + } else { + b.forEach(function(b, c) { + h.push(com.cognitect.transit.impl.writer.marshal(a, c, !0, d)); + h.push(com.cognitect.transit.impl.writer.marshal(a, b, !1, d)); + }); + } + return h; + } + e = a.unpack(b); + f = []; + g = a.emitString(com.cognitect.transit.delimiters.ESC_TAG, "cmap", "", !0, d); + if (e) { + for (;c < e.length;c += 2) { + f.push(com.cognitect.transit.impl.writer.marshal(a, e[c], !1, d)), f.push(com.cognitect.transit.impl.writer.marshal(a, e[c + 1], !1, d)); + } + } else { + b.forEach(function(b, c) { + f.push(com.cognitect.transit.impl.writer.marshal(a, c, !1, d)); + f.push(com.cognitect.transit.impl.writer.marshal(a, b, !1, d)); + }); + } + return [g, f]; + } + h = ["^ "]; + for (e = com.cognitect.transit.util.objectKeys(b);c < e.length;c++) { + h.push(com.cognitect.transit.impl.writer.marshal(a, e[c], !0, d)), h.push(com.cognitect.transit.impl.writer.marshal(a, b[e[c]], !1, d)); + } + return h; + } + if (null != a.objectBuilder) { + return a.objectBuilder(b, function(b) { + return com.cognitect.transit.impl.writer.marshal(a, b, !0, d); + }, function(b) { + return com.cognitect.transit.impl.writer.marshal(a, b, !1, d); + }); + } + c = com.cognitect.transit.handlers.constructor(b).name; + e = Error("Cannot write " + c); + e.data = {obj:b, type:c}; + throw e; + }; + com.cognitect.transit.impl.writer.emitTaggedMap = function(a, b, c, d, e) { + return a.verbose ? (d = {}, d[a.emitString(com.cognitect.transit.delimiters.ESC_TAG, b, "", !0, e)] = com.cognitect.transit.impl.writer.marshal(a, c, !1, e), d) : [a.emitString(com.cognitect.transit.delimiters.ESC_TAG, b, "", !0, e), com.cognitect.transit.impl.writer.marshal(a, c, !1, e)]; + }; + com.cognitect.transit.impl.writer.emitEncoded = function(a, b, c, d, e, f, g) { + if (1 === c.length) { + if ("string" === typeof d) { + return a.emitString(com.cognitect.transit.delimiters.ESC, c, d, f, g); + } + if (f || a.preferStrings) { + (d = a.verbose && b.getVerboseHandler()) ? (c = d.tag(e), d = d.stringRep(e, d)) : d = b.stringRep(e, b); + if (null !== d) { + return a.emitString(com.cognitect.transit.delimiters.ESC, c, d, f, g); + } + a = Error('Tag "' + c + '" cannot be encoded as string'); + a.data = {tag:c, rep:d, obj:e}; + throw a; + } + } + return com.cognitect.transit.impl.writer.emitTaggedMap(a, c, d, f, g); + }; + com.cognitect.transit.impl.writer.marshal = function(a, b, c, d) { + var e = a.handler(b) || (a.handlerForForeign ? a.handlerForForeign(b, a.handlers) : null), f = e ? e.tag(b) : null, g = e ? e.rep(b) : null; + if (null != e && null != f) { + switch(f) { + case "_": + return a.emitNil(c, d); + case "s": + return a.emitString("", "", com.cognitect.transit.impl.writer.escape(g), c, d); + case "?": + return a.emitBoolean(g, c, d); + case "i": + return a.emitInteger(g, c, d); + case "d": + return a.emitDouble(g, c, d); + case "b": + return a.emitBinary(g, c, d); + case "'": + return a.emitQuoted(a, g, d); + case "array": + return com.cognitect.transit.impl.writer.emitArray(a, g, c, d); + case "map": + return com.cognitect.transit.impl.writer.emitMap(a, g, c, d); + default: + return com.cognitect.transit.impl.writer.emitEncoded(a, e, f, g, b, c, d); + } + } else { + throw a = com.cognitect.transit.handlers.constructor(b).name, c = Error("Cannot write " + a), c.data = {obj:b, type:a}, c; + } + }; + com.cognitect.transit.impl.writer.maybeQuoted = function(a, b) { + var c = a.handler(b) || (a.handlerForForeign ? a.handlerForForeign(b, a.handlers) : null); + if (null != c) { + return 1 === c.tag(b).length ? com.cognitect.transit.types.quoted(b) : b; + } + var c = com.cognitect.transit.handlers.constructor(b).name, d = Error("Cannot write " + c); + d.data = {obj:b, type:c}; + throw d; + }; + com.cognitect.transit.impl.writer.marshalTop = function(a, b, c, d) { + return JSON.stringify(com.cognitect.transit.impl.writer.marshal(a, com.cognitect.transit.impl.writer.maybeQuoted(a, b), c, d)); + }; + com.cognitect.transit.impl.writer.Writer = function(a, b) { + this._marshaller = a; + this.options = b || {}; + this.cache = !1 === this.options.cache ? null : this.options.cache ? this.options.cache : new com.cognitect.transit.caching.WriteCache; + }; + com.cognitect.transit.impl.writer.Writer.prototype.marshaller = function() { + return this._marshaller; + }; + com.cognitect.transit.impl.writer.Writer.prototype.marshaller = com.cognitect.transit.impl.writer.Writer.prototype.marshaller; + com.cognitect.transit.impl.writer.Writer.prototype.write = function(a, b) { + var c = null, c = b || {}, d = c.asMapKey || !1, e = this._marshaller.verbose ? !1 : this.cache, c = !1 === c.marshalTop ? com.cognitect.transit.impl.writer.marshal(this._marshaller, a, d, e) : com.cognitect.transit.impl.writer.marshalTop(this._marshaller, a, d, e); + null != this.cache && this.cache.clear(); + return c; + }; + com.cognitect.transit.impl.writer.Writer.prototype.write = com.cognitect.transit.impl.writer.Writer.prototype.write; + com.cognitect.transit.impl.writer.Writer.prototype.register = function(a, b) { + this._marshaller.registerHandler(a, b); + }; + com.cognitect.transit.impl.writer.Writer.prototype.register = com.cognitect.transit.impl.writer.Writer.prototype.register; + var TRANSIT_DEV = !0, TRANSIT_NODE_TARGET = !0, TRANSIT_BROWSER_TARGET = !1, TRANSIT_BROWSER_AMD_TARGET = !1; + com.cognitect.transit.reader = function(a, b) { + if ("json" === a || "json-verbose" === a || null == a) { + var c = new com.cognitect.transit.impl.reader.JSONUnmarshaller(b); + return new com.cognitect.transit.impl.reader.Reader(c, b); + } + throw Error("Cannot create reader of type " + a); + }; + com.cognitect.transit.writer = function(a, b) { + if ("json" === a || "json-verbose" === a || null == a) { + "json-verbose" === a && (null == b && (b = {}), b.verbose = !0); + var c = new com.cognitect.transit.impl.writer.JSONMarshaller(b); + return new com.cognitect.transit.impl.writer.Writer(c, b); + } + c = Error('Type must be "json"'); + c.data = {type:a}; + throw c; + }; + com.cognitect.transit.makeWriteHandler = function(a) { + var b = function() { + }; + b.prototype.tag = a.tag; + b.prototype.rep = a.rep; + b.prototype.stringRep = a.stringRep; + b.prototype.getVerboseHandler = a.getVerboseHandler; + return new b; + }; + com.cognitect.transit.makeBuilder = function(a) { + var b = function() { + }; + b.prototype.init = a.init; + b.prototype.add = a.add; + b.prototype.finalize = a.finalize; + b.prototype.fromArray = a.fromArray; + return new b; + }; + com.cognitect.transit.date = com.cognitect.transit.types.date; + com.cognitect.transit.integer = com.cognitect.transit.types.intValue; + com.cognitect.transit.isInteger = com.cognitect.transit.types.isInteger; + com.cognitect.transit.uuid = com.cognitect.transit.types.uuid; + com.cognitect.transit.isUUID = com.cognitect.transit.types.isUUID; + com.cognitect.transit.bigInt = com.cognitect.transit.types.bigInteger; + com.cognitect.transit.isBigInt = com.cognitect.transit.types.isBigInteger; + com.cognitect.transit.bigDec = com.cognitect.transit.types.bigDecimalValue; + com.cognitect.transit.isBigDec = com.cognitect.transit.types.isBigDecimal; + com.cognitect.transit.keyword = com.cognitect.transit.types.keyword; + com.cognitect.transit.isKeyword = com.cognitect.transit.types.isKeyword; + com.cognitect.transit.symbol = com.cognitect.transit.types.symbol; + com.cognitect.transit.isSymbol = com.cognitect.transit.types.isSymbol; + com.cognitect.transit.binary = com.cognitect.transit.types.binary; + com.cognitect.transit.isBinary = com.cognitect.transit.types.isBinary; + com.cognitect.transit.uri = com.cognitect.transit.types.uri; + com.cognitect.transit.isURI = com.cognitect.transit.types.isURI; + com.cognitect.transit.map = com.cognitect.transit.types.map; + com.cognitect.transit.isMap = com.cognitect.transit.types.isMap; + com.cognitect.transit.set = com.cognitect.transit.types.set; + com.cognitect.transit.isSet = com.cognitect.transit.types.isSet; + com.cognitect.transit.list = com.cognitect.transit.types.list; + com.cognitect.transit.isList = com.cognitect.transit.types.isList; + com.cognitect.transit.quoted = com.cognitect.transit.types.quoted; + com.cognitect.transit.isQuoted = com.cognitect.transit.types.isQuoted; + com.cognitect.transit.tagged = com.cognitect.transit.types.taggedValue; + com.cognitect.transit.isTaggedValue = com.cognitect.transit.types.isTaggedValue; + com.cognitect.transit.link = com.cognitect.transit.types.link; + com.cognitect.transit.isLink = com.cognitect.transit.types.isLink; + com.cognitect.transit.hash = com.cognitect.transit.eq.hashCode; + com.cognitect.transit.hashMapLike = com.cognitect.transit.eq.hashMapLike; + com.cognitect.transit.hashArrayLike = com.cognitect.transit.eq.hashArrayLike; + com.cognitect.transit.equals = com.cognitect.transit.eq.equals; + com.cognitect.transit.extendToEQ = com.cognitect.transit.eq.extendToEQ; + com.cognitect.transit.mapToObject = function(a) { + var b = {}; + a.forEach(function(a, d) { + if ("string" !== typeof d) { + throw Error("Cannot convert map with non-string keys"); + } + b[d] = a; + }); + return b; + }; + com.cognitect.transit.objectToMap = function(a) { + var b = com.cognitect.transit.map(), c; + for (c in a) { + a.hasOwnProperty(c) && b.set(c, a[c]); + } + return b; + }; + com.cognitect.transit.decoder = com.cognitect.transit.impl.decoder.decoder; + com.cognitect.transit.readCache = com.cognitect.transit.caching.readCache; + com.cognitect.transit.writeCache = com.cognitect.transit.caching.writeCache; + com.cognitect.transit.UUIDfromString = com.cognitect.transit.types.UUIDfromString; + com.cognitect.transit.randomUUID = com.cognitect.transit.util.randomUUID; + com.cognitect.transit.stringableKeys = com.cognitect.transit.impl.writer.stringableKeys; + TRANSIT_BROWSER_TARGET && (goog.exportSymbol("transit.reader", com.cognitect.transit.reader), goog.exportSymbol("transit.writer", com.cognitect.transit.writer), goog.exportSymbol("transit.makeBuilder", com.cognitect.transit.makeBuilder), goog.exportSymbol("transit.makeWriteHandler", com.cognitect.transit.makeWriteHandler), goog.exportSymbol("transit.date", com.cognitect.transit.types.date), goog.exportSymbol("transit.integer", com.cognitect.transit.types.intValue), goog.exportSymbol("transit.isInteger", + com.cognitect.transit.types.isInteger), goog.exportSymbol("transit.uuid", com.cognitect.transit.types.uuid), goog.exportSymbol("transit.isUUID", com.cognitect.transit.types.isUUID), goog.exportSymbol("transit.bigInt", com.cognitect.transit.types.bigInteger), goog.exportSymbol("transit.isBigInt", com.cognitect.transit.types.isBigInteger), goog.exportSymbol("transit.bigDec", com.cognitect.transit.types.bigDecimalValue), goog.exportSymbol("transit.isBigDec", com.cognitect.transit.types.isBigDecimal), + goog.exportSymbol("transit.keyword", com.cognitect.transit.types.keyword), goog.exportSymbol("transit.isKeyword", com.cognitect.transit.types.isKeyword), goog.exportSymbol("transit.symbol", com.cognitect.transit.types.symbol), goog.exportSymbol("transit.isSymbol", com.cognitect.transit.types.isSymbol), goog.exportSymbol("transit.binary", com.cognitect.transit.types.binary), goog.exportSymbol("transit.isBinary", com.cognitect.transit.types.isBinary), goog.exportSymbol("transit.uri", com.cognitect.transit.types.uri), + goog.exportSymbol("transit.isURI", com.cognitect.transit.types.isURI), goog.exportSymbol("transit.map", com.cognitect.transit.types.map), goog.exportSymbol("transit.isMap", com.cognitect.transit.types.isMap), goog.exportSymbol("transit.set", com.cognitect.transit.types.set), goog.exportSymbol("transit.isSet", com.cognitect.transit.types.isSet), goog.exportSymbol("transit.list", com.cognitect.transit.types.list), goog.exportSymbol("transit.isList", com.cognitect.transit.types.isList), goog.exportSymbol("transit.quoted", + com.cognitect.transit.types.quoted), goog.exportSymbol("transit.isQuoted", com.cognitect.transit.types.isQuoted), goog.exportSymbol("transit.tagged", com.cognitect.transit.types.taggedValue), goog.exportSymbol("transit.isTaggedValue", com.cognitect.transit.types.isTaggedValue), goog.exportSymbol("transit.link", com.cognitect.transit.types.link), goog.exportSymbol("transit.isLink", com.cognitect.transit.types.isLink), goog.exportSymbol("transit.hash", com.cognitect.transit.eq.hashCode), goog.exportSymbol("transit.hashMapLike", + com.cognitect.transit.eq.hashMapLike), goog.exportSymbol("transit.hashArrayLike", com.cognitect.transit.eq.hashArrayLike), goog.exportSymbol("transit.equals", com.cognitect.transit.eq.equals), goog.exportSymbol("transit.extendToEQ", com.cognitect.transit.eq.extendToEQ), goog.exportSymbol("transit.mapToObject", com.cognitect.transit.mapToObject), goog.exportSymbol("transit.objectToMap", com.cognitect.transit.objectToMap), goog.exportSymbol("transit.decoder", com.cognitect.transit.impl.decoder.decoder), + goog.exportSymbol("transit.UUIDfromString", com.cognitect.transit.types.UUIDfromString), goog.exportSymbol("transit.randomUUID", com.cognitect.transit.util.randomUUID), goog.exportSymbol("transit.stringableKeys", com.cognitect.transit.impl.writer.stringableKeys), goog.exportSymbol("transit.readCache", com.cognitect.transit.caching.readCache), goog.exportSymbol("transit.writeCache", com.cognitect.transit.caching.writeCache)); + TRANSIT_NODE_TARGET && (module.exports = {reader:com.cognitect.transit.reader, writer:com.cognitect.transit.writer, makeBuilder:com.cognitect.transit.makeBuilder, makeWriteHandler:com.cognitect.transit.makeWriteHandler, date:com.cognitect.transit.types.date, integer:com.cognitect.transit.types.intValue, isInteger:com.cognitect.transit.types.isInteger, uuid:com.cognitect.transit.types.uuid, isUUID:com.cognitect.transit.types.isUUID, bigInt:com.cognitect.transit.types.bigInteger, isBigInt:com.cognitect.transit.types.isBigInteger, + bigDec:com.cognitect.transit.types.bigDecimalValue, isBigDec:com.cognitect.transit.types.isBigDecimal, keyword:com.cognitect.transit.types.keyword, isKeyword:com.cognitect.transit.types.isKeyword, symbol:com.cognitect.transit.types.symbol, isSymbol:com.cognitect.transit.types.isSymbol, binary:com.cognitect.transit.types.binary, isBinary:com.cognitect.transit.types.isBinary, uri:com.cognitect.transit.types.uri, isURI:com.cognitect.transit.types.isURI, map:com.cognitect.transit.types.map, isMap:com.cognitect.transit.types.isMap, + set:com.cognitect.transit.types.set, isSet:com.cognitect.transit.types.isSet, list:com.cognitect.transit.types.list, isList:com.cognitect.transit.types.isList, quoted:com.cognitect.transit.types.quoted, isQuoted:com.cognitect.transit.types.isQuoted, tagged:com.cognitect.transit.types.taggedValue, isTaggedValue:com.cognitect.transit.types.isTaggedValue, link:com.cognitect.transit.types.link, isLink:com.cognitect.transit.types.isLink, hash:com.cognitect.transit.eq.hashCode, hashArrayLike:com.cognitect.transit.eq.hashArrayLike, + hashMapLike:com.cognitect.transit.eq.hashMapLike, equals:com.cognitect.transit.eq.equals, extendToEQ:com.cognitect.transit.eq.extendToEQ, mapToObject:com.cognitect.transit.mapToObject, objectToMap:com.cognitect.transit.objectToMap, decoder:com.cognitect.transit.impl.decoder.decoder, UUIDfromString:com.cognitect.transit.types.UUIDfromString, randomUUID:com.cognitect.transit.util.randomUUID, stringableKeys:com.cognitect.transit.impl.writer.stringableKeys, readCache:com.cognitect.transit.caching.readCache, + writeCache:com.cognitect.transit.caching.writeCache}); + + + /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(51).Buffer)) + +/***/ }, +/* 51 */ +/***/ function(module, exports, __webpack_require__) { + + /* WEBPACK VAR INJECTION */(function(Buffer, global) {/*! + * The buffer module from node.js, for the browser. + * + * @author Feross Aboukhadijeh + * @license MIT + */ + /* eslint-disable no-proto */ + + 'use strict' + + var base64 = __webpack_require__(52) + var ieee754 = __webpack_require__(53) + var isArray = __webpack_require__(54) + + exports.Buffer = Buffer + exports.SlowBuffer = SlowBuffer + exports.INSPECT_MAX_BYTES = 50 + Buffer.poolSize = 8192 // not used by this implementation + + var rootParent = {} + + /** + * If `Buffer.TYPED_ARRAY_SUPPORT`: + * === true Use Uint8Array implementation (fastest) + * === false Use Object implementation (most compatible, even IE6) + * + * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+, + * Opera 11.6+, iOS 4.2+. + * + * Due to various browser bugs, sometimes the Object implementation will be used even + * when the browser supports typed arrays. + * + * Note: + * + * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances, + * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438. + * + * - Safari 5-7 lacks support for changing the `Object.prototype.constructor` property + * on objects. + * + * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function. + * + * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of + * incorrect length in some situations. + + * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they + * get the Object implementation, which is slower but behaves correctly. + */ + Buffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined + ? global.TYPED_ARRAY_SUPPORT + : typedArraySupport() + + function typedArraySupport () { + function Bar () {} + try { + var arr = new Uint8Array(1) + arr.foo = function () { return 42 } + arr.constructor = Bar + return arr.foo() === 42 && // typed array instances can be augmented + arr.constructor === Bar && // constructor can be set + typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray` + arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray` + } catch (e) { + return false + } + } + + function kMaxLength () { + return Buffer.TYPED_ARRAY_SUPPORT + ? 0x7fffffff + : 0x3fffffff + } + + /** + * Class: Buffer + * ============= + * + * The Buffer constructor returns instances of `Uint8Array` that are augmented + * with function properties for all the node `Buffer` API functions. We use + * `Uint8Array` so that square bracket notation works as expected -- it returns + * a single octet. + * + * By augmenting the instances, we can avoid modifying the `Uint8Array` + * prototype. + */ + function Buffer (arg) { + if (!(this instanceof Buffer)) { + // Avoid going through an ArgumentsAdaptorTrampoline in the common case. + if (arguments.length > 1) return new Buffer(arg, arguments[1]) + return new Buffer(arg) + } + + if (!Buffer.TYPED_ARRAY_SUPPORT) { + this.length = 0 + this.parent = undefined + } + + // Common case. + if (typeof arg === 'number') { + return fromNumber(this, arg) + } + + // Slightly less common case. + if (typeof arg === 'string') { + return fromString(this, arg, arguments.length > 1 ? arguments[1] : 'utf8') + } + + // Unusual. + return fromObject(this, arg) + } + + function fromNumber (that, length) { + that = allocate(that, length < 0 ? 0 : checked(length) | 0) + if (!Buffer.TYPED_ARRAY_SUPPORT) { + for (var i = 0; i < length; i++) { + that[i] = 0 + } + } + return that + } + + function fromString (that, string, encoding) { + if (typeof encoding !== 'string' || encoding === '') encoding = 'utf8' + + // Assumption: byteLength() return value is always < kMaxLength. + var length = byteLength(string, encoding) | 0 + that = allocate(that, length) + + that.write(string, encoding) + return that + } + + function fromObject (that, object) { + if (Buffer.isBuffer(object)) return fromBuffer(that, object) + + if (isArray(object)) return fromArray(that, object) + + if (object == null) { + throw new TypeError('must start with number, buffer, array or string') + } + + if (typeof ArrayBuffer !== 'undefined') { + if (object.buffer instanceof ArrayBuffer) { + return fromTypedArray(that, object) + } + if (object instanceof ArrayBuffer) { + return fromArrayBuffer(that, object) + } + } + + if (object.length) return fromArrayLike(that, object) + + return fromJsonObject(that, object) + } + + function fromBuffer (that, buffer) { + var length = checked(buffer.length) | 0 + that = allocate(that, length) + buffer.copy(that, 0, 0, length) + return that + } + + function fromArray (that, array) { + var length = checked(array.length) | 0 + that = allocate(that, length) + for (var i = 0; i < length; i += 1) { + that[i] = array[i] & 255 + } + return that + } + + // Duplicate of fromArray() to keep fromArray() monomorphic. + function fromTypedArray (that, array) { + var length = checked(array.length) | 0 + that = allocate(that, length) + // Truncating the elements is probably not what people expect from typed + // arrays with BYTES_PER_ELEMENT > 1 but it's compatible with the behavior + // of the old Buffer constructor. + for (var i = 0; i < length; i += 1) { + that[i] = array[i] & 255 + } + return that + } + + function fromArrayBuffer (that, array) { + if (Buffer.TYPED_ARRAY_SUPPORT) { + // Return an augmented `Uint8Array` instance, for best performance + array.byteLength + that = Buffer._augment(new Uint8Array(array)) + } else { + // Fallback: Return an object instance of the Buffer class + that = fromTypedArray(that, new Uint8Array(array)) + } + return that + } + + function fromArrayLike (that, array) { + var length = checked(array.length) | 0 + that = allocate(that, length) + for (var i = 0; i < length; i += 1) { + that[i] = array[i] & 255 + } + return that + } + + // Deserialize { type: 'Buffer', data: [1,2,3,...] } into a Buffer object. + // Returns a zero-length buffer for inputs that don't conform to the spec. + function fromJsonObject (that, object) { + var array + var length = 0 + + if (object.type === 'Buffer' && isArray(object.data)) { + array = object.data + length = checked(array.length) | 0 + } + that = allocate(that, length) + + for (var i = 0; i < length; i += 1) { + that[i] = array[i] & 255 + } + return that + } + + if (Buffer.TYPED_ARRAY_SUPPORT) { + Buffer.prototype.__proto__ = Uint8Array.prototype + Buffer.__proto__ = Uint8Array + } else { + // pre-set for values that may exist in the future + Buffer.prototype.length = undefined + Buffer.prototype.parent = undefined + } + + function allocate (that, length) { + if (Buffer.TYPED_ARRAY_SUPPORT) { + // Return an augmented `Uint8Array` instance, for best performance + that = Buffer._augment(new Uint8Array(length)) + that.__proto__ = Buffer.prototype + } else { + // Fallback: Return an object instance of the Buffer class + that.length = length + that._isBuffer = true + } + + var fromPool = length !== 0 && length <= Buffer.poolSize >>> 1 + if (fromPool) that.parent = rootParent + + return that + } + + function checked (length) { + // Note: cannot use `length < kMaxLength` here because that fails when + // length is NaN (which is otherwise coerced to zero.) + if (length >= kMaxLength()) { + throw new RangeError('Attempt to allocate Buffer larger than maximum ' + + 'size: 0x' + kMaxLength().toString(16) + ' bytes') + } + return length | 0 + } + + function SlowBuffer (subject, encoding) { + if (!(this instanceof SlowBuffer)) return new SlowBuffer(subject, encoding) + + var buf = new Buffer(subject, encoding) + delete buf.parent + return buf + } + + Buffer.isBuffer = function isBuffer (b) { + return !!(b != null && b._isBuffer) + } + + Buffer.compare = function compare (a, b) { + if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) { + throw new TypeError('Arguments must be Buffers') + } + + if (a === b) return 0 + + var x = a.length + var y = b.length + + var i = 0 + var len = Math.min(x, y) + while (i < len) { + if (a[i] !== b[i]) break + + ++i + } + + if (i !== len) { + x = a[i] + y = b[i] + } + + if (x < y) return -1 + if (y < x) return 1 + return 0 + } + + Buffer.isEncoding = function isEncoding (encoding) { + switch (String(encoding).toLowerCase()) { + case 'hex': + case 'utf8': + case 'utf-8': + case 'ascii': + case 'binary': + case 'base64': + case 'raw': + case 'ucs2': + case 'ucs-2': + case 'utf16le': + case 'utf-16le': + return true + default: + return false + } + } + + Buffer.concat = function concat (list, length) { + if (!isArray(list)) throw new TypeError('list argument must be an Array of Buffers.') + + if (list.length === 0) { + return new Buffer(0) + } + + var i + if (length === undefined) { + length = 0 + for (i = 0; i < list.length; i++) { + length += list[i].length + } + } + + var buf = new Buffer(length) + var pos = 0 + for (i = 0; i < list.length; i++) { + var item = list[i] + item.copy(buf, pos) + pos += item.length + } + return buf + } + + function byteLength (string, encoding) { + if (typeof string !== 'string') string = '' + string + + var len = string.length + if (len === 0) return 0 + + // Use a for loop to avoid recursion + var loweredCase = false + for (;;) { + switch (encoding) { + case 'ascii': + case 'binary': + // Deprecated + case 'raw': + case 'raws': + return len + case 'utf8': + case 'utf-8': + return utf8ToBytes(string).length + case 'ucs2': + case 'ucs-2': + case 'utf16le': + case 'utf-16le': + return len * 2 + case 'hex': + return len >>> 1 + case 'base64': + return base64ToBytes(string).length + default: + if (loweredCase) return utf8ToBytes(string).length // assume utf8 + encoding = ('' + encoding).toLowerCase() + loweredCase = true + } + } + } + Buffer.byteLength = byteLength + + function slowToString (encoding, start, end) { + var loweredCase = false + + start = start | 0 + end = end === undefined || end === Infinity ? this.length : end | 0 + + if (!encoding) encoding = 'utf8' + if (start < 0) start = 0 + if (end > this.length) end = this.length + if (end <= start) return '' + + while (true) { + switch (encoding) { + case 'hex': + return hexSlice(this, start, end) + + case 'utf8': + case 'utf-8': + return utf8Slice(this, start, end) + + case 'ascii': + return asciiSlice(this, start, end) + + case 'binary': + return binarySlice(this, start, end) + + case 'base64': + return base64Slice(this, start, end) + + case 'ucs2': + case 'ucs-2': + case 'utf16le': + case 'utf-16le': + return utf16leSlice(this, start, end) + + default: + if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) + encoding = (encoding + '').toLowerCase() + loweredCase = true + } + } + } + + Buffer.prototype.toString = function toString () { + var length = this.length | 0 + if (length === 0) return '' + if (arguments.length === 0) return utf8Slice(this, 0, length) + return slowToString.apply(this, arguments) + } + + Buffer.prototype.equals = function equals (b) { + if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer') + if (this === b) return true + return Buffer.compare(this, b) === 0 + } + + Buffer.prototype.inspect = function inspect () { + var str = '' + var max = exports.INSPECT_MAX_BYTES + if (this.length > 0) { + str = this.toString('hex', 0, max).match(/.{2}/g).join(' ') + if (this.length > max) str += ' ... ' + } + return '' + } + + Buffer.prototype.compare = function compare (b) { + if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer') + if (this === b) return 0 + return Buffer.compare(this, b) + } + + Buffer.prototype.indexOf = function indexOf (val, byteOffset) { + if (byteOffset > 0x7fffffff) byteOffset = 0x7fffffff + else if (byteOffset < -0x80000000) byteOffset = -0x80000000 + byteOffset >>= 0 + + if (this.length === 0) return -1 + if (byteOffset >= this.length) return -1 + + // Negative offsets start from the end of the buffer + if (byteOffset < 0) byteOffset = Math.max(this.length + byteOffset, 0) + + if (typeof val === 'string') { + if (val.length === 0) return -1 // special case: looking for empty string always fails + return String.prototype.indexOf.call(this, val, byteOffset) + } + if (Buffer.isBuffer(val)) { + return arrayIndexOf(this, val, byteOffset) + } + if (typeof val === 'number') { + if (Buffer.TYPED_ARRAY_SUPPORT && Uint8Array.prototype.indexOf === 'function') { + return Uint8Array.prototype.indexOf.call(this, val, byteOffset) + } + return arrayIndexOf(this, [ val ], byteOffset) + } + + function arrayIndexOf (arr, val, byteOffset) { + var foundIndex = -1 + for (var i = 0; byteOffset + i < arr.length; i++) { + if (arr[byteOffset + i] === val[foundIndex === -1 ? 0 : i - foundIndex]) { + if (foundIndex === -1) foundIndex = i + if (i - foundIndex + 1 === val.length) return byteOffset + foundIndex + } else { + foundIndex = -1 + } + } + return -1 + } + + throw new TypeError('val must be string, number or Buffer') + } + + // `get` is deprecated + Buffer.prototype.get = function get (offset) { + console.log('.get() is deprecated. Access using array indexes instead.') + return this.readUInt8(offset) + } + + // `set` is deprecated + Buffer.prototype.set = function set (v, offset) { + console.log('.set() is deprecated. Access using array indexes instead.') + return this.writeUInt8(v, offset) + } + + function hexWrite (buf, string, offset, length) { + offset = Number(offset) || 0 + var remaining = buf.length - offset + if (!length) { + length = remaining + } else { + length = Number(length) + if (length > remaining) { + length = remaining + } + } + + // must be an even number of digits + var strLen = string.length + if (strLen % 2 !== 0) throw new Error('Invalid hex string') + + if (length > strLen / 2) { + length = strLen / 2 + } + for (var i = 0; i < length; i++) { + var parsed = parseInt(string.substr(i * 2, 2), 16) + if (isNaN(parsed)) throw new Error('Invalid hex string') + buf[offset + i] = parsed + } + return i + } + + function utf8Write (buf, string, offset, length) { + return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length) + } + + function asciiWrite (buf, string, offset, length) { + return blitBuffer(asciiToBytes(string), buf, offset, length) + } + + function binaryWrite (buf, string, offset, length) { + return asciiWrite(buf, string, offset, length) + } + + function base64Write (buf, string, offset, length) { + return blitBuffer(base64ToBytes(string), buf, offset, length) + } + + function ucs2Write (buf, string, offset, length) { + return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length) + } + + Buffer.prototype.write = function write (string, offset, length, encoding) { + // Buffer#write(string) + if (offset === undefined) { + encoding = 'utf8' + length = this.length + offset = 0 + // Buffer#write(string, encoding) + } else if (length === undefined && typeof offset === 'string') { + encoding = offset + length = this.length + offset = 0 + // Buffer#write(string, offset[, length][, encoding]) + } else if (isFinite(offset)) { + offset = offset | 0 + if (isFinite(length)) { + length = length | 0 + if (encoding === undefined) encoding = 'utf8' + } else { + encoding = length + length = undefined + } + // legacy write(string, encoding, offset, length) - remove in v0.13 + } else { + var swap = encoding + encoding = offset + offset = length | 0 + length = swap + } + + var remaining = this.length - offset + if (length === undefined || length > remaining) length = remaining + + if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) { + throw new RangeError('attempt to write outside buffer bounds') + } + + if (!encoding) encoding = 'utf8' + + var loweredCase = false + for (;;) { + switch (encoding) { + case 'hex': + return hexWrite(this, string, offset, length) + + case 'utf8': + case 'utf-8': + return utf8Write(this, string, offset, length) + + case 'ascii': + return asciiWrite(this, string, offset, length) + + case 'binary': + return binaryWrite(this, string, offset, length) + + case 'base64': + // Warning: maxLength not taken into account in base64Write + return base64Write(this, string, offset, length) + + case 'ucs2': + case 'ucs-2': + case 'utf16le': + case 'utf-16le': + return ucs2Write(this, string, offset, length) + + default: + if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) + encoding = ('' + encoding).toLowerCase() + loweredCase = true + } + } + } + + Buffer.prototype.toJSON = function toJSON () { + return { + type: 'Buffer', + data: Array.prototype.slice.call(this._arr || this, 0) + } + } + + function base64Slice (buf, start, end) { + if (start === 0 && end === buf.length) { + return base64.fromByteArray(buf) + } else { + return base64.fromByteArray(buf.slice(start, end)) + } + } + + function utf8Slice (buf, start, end) { + end = Math.min(buf.length, end) + var res = [] + + var i = start + while (i < end) { + var firstByte = buf[i] + var codePoint = null + var bytesPerSequence = (firstByte > 0xEF) ? 4 + : (firstByte > 0xDF) ? 3 + : (firstByte > 0xBF) ? 2 + : 1 + + if (i + bytesPerSequence <= end) { + var secondByte, thirdByte, fourthByte, tempCodePoint + + switch (bytesPerSequence) { + case 1: + if (firstByte < 0x80) { + codePoint = firstByte + } + break + case 2: + secondByte = buf[i + 1] + if ((secondByte & 0xC0) === 0x80) { + tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F) + if (tempCodePoint > 0x7F) { + codePoint = tempCodePoint + } + } + break + case 3: + secondByte = buf[i + 1] + thirdByte = buf[i + 2] + if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) { + tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F) + if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) { + codePoint = tempCodePoint + } + } + break + case 4: + secondByte = buf[i + 1] + thirdByte = buf[i + 2] + fourthByte = buf[i + 3] + if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) { + tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F) + if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) { + codePoint = tempCodePoint + } + } + } + } + + if (codePoint === null) { + // we did not generate a valid codePoint so insert a + // replacement char (U+FFFD) and advance only 1 byte + codePoint = 0xFFFD + bytesPerSequence = 1 + } else if (codePoint > 0xFFFF) { + // encode to utf16 (surrogate pair dance) + codePoint -= 0x10000 + res.push(codePoint >>> 10 & 0x3FF | 0xD800) + codePoint = 0xDC00 | codePoint & 0x3FF + } + + res.push(codePoint) + i += bytesPerSequence + } + + return decodeCodePointsArray(res) + } + + // Based on http://stackoverflow.com/a/22747272/680742, the browser with + // the lowest limit is Chrome, with 0x10000 args. + // We go 1 magnitude less, for safety + var MAX_ARGUMENTS_LENGTH = 0x1000 + + function decodeCodePointsArray (codePoints) { + var len = codePoints.length + if (len <= MAX_ARGUMENTS_LENGTH) { + return String.fromCharCode.apply(String, codePoints) // avoid extra slice() + } + + // Decode in chunks to avoid "call stack size exceeded". + var res = '' + var i = 0 + while (i < len) { + res += String.fromCharCode.apply( + String, + codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH) + ) + } + return res + } + + function asciiSlice (buf, start, end) { + var ret = '' + end = Math.min(buf.length, end) + + for (var i = start; i < end; i++) { + ret += String.fromCharCode(buf[i] & 0x7F) + } + return ret + } + + function binarySlice (buf, start, end) { + var ret = '' + end = Math.min(buf.length, end) + + for (var i = start; i < end; i++) { + ret += String.fromCharCode(buf[i]) + } + return ret + } + + function hexSlice (buf, start, end) { + var len = buf.length + + if (!start || start < 0) start = 0 + if (!end || end < 0 || end > len) end = len + + var out = '' + for (var i = start; i < end; i++) { + out += toHex(buf[i]) + } + return out + } + + function utf16leSlice (buf, start, end) { + var bytes = buf.slice(start, end) + var res = '' + for (var i = 0; i < bytes.length; i += 2) { + res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256) + } + return res + } + + Buffer.prototype.slice = function slice (start, end) { + var len = this.length + start = ~~start + end = end === undefined ? len : ~~end + + if (start < 0) { + start += len + if (start < 0) start = 0 + } else if (start > len) { + start = len + } + + if (end < 0) { + end += len + if (end < 0) end = 0 + } else if (end > len) { + end = len + } + + if (end < start) end = start + + var newBuf + if (Buffer.TYPED_ARRAY_SUPPORT) { + newBuf = Buffer._augment(this.subarray(start, end)) + } else { + var sliceLen = end - start + newBuf = new Buffer(sliceLen, undefined) + for (var i = 0; i < sliceLen; i++) { + newBuf[i] = this[i + start] + } + } + + if (newBuf.length) newBuf.parent = this.parent || this + + return newBuf + } + + /* + * Need to make sure that buffer isn't trying to write out of bounds. + */ + function checkOffset (offset, ext, length) { + if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint') + if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length') + } + + Buffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) { + offset = offset | 0 + byteLength = byteLength | 0 + if (!noAssert) checkOffset(offset, byteLength, this.length) + + var val = this[offset] + var mul = 1 + var i = 0 + while (++i < byteLength && (mul *= 0x100)) { + val += this[offset + i] * mul + } + + return val + } + + Buffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) { + offset = offset | 0 + byteLength = byteLength | 0 + if (!noAssert) { + checkOffset(offset, byteLength, this.length) + } + + var val = this[offset + --byteLength] + var mul = 1 + while (byteLength > 0 && (mul *= 0x100)) { + val += this[offset + --byteLength] * mul + } + + return val + } + + Buffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) { + if (!noAssert) checkOffset(offset, 1, this.length) + return this[offset] + } + + Buffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) { + if (!noAssert) checkOffset(offset, 2, this.length) + return this[offset] | (this[offset + 1] << 8) + } + + Buffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) { + if (!noAssert) checkOffset(offset, 2, this.length) + return (this[offset] << 8) | this[offset + 1] + } + + Buffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) { + if (!noAssert) checkOffset(offset, 4, this.length) + + return ((this[offset]) | + (this[offset + 1] << 8) | + (this[offset + 2] << 16)) + + (this[offset + 3] * 0x1000000) + } + + Buffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) { + if (!noAssert) checkOffset(offset, 4, this.length) + + return (this[offset] * 0x1000000) + + ((this[offset + 1] << 16) | + (this[offset + 2] << 8) | + this[offset + 3]) + } + + Buffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) { + offset = offset | 0 + byteLength = byteLength | 0 + if (!noAssert) checkOffset(offset, byteLength, this.length) + + var val = this[offset] + var mul = 1 + var i = 0 + while (++i < byteLength && (mul *= 0x100)) { + val += this[offset + i] * mul + } + mul *= 0x80 + + if (val >= mul) val -= Math.pow(2, 8 * byteLength) + + return val + } + + Buffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) { + offset = offset | 0 + byteLength = byteLength | 0 + if (!noAssert) checkOffset(offset, byteLength, this.length) + + var i = byteLength + var mul = 1 + var val = this[offset + --i] + while (i > 0 && (mul *= 0x100)) { + val += this[offset + --i] * mul + } + mul *= 0x80 + + if (val >= mul) val -= Math.pow(2, 8 * byteLength) + + return val + } + + Buffer.prototype.readInt8 = function readInt8 (offset, noAssert) { + if (!noAssert) checkOffset(offset, 1, this.length) + if (!(this[offset] & 0x80)) return (this[offset]) + return ((0xff - this[offset] + 1) * -1) + } + + Buffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) { + if (!noAssert) checkOffset(offset, 2, this.length) + var val = this[offset] | (this[offset + 1] << 8) + return (val & 0x8000) ? val | 0xFFFF0000 : val + } + + Buffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) { + if (!noAssert) checkOffset(offset, 2, this.length) + var val = this[offset + 1] | (this[offset] << 8) + return (val & 0x8000) ? val | 0xFFFF0000 : val + } + + Buffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) { + if (!noAssert) checkOffset(offset, 4, this.length) + + return (this[offset]) | + (this[offset + 1] << 8) | + (this[offset + 2] << 16) | + (this[offset + 3] << 24) + } + + Buffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) { + if (!noAssert) checkOffset(offset, 4, this.length) + + return (this[offset] << 24) | + (this[offset + 1] << 16) | + (this[offset + 2] << 8) | + (this[offset + 3]) + } + + Buffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) { + if (!noAssert) checkOffset(offset, 4, this.length) + return ieee754.read(this, offset, true, 23, 4) + } + + Buffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) { + if (!noAssert) checkOffset(offset, 4, this.length) + return ieee754.read(this, offset, false, 23, 4) + } + + Buffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) { + if (!noAssert) checkOffset(offset, 8, this.length) + return ieee754.read(this, offset, true, 52, 8) + } + + Buffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) { + if (!noAssert) checkOffset(offset, 8, this.length) + return ieee754.read(this, offset, false, 52, 8) + } + + function checkInt (buf, value, offset, ext, max, min) { + if (!Buffer.isBuffer(buf)) throw new TypeError('buffer must be a Buffer instance') + if (value > max || value < min) throw new RangeError('value is out of bounds') + if (offset + ext > buf.length) throw new RangeError('index out of range') + } + + Buffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) { + value = +value + offset = offset | 0 + byteLength = byteLength | 0 + if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0) + + var mul = 1 + var i = 0 + this[offset] = value & 0xFF + while (++i < byteLength && (mul *= 0x100)) { + this[offset + i] = (value / mul) & 0xFF + } + + return offset + byteLength + } + + Buffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) { + value = +value + offset = offset | 0 + byteLength = byteLength | 0 + if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0) + + var i = byteLength - 1 + var mul = 1 + this[offset + i] = value & 0xFF + while (--i >= 0 && (mul *= 0x100)) { + this[offset + i] = (value / mul) & 0xFF + } + + return offset + byteLength + } + + Buffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) { + value = +value + offset = offset | 0 + if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0) + if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value) + this[offset] = (value & 0xff) + return offset + 1 + } + + function objectWriteUInt16 (buf, value, offset, littleEndian) { + if (value < 0) value = 0xffff + value + 1 + for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; i++) { + buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>> + (littleEndian ? i : 1 - i) * 8 + } + } + + Buffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) { + value = +value + offset = offset | 0 + if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0) + if (Buffer.TYPED_ARRAY_SUPPORT) { + this[offset] = (value & 0xff) + this[offset + 1] = (value >>> 8) + } else { + objectWriteUInt16(this, value, offset, true) + } + return offset + 2 + } + + Buffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) { + value = +value + offset = offset | 0 + if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0) + if (Buffer.TYPED_ARRAY_SUPPORT) { + this[offset] = (value >>> 8) + this[offset + 1] = (value & 0xff) + } else { + objectWriteUInt16(this, value, offset, false) + } + return offset + 2 + } + + function objectWriteUInt32 (buf, value, offset, littleEndian) { + if (value < 0) value = 0xffffffff + value + 1 + for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; i++) { + buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff + } + } + + Buffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) { + value = +value + offset = offset | 0 + if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0) + if (Buffer.TYPED_ARRAY_SUPPORT) { + this[offset + 3] = (value >>> 24) + this[offset + 2] = (value >>> 16) + this[offset + 1] = (value >>> 8) + this[offset] = (value & 0xff) + } else { + objectWriteUInt32(this, value, offset, true) + } + return offset + 4 + } + + Buffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) { + value = +value + offset = offset | 0 + if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0) + if (Buffer.TYPED_ARRAY_SUPPORT) { + this[offset] = (value >>> 24) + this[offset + 1] = (value >>> 16) + this[offset + 2] = (value >>> 8) + this[offset + 3] = (value & 0xff) + } else { + objectWriteUInt32(this, value, offset, false) + } + return offset + 4 + } + + Buffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) { + value = +value + offset = offset | 0 + if (!noAssert) { + var limit = Math.pow(2, 8 * byteLength - 1) + + checkInt(this, value, offset, byteLength, limit - 1, -limit) + } + + var i = 0 + var mul = 1 + var sub = value < 0 ? 1 : 0 + this[offset] = value & 0xFF + while (++i < byteLength && (mul *= 0x100)) { + this[offset + i] = ((value / mul) >> 0) - sub & 0xFF + } + + return offset + byteLength + } + + Buffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) { + value = +value + offset = offset | 0 + if (!noAssert) { + var limit = Math.pow(2, 8 * byteLength - 1) + + checkInt(this, value, offset, byteLength, limit - 1, -limit) + } + + var i = byteLength - 1 + var mul = 1 + var sub = value < 0 ? 1 : 0 + this[offset + i] = value & 0xFF + while (--i >= 0 && (mul *= 0x100)) { + this[offset + i] = ((value / mul) >> 0) - sub & 0xFF + } + + return offset + byteLength + } + + Buffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) { + value = +value + offset = offset | 0 + if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80) + if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value) + if (value < 0) value = 0xff + value + 1 + this[offset] = (value & 0xff) + return offset + 1 + } + + Buffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) { + value = +value + offset = offset | 0 + if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000) + if (Buffer.TYPED_ARRAY_SUPPORT) { + this[offset] = (value & 0xff) + this[offset + 1] = (value >>> 8) + } else { + objectWriteUInt16(this, value, offset, true) + } + return offset + 2 + } + + Buffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) { + value = +value + offset = offset | 0 + if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000) + if (Buffer.TYPED_ARRAY_SUPPORT) { + this[offset] = (value >>> 8) + this[offset + 1] = (value & 0xff) + } else { + objectWriteUInt16(this, value, offset, false) + } + return offset + 2 + } + + Buffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) { + value = +value + offset = offset | 0 + if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000) + if (Buffer.TYPED_ARRAY_SUPPORT) { + this[offset] = (value & 0xff) + this[offset + 1] = (value >>> 8) + this[offset + 2] = (value >>> 16) + this[offset + 3] = (value >>> 24) + } else { + objectWriteUInt32(this, value, offset, true) + } + return offset + 4 + } + + Buffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) { + value = +value + offset = offset | 0 + if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000) + if (value < 0) value = 0xffffffff + value + 1 + if (Buffer.TYPED_ARRAY_SUPPORT) { + this[offset] = (value >>> 24) + this[offset + 1] = (value >>> 16) + this[offset + 2] = (value >>> 8) + this[offset + 3] = (value & 0xff) + } else { + objectWriteUInt32(this, value, offset, false) + } + return offset + 4 + } + + function checkIEEE754 (buf, value, offset, ext, max, min) { + if (value > max || value < min) throw new RangeError('value is out of bounds') + if (offset + ext > buf.length) throw new RangeError('index out of range') + if (offset < 0) throw new RangeError('index out of range') + } + + function writeFloat (buf, value, offset, littleEndian, noAssert) { + if (!noAssert) { + checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38) + } + ieee754.write(buf, value, offset, littleEndian, 23, 4) + return offset + 4 + } + + Buffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) { + return writeFloat(this, value, offset, true, noAssert) + } + + Buffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) { + return writeFloat(this, value, offset, false, noAssert) + } + + function writeDouble (buf, value, offset, littleEndian, noAssert) { + if (!noAssert) { + checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308) + } + ieee754.write(buf, value, offset, littleEndian, 52, 8) + return offset + 8 + } + + Buffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) { + return writeDouble(this, value, offset, true, noAssert) + } + + Buffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) { + return writeDouble(this, value, offset, false, noAssert) + } + + // copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length) + Buffer.prototype.copy = function copy (target, targetStart, start, end) { + if (!start) start = 0 + if (!end && end !== 0) end = this.length + if (targetStart >= target.length) targetStart = target.length + if (!targetStart) targetStart = 0 + if (end > 0 && end < start) end = start + + // Copy 0 bytes; we're done + if (end === start) return 0 + if (target.length === 0 || this.length === 0) return 0 + + // Fatal error conditions + if (targetStart < 0) { + throw new RangeError('targetStart out of bounds') + } + if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds') + if (end < 0) throw new RangeError('sourceEnd out of bounds') + + // Are we oob? + if (end > this.length) end = this.length + if (target.length - targetStart < end - start) { + end = target.length - targetStart + start + } + + var len = end - start + var i + + if (this === target && start < targetStart && targetStart < end) { + // descending copy from end + for (i = len - 1; i >= 0; i--) { + target[i + targetStart] = this[i + start] + } + } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) { + // ascending copy from start + for (i = 0; i < len; i++) { + target[i + targetStart] = this[i + start] + } + } else { + target._set(this.subarray(start, start + len), targetStart) + } + + return len + } + + // fill(value, start=0, end=buffer.length) + Buffer.prototype.fill = function fill (value, start, end) { + if (!value) value = 0 + if (!start) start = 0 + if (!end) end = this.length + + if (end < start) throw new RangeError('end < start') + + // Fill 0 bytes; we're done + if (end === start) return + if (this.length === 0) return + + if (start < 0 || start >= this.length) throw new RangeError('start out of bounds') + if (end < 0 || end > this.length) throw new RangeError('end out of bounds') + + var i + if (typeof value === 'number') { + for (i = start; i < end; i++) { + this[i] = value + } + } else { + var bytes = utf8ToBytes(value.toString()) + var len = bytes.length + for (i = start; i < end; i++) { + this[i] = bytes[i % len] + } + } + + return this + } + + /** + * Creates a new `ArrayBuffer` with the *copied* memory of the buffer instance. + * Added in Node 0.12. Only available in browsers that support ArrayBuffer. + */ + Buffer.prototype.toArrayBuffer = function toArrayBuffer () { + if (typeof Uint8Array !== 'undefined') { + if (Buffer.TYPED_ARRAY_SUPPORT) { + return (new Buffer(this)).buffer + } else { + var buf = new Uint8Array(this.length) + for (var i = 0, len = buf.length; i < len; i += 1) { + buf[i] = this[i] + } + return buf.buffer + } + } else { + throw new TypeError('Buffer.toArrayBuffer not supported in this browser') + } + } + + // HELPER FUNCTIONS + // ================ + + var BP = Buffer.prototype + + /** + * Augment a Uint8Array *instance* (not the Uint8Array class!) with Buffer methods + */ + Buffer._augment = function _augment (arr) { + arr.constructor = Buffer + arr._isBuffer = true + + // save reference to original Uint8Array set method before overwriting + arr._set = arr.set + + // deprecated + arr.get = BP.get + arr.set = BP.set + + arr.write = BP.write + arr.toString = BP.toString + arr.toLocaleString = BP.toString + arr.toJSON = BP.toJSON + arr.equals = BP.equals + arr.compare = BP.compare + arr.indexOf = BP.indexOf + arr.copy = BP.copy + arr.slice = BP.slice + arr.readUIntLE = BP.readUIntLE + arr.readUIntBE = BP.readUIntBE + arr.readUInt8 = BP.readUInt8 + arr.readUInt16LE = BP.readUInt16LE + arr.readUInt16BE = BP.readUInt16BE + arr.readUInt32LE = BP.readUInt32LE + arr.readUInt32BE = BP.readUInt32BE + arr.readIntLE = BP.readIntLE + arr.readIntBE = BP.readIntBE + arr.readInt8 = BP.readInt8 + arr.readInt16LE = BP.readInt16LE + arr.readInt16BE = BP.readInt16BE + arr.readInt32LE = BP.readInt32LE + arr.readInt32BE = BP.readInt32BE + arr.readFloatLE = BP.readFloatLE + arr.readFloatBE = BP.readFloatBE + arr.readDoubleLE = BP.readDoubleLE + arr.readDoubleBE = BP.readDoubleBE + arr.writeUInt8 = BP.writeUInt8 + arr.writeUIntLE = BP.writeUIntLE + arr.writeUIntBE = BP.writeUIntBE + arr.writeUInt16LE = BP.writeUInt16LE + arr.writeUInt16BE = BP.writeUInt16BE + arr.writeUInt32LE = BP.writeUInt32LE + arr.writeUInt32BE = BP.writeUInt32BE + arr.writeIntLE = BP.writeIntLE + arr.writeIntBE = BP.writeIntBE + arr.writeInt8 = BP.writeInt8 + arr.writeInt16LE = BP.writeInt16LE + arr.writeInt16BE = BP.writeInt16BE + arr.writeInt32LE = BP.writeInt32LE + arr.writeInt32BE = BP.writeInt32BE + arr.writeFloatLE = BP.writeFloatLE + arr.writeFloatBE = BP.writeFloatBE + arr.writeDoubleLE = BP.writeDoubleLE + arr.writeDoubleBE = BP.writeDoubleBE + arr.fill = BP.fill + arr.inspect = BP.inspect + arr.toArrayBuffer = BP.toArrayBuffer + + return arr + } + + var INVALID_BASE64_RE = /[^+\/0-9A-Za-z-_]/g + + function base64clean (str) { + // Node strips out invalid characters like \n and \t from the string, base64-js does not + str = stringtrim(str).replace(INVALID_BASE64_RE, '') + // Node converts strings with length < 2 to '' + if (str.length < 2) return '' + // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not + while (str.length % 4 !== 0) { + str = str + '=' + } + return str + } + + function stringtrim (str) { + if (str.trim) return str.trim() + return str.replace(/^\s+|\s+$/g, '') + } + + function toHex (n) { + if (n < 16) return '0' + n.toString(16) + return n.toString(16) + } + + function utf8ToBytes (string, units) { + units = units || Infinity + var codePoint + var length = string.length + var leadSurrogate = null + var bytes = [] + + for (var i = 0; i < length; i++) { + codePoint = string.charCodeAt(i) + + // is surrogate component + if (codePoint > 0xD7FF && codePoint < 0xE000) { + // last char was a lead + if (!leadSurrogate) { + // no lead yet + if (codePoint > 0xDBFF) { + // unexpected trail + if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) + continue + } else if (i + 1 === length) { + // unpaired lead + if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) + continue + } + + // valid lead + leadSurrogate = codePoint + + continue + } + + // 2 leads in a row + if (codePoint < 0xDC00) { + if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) + leadSurrogate = codePoint + continue + } + + // valid surrogate pair + codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000 + } else if (leadSurrogate) { + // valid bmp char, but last char was a lead + if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) + } + + leadSurrogate = null + + // encode utf8 + if (codePoint < 0x80) { + if ((units -= 1) < 0) break + bytes.push(codePoint) + } else if (codePoint < 0x800) { + if ((units -= 2) < 0) break + bytes.push( + codePoint >> 0x6 | 0xC0, + codePoint & 0x3F | 0x80 + ) + } else if (codePoint < 0x10000) { + if ((units -= 3) < 0) break + bytes.push( + codePoint >> 0xC | 0xE0, + codePoint >> 0x6 & 0x3F | 0x80, + codePoint & 0x3F | 0x80 + ) + } else if (codePoint < 0x110000) { + if ((units -= 4) < 0) break + bytes.push( + codePoint >> 0x12 | 0xF0, + codePoint >> 0xC & 0x3F | 0x80, + codePoint >> 0x6 & 0x3F | 0x80, + codePoint & 0x3F | 0x80 + ) + } else { + throw new Error('Invalid code point') + } + } + + return bytes + } + + function asciiToBytes (str) { + var byteArray = [] + for (var i = 0; i < str.length; i++) { + // Node's code seems to be doing this and not & 0x7F.. + byteArray.push(str.charCodeAt(i) & 0xFF) + } + return byteArray + } + + function utf16leToBytes (str, units) { + var c, hi, lo + var byteArray = [] + for (var i = 0; i < str.length; i++) { + if ((units -= 2) < 0) break + + c = str.charCodeAt(i) + hi = c >> 8 + lo = c % 256 + byteArray.push(lo) + byteArray.push(hi) + } + + return byteArray + } + + function base64ToBytes (str) { + return base64.toByteArray(base64clean(str)) + } + + function blitBuffer (src, dst, offset, length) { + for (var i = 0; i < length; i++) { + if ((i + offset >= dst.length) || (i >= src.length)) break + dst[i + offset] = src[i] + } + return i + } + + /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(51).Buffer, (function() { return this; }()))) + +/***/ }, +/* 52 */ +/***/ function(module, exports, __webpack_require__) { + + var lookup = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'; + + ;(function (exports) { + 'use strict'; + + var Arr = (typeof Uint8Array !== 'undefined') + ? Uint8Array + : Array + + var PLUS = '+'.charCodeAt(0) + var SLASH = '/'.charCodeAt(0) + var NUMBER = '0'.charCodeAt(0) + var LOWER = 'a'.charCodeAt(0) + var UPPER = 'A'.charCodeAt(0) + var PLUS_URL_SAFE = '-'.charCodeAt(0) + var SLASH_URL_SAFE = '_'.charCodeAt(0) + + function decode (elt) { + var code = elt.charCodeAt(0) + if (code === PLUS || + code === PLUS_URL_SAFE) + return 62 // '+' + if (code === SLASH || + code === SLASH_URL_SAFE) + return 63 // '/' + if (code < NUMBER) + return -1 //no match + if (code < NUMBER + 10) + return code - NUMBER + 26 + 26 + if (code < UPPER + 26) + return code - UPPER + if (code < LOWER + 26) + return code - LOWER + 26 + } + + function b64ToByteArray (b64) { + var i, j, l, tmp, placeHolders, arr + + if (b64.length % 4 > 0) { + throw new Error('Invalid string. Length must be a multiple of 4') + } + + // the number of equal signs (place holders) + // if there are two placeholders, than the two characters before it + // represent one byte + // if there is only one, then the three characters before it represent 2 bytes + // this is just a cheap hack to not do indexOf twice + var len = b64.length + placeHolders = '=' === b64.charAt(len - 2) ? 2 : '=' === b64.charAt(len - 1) ? 1 : 0 + + // base64 is 4/3 + up to two characters of the original data + arr = new Arr(b64.length * 3 / 4 - placeHolders) + + // if there are placeholders, only get up to the last complete 4 chars + l = placeHolders > 0 ? b64.length - 4 : b64.length + + var L = 0 + + function push (v) { + arr[L++] = v + } + + for (i = 0, j = 0; i < l; i += 4, j += 3) { + tmp = (decode(b64.charAt(i)) << 18) | (decode(b64.charAt(i + 1)) << 12) | (decode(b64.charAt(i + 2)) << 6) | decode(b64.charAt(i + 3)) + push((tmp & 0xFF0000) >> 16) + push((tmp & 0xFF00) >> 8) + push(tmp & 0xFF) + } + + if (placeHolders === 2) { + tmp = (decode(b64.charAt(i)) << 2) | (decode(b64.charAt(i + 1)) >> 4) + push(tmp & 0xFF) + } else if (placeHolders === 1) { + tmp = (decode(b64.charAt(i)) << 10) | (decode(b64.charAt(i + 1)) << 4) | (decode(b64.charAt(i + 2)) >> 2) + push((tmp >> 8) & 0xFF) + push(tmp & 0xFF) + } + + return arr + } + + function uint8ToBase64 (uint8) { + var i, + extraBytes = uint8.length % 3, // if we have 1 byte left, pad 2 bytes + output = "", + temp, length + + function encode (num) { + return lookup.charAt(num) + } + + function tripletToBase64 (num) { + return encode(num >> 18 & 0x3F) + encode(num >> 12 & 0x3F) + encode(num >> 6 & 0x3F) + encode(num & 0x3F) + } + + // go through the array every three bytes, we'll deal with trailing stuff later + for (i = 0, length = uint8.length - extraBytes; i < length; i += 3) { + temp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2]) + output += tripletToBase64(temp) + } + + // pad the end with zeros, but make sure to not forget the extra bytes + switch (extraBytes) { + case 1: + temp = uint8[uint8.length - 1] + output += encode(temp >> 2) + output += encode((temp << 4) & 0x3F) + output += '==' + break + case 2: + temp = (uint8[uint8.length - 2] << 8) + (uint8[uint8.length - 1]) + output += encode(temp >> 10) + output += encode((temp >> 4) & 0x3F) + output += encode((temp << 2) & 0x3F) + output += '=' + break + } + + return output + } + + exports.toByteArray = b64ToByteArray + exports.fromByteArray = uint8ToBase64 + }( false ? (this.base64js = {}) : exports)) + + +/***/ }, +/* 53 */ +/***/ function(module, exports) { + + exports.read = function (buffer, offset, isLE, mLen, nBytes) { + var e, m + var eLen = nBytes * 8 - mLen - 1 + var eMax = (1 << eLen) - 1 + var eBias = eMax >> 1 + var nBits = -7 + var i = isLE ? (nBytes - 1) : 0 + var d = isLE ? -1 : 1 + var s = buffer[offset + i] + + i += d + + e = s & ((1 << (-nBits)) - 1) + s >>= (-nBits) + nBits += eLen + for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {} + + m = e & ((1 << (-nBits)) - 1) + e >>= (-nBits) + nBits += mLen + for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {} + + if (e === 0) { + e = 1 - eBias + } else if (e === eMax) { + return m ? NaN : ((s ? -1 : 1) * Infinity) + } else { + m = m + Math.pow(2, mLen) + e = e - eBias + } + return (s ? -1 : 1) * m * Math.pow(2, e - mLen) + } + + exports.write = function (buffer, value, offset, isLE, mLen, nBytes) { + var e, m, c + var eLen = nBytes * 8 - mLen - 1 + var eMax = (1 << eLen) - 1 + var eBias = eMax >> 1 + var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0) + var i = isLE ? 0 : (nBytes - 1) + var d = isLE ? 1 : -1 + var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0 + + value = Math.abs(value) + + if (isNaN(value) || value === Infinity) { + m = isNaN(value) ? 1 : 0 + e = eMax + } else { + e = Math.floor(Math.log(value) / Math.LN2) + if (value * (c = Math.pow(2, -e)) < 1) { + e-- + c *= 2 + } + if (e + eBias >= 1) { + value += rt / c + } else { + value += rt * Math.pow(2, 1 - eBias) + } + if (value * c >= 2) { + e++ + c /= 2 + } + + if (e + eBias >= eMax) { + m = 0 + e = eMax + } else if (e + eBias >= 1) { + m = (value * c - 1) * Math.pow(2, mLen) + e = e + eBias + } else { + m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen) + e = 0 } - this.handlers[b] = this.options.handlers[b]; } - this.preferStrings = null != this.options.preferStrings ? this.options.preferStrings : this.defaults.preferStrings; - this.preferBuffers = null != this.options.preferBuffers ? this.options.preferBuffers : this.defaults.preferBuffers; - this.defaultHandler = this.options.defaultHandler || this.defaults.defaultHandler; - this.mapBuilder = this.options.mapBuilder; - this.arrayBuilder = this.options.arrayBuilder; + + for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {} + + e = (e << mLen) | m + eLen += mLen + for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {} + + buffer[offset + i - d] |= s * 128 + } + + +/***/ }, +/* 54 */ +/***/ function(module, exports) { + + var toString = {}.toString; + + module.exports = Array.isArray || function (arr) { + return toString.call(arr) == '[object Array]'; }; - com.cognitect.transit.impl.decoder.Decoder.prototype.defaults = {handlers:{_:function(a, b) { - return com.cognitect.transit.types.nullValue(); - }, "?":function(a, b) { - return com.cognitect.transit.types.boolValue(a); - }, b:function(a, b) { - return com.cognitect.transit.types.binary(a, b); - }, i:function(a, b) { - return com.cognitect.transit.types.intValue(a); - }, n:function(a, b) { - return com.cognitect.transit.types.bigInteger(a); - }, d:function(a, b) { - return com.cognitect.transit.types.floatValue(a); - }, f:function(a, b) { - return com.cognitect.transit.types.bigDecimalValue(a); - }, c:function(a, b) { - return com.cognitect.transit.types.charValue(a); - }, ":":function(a, b) { - return com.cognitect.transit.types.keyword(a); - }, $:function(a, b) { - return com.cognitect.transit.types.symbol(a); - }, r:function(a, b) { - return com.cognitect.transit.types.uri(a); - }, z:function(a, b) { - return com.cognitect.transit.types.specialDouble(a); - }, "'":function(a, b) { - return a; - }, m:function(a, b) { - return com.cognitect.transit.types.date(a); - }, t:function(a, b) { - return com.cognitect.transit.types.verboseDate(a); - }, u:function(a, b) { - return com.cognitect.transit.types.uuid(a); - }, set:function(a, b) { - return com.cognitect.transit.types.set(a); - }, list:function(a, b) { - return com.cognitect.transit.types.list(a); - }, link:function(a, b) { - return com.cognitect.transit.types.link(a); - }, cmap:function(a, b) { - return com.cognitect.transit.types.map(a, !1); - }}, defaultHandler:function(a, b) { - return com.cognitect.transit.types.taggedValue(a, b); - }, preferStrings:!0, preferBuffers:!0}; - com.cognitect.transit.impl.decoder.Decoder.prototype.decode = function(a, b, c, d) { - if (null == a) { + + +/***/ }, +/* 55 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.SyntaxOrTermWrapper = undefined; + exports.unwrap = unwrap; + + var _errors = __webpack_require__(23); + + var _immutable = __webpack_require__(3); + + var _enforester = __webpack_require__(56); + + var _syntax = __webpack_require__(46); + + var _ramda = __webpack_require__(10); + + var _ = _interopRequireWildcard(_ramda); + + function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + + const symWrap = Symbol('wrapper'); + const privateData = new WeakMap(); + + const getVal = t => { + if (t.match("delimiter")) { return null; } - switch(typeof a) { - case "string": - return this.decodeString(a, b, c, d); - case "object": - return com.cognitect.transit.util.isArray(a) ? "^ " === a[0] ? this.decodeArrayHash(a, b, c, d) : this.decodeArray(a, b, c, d) : this.decodeHash(a, b, c, d); + if (typeof t.val === 'function') { + return t.val(); } - return a; - }; - com.cognitect.transit.impl.decoder.Decoder.prototype.decode = com.cognitect.transit.impl.decoder.Decoder.prototype.decode; - com.cognitect.transit.impl.decoder.Decoder.prototype.decodeString = function(a, b, c, d) { - return com.cognitect.transit.caching.isCacheable(a, c) ? (a = this.parseString(a, b, !1), b && b.write(a, c), a) : com.cognitect.transit.caching.isCacheCode(a) ? b.read(a, c) : this.parseString(a, b, c); + return null; }; - com.cognitect.transit.impl.decoder.Decoder.prototype.decodeHash = function(a, b, c, d) { - c = com.cognitect.transit.util.objectKeys(a); - var e = c[0]; - d = 1 == c.length ? this.decode(e, b, !1, !1) : null; - if (com.cognitect.transit.impl.decoder.isTag(d)) { - return a = a[e], c = this.handlers[d.str], null != c ? c(this.decode(a, b, !1, !0), this) : com.cognitect.transit.types.taggedValue(d.str, this.decode(a, b, !1, !1)); + + class SyntaxOrTermWrapper { + constructor(s) { + let context = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + + this[symWrap] = s; + this.context = context; } - if (this.mapBuilder) { - if (c.length < 2 * com.cognitect.transit.types.SMALL_ARRAY_MAP_THRESHOLD && this.mapBuilder.fromArray) { - var f = []; - for (d = 0;d < c.length;d++) { - e = c[d], f.push(this.decode(e, b, !0, !1)), f.push(this.decode(a[e], b, !1, !1)); - } - return this.mapBuilder.fromArray(f, a); - } - f = this.mapBuilder.init(a); - for (d = 0;d < c.length;d++) { - e = c[d], f = this.mapBuilder.add(f, this.decode(e, b, !0, !1), this.decode(a[e], b, !1, !1), a); + + from(type, value) { + let stx = this[symWrap]; + if (typeof stx.from === 'function') { + return stx.from(type, value); } - return this.mapBuilder.finalize(f, a); } - f = []; - for (d = 0;d < c.length;d++) { - e = c[d], f.push(this.decode(e, b, !0, !1)), f.push(this.decode(a[e], b, !1, !1)); + fromNull() { + return this.from("null", null); } - return com.cognitect.transit.types.map(f, !1); - }; - com.cognitect.transit.impl.decoder.Decoder.prototype.decodeArrayHash = function(a, b, c, d) { - if (this.mapBuilder) { - if (a.length < 2 * com.cognitect.transit.types.SMALL_ARRAY_MAP_THRESHOLD + 1 && this.mapBuilder.fromArray) { - d = []; - for (c = 1;c < a.length;c += 2) { - d.push(this.decode(a[c], b, !0, !1)), d.push(this.decode(a[c + 1], b, !1, !1)); - } - return this.mapBuilder.fromArray(d, a); - } - d = this.mapBuilder.init(a); - for (c = 1;c < a.length;c += 2) { - d = this.mapBuilder.add(d, this.decode(a[c], b, !0, !1), this.decode(a[c + 1], b, !1, !1), a); - } - return this.mapBuilder.finalize(d, a); + + fromNumber(value) { + return this.from('number', value); } - d = []; - for (c = 1;c < a.length;c += 2) { - d.push(this.decode(a[c], b, !0, !1)), d.push(this.decode(a[c + 1], b, !1, !1)); + + fromString(value) { + return this.from("string", value); } - return com.cognitect.transit.types.map(d, !1); - }; - com.cognitect.transit.impl.decoder.Decoder.prototype.decodeArray = function(a, b, c, d) { - if (d) { - var e = []; - for (d = 0;d < a.length;d++) { - e.push(this.decode(a[d], b, c, !1)); + + fromPunctuator(value) { + return this.from("punctuator", value); + } + + fromKeyword(value) { + return this.from("keyword", value); + } + + fromIdentifier(value) { + return this.from("identifier", value); + } + + fromRegularExpression(value) { + return this.from("regularExpression", value); + } + + fromBraces(inner) { + return this.from("braces", inner); + } + + fromBrackets(inner) { + return this.from("brackets", inner); + } + + fromParens(inner) { + return this.from("parens", inner); + } + + match(type, value) { + let stx = this[symWrap]; + if (typeof stx.match === 'function') { + return stx.match(type, value); } - return e; } - e = b && b.idx; - if (2 === a.length && "string" === typeof a[0] && (d = this.decode(a[0], b, !1, !1), com.cognitect.transit.impl.decoder.isTag(d))) { - return a = a[1], e = this.handlers[d.str], null != e ? e = e(this.decode(a, b, c, !0), this) : com.cognitect.transit.types.taggedValue(d.str, this.decode(a, b, c, !1)); + + isIdentifier(value) { + return this.match("identifier", value); } - b && e != b.idx && (b.idx = e); - if (this.arrayBuilder) { - if (32 >= a.length && this.arrayBuilder.fromArray) { - e = []; - for (d = 0;d < a.length;d++) { - e.push(this.decode(a[d], b, c, !1)); - } - return this.arrayBuilder.fromArray(e, a); + + isAssign(value) { + return this.match("assign", value); + } + + isBooleanLiteral(value) { + return this.match("boolean", value); + } + + isKeyword(value) { + return this.match("keyword", value); + } + + isNullLiteral(value) { + return this.match("null", value); + } + + isNumericLiteral(value) { + return this.match("number", value); + } + + isPunctuator(value) { + return this.match("punctuator", value); + } + + isStringLiteral(value) { + return this.match("string", value); + } + + isRegularExpression(value) { + return this.match("regularExpression", value); + } + + isTemplate(value) { + return this.match("template", value); + } + + isDelimiter(value) { + return this.match("delimiter", value); + } + + isParens(value) { + return this.match("parens", value); + } + + isBraces(value) { + return this.match("braces", value); + } + + isBrackets(value) { + return this.match("brackets", value); + } + + isSyntaxTemplate(value) { + return this.match("syntaxTemplate", value); + } + + isEOF(value) { + return this.match("eof", value); + } + + lineNumber() { + return this[symWrap].lineNumber(); + } + + val() { + return getVal(this[symWrap]); + } + + inner() { + let stx = this[symWrap]; + if (!stx.match("delimiter")) { + throw new Error('Can only get inner syntax on a delimiter'); } - e = this.arrayBuilder.init(a); - for (d = 0;d < a.length;d++) { - e = this.arrayBuilder.add(e, this.decode(a[d], b, c, !1), a); + + let enf = new _enforester.Enforester(stx.inner(), (0, _immutable.List)(), this.context); + return new MacroContext(enf, 'inner', this.context); + } + } + + exports.SyntaxOrTermWrapper = SyntaxOrTermWrapper; + function unwrap(x) { + if (x instanceof SyntaxOrTermWrapper) { + return x[symWrap]; + } + return x; + } + + function cloneEnforester(enf) { + const rest = enf.rest; + const prev = enf.prev; + const context = enf.context; + + return new _enforester.Enforester(rest, prev, context); + } + + function Marker() {} + + /* + ctx :: { + of: (Syntax) -> ctx + next: (String) -> Syntax or Term + } + */ + class MacroContext { + + constructor(enf, name, context, useScope, introducedScope) { + const startMarker = new Marker(); + const startEnf = cloneEnforester(enf); + const priv = { + name: name, + context: context, + enf: startEnf, + startMarker: startMarker, + markers: new Map([[startMarker, enf]]) + }; + + if (useScope && introducedScope) { + priv.noScopes = false; + priv.useScope = useScope; + priv.introducedScope = introducedScope; + } else { + priv.noScopes = true; } - return this.arrayBuilder.finalize(e, a); + privateData.set(this, priv); + this.reset(); // set current enforester + + this[Symbol.iterator] = () => this; } - e = []; - for (d = 0;d < a.length;d++) { - e.push(this.decode(a[d], b, c, !1)); + + name() { + var _privateData$get = privateData.get(this); + + const name = _privateData$get.name; + const context = _privateData$get.context; + + return new SyntaxOrTermWrapper(name, context); } - return e; - }; - com.cognitect.transit.impl.decoder.Decoder.prototype.parseString = function(a, b, c) { - if (a.charAt(0) === com.cognitect.transit.delimiters.ESC) { - b = a.charAt(1); - if (b === com.cognitect.transit.delimiters.ESC || b === com.cognitect.transit.delimiters.SUB || b === com.cognitect.transit.delimiters.RES) { - return a.substring(1); + + expand(type) { + var _privateData$get2 = privateData.get(this); + + const enf = _privateData$get2.enf; + const context = _privateData$get2.context; + + if (enf.rest.size === 0) { + return { + done: true, + value: null + }; } - if (b === com.cognitect.transit.delimiters.TAG) { - return com.cognitect.transit.impl.decoder.tag(a.substring(2)); + enf.expandMacro(); + let originalRest = enf.rest; + let value; + switch (type) { + case 'AssignmentExpression': + case 'expr': + value = enf.enforestExpressionLoop(); + break; + case 'Expression': + value = enf.enforestExpression(); + break; + case 'Statement': + case 'stmt': + value = enf.enforestStatement(); + break; + case 'BlockStatement': + case 'WhileStatement': + case 'IfStatement': + case 'ForStatement': + case 'SwitchStatement': + case 'BreakStatement': + case 'ContinueStatement': + case 'DebuggerStatement': + case 'WithStatement': + case 'TryStatement': + case 'ThrowStatement': + case 'ClassDeclaration': + case 'FunctionDeclaration': + case 'LabeledStatement': + case 'VariableDeclarationStatement': + case 'ReturnStatement': + case 'ExpressionStatement': + value = enf.enforestStatement(); + (0, _errors.expect)(_.whereEq({ type: type }, value), `Expecting a ${ type }`, value, originalRest); + break; + case 'YieldExpression': + value = enf.enforestYieldExpression(); + break; + case 'ClassExpression': + value = enf.enforestClass({ isExpr: true }); + break; + case 'ArrowExpression': + value = enf.enforestArrowExpression(); + break; + case 'NewExpression': + value = enf.enforestNewExpression(); + break; + case 'ThisExpression': + case 'FunctionExpression': + case 'IdentifierExpression': + case 'LiteralNumericExpression': + case 'LiteralInfinityExpression': + case 'LiteralStringExpression': + case 'TemplateExpression': + case 'LiteralBooleanExpression': + case 'LiteralNullExpression': + case 'LiteralRegExpExpression': + case 'ObjectExpression': + case 'ArrayExpression': + value = enf.enforestPrimaryExpression(); + break; + case 'UnaryExpression': + case 'UpdateExpression': + case 'BinaryExpression': + case 'StaticMemberExpression': + case 'ComputedMemberExpression': + case 'CompoundAssignmentExpression': + case 'ConditionalExpression': + value = enf.enforestExpressionLoop(); + (0, _errors.expect)(_.whereEq({ type: type }, value), `Expecting a ${ type }`, value, originalRest); + break; + default: + throw new Error('Unknown term type: ' + type); } - c = this.handlers[b]; - return null == c ? this.defaultHandler(b, a.substring(2)) : c(a.substring(2), this); - } - return a; - }; - com.cognitect.transit.impl.decoder.decoder = function(a) { - return new com.cognitect.transit.impl.decoder.Decoder(a); - }; - com.cognitect.transit.impl.reader = {}; - com.cognitect.transit.impl.reader.JSONUnmarshaller = function(a) { - this.decoder = new com.cognitect.transit.impl.decoder.Decoder(a); - }; - com.cognitect.transit.impl.reader.JSONUnmarshaller.prototype.unmarshal = function(a, b) { - return this.decoder.decode(JSON.parse(a), b); - }; - com.cognitect.transit.impl.reader.Reader = function(a, b) { - this.unmarshaller = a; - this.options = b || {}; - this.cache = this.options.cache ? this.options.cache : new com.cognitect.transit.caching.ReadCache; - }; - com.cognitect.transit.impl.reader.Reader.prototype.read = function(a) { - a = this.unmarshaller.unmarshal(a, this.cache); - this.cache.clear(); - return a; - }; - com.cognitect.transit.impl.reader.Reader.prototype.read = com.cognitect.transit.impl.reader.Reader.prototype.read; - com.cognitect.transit.impl.writer = {}; - com.cognitect.transit.impl.writer.escape = function(a) { - if (0 < a.length) { - var b = a.charAt(0); - return b === com.cognitect.transit.delimiters.ESC || b === com.cognitect.transit.delimiters.SUB || b === com.cognitect.transit.delimiters.RES ? com.cognitect.transit.delimiters.ESC + a : a; + return { + done: false, + value: new SyntaxOrTermWrapper(value, context) + }; } - return a; - }; - com.cognitect.transit.impl.writer.JSONMarshaller = function(a) { - this.opts = a || {}; - this.preferStrings = null != this.opts.preferStrings ? this.opts.preferStrings : !0; - this.objectBuilder = this.opts.objectBuilder || null; - this.handlers = new com.cognitect.transit.handlers.Handlers; - if (a = this.opts.handlers) { - if (com.cognitect.transit.util.isArray(a) || !a.forEach) { - throw Error('transit writer "handlers" option must be a map'); + + _rest(enf) { + const priv = privateData.get(this); + if (priv.markers.get(priv.startMarker) === enf) { + return priv.enf.rest; } - var b = this; - a.forEach(function(a, d) { - if (void 0 !== d) { - b.handlers.set(d, a); + throw Error("Unauthorized access!"); + } + + reset(marker) { + const priv = privateData.get(this); + let enf; + if (marker == null) { + // go to the beginning + enf = priv.markers.get(priv.startMarker); + } else if (marker && marker instanceof Marker) { + // marker could be from another context + if (priv.markers.has(marker)) { + enf = priv.markers.get(marker); } else { - throw Error("Cannot create handler for JavaScript undefined"); + throw new Error('marker must originate from this context'); } - }); + } else { + throw new Error('marker must be an instance of Marker'); + } + priv.enf = cloneEnforester(enf); } - this.handlerForForeign = this.opts.handlerForForeign; - this.unpack = this.opts.unpack || function(a) { - return com.cognitect.transit.types.isArrayMap(a) && null === a.backingMap ? a._entries : !1; - }; - this.verbose = this.opts && this.opts.verbose || !1; - }; - com.cognitect.transit.impl.writer.JSONMarshaller.prototype.handler = function(a) { - var b = this.handlers.get(com.cognitect.transit.handlers.constructor(a)); - return null != b ? b : (a = a && a.transitTag) ? this.handlers.get(a) : null; - }; - com.cognitect.transit.impl.writer.JSONMarshaller.prototype.registerHandler = function(a, b) { - this.handlers.set(a, b); - }; - com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitNil = function(a, b) { - return a ? this.emitString(com.cognitect.transit.delimiters.ESC, "_", "", a, b) : null; - }; - com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitString = function(a, b, c, d, e) { - a = a + b + c; - return e ? e.write(a, d) : a; - }; - com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitBoolean = function(a, b, c) { - return b ? this.emitString(com.cognitect.transit.delimiters.ESC, "?", a.toString()[0], b, c) : a; - }; - com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitInteger = function(a, b, c) { - return Infinity === a ? this.emitString(com.cognitect.transit.delimiters.ESC, "z", "INF", b, c) : -Infinity === a ? this.emitString(com.cognitect.transit.delimiters.ESC, "z", "-INF", b, c) : isNaN(a) ? this.emitString(com.cognitect.transit.delimiters.ESC, "z", "NaN", b, c) : b || "string" === typeof a || a instanceof goog.math.Long ? this.emitString(com.cognitect.transit.delimiters.ESC, "i", a.toString(), b, c) : a; - }; - com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitDouble = function(a, b, c) { - return b ? this.emitString(a.ESC, "d", a, b, c) : a; - }; - com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitBinary = function(a, b, c) { - return this.emitString(com.cognitect.transit.delimiters.ESC, "b", a, b, c); - }; - com.cognitect.transit.impl.writer.JSONMarshaller.prototype.emitQuoted = function(a, b, c) { - if (a.verbose) { - a = {}; - var d = this.emitString(com.cognitect.transit.delimiters.ESC_TAG, "'", "", !0, c); - a[d] = com.cognitect.transit.impl.writer.marshal(this, b, !1, c); - return a; + + mark() { + const priv = privateData.get(this); + let marker; + + // the idea here is that marking at the beginning shouldn't happen more than once. + // We can reuse startMarker. + if (priv.enf.rest === priv.markers.get(priv.startMarker).rest) { + marker = priv.startMarker; + } else if (priv.enf.rest.isEmpty()) { + // same reason as above + if (!priv.endMarker) priv.endMarker = new Marker(); + marker = priv.endMarker; + } else { + //TODO(optimization/dubious): check that there isn't already a marker for this index? + marker = new Marker(); + } + if (!priv.markers.has(marker)) { + priv.markers.set(marker, cloneEnforester(priv.enf)); + } + return marker; + } + + next() { + var _privateData$get3 = privateData.get(this); + + const enf = _privateData$get3.enf; + const noScopes = _privateData$get3.noScopes; + const useScope = _privateData$get3.useScope; + const introducedScope = _privateData$get3.introducedScope; + const context = _privateData$get3.context; + + if (enf.rest.size === 0) { + return { + done: true, + value: null + }; + } + let value = enf.advance(); + if (!noScopes) { + value = value.addScope(useScope, context.bindings, _syntax.ALL_PHASES).addScope(introducedScope, context.bindings, _syntax.ALL_PHASES, { flip: true }); + } + return { + done: false, + value: new SyntaxOrTermWrapper(value, context) + }; + } + } + exports.default = MacroContext; + //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/macro-context.js"],"names":[],"mappings":"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","file":"macro-context.js","sourcesContent":["import { expect } from './errors';\nimport { List } from 'immutable';\nimport { Enforester } from './enforester';\nimport { ALL_PHASES } from './syntax';\nimport * as _ from 'ramda';\n\nconst symWrap = Symbol('wrapper');\nconst privateData = new WeakMap();\n\nconst getVal = t => {\n  if (t.match(\"delimiter\")) {\n    return null;\n  }\n  if (typeof t.val === 'function') {\n    return t.val();\n  }\n  return null;\n};\n\nexport class SyntaxOrTermWrapper {\n  constructor(s, context = {}) {\n    this[symWrap] = s;\n    this.context = context;\n  }\n\n  from(type, value) {\n    let stx = this[symWrap];\n    if (typeof stx.from === 'function') {\n      return stx.from(type, value);\n    }\n  }\n  fromNull() {\n    return this.from(\"null\", null);\n  }\n\n  fromNumber(value) {\n    return this.from('number', value);\n  }\n\n  fromString(value) {\n    return this.from(\"string\", value);\n  }\n\n  fromPunctuator(value) {\n    return this.from(\"punctuator\", value);\n  }\n\n  fromKeyword(value) {\n    return this.from(\"keyword\", value);\n  }\n\n  fromIdentifier(value) {\n    return this.from(\"identifier\", value);\n  }\n\n  fromRegularExpression(value) {\n    return this.from(\"regularExpression\", value);\n  }\n\n  fromBraces(inner) {\n    return this.from(\"braces\", inner);\n  }\n\n  fromBrackets(inner) {\n    return this.from(\"brackets\", inner);\n  }\n\n  fromParens(inner) {\n    return this.from(\"parens\", inner);\n  }\n\n  match(type, value) {\n    let stx = this[symWrap];\n    if (typeof stx.match === 'function') {\n      return stx.match(type, value);\n    }\n  }\n\n  isIdentifier(value) {\n    return this.match(\"identifier\", value);\n  }\n\n  isAssign(value) {\n    return this.match(\"assign\", value);\n  }\n\n  isBooleanLiteral(value) {\n    return this.match(\"boolean\", value);\n  }\n\n  isKeyword(value) {\n    return this.match(\"keyword\", value);\n  }\n\n  isNullLiteral(value) {\n    return this.match(\"null\", value);\n  }\n\n  isNumericLiteral(value) {\n    return this.match(\"number\", value);\n  }\n\n  isPunctuator(value) {\n    return this.match(\"punctuator\", value);\n  }\n\n  isStringLiteral(value) {\n    return this.match(\"string\", value);\n  }\n\n  isRegularExpression(value) {\n    return this.match(\"regularExpression\", value);\n  }\n\n  isTemplate(value) {\n    return this.match(\"template\", value);\n  }\n\n  isDelimiter(value) {\n    return this.match(\"delimiter\", value);\n  }\n\n  isParens(value) {\n    return this.match(\"parens\", value);\n  }\n\n  isBraces(value) {\n    return this.match(\"braces\", value);\n  }\n\n  isBrackets(value) {\n    return this.match(\"brackets\", value);\n  }\n\n  isSyntaxTemplate(value) {\n    return this.match(\"syntaxTemplate\", value);\n  }\n\n  isEOF(value) {\n    return this.match(\"eof\", value);\n  }\n\n  lineNumber() {\n    return this[symWrap].lineNumber();\n  }\n\n  val() {\n    return getVal(this[symWrap]);\n  }\n\n  inner() {\n    let stx = this[symWrap];\n    if (!stx.match(\"delimiter\")) {\n      throw new Error('Can only get inner syntax on a delimiter');\n    }\n\n    let enf = new Enforester(stx.inner(), List(), this.context);\n    return new MacroContext(enf, 'inner', this.context);\n  }\n}\n\nexport function unwrap(x) {\n  if (x instanceof SyntaxOrTermWrapper) {\n    return x[symWrap];\n  }\n  return x;\n}\n\nfunction cloneEnforester(enf) {\n  const { rest, prev, context } = enf;\n  return new Enforester(rest, prev, context);\n}\n\nfunction Marker () {}\n\n/*\nctx :: {\n  of: (Syntax) -> ctx\n  next: (String) -> Syntax or Term\n}\n*/\nexport default class MacroContext {\n\n  constructor(enf, name, context, useScope, introducedScope) {\n    const startMarker = new Marker();\n    const startEnf = cloneEnforester(enf);\n    const priv = {\n      name,\n      context,\n      enf: startEnf,\n      startMarker,\n      markers: new Map([[startMarker, enf]]),\n    };\n\n    if (useScope && introducedScope) {\n      priv.noScopes = false;\n      priv.useScope = useScope;\n      priv.introducedScope = introducedScope;\n    } else {\n      priv.noScopes = true;\n    }\n    privateData.set(this, priv);\n    this.reset(); // set current enforester\n\n    this[Symbol.iterator] = () => this;\n  }\n\n  name() {\n    const { name, context } = privateData.get(this);\n    return new SyntaxOrTermWrapper(name, context);\n  }\n\n  expand(type) {\n    const { enf, context } = privateData.get(this);\n    if (enf.rest.size === 0) {\n      return {\n        done: true,\n        value: null\n      };\n    }\n    enf.expandMacro();\n    let originalRest = enf.rest;\n    let value;\n    switch(type) {\n      case 'AssignmentExpression':\n      case 'expr':\n        value = enf.enforestExpressionLoop();\n        break;\n      case 'Expression':\n        value = enf.enforestExpression();\n        break;\n      case 'Statement':\n      case 'stmt':\n        value = enf.enforestStatement();\n        break;\n      case 'BlockStatement':\n      case 'WhileStatement':\n      case 'IfStatement':\n      case 'ForStatement':\n      case 'SwitchStatement':\n      case 'BreakStatement':\n      case 'ContinueStatement':\n      case 'DebuggerStatement':\n      case 'WithStatement':\n      case 'TryStatement':\n      case 'ThrowStatement':\n      case 'ClassDeclaration':\n      case 'FunctionDeclaration':\n      case 'LabeledStatement':\n      case 'VariableDeclarationStatement':\n      case 'ReturnStatement':\n      case 'ExpressionStatement':\n        value = enf.enforestStatement();\n        expect(_.whereEq({type}, value), `Expecting a ${type}`, value, originalRest);\n        break;\n      case 'YieldExpression':\n        value = enf.enforestYieldExpression();\n        break;\n      case 'ClassExpression':\n        value = enf.enforestClass({isExpr: true});\n        break;\n      case 'ArrowExpression':\n        value = enf.enforestArrowExpression();\n        break;\n      case 'NewExpression':\n        value = enf.enforestNewExpression();\n        break;\n      case 'ThisExpression':\n      case 'FunctionExpression':\n      case 'IdentifierExpression':\n      case 'LiteralNumericExpression':\n      case 'LiteralInfinityExpression':\n      case 'LiteralStringExpression':\n      case 'TemplateExpression':\n      case 'LiteralBooleanExpression':\n      case 'LiteralNullExpression':\n      case 'LiteralRegExpExpression':\n      case 'ObjectExpression':\n      case 'ArrayExpression':\n        value = enf.enforestPrimaryExpression();\n        break;\n      case 'UnaryExpression':\n      case 'UpdateExpression':\n      case 'BinaryExpression':\n      case 'StaticMemberExpression':\n      case 'ComputedMemberExpression':\n      case 'CompoundAssignmentExpression':\n      case 'ConditionalExpression':\n        value = enf.enforestExpressionLoop();\n        expect(_.whereEq({type}, value), `Expecting a ${type}`, value, originalRest);\n        break;\n      default:\n        throw new Error('Unknown term type: ' + type);\n    }\n    return {\n      done: false,\n      value: new SyntaxOrTermWrapper(value, context)\n    };\n  }\n\n  _rest(enf) {\n    const priv = privateData.get(this);\n    if (priv.markers.get(priv.startMarker) === enf) {\n      return priv.enf.rest;\n    }\n    throw Error(\"Unauthorized access!\");\n  }\n\n  reset(marker) {\n    const priv = privateData.get(this);\n    let enf;\n    if (marker == null) {\n      // go to the beginning\n      enf = priv.markers.get(priv.startMarker);\n    } else if (marker && marker instanceof Marker) {\n      // marker could be from another context\n      if (priv.markers.has(marker)) {\n        enf = priv.markers.get(marker);\n      } else {\n        throw new Error('marker must originate from this context');\n      }\n    } else {\n      throw new Error('marker must be an instance of Marker');\n    }\n    priv.enf = cloneEnforester(enf);\n  }\n\n  mark() {\n    const priv = privateData.get(this);\n    let marker;\n\n    // the idea here is that marking at the beginning shouldn't happen more than once.\n    // We can reuse startMarker.\n    if (priv.enf.rest === priv.markers.get(priv.startMarker).rest) {\n      marker = priv.startMarker;\n    } else if (priv.enf.rest.isEmpty()) {\n      // same reason as above\n      if (!priv.endMarker) priv.endMarker = new Marker();\n      marker = priv.endMarker;\n    } else {\n      //TODO(optimization/dubious): check that there isn't already a marker for this index?\n      marker = new Marker();\n    }\n    if (!priv.markers.has(marker)) {\n      priv.markers.set(marker, cloneEnforester(priv.enf));\n    }\n    return marker;\n  }\n\n  next() {\n    const { enf, noScopes, useScope, introducedScope, context } = privateData.get(this);\n    if (enf.rest.size === 0) {\n      return {\n        done: true,\n        value: null\n      };\n    }\n    let value = enf.advance();\n    if (!noScopes) {\n      value = value\n        .addScope(useScope, context.bindings, ALL_PHASES)\n        .addScope(introducedScope, context.bindings, ALL_PHASES, { flip: true });\n    }\n    return {\n      done: false,\n      value: new SyntaxOrTermWrapper(value, context)\n    };\n  }\n}\n"]} + +/***/ }, +/* 56 */ +/***/ function(module, exports, __webpack_require__) { + + "use strict"; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.Enforester = undefined; + + var _terms = __webpack_require__(9); + + var _terms2 = _interopRequireDefault(_terms); + + var _ramdaFantasy = __webpack_require__(24); + + var _transforms = __webpack_require__(38); + + var _immutable = __webpack_require__(3); + + var _errors = __webpack_require__(23); + + var _operators = __webpack_require__(57); + + var _syntax = __webpack_require__(46); + + var _syntax2 = _interopRequireDefault(_syntax); + + var _scope = __webpack_require__(58); + + var _loadSyntax = __webpack_require__(48); + + var _macroContext = __webpack_require__(55); + + var _macroContext2 = _interopRequireDefault(_macroContext); + + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + + const Just = _ramdaFantasy.Maybe.Just; + const Nothing = _ramdaFantasy.Maybe.Nothing; + + const EXPR_LOOP_OPERATOR = {}; + const EXPR_LOOP_NO_CHANGE = {}; + const EXPR_LOOP_EXPANSION = {}; + + class Enforester { + constructor(stxl, prev, context) { + this.done = false; + (0, _errors.assert)(_immutable.List.isList(stxl), "expecting a list of terms to enforest"); + (0, _errors.assert)(_immutable.List.isList(prev), "expecting a list of terms to enforest"); + (0, _errors.assert)(context, "expecting a context to enforest"); + this.term = null; + + this.rest = stxl; + this.prev = prev; + + this.context = context; } - return [this.emitString(com.cognitect.transit.delimiters.ESC_TAG, "'", "", !0, c), com.cognitect.transit.impl.writer.marshal(this, b, !1, c)]; - }; - com.cognitect.transit.impl.writer.emitObjects = function(a, b, c) { - var d = []; - if (com.cognitect.transit.util.isArray(b)) { - for (var e = 0;e < b.length;e++) { - d.push(com.cognitect.transit.impl.writer.marshal(a, b[e], !1, c)); - } - } else { - b.forEach(function(b, e) { - d.push(com.cognitect.transit.impl.writer.marshal(a, b, !1, c)); - }); + + peek() { + let n = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0]; + + return this.rest.get(n); } - return d; - }; - com.cognitect.transit.impl.writer.emitArray = function(a, b, c, d) { - return com.cognitect.transit.impl.writer.emitObjects(a, b, d); - }; - com.cognitect.transit.impl.writer.isStringableKey = function(a, b) { - if ("string" !== typeof b) { - var c = a.handler(b); - return c && 1 === c.tag(b).length; + + advance() { + let ret = this.rest.first(); + this.rest = this.rest.rest(); + return ret; } - return !0; - }; - com.cognitect.transit.impl.writer.stringableKeys = function(a, b) { - var c = a.unpack(b), d = !0; - if (c) { - for (var e = 0;e < c.length && (d = com.cognitect.transit.impl.writer.isStringableKey(a, c[e]), d);e += 2) { + + /* + enforest works over: + prev - a list of the previously enforest Terms + term - the current term being enforested (initially null) + rest - remaining Terms to enforest + */ + enforest() { + let type = arguments.length <= 0 || arguments[0] === undefined ? "Module" : arguments[0]; + + // initialize the term + this.term = null; + + if (this.rest.size === 0) { + this.done = true; + return this.term; } - return d; - } - if (b.keys && (c = b.keys(), e = null, c.next)) { - for (e = c.next();!e.done;) { - d = com.cognitect.transit.impl.writer.isStringableKey(a, e.value); - if (!d) { - break; - } - e = c.next(); + + if (this.isEOF(this.peek())) { + this.term = new _terms2.default("EOF", {}); + this.advance(); + return this.term; } - return d; + + let result; + if (type === "expression") { + result = this.enforestExpressionLoop(); + } else { + result = this.enforestModule(); + } + + if (this.rest.size === 0) { + this.done = true; + } + return result; } - if (b.forEach) { - return b.forEach(function(b, c) { - d = d && com.cognitect.transit.impl.writer.isStringableKey(a, c); - }), d; + + enforestModule() { + return this.enforestBody(); } - throw Error("Cannot walk keys of object type " + com.cognitect.transit.handlers.constructor(b).name); - }; - com.cognitect.transit.impl.writer.isForeignObject = function(a) { - if (a.constructor.transit$isObject) { - return !0; + + enforestBody() { + return this.enforestModuleItem(); } - var b = a.constructor.toString(), b = b.substr(9), b = b.substr(0, b.indexOf("(")); - isObject = "Object" == b; - "undefined" != typeof Object.defineProperty ? Object.defineProperty(a.constructor, "transit$isObject", {value:isObject, enumerable:!1}) : a.constructor.transit$isObject = isObject; - return isObject; - }; - com.cognitect.transit.impl.writer.emitMap = function(a, b, c, d) { - var e = null, f = null, g = null, e = null; - c = 0; - if (b.constructor === Object || null != b.forEach || a.handlerForForeign && com.cognitect.transit.impl.writer.isForeignObject(b)) { - if (a.verbose) { - if (null != b.forEach) { - if (com.cognitect.transit.impl.writer.stringableKeys(a, b)) { - var h = {}; - b.forEach(function(b, c) { - h[com.cognitect.transit.impl.writer.marshal(a, c, !0, !1)] = com.cognitect.transit.impl.writer.marshal(a, b, !1, d); - }); - } else { - e = a.unpack(b); - f = []; - g = a.emitString(com.cognitect.transit.delimiters.ESC_TAG, "cmap", "", !0, d); - if (e) { - for (;c < e.length;c += 2) { - f.push(com.cognitect.transit.impl.writer.marshal(a, e[c], !1, !1)), f.push(com.cognitect.transit.impl.writer.marshal(a, e[c + 1], !1, d)); - } - } else { - b.forEach(function(b, c) { - f.push(com.cognitect.transit.impl.writer.marshal(a, c, !1, !1)); - f.push(com.cognitect.transit.impl.writer.marshal(a, b, !1, d)); - }); - } - h = {}; - h[g] = f; - } - } else { - for (e = com.cognitect.transit.util.objectKeys(b), h = {};c < e.length;c++) { - h[com.cognitect.transit.impl.writer.marshal(a, e[c], !0, !1)] = com.cognitect.transit.impl.writer.marshal(a, b[e[c]], !1, d); - } - } - return h; + + enforestModuleItem() { + let lookahead = this.peek(); + if (this.isKeyword(lookahead, 'import')) { + this.advance(); + return this.enforestImportDeclaration(); + } else if (this.isKeyword(lookahead, 'export')) { + this.advance(); + return this.enforestExportDeclaration(); + } else if (this.isIdentifier(lookahead, '#')) { + return this.enforestLanguagePragma(); } - if (null != b.forEach) { - if (com.cognitect.transit.impl.writer.stringableKeys(a, b)) { - e = a.unpack(b); - h = ["^ "]; - if (e) { - for (;c < e.length;c += 2) { - h.push(com.cognitect.transit.impl.writer.marshal(a, e[c], !0, d)), h.push(com.cognitect.transit.impl.writer.marshal(a, e[c + 1], !1, d)); - } - } else { - b.forEach(function(b, c) { - h.push(com.cognitect.transit.impl.writer.marshal(a, c, !0, d)); - h.push(com.cognitect.transit.impl.writer.marshal(a, b, !1, d)); - }); - } - return h; + return this.enforestStatement(); + } + + enforestLanguagePragma() { + this.matchIdentifier('#'); + this.matchIdentifier('lang'); + let path = this.matchStringLiteral(); + this.consumeSemicolon(); + return new _terms2.default('Pragma', { + kind: 'lang', + items: _immutable.List.of(path) + }); + } + + enforestExportDeclaration() { + let lookahead = this.peek(); + if (this.isPunctuator(lookahead, '*')) { + this.advance(); + let moduleSpecifier = this.enforestFromClause(); + return new _terms2.default('ExportAllFrom', { moduleSpecifier: moduleSpecifier }); + } else if (this.isBraces(lookahead)) { + let namedExports = this.enforestExportClause(); + let moduleSpecifier = null; + if (this.isIdentifier(this.peek(), 'from')) { + moduleSpecifier = this.enforestFromClause(); } - e = a.unpack(b); - f = []; - g = a.emitString(com.cognitect.transit.delimiters.ESC_TAG, "cmap", "", !0, d); - if (e) { - for (;c < e.length;c += 2) { - f.push(com.cognitect.transit.impl.writer.marshal(a, e[c], !1, d)), f.push(com.cognitect.transit.impl.writer.marshal(a, e[c + 1], !1, d)); - } - } else { - b.forEach(function(b, c) { - f.push(com.cognitect.transit.impl.writer.marshal(a, c, !1, d)); - f.push(com.cognitect.transit.impl.writer.marshal(a, b, !1, d)); + return new _terms2.default('ExportFrom', { namedExports: namedExports, moduleSpecifier: moduleSpecifier }); + } else if (this.isKeyword(lookahead, 'class')) { + return new _terms2.default('Export', { + declaration: this.enforestClass({ isExpr: false }) + }); + } else if (this.isFnDeclTransform(lookahead)) { + return new _terms2.default('Export', { + declaration: this.enforestFunction({ isExpr: false, inDefault: false }) + }); + } else if (this.isKeyword(lookahead, 'default')) { + this.advance(); + if (this.isFnDeclTransform(this.peek())) { + return new _terms2.default('ExportDefault', { + body: this.enforestFunction({ isExpr: false, inDefault: true }) }); + } else if (this.isKeyword(this.peek(), 'class')) { + return new _terms2.default('ExportDefault', { + body: this.enforestClass({ isExpr: false, inDefault: true }) + }); + } else { + let body = this.enforestExpressionLoop(); + this.consumeSemicolon(); + return new _terms2.default('ExportDefault', { body: body }); } - return [g, f]; + } else if (this.isVarDeclTransform(lookahead) || this.isLetDeclTransform(lookahead) || this.isConstDeclTransform(lookahead) || this.isSyntaxrecDeclTransform(lookahead) || this.isSyntaxDeclTransform(lookahead)) { + return new _terms2.default('Export', { + declaration: this.enforestVariableDeclaration() + }); } - h = ["^ "]; - for (e = com.cognitect.transit.util.objectKeys(b);c < e.length;c++) { - h.push(com.cognitect.transit.impl.writer.marshal(a, e[c], !0, d)), h.push(com.cognitect.transit.impl.writer.marshal(a, b[e[c]], !1, d)); + throw this.createError(lookahead, 'unexpected syntax'); + } + + enforestExportClause() { + let enf = new Enforester(this.matchCurlies(), (0, _immutable.List)(), this.context); + let result = []; + while (enf.rest.size !== 0) { + result.push(enf.enforestExportSpecifier()); + enf.consumeComma(); } - return h; + return (0, _immutable.List)(result); } - if (null != a.objectBuilder) { - return a.objectBuilder(b, function(b) { - return com.cognitect.transit.impl.writer.marshal(a, b, !0, d); - }, function(b) { - return com.cognitect.transit.impl.writer.marshal(a, b, !1, d); + + enforestExportSpecifier() { + let name = this.enforestIdentifier(); + if (this.isIdentifier(this.peek(), 'as')) { + this.advance(); + let exportedName = this.enforestIdentifier(); + return new _terms2.default('ExportSpecifier', { name: name, exportedName: exportedName }); + } + return new _terms2.default('ExportSpecifier', { + name: null, + exportedName: name }); } - c = com.cognitect.transit.handlers.constructor(b).name; - e = Error("Cannot write " + c); - e.data = {obj:b, type:c}; - throw e; - }; - com.cognitect.transit.impl.writer.emitTaggedMap = function(a, b, c, d, e) { - return a.verbose ? (d = {}, d[a.emitString(com.cognitect.transit.delimiters.ESC_TAG, b, "", !0, e)] = com.cognitect.transit.impl.writer.marshal(a, c, !1, e), d) : [a.emitString(com.cognitect.transit.delimiters.ESC_TAG, b, "", !0, e), com.cognitect.transit.impl.writer.marshal(a, c, !1, e)]; - }; - com.cognitect.transit.impl.writer.emitEncoded = function(a, b, c, d, e, f, g) { - if (1 === c.length) { - if ("string" === typeof d) { - return a.emitString(com.cognitect.transit.delimiters.ESC, c, d, f, g); + + enforestImportDeclaration() { + let lookahead = this.peek(); + let defaultBinding = null; + let namedImports = (0, _immutable.List)(); + let forSyntax = false; + + if (this.isStringLiteral(lookahead)) { + let moduleSpecifier = this.advance(); + this.consumeSemicolon(); + return new _terms2.default('Import', { + defaultBinding: defaultBinding, + namedImports: namedImports, + moduleSpecifier: moduleSpecifier, + forSyntax: forSyntax + }); } - if (f || a.preferStrings) { - (d = a.verbose && b.getVerboseHandler()) ? (c = d.tag(e), d = d.stringRep(e, d)) : d = b.stringRep(e, b); - if (null !== d) { - return a.emitString(com.cognitect.transit.delimiters.ESC, c, d, f, g); + + if (this.isIdentifier(lookahead) || this.isKeyword(lookahead)) { + defaultBinding = this.enforestBindingIdentifier(); + if (!this.isPunctuator(this.peek(), ',')) { + let moduleSpecifier = this.enforestFromClause(); + if (this.isKeyword(this.peek(), 'for') && this.isIdentifier(this.peek(1), 'syntax')) { + this.advance(); + this.advance(); + forSyntax = true; + } + + return new _terms2.default('Import', { + defaultBinding: defaultBinding, moduleSpecifier: moduleSpecifier, + namedImports: (0, _immutable.List)(), + forSyntax: forSyntax + }); } - a = Error('Tag "' + c + '" cannot be encoded as string'); - a.data = {tag:c, rep:d, obj:e}; - throw a; } - } - return com.cognitect.transit.impl.writer.emitTaggedMap(a, c, d, f, g); - }; - com.cognitect.transit.impl.writer.marshal = function(a, b, c, d) { - var e = a.handler(b) || (a.handlerForForeign ? a.handlerForForeign(b, a.handlers) : null), f = e ? e.tag(b) : null, g = e ? e.rep(b) : null; - if (null != e && null != f) { - switch(f) { - case "_": - return a.emitNil(c, d); - case "s": - return a.emitString("", "", com.cognitect.transit.impl.writer.escape(g), c, d); - case "?": - return a.emitBoolean(g, c, d); - case "i": - return a.emitInteger(g, c, d); - case "d": - return a.emitDouble(g, c, d); - case "b": - return a.emitBinary(g, c, d); - case "'": - return a.emitQuoted(a, g, d); - case "array": - return com.cognitect.transit.impl.writer.emitArray(a, g, c, d); - case "map": - return com.cognitect.transit.impl.writer.emitMap(a, g, c, d); - default: - return com.cognitect.transit.impl.writer.emitEncoded(a, e, f, g, b, c, d); + this.consumeComma(); + lookahead = this.peek(); + if (this.isBraces(lookahead)) { + let imports = this.enforestNamedImports(); + let fromClause = this.enforestFromClause(); + if (this.isKeyword(this.peek(), 'for') && this.isIdentifier(this.peek(1), 'syntax')) { + this.advance(); + this.advance(); + forSyntax = true; + } + + return new _terms2.default("Import", { + defaultBinding: defaultBinding, + forSyntax: forSyntax, + namedImports: imports, + moduleSpecifier: fromClause + + }); + } else if (this.isPunctuator(lookahead, '*')) { + let namespaceBinding = this.enforestNamespaceBinding(); + let moduleSpecifier = this.enforestFromClause(); + if (this.isKeyword(this.peek(), 'for') && this.isIdentifier(this.peek(1), 'syntax')) { + this.advance(); + this.advance(); + forSyntax = true; + } + return new _terms2.default('ImportNamespace', { + defaultBinding: defaultBinding, forSyntax: forSyntax, namespaceBinding: namespaceBinding, moduleSpecifier: moduleSpecifier + }); } - } else { - throw a = com.cognitect.transit.handlers.constructor(b).name, c = Error("Cannot write " + a), c.data = {obj:b, type:a}, c; - } - }; - com.cognitect.transit.impl.writer.maybeQuoted = function(a, b) { - var c = a.handler(b) || (a.handlerForForeign ? a.handlerForForeign(b, a.handlers) : null); - if (null != c) { - return 1 === c.tag(b).length ? com.cognitect.transit.types.quoted(b) : b; + throw this.createError(lookahead, 'unexpected syntax'); } - var c = com.cognitect.transit.handlers.constructor(b).name, d = Error("Cannot write " + c); - d.data = {obj:b, type:c}; - throw d; - }; - com.cognitect.transit.impl.writer.marshalTop = function(a, b, c, d) { - return JSON.stringify(com.cognitect.transit.impl.writer.marshal(a, com.cognitect.transit.impl.writer.maybeQuoted(a, b), c, d)); - }; - com.cognitect.transit.impl.writer.Writer = function(a, b) { - this._marshaller = a; - this.options = b || {}; - this.cache = !1 === this.options.cache ? null : this.options.cache ? this.options.cache : new com.cognitect.transit.caching.WriteCache; - }; - com.cognitect.transit.impl.writer.Writer.prototype.marshaller = function() { - return this._marshaller; - }; - com.cognitect.transit.impl.writer.Writer.prototype.marshaller = com.cognitect.transit.impl.writer.Writer.prototype.marshaller; - com.cognitect.transit.impl.writer.Writer.prototype.write = function(a, b) { - var c = null, c = b || {}, d = c.asMapKey || !1, e = this._marshaller.verbose ? !1 : this.cache, c = !1 === c.marshalTop ? com.cognitect.transit.impl.writer.marshal(this._marshaller, a, d, e) : com.cognitect.transit.impl.writer.marshalTop(this._marshaller, a, d, e); - null != this.cache && this.cache.clear(); - return c; - }; - com.cognitect.transit.impl.writer.Writer.prototype.write = com.cognitect.transit.impl.writer.Writer.prototype.write; - com.cognitect.transit.impl.writer.Writer.prototype.register = function(a, b) { - this._marshaller.registerHandler(a, b); - }; - com.cognitect.transit.impl.writer.Writer.prototype.register = com.cognitect.transit.impl.writer.Writer.prototype.register; - var TRANSIT_DEV = !0, TRANSIT_NODE_TARGET = !0, TRANSIT_BROWSER_TARGET = !1, TRANSIT_BROWSER_AMD_TARGET = !1; - com.cognitect.transit.reader = function(a, b) { - if ("json" === a || "json-verbose" === a || null == a) { - var c = new com.cognitect.transit.impl.reader.JSONUnmarshaller(b); - return new com.cognitect.transit.impl.reader.Reader(c, b); + + enforestNamespaceBinding() { + this.matchPunctuator('*'); + this.matchIdentifier('as'); + return this.enforestBindingIdentifier(); } - throw Error("Cannot create reader of type " + a); - }; - com.cognitect.transit.writer = function(a, b) { - if ("json" === a || "json-verbose" === a || null == a) { - "json-verbose" === a && (null == b && (b = {}), b.verbose = !0); - var c = new com.cognitect.transit.impl.writer.JSONMarshaller(b); - return new com.cognitect.transit.impl.writer.Writer(c, b); + + enforestNamedImports() { + let enf = new Enforester(this.matchCurlies(), (0, _immutable.List)(), this.context); + let result = []; + while (enf.rest.size !== 0) { + result.push(enf.enforestImportSpecifiers()); + enf.consumeComma(); + } + return (0, _immutable.List)(result); } - c = Error('Type must be "json"'); - c.data = {type:a}; - throw c; - }; - com.cognitect.transit.makeWriteHandler = function(a) { - var b = function() { - }; - b.prototype.tag = a.tag; - b.prototype.rep = a.rep; - b.prototype.stringRep = a.stringRep; - b.prototype.getVerboseHandler = a.getVerboseHandler; - return new b; - }; - com.cognitect.transit.makeBuilder = function(a) { - var b = function() { - }; - b.prototype.init = a.init; - b.prototype.add = a.add; - b.prototype.finalize = a.finalize; - b.prototype.fromArray = a.fromArray; - return new b; - }; - com.cognitect.transit.date = com.cognitect.transit.types.date; - com.cognitect.transit.integer = com.cognitect.transit.types.intValue; - com.cognitect.transit.isInteger = com.cognitect.transit.types.isInteger; - com.cognitect.transit.uuid = com.cognitect.transit.types.uuid; - com.cognitect.transit.isUUID = com.cognitect.transit.types.isUUID; - com.cognitect.transit.bigInt = com.cognitect.transit.types.bigInteger; - com.cognitect.transit.isBigInt = com.cognitect.transit.types.isBigInteger; - com.cognitect.transit.bigDec = com.cognitect.transit.types.bigDecimalValue; - com.cognitect.transit.isBigDec = com.cognitect.transit.types.isBigDecimal; - com.cognitect.transit.keyword = com.cognitect.transit.types.keyword; - com.cognitect.transit.isKeyword = com.cognitect.transit.types.isKeyword; - com.cognitect.transit.symbol = com.cognitect.transit.types.symbol; - com.cognitect.transit.isSymbol = com.cognitect.transit.types.isSymbol; - com.cognitect.transit.binary = com.cognitect.transit.types.binary; - com.cognitect.transit.isBinary = com.cognitect.transit.types.isBinary; - com.cognitect.transit.uri = com.cognitect.transit.types.uri; - com.cognitect.transit.isURI = com.cognitect.transit.types.isURI; - com.cognitect.transit.map = com.cognitect.transit.types.map; - com.cognitect.transit.isMap = com.cognitect.transit.types.isMap; - com.cognitect.transit.set = com.cognitect.transit.types.set; - com.cognitect.transit.isSet = com.cognitect.transit.types.isSet; - com.cognitect.transit.list = com.cognitect.transit.types.list; - com.cognitect.transit.isList = com.cognitect.transit.types.isList; - com.cognitect.transit.quoted = com.cognitect.transit.types.quoted; - com.cognitect.transit.isQuoted = com.cognitect.transit.types.isQuoted; - com.cognitect.transit.tagged = com.cognitect.transit.types.taggedValue; - com.cognitect.transit.isTaggedValue = com.cognitect.transit.types.isTaggedValue; - com.cognitect.transit.link = com.cognitect.transit.types.link; - com.cognitect.transit.isLink = com.cognitect.transit.types.isLink; - com.cognitect.transit.hash = com.cognitect.transit.eq.hashCode; - com.cognitect.transit.hashMapLike = com.cognitect.transit.eq.hashMapLike; - com.cognitect.transit.hashArrayLike = com.cognitect.transit.eq.hashArrayLike; - com.cognitect.transit.equals = com.cognitect.transit.eq.equals; - com.cognitect.transit.extendToEQ = com.cognitect.transit.eq.extendToEQ; - com.cognitect.transit.mapToObject = function(a) { - var b = {}; - a.forEach(function(a, d) { - if ("string" !== typeof d) { - throw Error("Cannot convert map with non-string keys"); + + enforestImportSpecifiers() { + let lookahead = this.peek(); + let name; + if (this.isIdentifier(lookahead) || this.isKeyword(lookahead)) { + name = this.advance(); + if (!this.isIdentifier(this.peek(), 'as')) { + return new _terms2.default('ImportSpecifier', { + name: null, + binding: new _terms2.default('BindingIdentifier', { + name: name + }) + }); + } else { + this.matchIdentifier('as'); + } + } else { + throw this.createError(lookahead, 'unexpected token in import specifier'); } - b[d] = a; - }); - return b; - }; - com.cognitect.transit.objectToMap = function(a) { - var b = com.cognitect.transit.map(), c; - for (c in a) { - a.hasOwnProperty(c) && b.set(c, a[c]); + return new _terms2.default('ImportSpecifier', { + name: name, binding: this.enforestBindingIdentifier() + }); } - return b; - }; - com.cognitect.transit.decoder = com.cognitect.transit.impl.decoder.decoder; - com.cognitect.transit.readCache = com.cognitect.transit.caching.readCache; - com.cognitect.transit.writeCache = com.cognitect.transit.caching.writeCache; - com.cognitect.transit.UUIDfromString = com.cognitect.transit.types.UUIDfromString; - com.cognitect.transit.randomUUID = com.cognitect.transit.util.randomUUID; - com.cognitect.transit.stringableKeys = com.cognitect.transit.impl.writer.stringableKeys; - TRANSIT_BROWSER_TARGET && (goog.exportSymbol("transit.reader", com.cognitect.transit.reader), goog.exportSymbol("transit.writer", com.cognitect.transit.writer), goog.exportSymbol("transit.makeBuilder", com.cognitect.transit.makeBuilder), goog.exportSymbol("transit.makeWriteHandler", com.cognitect.transit.makeWriteHandler), goog.exportSymbol("transit.date", com.cognitect.transit.types.date), goog.exportSymbol("transit.integer", com.cognitect.transit.types.intValue), goog.exportSymbol("transit.isInteger", - com.cognitect.transit.types.isInteger), goog.exportSymbol("transit.uuid", com.cognitect.transit.types.uuid), goog.exportSymbol("transit.isUUID", com.cognitect.transit.types.isUUID), goog.exportSymbol("transit.bigInt", com.cognitect.transit.types.bigInteger), goog.exportSymbol("transit.isBigInt", com.cognitect.transit.types.isBigInteger), goog.exportSymbol("transit.bigDec", com.cognitect.transit.types.bigDecimalValue), goog.exportSymbol("transit.isBigDec", com.cognitect.transit.types.isBigDecimal), - goog.exportSymbol("transit.keyword", com.cognitect.transit.types.keyword), goog.exportSymbol("transit.isKeyword", com.cognitect.transit.types.isKeyword), goog.exportSymbol("transit.symbol", com.cognitect.transit.types.symbol), goog.exportSymbol("transit.isSymbol", com.cognitect.transit.types.isSymbol), goog.exportSymbol("transit.binary", com.cognitect.transit.types.binary), goog.exportSymbol("transit.isBinary", com.cognitect.transit.types.isBinary), goog.exportSymbol("transit.uri", com.cognitect.transit.types.uri), - goog.exportSymbol("transit.isURI", com.cognitect.transit.types.isURI), goog.exportSymbol("transit.map", com.cognitect.transit.types.map), goog.exportSymbol("transit.isMap", com.cognitect.transit.types.isMap), goog.exportSymbol("transit.set", com.cognitect.transit.types.set), goog.exportSymbol("transit.isSet", com.cognitect.transit.types.isSet), goog.exportSymbol("transit.list", com.cognitect.transit.types.list), goog.exportSymbol("transit.isList", com.cognitect.transit.types.isList), goog.exportSymbol("transit.quoted", - com.cognitect.transit.types.quoted), goog.exportSymbol("transit.isQuoted", com.cognitect.transit.types.isQuoted), goog.exportSymbol("transit.tagged", com.cognitect.transit.types.taggedValue), goog.exportSymbol("transit.isTaggedValue", com.cognitect.transit.types.isTaggedValue), goog.exportSymbol("transit.link", com.cognitect.transit.types.link), goog.exportSymbol("transit.isLink", com.cognitect.transit.types.isLink), goog.exportSymbol("transit.hash", com.cognitect.transit.eq.hashCode), goog.exportSymbol("transit.hashMapLike", - com.cognitect.transit.eq.hashMapLike), goog.exportSymbol("transit.hashArrayLike", com.cognitect.transit.eq.hashArrayLike), goog.exportSymbol("transit.equals", com.cognitect.transit.eq.equals), goog.exportSymbol("transit.extendToEQ", com.cognitect.transit.eq.extendToEQ), goog.exportSymbol("transit.mapToObject", com.cognitect.transit.mapToObject), goog.exportSymbol("transit.objectToMap", com.cognitect.transit.objectToMap), goog.exportSymbol("transit.decoder", com.cognitect.transit.impl.decoder.decoder), - goog.exportSymbol("transit.UUIDfromString", com.cognitect.transit.types.UUIDfromString), goog.exportSymbol("transit.randomUUID", com.cognitect.transit.util.randomUUID), goog.exportSymbol("transit.stringableKeys", com.cognitect.transit.impl.writer.stringableKeys), goog.exportSymbol("transit.readCache", com.cognitect.transit.caching.readCache), goog.exportSymbol("transit.writeCache", com.cognitect.transit.caching.writeCache)); - TRANSIT_NODE_TARGET && (module.exports = {reader:com.cognitect.transit.reader, writer:com.cognitect.transit.writer, makeBuilder:com.cognitect.transit.makeBuilder, makeWriteHandler:com.cognitect.transit.makeWriteHandler, date:com.cognitect.transit.types.date, integer:com.cognitect.transit.types.intValue, isInteger:com.cognitect.transit.types.isInteger, uuid:com.cognitect.transit.types.uuid, isUUID:com.cognitect.transit.types.isUUID, bigInt:com.cognitect.transit.types.bigInteger, isBigInt:com.cognitect.transit.types.isBigInteger, - bigDec:com.cognitect.transit.types.bigDecimalValue, isBigDec:com.cognitect.transit.types.isBigDecimal, keyword:com.cognitect.transit.types.keyword, isKeyword:com.cognitect.transit.types.isKeyword, symbol:com.cognitect.transit.types.symbol, isSymbol:com.cognitect.transit.types.isSymbol, binary:com.cognitect.transit.types.binary, isBinary:com.cognitect.transit.types.isBinary, uri:com.cognitect.transit.types.uri, isURI:com.cognitect.transit.types.isURI, map:com.cognitect.transit.types.map, isMap:com.cognitect.transit.types.isMap, - set:com.cognitect.transit.types.set, isSet:com.cognitect.transit.types.isSet, list:com.cognitect.transit.types.list, isList:com.cognitect.transit.types.isList, quoted:com.cognitect.transit.types.quoted, isQuoted:com.cognitect.transit.types.isQuoted, tagged:com.cognitect.transit.types.taggedValue, isTaggedValue:com.cognitect.transit.types.isTaggedValue, link:com.cognitect.transit.types.link, isLink:com.cognitect.transit.types.isLink, hash:com.cognitect.transit.eq.hashCode, hashArrayLike:com.cognitect.transit.eq.hashArrayLike, - hashMapLike:com.cognitect.transit.eq.hashMapLike, equals:com.cognitect.transit.eq.equals, extendToEQ:com.cognitect.transit.eq.extendToEQ, mapToObject:com.cognitect.transit.mapToObject, objectToMap:com.cognitect.transit.objectToMap, decoder:com.cognitect.transit.impl.decoder.decoder, UUIDfromString:com.cognitect.transit.types.UUIDfromString, randomUUID:com.cognitect.transit.util.randomUUID, stringableKeys:com.cognitect.transit.impl.writer.stringableKeys, readCache:com.cognitect.transit.caching.readCache, - writeCache:com.cognitect.transit.caching.writeCache}); + enforestFromClause() { + this.matchIdentifier('from'); + let lookahead = this.matchStringLiteral(); + this.consumeSemicolon(); + return lookahead; + } - /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(59).Buffer)) + enforestStatementListItem() { + let lookahead = this.peek(); -/***/ }, -/* 59 */ -/***/ function(module, exports, __webpack_require__) { + if (this.isFnDeclTransform(lookahead)) { + return this.enforestFunctionDeclaration({ isExpr: false }); + } else if (this.isKeyword(lookahead, 'class')) { + return this.enforestClass({ isExpr: false }); + } else { + return this.enforestStatement(); + } + } - /* WEBPACK VAR INJECTION */(function(Buffer, global) {/*! - * The buffer module from node.js, for the browser. - * - * @author Feross Aboukhadijeh - * @license MIT - */ - /* eslint-disable no-proto */ + enforestStatement() { + let lookahead = this.peek(); - 'use strict' + if (this.term === null && this.isCompiletimeTransform(lookahead)) { + this.expandMacro(); + lookahead = this.peek(); + } - var base64 = __webpack_require__(60) - var ieee754 = __webpack_require__(61) - var isArray = __webpack_require__(62) + if (this.term === null && this.isTerm(lookahead)) { + // TODO: check that this is actually an statement + return this.advance(); + } - exports.Buffer = Buffer - exports.SlowBuffer = SlowBuffer - exports.INSPECT_MAX_BYTES = 50 - Buffer.poolSize = 8192 // not used by this implementation + if (this.term === null && this.isBraces(lookahead)) { + return this.enforestBlockStatement(); + } - var rootParent = {} + if (this.term === null && this.isWhileTransform(lookahead)) { + return this.enforestWhileStatement(); + } - /** - * If `Buffer.TYPED_ARRAY_SUPPORT`: - * === true Use Uint8Array implementation (fastest) - * === false Use Object implementation (most compatible, even IE6) - * - * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+, - * Opera 11.6+, iOS 4.2+. - * - * Due to various browser bugs, sometimes the Object implementation will be used even - * when the browser supports typed arrays. - * - * Note: - * - * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances, - * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438. - * - * - Safari 5-7 lacks support for changing the `Object.prototype.constructor` property - * on objects. - * - * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function. - * - * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of - * incorrect length in some situations. + if (this.term === null && this.isIfTransform(lookahead)) { + return this.enforestIfStatement(); + } + if (this.term === null && this.isForTransform(lookahead)) { + return this.enforestForStatement(); + } + if (this.term === null && this.isSwitchTransform(lookahead)) { + return this.enforestSwitchStatement(); + } + if (this.term === null && this.isBreakTransform(lookahead)) { + return this.enforestBreakStatement(); + } + if (this.term === null && this.isContinueTransform(lookahead)) { + return this.enforestContinueStatement(); + } + if (this.term === null && this.isDoTransform(lookahead)) { + return this.enforestDoStatement(); + } + if (this.term === null && this.isDebuggerTransform(lookahead)) { + return this.enforestDebuggerStatement(); + } + if (this.term === null && this.isWithTransform(lookahead)) { + return this.enforestWithStatement(); + } + if (this.term === null && this.isTryTransform(lookahead)) { + return this.enforestTryStatement(); + } + if (this.term === null && this.isThrowTransform(lookahead)) { + return this.enforestThrowStatement(); + } + + // TODO: put somewhere else + if (this.term === null && this.isKeyword(lookahead, "class")) { + return this.enforestClass({ isExpr: false }); + } + + if (this.term === null && this.isFnDeclTransform(lookahead)) { + return this.enforestFunctionDeclaration(); + } - * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they - * get the Object implementation, which is slower but behaves correctly. - */ - Buffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined - ? global.TYPED_ARRAY_SUPPORT - : typedArraySupport() + if (this.term === null && this.isIdentifier(lookahead) && this.isPunctuator(this.peek(1), ':')) { + return this.enforestLabeledStatement(); + } - function typedArraySupport () { - function Bar () {} - try { - var arr = new Uint8Array(1) - arr.foo = function () { return 42 } - arr.constructor = Bar - return arr.foo() === 42 && // typed array instances can be augmented - arr.constructor === Bar && // constructor can be set - typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray` - arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray` - } catch (e) { - return false - } - } + if (this.term === null && (this.isVarDeclTransform(lookahead) || this.isLetDeclTransform(lookahead) || this.isConstDeclTransform(lookahead) || this.isSyntaxrecDeclTransform(lookahead) || this.isSyntaxDeclTransform(lookahead))) { + let stmt = new _terms2.default('VariableDeclarationStatement', { + declaration: this.enforestVariableDeclaration() + }); + this.consumeSemicolon(); + return stmt; + } - function kMaxLength () { - return Buffer.TYPED_ARRAY_SUPPORT - ? 0x7fffffff - : 0x3fffffff - } + if (this.term === null && this.isReturnStmtTransform(lookahead)) { + return this.enforestReturnStatement(); + } - /** - * Class: Buffer - * ============= - * - * The Buffer constructor returns instances of `Uint8Array` that are augmented - * with function properties for all the node `Buffer` API functions. We use - * `Uint8Array` so that square bracket notation works as expected -- it returns - * a single octet. - * - * By augmenting the instances, we can avoid modifying the `Uint8Array` - * prototype. - */ - function Buffer (arg) { - if (!(this instanceof Buffer)) { - // Avoid going through an ArgumentsAdaptorTrampoline in the common case. - if (arguments.length > 1) return new Buffer(arg, arguments[1]) - return new Buffer(arg) + if (this.term === null && this.isPunctuator(lookahead, ";")) { + this.advance(); + return new _terms2.default("EmptyStatement", {}); + } + + return this.enforestExpressionStatement(); } - if (!Buffer.TYPED_ARRAY_SUPPORT) { - this.length = 0 - this.parent = undefined + enforestLabeledStatement() { + let label = this.matchIdentifier(); + this.matchPunctuator(':'); + let stmt = this.enforestStatement(); + + return new _terms2.default('LabeledStatement', { + label: label, + body: stmt + }); } - // Common case. - if (typeof arg === 'number') { - return fromNumber(this, arg) + enforestBreakStatement() { + this.matchKeyword('break'); + let lookahead = this.peek(); + let label = null; + if (this.rest.size === 0 || this.isPunctuator(lookahead, ';')) { + this.consumeSemicolon(); + return new _terms2.default('BreakStatement', { label: label }); + } + if (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'yield') || this.isKeyword(lookahead, 'let')) { + label = this.enforestIdentifier(); + } + this.consumeSemicolon(); + + return new _terms2.default('BreakStatement', { label: label }); } - // Slightly less common case. - if (typeof arg === 'string') { - return fromString(this, arg, arguments.length > 1 ? arguments[1] : 'utf8') + enforestTryStatement() { + this.matchKeyword('try'); + let body = this.enforestBlock(); + if (this.isKeyword(this.peek(), 'catch')) { + let catchClause = this.enforestCatchClause(); + if (this.isKeyword(this.peek(), 'finally')) { + this.advance(); + let finalizer = this.enforestBlock(); + return new _terms2.default('TryFinallyStatement', { + body: body, catchClause: catchClause, finalizer: finalizer + }); + } + return new _terms2.default('TryCatchStatement', { body: body, catchClause: catchClause }); + } + if (this.isKeyword(this.peek(), 'finally')) { + this.advance(); + let finalizer = this.enforestBlock(); + return new _terms2.default('TryFinallyStatement', { body: body, catchClause: null, finalizer: finalizer }); + } + throw this.createError(this.peek(), 'try with no catch or finally'); } - // Unusual. - return fromObject(this, arg) - } + enforestCatchClause() { + this.matchKeyword('catch'); + let bindingParens = this.matchParens(); + let enf = new Enforester(bindingParens, (0, _immutable.List)(), this.context); + let binding = enf.enforestBindingTarget(); + let body = this.enforestBlock(); + return new _terms2.default('CatchClause', { binding: binding, body: body }); + } - function fromNumber (that, length) { - that = allocate(that, length < 0 ? 0 : checked(length) | 0) - if (!Buffer.TYPED_ARRAY_SUPPORT) { - for (var i = 0; i < length; i++) { - that[i] = 0 - } + enforestThrowStatement() { + this.matchKeyword('throw'); + let expression = this.enforestExpression(); + this.consumeSemicolon(); + return new _terms2.default('ThrowStatement', { expression: expression }); } - return that - } - function fromString (that, string, encoding) { - if (typeof encoding !== 'string' || encoding === '') encoding = 'utf8' + enforestWithStatement() { + this.matchKeyword('with'); + let objParens = this.matchParens(); + let enf = new Enforester(objParens, (0, _immutable.List)(), this.context); + let object = enf.enforestExpression(); + let body = this.enforestStatement(); + return new _terms2.default('WithStatement', { object: object, body: body }); + } - // Assumption: byteLength() return value is always < kMaxLength. - var length = byteLength(string, encoding) | 0 - that = allocate(that, length) + enforestDebuggerStatement() { + this.matchKeyword('debugger'); - that.write(string, encoding) - return that - } + return new _terms2.default('DebuggerStatement', {}); + } - function fromObject (that, object) { - if (Buffer.isBuffer(object)) return fromBuffer(that, object) + enforestDoStatement() { + this.matchKeyword('do'); + let body = this.enforestStatement(); + this.matchKeyword('while'); + let testBody = this.matchParens(); + let enf = new Enforester(testBody, (0, _immutable.List)(), this.context); + let test = enf.enforestExpression(); + this.consumeSemicolon(); + return new _terms2.default('DoWhileStatement', { body: body, test: test }); + } - if (isArray(object)) return fromArray(that, object) + enforestContinueStatement() { + let kwd = this.matchKeyword('continue'); + let lookahead = this.peek(); + let label = null; + if (this.rest.size === 0 || this.isPunctuator(lookahead, ';')) { + this.consumeSemicolon(); + return new _terms2.default('ContinueStatement', { label: label }); + } + if (this.lineNumberEq(kwd, lookahead) && (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'yield') || this.isKeyword(lookahead, 'let'))) { + label = this.enforestIdentifier(); + } + this.consumeSemicolon(); - if (object == null) { - throw new TypeError('must start with number, buffer, array or string') + return new _terms2.default('ContinueStatement', { label: label }); } - if (typeof ArrayBuffer !== 'undefined') { - if (object.buffer instanceof ArrayBuffer) { - return fromTypedArray(that, object) + enforestSwitchStatement() { + this.matchKeyword('switch'); + let cond = this.matchParens(); + let enf = new Enforester(cond, (0, _immutable.List)(), this.context); + let discriminant = enf.enforestExpression(); + let body = this.matchCurlies(); + + if (body.size === 0) { + return new _terms2.default('SwitchStatement', { + discriminant: discriminant, + cases: (0, _immutable.List)() + }); } - if (object instanceof ArrayBuffer) { - return fromArrayBuffer(that, object) + enf = new Enforester(body, (0, _immutable.List)(), this.context); + let cases = enf.enforestSwitchCases(); + let lookahead = enf.peek(); + if (enf.isKeyword(lookahead, 'default')) { + let defaultCase = enf.enforestSwitchDefault(); + let postDefaultCases = enf.enforestSwitchCases(); + return new _terms2.default('SwitchStatementWithDefault', { + discriminant: discriminant, + preDefaultCases: cases, + defaultCase: defaultCase, + postDefaultCases: postDefaultCases + }); } + return new _terms2.default('SwitchStatement', { discriminant: discriminant, cases: cases }); } - if (object.length) return fromArrayLike(that, object) + enforestSwitchCases() { + let cases = []; + while (!(this.rest.size === 0 || this.isKeyword(this.peek(), 'default'))) { + cases.push(this.enforestSwitchCase()); + } + return (0, _immutable.List)(cases); + } - return fromJsonObject(that, object) - } + enforestSwitchCase() { + this.matchKeyword('case'); + return new _terms2.default('SwitchCase', { + test: this.enforestExpression(), + consequent: this.enforestSwitchCaseBody() + }); + } - function fromBuffer (that, buffer) { - var length = checked(buffer.length) | 0 - that = allocate(that, length) - buffer.copy(that, 0, 0, length) - return that - } + enforestSwitchCaseBody() { + this.matchPunctuator(':'); + return this.enforestStatementListInSwitchCaseBody(); + } - function fromArray (that, array) { - var length = checked(array.length) | 0 - that = allocate(that, length) - for (var i = 0; i < length; i += 1) { - that[i] = array[i] & 255 + enforestStatementListInSwitchCaseBody() { + let result = []; + while (!(this.rest.size === 0 || this.isKeyword(this.peek(), 'default') || this.isKeyword(this.peek(), 'case'))) { + result.push(this.enforestStatementListItem()); + } + return (0, _immutable.List)(result); } - return that - } - // Duplicate of fromArray() to keep fromArray() monomorphic. - function fromTypedArray (that, array) { - var length = checked(array.length) | 0 - that = allocate(that, length) - // Truncating the elements is probably not what people expect from typed - // arrays with BYTES_PER_ELEMENT > 1 but it's compatible with the behavior - // of the old Buffer constructor. - for (var i = 0; i < length; i += 1) { - that[i] = array[i] & 255 + enforestSwitchDefault() { + this.matchKeyword('default'); + return new _terms2.default('SwitchDefault', { + consequent: this.enforestSwitchCaseBody() + }); } - return that - } - function fromArrayBuffer (that, array) { - if (Buffer.TYPED_ARRAY_SUPPORT) { - // Return an augmented `Uint8Array` instance, for best performance - array.byteLength - that = Buffer._augment(new Uint8Array(array)) - } else { - // Fallback: Return an object instance of the Buffer class - that = fromTypedArray(that, new Uint8Array(array)) + enforestForStatement() { + this.matchKeyword('for'); + let cond = this.matchParens(); + let enf = new Enforester(cond, (0, _immutable.List)(), this.context); + let lookahead, test, init, right, type, left, update; + + // case where init is null + if (enf.isPunctuator(enf.peek(), ';')) { + enf.advance(); + if (!enf.isPunctuator(enf.peek(), ';')) { + test = enf.enforestExpression(); + } + enf.matchPunctuator(';'); + if (enf.rest.size !== 0) { + right = enf.enforestExpression(); + } + return new _terms2.default('ForStatement', { + init: null, + test: test, + update: right, + body: this.enforestStatement() + }); + // case where init is not null + } else { + // testing + lookahead = enf.peek(); + if (enf.isVarDeclTransform(lookahead) || enf.isLetDeclTransform(lookahead) || enf.isConstDeclTransform(lookahead)) { + init = enf.enforestVariableDeclaration(); + lookahead = enf.peek(); + if (this.isKeyword(lookahead, 'in') || this.isIdentifier(lookahead, 'of')) { + if (this.isKeyword(lookahead, 'in')) { + enf.advance(); + right = enf.enforestExpression(); + type = 'ForInStatement'; + } else if (this.isIdentifier(lookahead, 'of')) { + enf.advance(); + right = enf.enforestExpression(); + type = 'ForOfStatement'; + } + return new _terms2.default(type, { + left: init, right: right, body: this.enforestStatement() + }); + } + enf.matchPunctuator(';'); + if (enf.isPunctuator(enf.peek(), ';')) { + enf.advance(); + test = null; + } else { + test = enf.enforestExpression(); + enf.matchPunctuator(';'); + } + update = enf.enforestExpression(); + } else { + if (this.isKeyword(enf.peek(1), 'in') || this.isIdentifier(enf.peek(1), 'of')) { + left = enf.enforestBindingIdentifier(); + let kind = enf.advance(); + if (this.isKeyword(kind, 'in')) { + type = 'ForInStatement'; + } else { + type = 'ForOfStatement'; + } + right = enf.enforestExpression(); + return new _terms2.default(type, { + left: left, right: right, body: this.enforestStatement() + }); + } + init = enf.enforestExpression(); + enf.matchPunctuator(';'); + if (enf.isPunctuator(enf.peek(), ';')) { + enf.advance(); + test = null; + } else { + test = enf.enforestExpression(); + enf.matchPunctuator(';'); + } + update = enf.enforestExpression(); + } + return new _terms2.default('ForStatement', { init: init, test: test, update: update, body: this.enforestStatement() }); + } } - return that - } - function fromArrayLike (that, array) { - var length = checked(array.length) | 0 - that = allocate(that, length) - for (var i = 0; i < length; i += 1) { - that[i] = array[i] & 255 + enforestIfStatement() { + this.matchKeyword('if'); + let cond = this.matchParens(); + let enf = new Enforester(cond, (0, _immutable.List)(), this.context); + let lookahead = enf.peek(); + let test = enf.enforestExpression(); + if (test === null) { + throw enf.createError(lookahead, 'expecting an expression'); + } + let consequent = this.enforestStatement(); + let alternate = null; + if (this.isKeyword(this.peek(), 'else')) { + this.advance(); + alternate = this.enforestStatement(); + } + return new _terms2.default('IfStatement', { test: test, consequent: consequent, alternate: alternate }); } - return that - } - // Deserialize { type: 'Buffer', data: [1,2,3,...] } into a Buffer object. - // Returns a zero-length buffer for inputs that don't conform to the spec. - function fromJsonObject (that, object) { - var array - var length = 0 + enforestWhileStatement() { + this.matchKeyword('while'); + let cond = this.matchParens(); + let enf = new Enforester(cond, (0, _immutable.List)(), this.context); + let lookahead = enf.peek(); + let test = enf.enforestExpression(); + if (test === null) { + throw enf.createError(lookahead, 'expecting an expression'); + } + let body = this.enforestStatement(); - if (object.type === 'Buffer' && isArray(object.data)) { - array = object.data - length = checked(array.length) | 0 + return new _terms2.default('WhileStatement', { test: test, body: body }); } - that = allocate(that, length) - for (var i = 0; i < length; i += 1) { - that[i] = array[i] & 255 + enforestBlockStatement() { + return new _terms2.default('BlockStatement', { + block: this.enforestBlock() + }); } - return that - } - - if (Buffer.TYPED_ARRAY_SUPPORT) { - Buffer.prototype.__proto__ = Uint8Array.prototype - Buffer.__proto__ = Uint8Array - } else { - // pre-set for values that may exist in the future - Buffer.prototype.length = undefined - Buffer.prototype.parent = undefined - } - function allocate (that, length) { - if (Buffer.TYPED_ARRAY_SUPPORT) { - // Return an augmented `Uint8Array` instance, for best performance - that = Buffer._augment(new Uint8Array(length)) - that.__proto__ = Buffer.prototype - } else { - // Fallback: Return an object instance of the Buffer class - that.length = length - that._isBuffer = true + enforestBlock() { + return new _terms2.default('Block', { + statements: this.matchCurlies() + }); } - var fromPool = length !== 0 && length <= Buffer.poolSize >>> 1 - if (fromPool) that.parent = rootParent + enforestClass(_ref) { + let isExpr = _ref.isExpr; + let inDefault = _ref.inDefault; - return that - } + let kw = this.advance(); + let name = null, + supr = null; + let type = isExpr ? 'ClassExpression' : 'ClassDeclaration'; - function checked (length) { - // Note: cannot use `length < kMaxLength` here because that fails when - // length is NaN (which is otherwise coerced to zero.) - if (length >= kMaxLength()) { - throw new RangeError('Attempt to allocate Buffer larger than maximum ' + - 'size: 0x' + kMaxLength().toString(16) + ' bytes') - } - return length | 0 - } + if (this.isIdentifier(this.peek())) { + name = this.enforestBindingIdentifier(); + } else if (!isExpr) { + if (inDefault) { + name = new _terms2.default('BindingIdentifier', { + name: _syntax2.default.fromIdentifier('_default', kw) + }); + } else { + throw this.createError(this.peek(), 'unexpected syntax'); + } + } - function SlowBuffer (subject, encoding) { - if (!(this instanceof SlowBuffer)) return new SlowBuffer(subject, encoding) + if (this.isKeyword(this.peek(), 'extends')) { + this.advance(); + supr = this.enforestExpressionLoop(); + } - var buf = new Buffer(subject, encoding) - delete buf.parent - return buf - } + let elements = []; + let enf = new Enforester(this.matchCurlies(), (0, _immutable.List)(), this.context); + while (enf.rest.size !== 0) { + if (enf.isPunctuator(enf.peek(), ';')) { + enf.advance(); + continue; + } - Buffer.isBuffer = function isBuffer (b) { - return !!(b != null && b._isBuffer) - } + let isStatic = false; - Buffer.compare = function compare (a, b) { - if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) { - throw new TypeError('Arguments must be Buffers') - } + var _enf$enforestMethodDe = enf.enforestMethodDefinition(); - if (a === b) return 0 + let methodOrKey = _enf$enforestMethodDe.methodOrKey; + let kind = _enf$enforestMethodDe.kind; - var x = a.length - var y = b.length + if (kind === 'identifier' && methodOrKey.value.val() === 'static') { + isStatic = true; - var i = 0 - var len = Math.min(x, y) - while (i < len) { - if (a[i] !== b[i]) break + var _enf$enforestMethodDe2 = enf.enforestMethodDefinition(); - ++i - } + methodOrKey = _enf$enforestMethodDe2.methodOrKey; + kind = _enf$enforestMethodDe2.kind; + } + if (kind === 'method') { + elements.push(new _terms2.default('ClassElement', { isStatic: isStatic, method: methodOrKey })); + } else { + throw this.createError(enf.peek(), "Only methods are allowed in classes"); + } + } - if (i !== len) { - x = a[i] - y = b[i] + return new _terms2.default(type, { + name: name, super: supr, + elements: (0, _immutable.List)(elements) + }); } - if (x < y) return -1 - if (y < x) return 1 - return 0 - } - - Buffer.isEncoding = function isEncoding (encoding) { - switch (String(encoding).toLowerCase()) { - case 'hex': - case 'utf8': - case 'utf-8': - case 'ascii': - case 'binary': - case 'base64': - case 'raw': - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return true - default: - return false - } - } + enforestBindingTarget() { + var _ref2 = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; - Buffer.concat = function concat (list, length) { - if (!isArray(list)) throw new TypeError('list argument must be an Array of Buffers.') + let allowPunctuator = _ref2.allowPunctuator; - if (list.length === 0) { - return new Buffer(0) + let lookahead = this.peek(); + if (this.isIdentifier(lookahead) || this.isKeyword(lookahead) || allowPunctuator && this.isPunctuator(lookahead)) { + return this.enforestBindingIdentifier({ allowPunctuator: allowPunctuator }); + } else if (this.isBrackets(lookahead)) { + return this.enforestArrayBinding(); + } else if (this.isBraces(lookahead)) { + return this.enforestObjectBinding(); + } + (0, _errors.assert)(false, 'not implemented yet'); } - var i - if (length === undefined) { - length = 0 - for (i = 0; i < list.length; i++) { - length += list[i].length + enforestObjectBinding() { + let enf = new Enforester(this.matchCurlies(), (0, _immutable.List)(), this.context); + let properties = []; + while (enf.rest.size !== 0) { + properties.push(enf.enforestBindingProperty()); + enf.consumeComma(); } - } - var buf = new Buffer(length) - var pos = 0 - for (i = 0; i < list.length; i++) { - var item = list[i] - item.copy(buf, pos) - pos += item.length + return new _terms2.default('ObjectBinding', { + properties: (0, _immutable.List)(properties) + }); } - return buf - } - function byteLength (string, encoding) { - if (typeof string !== 'string') string = '' + string + enforestBindingProperty() { + let lookahead = this.peek(); - var len = string.length - if (len === 0) return 0 + var _enforestPropertyName = this.enforestPropertyName(); - // Use a for loop to avoid recursion - var loweredCase = false - for (;;) { - switch (encoding) { - case 'ascii': - case 'binary': - // Deprecated - case 'raw': - case 'raws': - return len - case 'utf8': - case 'utf-8': - return utf8ToBytes(string).length - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return len * 2 - case 'hex': - return len >>> 1 - case 'base64': - return base64ToBytes(string).length - default: - if (loweredCase) return utf8ToBytes(string).length // assume utf8 - encoding = ('' + encoding).toLowerCase() - loweredCase = true + let name = _enforestPropertyName.name; + let binding = _enforestPropertyName.binding; + + if (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'let') || this.isKeyword(lookahead, 'yield')) { + if (!this.isPunctuator(this.peek(), ':')) { + let defaultValue = null; + if (this.isAssign(this.peek())) { + this.advance(); + let expr = this.enforestExpressionLoop(); + defaultValue = expr; + } + return new _terms2.default('BindingPropertyIdentifier', { + binding: binding, init: defaultValue + }); + } } + this.matchPunctuator(':'); + binding = this.enforestBindingElement(); + return new _terms2.default('BindingPropertyProperty', { + name: name, binding: binding + }); } - } - Buffer.byteLength = byteLength - function slowToString (encoding, start, end) { - var loweredCase = false + enforestArrayBinding() { + let bracket = this.matchSquares(); + let enf = new Enforester(bracket, (0, _immutable.List)(), this.context); + let elements = [], + restElement = null; + while (enf.rest.size !== 0) { + let el; + if (enf.isPunctuator(enf.peek(), ',')) { + enf.consumeComma(); + el = null; + } else { + if (enf.isPunctuator(enf.peek(), '...')) { + enf.advance(); + restElement = enf.enforestBindingTarget(); + break; + } else { + el = enf.enforestBindingElement(); + } + enf.consumeComma(); + } + elements.push(el); + } + return new _terms2.default('ArrayBinding', { + elements: (0, _immutable.List)(elements), + restElement: restElement + }); + } - start = start | 0 - end = end === undefined || end === Infinity ? this.length : end | 0 + enforestBindingElement() { + let binding = this.enforestBindingTarget(); - if (!encoding) encoding = 'utf8' - if (start < 0) start = 0 - if (end > this.length) end = this.length - if (end <= start) return '' + if (this.isAssign(this.peek())) { + this.advance(); + let init = this.enforestExpressionLoop(); + binding = new _terms2.default('BindingWithDefault', { binding: binding, init: init }); + } + return binding; + } - while (true) { - switch (encoding) { - case 'hex': - return hexSlice(this, start, end) + enforestBindingIdentifier() { + var _ref3 = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; - case 'utf8': - case 'utf-8': - return utf8Slice(this, start, end) + let allowPunctuator = _ref3.allowPunctuator; - case 'ascii': - return asciiSlice(this, start, end) + let name; + if (allowPunctuator && this.isPunctuator(this.peek())) { + name = this.enforestPunctuator(); + } else { + name = this.enforestIdentifier(); + } + return new _terms2.default("BindingIdentifier", { name: name }); + } - case 'binary': - return binarySlice(this, start, end) + enforestPunctuator() { + let lookahead = this.peek(); + if (this.isPunctuator(lookahead)) { + return this.advance(); + } + throw this.createError(lookahead, "expecting a punctuator"); + } - case 'base64': - return base64Slice(this, start, end) + enforestIdentifier() { + let lookahead = this.peek(); + if (this.isIdentifier(lookahead) || this.isKeyword(lookahead)) { + return this.advance(); + } + throw this.createError(lookahead, "expecting an identifier"); + } - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return utf16leSlice(this, start, end) + enforestReturnStatement() { + let kw = this.advance(); + let lookahead = this.peek(); - default: - if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) - encoding = (encoding + '').toLowerCase() - loweredCase = true + // short circuit for the empty expression case + if (this.rest.size === 0 || lookahead && !this.lineNumberEq(kw, lookahead)) { + return new _terms2.default("ReturnStatement", { + expression: null + }); + } + + let term = null; + if (!this.isPunctuator(lookahead, ';')) { + term = this.enforestExpression(); + (0, _errors.expect)(term != null, "Expecting an expression to follow return keyword", lookahead, this.rest); } + + this.consumeSemicolon(); + return new _terms2.default("ReturnStatement", { + expression: term + }); } - } - Buffer.prototype.toString = function toString () { - var length = this.length | 0 - if (length === 0) return '' - if (arguments.length === 0) return utf8Slice(this, 0, length) - return slowToString.apply(this, arguments) - } + enforestVariableDeclaration() { + let kind; + let lookahead = this.advance(); + let kindSyn = lookahead; + let phase = this.context.phase; - Buffer.prototype.equals = function equals (b) { - if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer') - if (this === b) return true - return Buffer.compare(this, b) === 0 - } + if (kindSyn && this.context.env.get(kindSyn.resolve(phase)) === _transforms.VariableDeclTransform) { + kind = "var"; + } else if (kindSyn && this.context.env.get(kindSyn.resolve(phase)) === _transforms.LetDeclTransform) { + kind = "let"; + } else if (kindSyn && this.context.env.get(kindSyn.resolve(phase)) === _transforms.ConstDeclTransform) { + kind = "const"; + } else if (kindSyn && this.context.env.get(kindSyn.resolve(phase)) === _transforms.SyntaxDeclTransform) { + kind = "syntax"; + } else if (kindSyn && this.context.env.get(kindSyn.resolve(phase)) === _transforms.SyntaxrecDeclTransform) { + kind = "syntaxrec"; + } - Buffer.prototype.inspect = function inspect () { - var str = '' - var max = exports.INSPECT_MAX_BYTES - if (this.length > 0) { - str = this.toString('hex', 0, max).match(/.{2}/g).join(' ') - if (this.length > max) str += ' ... ' - } - return '' - } + let decls = (0, _immutable.List)(); - Buffer.prototype.compare = function compare (b) { - if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer') - if (this === b) return 0 - return Buffer.compare(this, b) - } + while (true) { + let term = this.enforestVariableDeclarator({ isSyntax: kind === "syntax" || kind === 'syntaxrec' }); + let lookahead = this.peek(); + decls = decls.concat(term); - Buffer.prototype.indexOf = function indexOf (val, byteOffset) { - if (byteOffset > 0x7fffffff) byteOffset = 0x7fffffff - else if (byteOffset < -0x80000000) byteOffset = -0x80000000 - byteOffset >>= 0 + if (this.isPunctuator(lookahead, ",")) { + this.advance(); + } else { + break; + } + } + + return new _terms2.default('VariableDeclaration', { + kind: kind, + declarators: decls + }); + } - if (this.length === 0) return -1 - if (byteOffset >= this.length) return -1 + enforestVariableDeclarator(_ref4) { + let isSyntax = _ref4.isSyntax; - // Negative offsets start from the end of the buffer - if (byteOffset < 0) byteOffset = Math.max(this.length + byteOffset, 0) + let id = this.enforestBindingTarget({ allowPunctuator: isSyntax }); + let lookahead = this.peek(); - if (typeof val === 'string') { - if (val.length === 0) return -1 // special case: looking for empty string always fails - return String.prototype.indexOf.call(this, val, byteOffset) - } - if (Buffer.isBuffer(val)) { - return arrayIndexOf(this, val, byteOffset) + let init; + if (this.isPunctuator(lookahead, '=')) { + this.advance(); + let enf = new Enforester(this.rest, (0, _immutable.List)(), this.context); + init = enf.enforest("expression"); + this.rest = enf.rest; + } else { + init = null; + } + return new _terms2.default("VariableDeclarator", { + binding: id, + init: init + }); } - if (typeof val === 'number') { - if (Buffer.TYPED_ARRAY_SUPPORT && Uint8Array.prototype.indexOf === 'function') { - return Uint8Array.prototype.indexOf.call(this, val, byteOffset) + + enforestExpressionStatement() { + let start = this.rest.get(0); + let expr = this.enforestExpression(); + if (expr === null) { + throw this.createError(start, "not a valid expression"); } - return arrayIndexOf(this, [ val ], byteOffset) + this.consumeSemicolon(); + + return new _terms2.default("ExpressionStatement", { + expression: expr + }); } - function arrayIndexOf (arr, val, byteOffset) { - var foundIndex = -1 - for (var i = 0; byteOffset + i < arr.length; i++) { - if (arr[byteOffset + i] === val[foundIndex === -1 ? 0 : i - foundIndex]) { - if (foundIndex === -1) foundIndex = i - if (i - foundIndex + 1 === val.length) return byteOffset + foundIndex - } else { - foundIndex = -1 + enforestExpression() { + let left = this.enforestExpressionLoop(); + let lookahead = this.peek(); + if (this.isPunctuator(lookahead, ',')) { + while (this.rest.size !== 0) { + if (!this.isPunctuator(this.peek(), ',')) { + break; + } + let operator = this.advance(); + let right = this.enforestExpressionLoop(); + left = new _terms2.default('BinaryExpression', { left: left, operator: operator, right: right }); } } - return -1 + this.term = null; + return left; } - throw new TypeError('val must be string, number or Buffer') - } + enforestExpressionLoop() { + this.term = null; + this.opCtx = { + prec: 0, + combine: x => x, + stack: (0, _immutable.List)() + }; - // `get` is deprecated - Buffer.prototype.get = function get (offset) { - console.log('.get() is deprecated. Access using array indexes instead.') - return this.readUInt8(offset) - } + do { + let term = this.enforestAssignmentExpression(); + // no change means we've done as much enforesting as possible + // if nothing changed, maybe we just need to pop the expr stack + if (term === EXPR_LOOP_NO_CHANGE && this.opCtx.stack.size > 0) { + this.term = this.opCtx.combine(this.term); - // `set` is deprecated - Buffer.prototype.set = function set (v, offset) { - console.log('.set() is deprecated. Access using array indexes instead.') - return this.writeUInt8(v, offset) - } + var _opCtx$stack$last = this.opCtx.stack.last(); - function hexWrite (buf, string, offset, length) { - offset = Number(offset) || 0 - var remaining = buf.length - offset - if (!length) { - length = remaining - } else { - length = Number(length) - if (length > remaining) { - length = remaining - } + let prec = _opCtx$stack$last.prec; + let combine = _opCtx$stack$last.combine; + + this.opCtx.prec = prec; + this.opCtx.combine = combine; + this.opCtx.stack = this.opCtx.stack.pop(); + } else if (term === EXPR_LOOP_NO_CHANGE) { + break; + } else if (term === EXPR_LOOP_OPERATOR || term === EXPR_LOOP_EXPANSION) { + // operator means an opCtx was pushed on the stack + this.term = null; + } else { + this.term = term; + } + } while (true); // get a fixpoint + return this.term; } - // must be an even number of digits - var strLen = string.length - if (strLen % 2 !== 0) throw new Error('Invalid hex string') + enforestAssignmentExpression() { + let lookahead = this.peek(); - if (length > strLen / 2) { - length = strLen / 2 - } - for (var i = 0; i < length; i++) { - var parsed = parseInt(string.substr(i * 2, 2), 16) - if (isNaN(parsed)) throw new Error('Invalid hex string') - buf[offset + i] = parsed - } - return i - } + if (this.term === null && this.isCompiletimeTransform(lookahead)) { + this.expandMacro(); + lookahead = this.peek(); + } - function utf8Write (buf, string, offset, length) { - return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length) - } + if (this.term === null && this.isTerm(lookahead)) { + // TODO: check that this is actually an expression + return this.advance(); + } - function asciiWrite (buf, string, offset, length) { - return blitBuffer(asciiToBytes(string), buf, offset, length) - } + if (this.term === null && this.isKeyword(lookahead, 'yield')) { + return this.enforestYieldExpression(); + } - function binaryWrite (buf, string, offset, length) { - return asciiWrite(buf, string, offset, length) - } + if (this.term === null && this.isKeyword(lookahead, 'class')) { + return this.enforestClass({ isExpr: true }); + } + if (this.term === null && (this.isIdentifier(lookahead) || this.isParens(lookahead)) && this.isPunctuator(this.peek(1), '=>') && this.lineNumberEq(lookahead, this.peek(1))) { + return this.enforestArrowExpression(); + } - function base64Write (buf, string, offset, length) { - return blitBuffer(base64ToBytes(string), buf, offset, length) - } + if (this.term === null && this.isSyntaxTemplate(lookahead)) { + return this.enforestSyntaxTemplate(); + } + // syntaxQuote ` ... ` + if (this.term === null && this.isSyntaxQuoteTransform(lookahead)) { + return this.enforestSyntaxQuote(); + } - function ucs2Write (buf, string, offset, length) { - return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length) - } + // ($x:expr) + if (this.term === null && this.isParens(lookahead)) { + return new _terms2.default("ParenthesizedExpression", { + inner: this.advance().inner() + }); + } - Buffer.prototype.write = function write (string, offset, length, encoding) { - // Buffer#write(string) - if (offset === undefined) { - encoding = 'utf8' - length = this.length - offset = 0 - // Buffer#write(string, encoding) - } else if (length === undefined && typeof offset === 'string') { - encoding = offset - length = this.length - offset = 0 - // Buffer#write(string, offset[, length][, encoding]) - } else if (isFinite(offset)) { - offset = offset | 0 - if (isFinite(length)) { - length = length | 0 - if (encoding === undefined) encoding = 'utf8' - } else { - encoding = length - length = undefined + if (this.term === null && (this.isKeyword(lookahead, "this") || this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'let') || this.isKeyword(lookahead, 'yield') || this.isNumericLiteral(lookahead) || this.isStringLiteral(lookahead) || this.isTemplate(lookahead) || this.isBooleanLiteral(lookahead) || this.isNullLiteral(lookahead) || this.isRegularExpression(lookahead) || this.isFnDeclTransform(lookahead) || this.isBraces(lookahead) || this.isBrackets(lookahead))) { + return this.enforestPrimaryExpression(); } - // legacy write(string, encoding, offset, length) - remove in v0.13 - } else { - var swap = encoding - encoding = offset - offset = length | 0 - length = swap - } - var remaining = this.length - offset - if (length === undefined || length > remaining) length = remaining + // prefix unary + if (this.term === null && this.isOperator(lookahead)) { + return this.enforestUnaryExpression(); + } - if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) { - throw new RangeError('attempt to write outside buffer bounds') - } + if (this.term === null && this.isVarBindingTransform(lookahead)) { + let id = this.getFromCompiletimeEnvironment(lookahead).id; + if (id !== lookahead) { + this.advance(); + this.rest = _immutable.List.of(id).concat(this.rest); + return EXPR_LOOP_EXPANSION; + } + } - if (!encoding) encoding = 'utf8' + if (this.term === null && (this.isNewTransform(lookahead) || this.isKeyword(lookahead, 'super')) || + // and then check the cases where the term part of p is something... + this.term && ( + // $x:expr . $prop:ident + this.isPunctuator(lookahead, '.') && (this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1))) || + // $x:expr [ $b:expr ] + this.isBrackets(lookahead) || + // $x:expr (...) + this.isParens(lookahead))) { + return this.enforestLeftHandSideExpression({ allowCall: true }); + } - var loweredCase = false - for (;;) { - switch (encoding) { - case 'hex': - return hexWrite(this, string, offset, length) + // $x:id `...` + if (this.term && this.isTemplate(lookahead)) { + return this.enforestTemplateLiteral(); + } - case 'utf8': - case 'utf-8': - return utf8Write(this, string, offset, length) + // postfix unary + if (this.term && this.isUpdateOperator(lookahead)) { + return this.enforestUpdateExpression(); + } - case 'ascii': - return asciiWrite(this, string, offset, length) + // $l:expr $op:binaryOperator $r:expr + if (this.term && this.isOperator(lookahead)) { + return this.enforestBinaryExpression(); + } - case 'binary': - return binaryWrite(this, string, offset, length) + // $x:expr = $init:expr + if (this.term && this.isAssign(lookahead)) { + let binding = this.transformDestructuring(this.term); + let op = this.advance(); - case 'base64': - // Warning: maxLength not taken into account in base64Write - return base64Write(this, string, offset, length) + let enf = new Enforester(this.rest, (0, _immutable.List)(), this.context); + let init = enf.enforest("expression"); + this.rest = enf.rest; - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return ucs2Write(this, string, offset, length) + if (op.val() === '=') { + return new _terms2.default('AssignmentExpression', { + binding: binding, + expression: init + }); + } else { + return new _terms2.default('CompoundAssignmentExpression', { + binding: binding, + operator: op.val(), + expression: init + }); + } + } - default: - if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) - encoding = ('' + encoding).toLowerCase() - loweredCase = true + if (this.term && this.isPunctuator(lookahead, '?')) { + return this.enforestConditionalExpression(); } - } - } - Buffer.prototype.toJSON = function toJSON () { - return { - type: 'Buffer', - data: Array.prototype.slice.call(this._arr || this, 0) + return EXPR_LOOP_NO_CHANGE; } - } - function base64Slice (buf, start, end) { - if (start === 0 && end === buf.length) { - return base64.fromByteArray(buf) - } else { - return base64.fromByteArray(buf.slice(start, end)) + enforestPrimaryExpression() { + let lookahead = this.peek(); + // $x:ThisExpression + if (this.term === null && this.isKeyword(lookahead, "this")) { + return this.enforestThisExpression(); + } + // $x:ident + if (this.term === null && (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'let') || this.isKeyword(lookahead, 'yield'))) { + return this.enforestIdentifierExpression(); + } + if (this.term === null && this.isNumericLiteral(lookahead)) { + return this.enforestNumericLiteral(); + } + if (this.term === null && this.isStringLiteral(lookahead)) { + return this.enforestStringLiteral(); + } + if (this.term === null && this.isTemplate(lookahead)) { + return this.enforestTemplateLiteral(); + } + if (this.term === null && this.isBooleanLiteral(lookahead)) { + return this.enforestBooleanLiteral(); + } + if (this.term === null && this.isNullLiteral(lookahead)) { + return this.enforestNullLiteral(); + } + if (this.term === null && this.isRegularExpression(lookahead)) { + return this.enforestRegularExpressionLiteral(); + } + // $x:FunctionExpression + if (this.term === null && this.isFnDeclTransform(lookahead)) { + return this.enforestFunctionExpression(); + } + // { $p:prop (,) ... } + if (this.term === null && this.isBraces(lookahead)) { + return this.enforestObjectExpression(); + } + // [$x:expr (,) ...] + if (this.term === null && this.isBrackets(lookahead)) { + return this.enforestArrayExpression(); + } + (0, _errors.assert)(false, 'Not a primary expression'); } - } - function utf8Slice (buf, start, end) { - end = Math.min(buf.length, end) - var res = [] + enforestLeftHandSideExpression(_ref5) { + let allowCall = _ref5.allowCall; - var i = start - while (i < end) { - var firstByte = buf[i] - var codePoint = null - var bytesPerSequence = (firstByte > 0xEF) ? 4 - : (firstByte > 0xDF) ? 3 - : (firstByte > 0xBF) ? 2 - : 1 + let lookahead = this.peek(); - if (i + bytesPerSequence <= end) { - var secondByte, thirdByte, fourthByte, tempCodePoint + if (this.isKeyword(lookahead, 'super')) { + this.advance(); + this.term = new _terms2.default('Super', {}); + } else if (this.isNewTransform(lookahead)) { + this.term = this.enforestNewExpression(); + } - switch (bytesPerSequence) { - case 1: - if (firstByte < 0x80) { - codePoint = firstByte - } - break - case 2: - secondByte = buf[i + 1] - if ((secondByte & 0xC0) === 0x80) { - tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F) - if (tempCodePoint > 0x7F) { - codePoint = tempCodePoint - } - } - break - case 3: - secondByte = buf[i + 1] - thirdByte = buf[i + 2] - if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) { - tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F) - if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) { - codePoint = tempCodePoint - } - } - break - case 4: - secondByte = buf[i + 1] - thirdByte = buf[i + 2] - fourthByte = buf[i + 3] - if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) { - tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F) - if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) { - codePoint = tempCodePoint - } + while (true) { + lookahead = this.peek(); + if (this.isParens(lookahead)) { + if (!allowCall) { + // we're dealing with a new expression + if (this.term && ((0, _terms.isIdentifierExpression)(this.term) || (0, _terms.isStaticMemberExpression)(this.term) || (0, _terms.isComputedMemberExpression)(this.term))) { + return this.term; } + this.term = this.enforestExpressionLoop(); + } else { + this.term = this.enforestCallExpression(); + } + } else if (this.isBrackets(lookahead)) { + this.term = this.term ? this.enforestComputedMemberExpression() : this.enforestPrimaryExpression(); + } else if (this.isPunctuator(lookahead, '.') && (this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1)))) { + this.term = this.enforestStaticMemberExpression(); + } else if (this.isTemplate(lookahead)) { + this.term = this.enforestTemplateLiteral(); + } else if (this.isBraces(lookahead)) { + this.term = this.enforestPrimaryExpression(); + } else if (this.isIdentifier(lookahead)) { + this.term = new _terms2.default('IdentifierExpression', { name: this.enforestIdentifier() }); + } else { + break; } } - - if (codePoint === null) { - // we did not generate a valid codePoint so insert a - // replacement char (U+FFFD) and advance only 1 byte - codePoint = 0xFFFD - bytesPerSequence = 1 - } else if (codePoint > 0xFFFF) { - // encode to utf16 (surrogate pair dance) - codePoint -= 0x10000 - res.push(codePoint >>> 10 & 0x3FF | 0xD800) - codePoint = 0xDC00 | codePoint & 0x3FF - } - - res.push(codePoint) - i += bytesPerSequence + return this.term; } - return decodeCodePointsArray(res) - } - - // Based on http://stackoverflow.com/a/22747272/680742, the browser with - // the lowest limit is Chrome, with 0x10000 args. - // We go 1 magnitude less, for safety - var MAX_ARGUMENTS_LENGTH = 0x1000 + enforestBooleanLiteral() { + return new _terms2.default("LiteralBooleanExpression", { + value: this.advance() + }); + } - function decodeCodePointsArray (codePoints) { - var len = codePoints.length - if (len <= MAX_ARGUMENTS_LENGTH) { - return String.fromCharCode.apply(String, codePoints) // avoid extra slice() + enforestTemplateLiteral() { + return new _terms2.default('TemplateExpression', { + tag: this.term, + elements: this.enforestTemplateElements() + }); } - // Decode in chunks to avoid "call stack size exceeded". - var res = '' - var i = 0 - while (i < len) { - res += String.fromCharCode.apply( - String, - codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH) - ) + enforestStringLiteral() { + return new _terms2.default("LiteralStringExpression", { + value: this.advance() + }); } - return res - } - function asciiSlice (buf, start, end) { - var ret = '' - end = Math.min(buf.length, end) + enforestNumericLiteral() { + let num = this.advance(); + if (num.val() === 1 / 0) { + return new _terms2.default('LiteralInfinityExpression', {}); + } + return new _terms2.default("LiteralNumericExpression", { + value: num + }); + } - for (var i = start; i < end; i++) { - ret += String.fromCharCode(buf[i] & 0x7F) + enforestIdentifierExpression() { + return new _terms2.default("IdentifierExpression", { + name: this.advance() + }); } - return ret - } - function binarySlice (buf, start, end) { - var ret = '' - end = Math.min(buf.length, end) + enforestRegularExpressionLiteral() { + let reStx = this.advance(); - for (var i = start; i < end; i++) { - ret += String.fromCharCode(buf[i]) + let lastSlash = reStx.token.value.lastIndexOf("/"); + let pattern = reStx.token.value.slice(1, lastSlash); + let flags = reStx.token.value.slice(lastSlash + 1); + return new _terms2.default("LiteralRegExpExpression", { + pattern: pattern, flags: flags + }); } - return ret - } - - function hexSlice (buf, start, end) { - var len = buf.length - if (!start || start < 0) start = 0 - if (!end || end < 0 || end > len) end = len + enforestNullLiteral() { + this.advance(); + return new _terms2.default("LiteralNullExpression", {}); + } - var out = '' - for (var i = start; i < end; i++) { - out += toHex(buf[i]) + enforestThisExpression() { + return new _terms2.default("ThisExpression", { + stx: this.advance() + }); } - return out - } - function utf16leSlice (buf, start, end) { - var bytes = buf.slice(start, end) - var res = '' - for (var i = 0; i < bytes.length; i += 2) { - res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256) + enforestArgumentList() { + let result = []; + while (this.rest.size > 0) { + let arg; + if (this.isPunctuator(this.peek(), '...')) { + this.advance(); + arg = new _terms2.default('SpreadElement', { + expression: this.enforestExpressionLoop() + }); + } else { + arg = this.enforestExpressionLoop(); + } + if (this.rest.size > 0) { + this.matchPunctuator(','); + } + result.push(arg); + } + return (0, _immutable.List)(result); } - return res - } - Buffer.prototype.slice = function slice (start, end) { - var len = this.length - start = ~~start - end = end === undefined ? len : ~~end + enforestNewExpression() { + this.matchKeyword('new'); + if (this.isPunctuator(this.peek(), '.') && this.isIdentifier(this.peek(1), 'target')) { + this.advance(); + this.advance(); + return new _terms2.default('NewTargetExpression', {}); + } - if (start < 0) { - start += len - if (start < 0) start = 0 - } else if (start > len) { - start = len + let callee = this.enforestLeftHandSideExpression({ allowCall: false }); + let args; + if (this.isParens(this.peek())) { + args = this.matchParens(); + } else { + args = (0, _immutable.List)(); + } + return new _terms2.default('NewExpression', { + callee: callee, + arguments: args + }); } - if (end < 0) { - end += len - if (end < 0) end = 0 - } else if (end > len) { - end = len + enforestComputedMemberExpression() { + let enf = new Enforester(this.matchSquares(), (0, _immutable.List)(), this.context); + return new _terms2.default('ComputedMemberExpression', { + object: this.term, + expression: enf.enforestExpression() + }); } - if (end < start) end = start + transformDestructuring(term) { + switch (term.type) { + case 'IdentifierExpression': + return new _terms2.default('BindingIdentifier', { name: term.name }); - var newBuf - if (Buffer.TYPED_ARRAY_SUPPORT) { - newBuf = Buffer._augment(this.subarray(start, end)) - } else { - var sliceLen = end - start - newBuf = new Buffer(sliceLen, undefined) - for (var i = 0; i < sliceLen; i++) { - newBuf[i] = this[i + start] + case 'ParenthesizedExpression': + if (term.inner.size === 1 && this.isIdentifier(term.inner.get(0))) { + return new _terms2.default('BindingIdentifier', { name: term.inner.get(0) }); + } + return term; + case 'DataProperty': + return new _terms2.default('BindingPropertyProperty', { + name: term.name, + binding: this.transformDestructuringWithDefault(term.expression) + }); + case 'ShorthandProperty': + return new _terms2.default('BindingPropertyIdentifier', { + binding: new _terms2.default('BindingIdentifier', { name: term.name }), + init: null + }); + case 'ObjectExpression': + return new _terms2.default('ObjectBinding', { + properties: term.properties.map(t => this.transformDestructuring(t)) + }); + case 'ArrayExpression': + { + let last = term.elements.last(); + if (last != null && last.type === 'SpreadElement') { + return new _terms2.default('ArrayBinding', { + elements: term.elements.slice(0, -1).map(t => t && this.transformDestructuringWithDefault(t)), + restElement: this.transformDestructuringWithDefault(last.expression) + }); + } else { + return new _terms2.default('ArrayBinding', { + elements: term.elements.map(t => t && this.transformDestructuringWithDefault(t)), + restElement: null + }); + } + } + case 'StaticPropertyName': + return new _terms2.default('BindingIdentifier', { + name: term.value + }); + case 'ComputedMemberExpression': + case 'StaticMemberExpression': + case 'ArrayBinding': + case 'BindingIdentifier': + case 'BindingPropertyIdentifier': + case 'BindingPropertyProperty': + case 'BindingWithDefault': + case 'ObjectBinding': + return term; } + (0, _errors.assert)(false, 'not implemented yet for ' + term.type); } - if (newBuf.length) newBuf.parent = this.parent || this + transformDestructuringWithDefault(term) { + switch (term.type) { + case "AssignmentExpression": + return new _terms2.default('BindingWithDefault', { + binding: this.transformDestructuring(term.binding), + init: term.expression + }); + } + return this.transformDestructuring(term); + } - return newBuf - } + enforestCallExpression() { + let paren = this.advance(); + return new _terms2.default("CallExpression", { + callee: this.term, + arguments: paren.inner() + }); + } - /* - * Need to make sure that buffer isn't trying to write out of bounds. - */ - function checkOffset (offset, ext, length) { - if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint') - if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length') - } + enforestArrowExpression() { + let enf; + if (this.isIdentifier(this.peek())) { + enf = new Enforester(_immutable.List.of(this.advance()), (0, _immutable.List)(), this.context); + } else { + let p = this.matchParens(); + enf = new Enforester(p, (0, _immutable.List)(), this.context); + } + let params = enf.enforestFormalParameters(); + this.matchPunctuator('=>'); - Buffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) { - offset = offset | 0 - byteLength = byteLength | 0 - if (!noAssert) checkOffset(offset, byteLength, this.length) + let body; + if (this.isBraces(this.peek())) { + body = this.matchCurlies(); + } else { + enf = new Enforester(this.rest, (0, _immutable.List)(), this.context); + body = enf.enforestExpressionLoop(); + this.rest = enf.rest; + } + return new _terms2.default('ArrowExpression', { params: params, body: body }); + } - var val = this[offset] - var mul = 1 - var i = 0 - while (++i < byteLength && (mul *= 0x100)) { - val += this[offset + i] * mul + enforestYieldExpression() { + let kwd = this.matchKeyword('yield'); + let lookahead = this.peek(); + + if (this.rest.size === 0 || lookahead && !this.lineNumberEq(kwd, lookahead)) { + return new _terms2.default('YieldExpression', { + expression: null + }); + } else { + let isGenerator = false; + if (this.isPunctuator(this.peek(), '*')) { + isGenerator = true; + this.advance(); + } + let expr = this.enforestExpression(); + let type = isGenerator ? 'YieldGeneratorExpression' : 'YieldExpression'; + return new _terms2.default(type, { + expression: expr + }); + } } - return val - } + enforestSyntaxTemplate() { + return new _terms2.default('SyntaxTemplate', { + template: this.advance() + }); + } - Buffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) { - offset = offset | 0 - byteLength = byteLength | 0 - if (!noAssert) { - checkOffset(offset, byteLength, this.length) + enforestSyntaxQuote() { + let name = this.advance(); + return new _terms2.default('SyntaxQuote', { + name: name, + template: new _terms2.default('TemplateExpression', { + tag: new _terms2.default('IdentifierExpression', { + name: name + }), + elements: this.enforestTemplateElements() + }) + }); } - var val = this[offset + --byteLength] - var mul = 1 - while (byteLength > 0 && (mul *= 0x100)) { - val += this[offset + --byteLength] * mul + enforestStaticMemberExpression() { + let object = this.term; + this.advance(); + let property = this.advance(); + + return new _terms2.default("StaticMemberExpression", { + object: object, + property: property + }); } - return val - } + enforestArrayExpression() { + let arr = this.advance(); - Buffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) { - if (!noAssert) checkOffset(offset, 1, this.length) - return this[offset] - } + let elements = []; - Buffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length) - return this[offset] | (this[offset + 1] << 8) - } + let enf = new Enforester(arr.inner(), (0, _immutable.List)(), this.context); - Buffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length) - return (this[offset] << 8) | this[offset + 1] - } + while (enf.rest.size > 0) { + let lookahead = enf.peek(); + if (enf.isPunctuator(lookahead, ",")) { + enf.advance(); + elements.push(null); + } else if (enf.isPunctuator(lookahead, '...')) { + enf.advance(); + let expression = enf.enforestExpressionLoop(); + if (expression == null) { + throw enf.createError(lookahead, 'expecting expression'); + } + elements.push(new _terms2.default('SpreadElement', { expression: expression })); + } else { + let term = enf.enforestExpressionLoop(); + if (term == null) { + throw enf.createError(lookahead, "expected expression"); + } + elements.push(term); + enf.consumeComma(); + } + } - Buffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length) + return new _terms2.default("ArrayExpression", { + elements: (0, _immutable.List)(elements) + }); + } - return ((this[offset]) | - (this[offset + 1] << 8) | - (this[offset + 2] << 16)) + - (this[offset + 3] * 0x1000000) - } + enforestObjectExpression() { + let obj = this.advance(); - Buffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length) + let properties = (0, _immutable.List)(); - return (this[offset] * 0x1000000) + - ((this[offset + 1] << 16) | - (this[offset + 2] << 8) | - this[offset + 3]) - } + let enf = new Enforester(obj.inner(), (0, _immutable.List)(), this.context); - Buffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) { - offset = offset | 0 - byteLength = byteLength | 0 - if (!noAssert) checkOffset(offset, byteLength, this.length) + let lastProp = null; + while (enf.rest.size > 0) { + let prop = enf.enforestPropertyDefinition(); + enf.consumeComma(); + properties = properties.concat(prop); - var val = this[offset] - var mul = 1 - var i = 0 - while (++i < byteLength && (mul *= 0x100)) { - val += this[offset + i] * mul + if (lastProp === prop) { + throw enf.createError(prop, "invalid syntax in object"); + } + lastProp = prop; + } + + return new _terms2.default("ObjectExpression", { + properties: properties + }); } - mul *= 0x80 - if (val >= mul) val -= Math.pow(2, 8 * byteLength) + enforestPropertyDefinition() { + var _enforestMethodDefini = this.enforestMethodDefinition(); - return val - } + let methodOrKey = _enforestMethodDefini.methodOrKey; + let kind = _enforestMethodDefini.kind; - Buffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) { - offset = offset | 0 - byteLength = byteLength | 0 - if (!noAssert) checkOffset(offset, byteLength, this.length) - var i = byteLength - var mul = 1 - var val = this[offset + --i] - while (i > 0 && (mul *= 0x100)) { - val += this[offset + --i] * mul - } - mul *= 0x80 + switch (kind) { + case 'method': + return methodOrKey; + case 'identifier': + if (this.isAssign(this.peek())) { + this.advance(); + let init = this.enforestExpressionLoop(); + return new _terms2.default('BindingPropertyIdentifier', { + init: init, binding: this.transformDestructuring(methodOrKey) + }); + } else if (!this.isPunctuator(this.peek(), ':')) { + return new _terms2.default('ShorthandProperty', { + name: methodOrKey.value + }); + } + } - if (val >= mul) val -= Math.pow(2, 8 * byteLength) + this.matchPunctuator(':'); + let expr = this.enforestExpressionLoop(); - return val - } + return new _terms2.default("DataProperty", { + name: methodOrKey, + expression: expr + }); + } - Buffer.prototype.readInt8 = function readInt8 (offset, noAssert) { - if (!noAssert) checkOffset(offset, 1, this.length) - if (!(this[offset] & 0x80)) return (this[offset]) - return ((0xff - this[offset] + 1) * -1) - } + enforestMethodDefinition() { + let lookahead = this.peek(); + let isGenerator = false; + if (this.isPunctuator(lookahead, '*')) { + isGenerator = true; + this.advance(); + } - Buffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length) - var val = this[offset] | (this[offset + 1] << 8) - return (val & 0x8000) ? val | 0xFFFF0000 : val - } + if (this.isIdentifier(lookahead, 'get') && this.isPropertyName(this.peek(1))) { + this.advance(); - Buffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length) - var val = this[offset + 1] | (this[offset] << 8) - return (val & 0x8000) ? val | 0xFFFF0000 : val - } + var _enforestPropertyName2 = this.enforestPropertyName(); - Buffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length) + let name = _enforestPropertyName2.name; - return (this[offset]) | - (this[offset + 1] << 8) | - (this[offset + 2] << 16) | - (this[offset + 3] << 24) - } + this.matchParens(); + let body = this.matchCurlies(); + return { + methodOrKey: new _terms2.default('Getter', { name: name, body: body }), + kind: 'method' + }; + } else if (this.isIdentifier(lookahead, 'set') && this.isPropertyName(this.peek(1))) { + this.advance(); - Buffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length) + var _enforestPropertyName3 = this.enforestPropertyName(); - return (this[offset] << 24) | - (this[offset + 1] << 16) | - (this[offset + 2] << 8) | - (this[offset + 3]) - } + let name = _enforestPropertyName3.name; - Buffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length) - return ieee754.read(this, offset, true, 23, 4) - } + let enf = new Enforester(this.matchParens(), (0, _immutable.List)(), this.context); + let param = enf.enforestBindingElement(); + let body = this.matchCurlies(); + return { + methodOrKey: new _terms2.default('Setter', { name: name, param: param, body: body }), + kind: 'method' + }; + } - Buffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length) - return ieee754.read(this, offset, false, 23, 4) - } + var _enforestPropertyName4 = this.enforestPropertyName(); - Buffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 8, this.length) - return ieee754.read(this, offset, true, 52, 8) - } + let name = _enforestPropertyName4.name; - Buffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 8, this.length) - return ieee754.read(this, offset, false, 52, 8) - } + if (this.isParens(this.peek())) { + let params = this.matchParens(); + let enf = new Enforester(params, (0, _immutable.List)(), this.context); + let formalParams = enf.enforestFormalParameters(); - function checkInt (buf, value, offset, ext, max, min) { - if (!Buffer.isBuffer(buf)) throw new TypeError('buffer must be a Buffer instance') - if (value > max || value < min) throw new RangeError('value is out of bounds') - if (offset + ext > buf.length) throw new RangeError('index out of range') - } + let body = this.matchCurlies(); + return { + methodOrKey: new _terms2.default('Method', { + isGenerator: isGenerator, + name: name, params: formalParams, body: body + }), + kind: 'method' + }; + } + return { + methodOrKey: name, + kind: this.isIdentifier(lookahead) || this.isKeyword(lookahead) ? 'identifier' : 'property' + }; + } - Buffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) { - value = +value - offset = offset | 0 - byteLength = byteLength | 0 - if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0) + enforestPropertyName() { + let lookahead = this.peek(); - var mul = 1 - var i = 0 - this[offset] = value & 0xFF - while (++i < byteLength && (mul *= 0x100)) { - this[offset + i] = (value / mul) & 0xFF + if (this.isStringLiteral(lookahead) || this.isNumericLiteral(lookahead)) { + return { + name: new _terms2.default('StaticPropertyName', { + value: this.advance() + }), + binding: null + }; + } else if (this.isBrackets(lookahead)) { + let enf = new Enforester(this.matchSquares(), (0, _immutable.List)(), this.context); + let expr = enf.enforestExpressionLoop(); + return { + name: new _terms2.default('ComputedPropertyName', { + expression: expr + }), + binding: null + }; + } + let name = this.advance(); + return { + name: new _terms2.default('StaticPropertyName', { value: name }), + binding: new _terms2.default('BindingIdentifier', { name: name }) + }; } - return offset + byteLength - } - - Buffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) { - value = +value - offset = offset | 0 - byteLength = byteLength | 0 - if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0) + enforestFunction(_ref6) { + let isExpr = _ref6.isExpr; + let inDefault = _ref6.inDefault; - var i = byteLength - 1 - var mul = 1 - this[offset + i] = value & 0xFF - while (--i >= 0 && (mul *= 0x100)) { - this[offset + i] = (value / mul) & 0xFF - } + let name = null, + params, + body; + let isGenerator = false; + // eat the function keyword + let fnKeyword = this.advance(); + let lookahead = this.peek(); + let type = isExpr ? 'FunctionExpression' : 'FunctionDeclaration'; + + if (this.isPunctuator(lookahead, "*")) { + isGenerator = true; + this.advance(); + lookahead = this.peek(); + } - return offset + byteLength - } + if (!this.isParens(lookahead)) { + name = this.enforestBindingIdentifier(); + } else if (inDefault) { + name = new _terms2.default('BindingIdentifier', { + name: _syntax2.default.fromIdentifier('*default*', fnKeyword) + }); + } - Buffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) { - value = +value - offset = offset | 0 - if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0) - if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value) - this[offset] = (value & 0xff) - return offset + 1 - } + params = this.matchParens(); - function objectWriteUInt16 (buf, value, offset, littleEndian) { - if (value < 0) value = 0xffff + value + 1 - for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; i++) { - buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>> - (littleEndian ? i : 1 - i) * 8 - } - } + body = this.matchCurlies(); - Buffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) { - value = +value - offset = offset | 0 - if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0) - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value & 0xff) - this[offset + 1] = (value >>> 8) - } else { - objectWriteUInt16(this, value, offset, true) - } - return offset + 2 - } + let enf = new Enforester(params, (0, _immutable.List)(), this.context); + let formalParams = enf.enforestFormalParameters(); - Buffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) { - value = +value - offset = offset | 0 - if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0) - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 8) - this[offset + 1] = (value & 0xff) - } else { - objectWriteUInt16(this, value, offset, false) + return new _terms2.default(type, { + name: name, + isGenerator: isGenerator, + params: formalParams, + body: body + }); } - return offset + 2 - } - function objectWriteUInt32 (buf, value, offset, littleEndian) { - if (value < 0) value = 0xffffffff + value + 1 - for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; i++) { - buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff - } - } + enforestFunctionExpression() { + let name = null, + params, + body; + let isGenerator = false; + // eat the function keyword + this.advance(); + let lookahead = this.peek(); - Buffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) { - value = +value - offset = offset | 0 - if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0) - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset + 3] = (value >>> 24) - this[offset + 2] = (value >>> 16) - this[offset + 1] = (value >>> 8) - this[offset] = (value & 0xff) - } else { - objectWriteUInt32(this, value, offset, true) - } - return offset + 4 - } + if (this.isPunctuator(lookahead, "*")) { + isGenerator = true; + this.advance(); + lookahead = this.peek(); + } - Buffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) { - value = +value - offset = offset | 0 - if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0) - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 24) - this[offset + 1] = (value >>> 16) - this[offset + 2] = (value >>> 8) - this[offset + 3] = (value & 0xff) - } else { - objectWriteUInt32(this, value, offset, false) - } - return offset + 4 - } + if (!this.isParens(lookahead)) { + name = this.enforestBindingIdentifier(); + } - Buffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) { - value = +value - offset = offset | 0 - if (!noAssert) { - var limit = Math.pow(2, 8 * byteLength - 1) + params = this.matchParens(); + body = this.matchCurlies(); - checkInt(this, value, offset, byteLength, limit - 1, -limit) - } + let enf = new Enforester(params, (0, _immutable.List)(), this.context); + let formalParams = enf.enforestFormalParameters(); - var i = 0 - var mul = 1 - var sub = value < 0 ? 1 : 0 - this[offset] = value & 0xFF - while (++i < byteLength && (mul *= 0x100)) { - this[offset + i] = ((value / mul) >> 0) - sub & 0xFF + return new _terms2.default("FunctionExpression", { + name: name, + isGenerator: isGenerator, + params: formalParams, + body: body + }); } - return offset + byteLength - } - - Buffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) { - value = +value - offset = offset | 0 - if (!noAssert) { - var limit = Math.pow(2, 8 * byteLength - 1) + enforestFunctionDeclaration() { + let name, params, body; + let isGenerator = false; + // eat the function keyword + this.advance(); + let lookahead = this.peek(); - checkInt(this, value, offset, byteLength, limit - 1, -limit) - } + if (this.isPunctuator(lookahead, "*")) { + isGenerator = true; + this.advance(); + } - var i = byteLength - 1 - var mul = 1 - var sub = value < 0 ? 1 : 0 - this[offset + i] = value & 0xFF - while (--i >= 0 && (mul *= 0x100)) { - this[offset + i] = ((value / mul) >> 0) - sub & 0xFF - } + name = this.enforestBindingIdentifier(); - return offset + byteLength - } + params = this.matchParens(); + body = this.matchCurlies(); - Buffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) { - value = +value - offset = offset | 0 - if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80) - if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value) - if (value < 0) value = 0xff + value + 1 - this[offset] = (value & 0xff) - return offset + 1 - } + let enf = new Enforester(params, (0, _immutable.List)(), this.context); + let formalParams = enf.enforestFormalParameters(); - Buffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) { - value = +value - offset = offset | 0 - if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000) - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value & 0xff) - this[offset + 1] = (value >>> 8) - } else { - objectWriteUInt16(this, value, offset, true) + return new _terms2.default("FunctionDeclaration", { + name: name, + isGenerator: isGenerator, + params: formalParams, + body: body + }); } - return offset + 2 - } - Buffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) { - value = +value - offset = offset | 0 - if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000) - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 8) - this[offset + 1] = (value & 0xff) - } else { - objectWriteUInt16(this, value, offset, false) + enforestFormalParameters() { + let items = []; + let rest = null; + while (this.rest.size !== 0) { + let lookahead = this.peek(); + if (this.isPunctuator(lookahead, '...')) { + this.matchPunctuator('...'); + rest = this.enforestBindingIdentifier(); + break; + } + items.push(this.enforestParam()); + this.consumeComma(); + } + return new _terms2.default("FormalParameters", { + items: (0, _immutable.List)(items), rest: rest + }); } - return offset + 2 - } - Buffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) { - value = +value - offset = offset | 0 - if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000) - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value & 0xff) - this[offset + 1] = (value >>> 8) - this[offset + 2] = (value >>> 16) - this[offset + 3] = (value >>> 24) - } else { - objectWriteUInt32(this, value, offset, true) + enforestParam() { + return this.enforestBindingElement(); } - return offset + 4 - } - Buffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) { - value = +value - offset = offset | 0 - if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000) - if (value < 0) value = 0xffffffff + value + 1 - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 24) - this[offset + 1] = (value >>> 16) - this[offset + 2] = (value >>> 8) - this[offset + 3] = (value & 0xff) - } else { - objectWriteUInt32(this, value, offset, false) - } - return offset + 4 - } + enforestUpdateExpression() { + let operator = this.matchUnaryOperator(); - function checkIEEE754 (buf, value, offset, ext, max, min) { - if (value > max || value < min) throw new RangeError('value is out of bounds') - if (offset + ext > buf.length) throw new RangeError('index out of range') - if (offset < 0) throw new RangeError('index out of range') - } + return new _terms2.default('UpdateExpression', { + isPrefix: false, + operator: operator.val(), + operand: this.transformDestructuring(this.term) + }); + } - function writeFloat (buf, value, offset, littleEndian, noAssert) { - if (!noAssert) { - checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38) + enforestUnaryExpression() { + let operator = this.matchUnaryOperator(); + this.opCtx.stack = this.opCtx.stack.push({ + prec: this.opCtx.prec, + combine: this.opCtx.combine + }); + // TODO: all builtins are 14, custom operators will change this + this.opCtx.prec = 14; + this.opCtx.combine = rightTerm => { + if (operator.val() === '++' || operator.val() === '--') { + return new _terms2.default('UpdateExpression', { + operator: operator.val(), + operand: this.transformDestructuring(rightTerm), + isPrefix: true + }); + } else { + return new _terms2.default('UnaryExpression', { + operator: operator.val(), + operand: rightTerm + }); + } + }; + return EXPR_LOOP_OPERATOR; } - ieee754.write(buf, value, offset, littleEndian, 23, 4) - return offset + 4 - } - Buffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) { - return writeFloat(this, value, offset, true, noAssert) - } + enforestConditionalExpression() { + // first, pop the operator stack + let test = this.opCtx.combine(this.term); + if (this.opCtx.stack.size > 0) { + var _opCtx$stack$last2 = this.opCtx.stack.last(); - Buffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) { - return writeFloat(this, value, offset, false, noAssert) - } + let prec = _opCtx$stack$last2.prec; + let combine = _opCtx$stack$last2.combine; - function writeDouble (buf, value, offset, littleEndian, noAssert) { - if (!noAssert) { - checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308) + this.opCtx.stack = this.opCtx.stack.pop(); + this.opCtx.prec = prec; + this.opCtx.combine = combine; + } + + this.matchPunctuator('?'); + let enf = new Enforester(this.rest, (0, _immutable.List)(), this.context); + let consequent = enf.enforestExpressionLoop(); + enf.matchPunctuator(':'); + enf = new Enforester(enf.rest, (0, _immutable.List)(), this.context); + let alternate = enf.enforestExpressionLoop(); + this.rest = enf.rest; + return new _terms2.default('ConditionalExpression', { + test: test, consequent: consequent, alternate: alternate + }); } - ieee754.write(buf, value, offset, littleEndian, 52, 8) - return offset + 8 - } - Buffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) { - return writeDouble(this, value, offset, true, noAssert) - } + enforestBinaryExpression() { - Buffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) { - return writeDouble(this, value, offset, false, noAssert) - } + let leftTerm = this.term; + let opStx = this.peek(); + let op = opStx.val(); + let opPrec = (0, _operators.getOperatorPrec)(op); + let opAssoc = (0, _operators.getOperatorAssoc)(op); - // copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length) - Buffer.prototype.copy = function copy (target, targetStart, start, end) { - if (!start) start = 0 - if (!end && end !== 0) end = this.length - if (targetStart >= target.length) targetStart = target.length - if (!targetStart) targetStart = 0 - if (end > 0 && end < start) end = start + if ((0, _operators.operatorLt)(this.opCtx.prec, opPrec, opAssoc)) { + this.opCtx.stack = this.opCtx.stack.push({ + prec: this.opCtx.prec, + combine: this.opCtx.combine + }); + this.opCtx.prec = opPrec; + this.opCtx.combine = rightTerm => { + return new _terms2.default("BinaryExpression", { + left: leftTerm, + operator: opStx, + right: rightTerm + }); + }; + this.advance(); + return EXPR_LOOP_OPERATOR; + } else { + let term = this.opCtx.combine(leftTerm); + // this.rest does not change - // Copy 0 bytes; we're done - if (end === start) return 0 - if (target.length === 0 || this.length === 0) return 0 + var _opCtx$stack$last3 = this.opCtx.stack.last(); - // Fatal error conditions - if (targetStart < 0) { - throw new RangeError('targetStart out of bounds') + let prec = _opCtx$stack$last3.prec; + let combine = _opCtx$stack$last3.combine; + + this.opCtx.stack = this.opCtx.stack.pop(); + this.opCtx.prec = prec; + this.opCtx.combine = combine; + return term; + } } - if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds') - if (end < 0) throw new RangeError('sourceEnd out of bounds') - // Are we oob? - if (end > this.length) end = this.length - if (target.length - targetStart < end - start) { - end = target.length - targetStart + start + enforestTemplateElements() { + let lookahead = this.matchTemplate(); + let elements = lookahead.token.items.map(it => { + if (this.isDelimiter(it)) { + let enf = new Enforester(it.inner(), (0, _immutable.List)(), this.context); + return enf.enforest("expression"); + } + return new _terms2.default('TemplateElement', { + rawValue: it.slice.text + }); + }); + return elements; } - var len = end - start - var i + expandMacro() { + let lookahead = this.peek(); + while (this.isCompiletimeTransform(lookahead)) { + let name = this.advance(); + + let syntaxTransform = this.getFromCompiletimeEnvironment(name); + if (syntaxTransform == null || typeof syntaxTransform.value !== "function") { + throw this.createError(name, "the macro name was not bound to a value that could be invoked"); + } + let useSiteScope = (0, _scope.freshScope)("u"); + let introducedScope = (0, _scope.freshScope)("i"); + // TODO: needs to be a list of scopes I think + this.context.useScope = useSiteScope; + + let ctx = new _macroContext2.default(this, name, this.context, useSiteScope, introducedScope); + + let result = (0, _loadSyntax.sanitizeReplacementValues)(syntaxTransform.value.call(null, ctx)); + if (!_immutable.List.isList(result)) { + throw this.createError(name, "macro must return a list but got: " + result); + } + result = result.map(stx => { + if (!(stx && typeof stx.addScope === 'function')) { + throw this.createError(name, 'macro must return syntax objects or terms but got: ' + stx); + } + return stx.addScope(introducedScope, this.context.bindings, _syntax.ALL_PHASES, { flip: true }); + }); - if (this === target && start < targetStart && targetStart < end) { - // descending copy from end - for (i = len - 1; i >= 0; i--) { - target[i + targetStart] = this[i + start] - } - } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) { - // ascending copy from start - for (i = 0; i < len; i++) { - target[i + targetStart] = this[i + start] + this.rest = result.concat(ctx._rest(this)); + lookahead = this.peek(); } - } else { - target._set(this.subarray(start, start + len), targetStart) } - return len - } + consumeSemicolon() { + let lookahead = this.peek(); - // fill(value, start=0, end=buffer.length) - Buffer.prototype.fill = function fill (value, start, end) { - if (!value) value = 0 - if (!start) start = 0 - if (!end) end = this.length + if (lookahead && this.isPunctuator(lookahead, ";")) { + this.advance(); + } + } - if (end < start) throw new RangeError('end < start') + consumeComma() { + let lookahead = this.peek(); - // Fill 0 bytes; we're done - if (end === start) return - if (this.length === 0) return + if (lookahead && this.isPunctuator(lookahead, ',')) { + this.advance(); + } + } - if (start < 0 || start >= this.length) throw new RangeError('start out of bounds') - if (end < 0 || end > this.length) throw new RangeError('end out of bounds') + safeCheck(obj, type) { + let val = arguments.length <= 2 || arguments[2] === undefined ? null : arguments[2]; - var i - if (typeof value === 'number') { - for (i = start; i < end; i++) { - this[i] = value - } - } else { - var bytes = utf8ToBytes(value.toString()) - var len = bytes.length - for (i = start; i < end; i++) { - this[i] = bytes[i % len] - } + return obj && (typeof obj.match === 'function' ? obj.match(type, val) : false); } - return this - } + isTerm(term) { + return term && term instanceof _terms2.default; + } - /** - * Creates a new `ArrayBuffer` with the *copied* memory of the buffer instance. - * Added in Node 0.12. Only available in browsers that support ArrayBuffer. - */ - Buffer.prototype.toArrayBuffer = function toArrayBuffer () { - if (typeof Uint8Array !== 'undefined') { - if (Buffer.TYPED_ARRAY_SUPPORT) { - return (new Buffer(this)).buffer - } else { - var buf = new Uint8Array(this.length) - for (var i = 0, len = buf.length; i < len; i += 1) { - buf[i] = this[i] - } - return buf.buffer - } - } else { - throw new TypeError('Buffer.toArrayBuffer not supported in this browser') + isEOF(obj) { + return this.safeCheck(obj, 'eof'); } - } - // HELPER FUNCTIONS - // ================ + isIdentifier(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - var BP = Buffer.prototype + return this.safeCheck(obj, 'identifier', val); + } - /** - * Augment a Uint8Array *instance* (not the Uint8Array class!) with Buffer methods - */ - Buffer._augment = function _augment (arr) { - arr.constructor = Buffer - arr._isBuffer = true + isPropertyName(obj) { + return this.isIdentifier(obj) || this.isKeyword(obj) || this.isNumericLiteral(obj) || this.isStringLiteral(obj) || this.isBrackets(obj); + } - // save reference to original Uint8Array set method before overwriting - arr._set = arr.set + isNumericLiteral(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - // deprecated - arr.get = BP.get - arr.set = BP.set + return this.safeCheck(obj, 'number', val); + } - arr.write = BP.write - arr.toString = BP.toString - arr.toLocaleString = BP.toString - arr.toJSON = BP.toJSON - arr.equals = BP.equals - arr.compare = BP.compare - arr.indexOf = BP.indexOf - arr.copy = BP.copy - arr.slice = BP.slice - arr.readUIntLE = BP.readUIntLE - arr.readUIntBE = BP.readUIntBE - arr.readUInt8 = BP.readUInt8 - arr.readUInt16LE = BP.readUInt16LE - arr.readUInt16BE = BP.readUInt16BE - arr.readUInt32LE = BP.readUInt32LE - arr.readUInt32BE = BP.readUInt32BE - arr.readIntLE = BP.readIntLE - arr.readIntBE = BP.readIntBE - arr.readInt8 = BP.readInt8 - arr.readInt16LE = BP.readInt16LE - arr.readInt16BE = BP.readInt16BE - arr.readInt32LE = BP.readInt32LE - arr.readInt32BE = BP.readInt32BE - arr.readFloatLE = BP.readFloatLE - arr.readFloatBE = BP.readFloatBE - arr.readDoubleLE = BP.readDoubleLE - arr.readDoubleBE = BP.readDoubleBE - arr.writeUInt8 = BP.writeUInt8 - arr.writeUIntLE = BP.writeUIntLE - arr.writeUIntBE = BP.writeUIntBE - arr.writeUInt16LE = BP.writeUInt16LE - arr.writeUInt16BE = BP.writeUInt16BE - arr.writeUInt32LE = BP.writeUInt32LE - arr.writeUInt32BE = BP.writeUInt32BE - arr.writeIntLE = BP.writeIntLE - arr.writeIntBE = BP.writeIntBE - arr.writeInt8 = BP.writeInt8 - arr.writeInt16LE = BP.writeInt16LE - arr.writeInt16BE = BP.writeInt16BE - arr.writeInt32LE = BP.writeInt32LE - arr.writeInt32BE = BP.writeInt32BE - arr.writeFloatLE = BP.writeFloatLE - arr.writeFloatBE = BP.writeFloatBE - arr.writeDoubleLE = BP.writeDoubleLE - arr.writeDoubleBE = BP.writeDoubleBE - arr.fill = BP.fill - arr.inspect = BP.inspect - arr.toArrayBuffer = BP.toArrayBuffer + isStringLiteral(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - return arr - } + return this.safeCheck(obj, 'string', val); + } - var INVALID_BASE64_RE = /[^+\/0-9A-Za-z-_]/g + isTemplate(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - function base64clean (str) { - // Node strips out invalid characters like \n and \t from the string, base64-js does not - str = stringtrim(str).replace(INVALID_BASE64_RE, '') - // Node converts strings with length < 2 to '' - if (str.length < 2) return '' - // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not - while (str.length % 4 !== 0) { - str = str + '=' + return this.safeCheck(obj, 'template', val); } - return str - } - function stringtrim (str) { - if (str.trim) return str.trim() - return str.replace(/^\s+|\s+$/g, '') - } + isSyntaxTemplate(obj) { + return this.safeCheck(obj, 'syntaxTemplate'); + } - function toHex (n) { - if (n < 16) return '0' + n.toString(16) - return n.toString(16) - } + isBooleanLiteral(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - function utf8ToBytes (string, units) { - units = units || Infinity - var codePoint - var length = string.length - var leadSurrogate = null - var bytes = [] + return this.safeCheck(obj, 'boolean', val); + } - for (var i = 0; i < length; i++) { - codePoint = string.charCodeAt(i) + isNullLiteral(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - // is surrogate component - if (codePoint > 0xD7FF && codePoint < 0xE000) { - // last char was a lead - if (!leadSurrogate) { - // no lead yet - if (codePoint > 0xDBFF) { - // unexpected trail - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) - continue - } else if (i + 1 === length) { - // unpaired lead - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) - continue - } + return this.safeCheck(obj, 'null', val); + } - // valid lead - leadSurrogate = codePoint + isRegularExpression(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - continue - } + return this.safeCheck(obj, 'regularExpression', val); + } - // 2 leads in a row - if (codePoint < 0xDC00) { - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) - leadSurrogate = codePoint - continue - } + isDelimiter(obj) { + return this.safeCheck(obj, 'delimiter'); + } - // valid surrogate pair - codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000 - } else if (leadSurrogate) { - // valid bmp char, but last char was a lead - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) - } + isParens(obj) { + return this.safeCheck(obj, 'parens'); + } - leadSurrogate = null + isBraces(obj) { + return this.safeCheck(obj, 'braces'); + } - // encode utf8 - if (codePoint < 0x80) { - if ((units -= 1) < 0) break - bytes.push(codePoint) - } else if (codePoint < 0x800) { - if ((units -= 2) < 0) break - bytes.push( - codePoint >> 0x6 | 0xC0, - codePoint & 0x3F | 0x80 - ) - } else if (codePoint < 0x10000) { - if ((units -= 3) < 0) break - bytes.push( - codePoint >> 0xC | 0xE0, - codePoint >> 0x6 & 0x3F | 0x80, - codePoint & 0x3F | 0x80 - ) - } else if (codePoint < 0x110000) { - if ((units -= 4) < 0) break - bytes.push( - codePoint >> 0x12 | 0xF0, - codePoint >> 0xC & 0x3F | 0x80, - codePoint >> 0x6 & 0x3F | 0x80, - codePoint & 0x3F | 0x80 - ) - } else { - throw new Error('Invalid code point') - } + isBrackets(obj) { + return this.safeCheck(obj, 'brackets'); } - return bytes - } + isAssign(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - function asciiToBytes (str) { - var byteArray = [] - for (var i = 0; i < str.length; i++) { - // Node's code seems to be doing this and not & 0x7F.. - byteArray.push(str.charCodeAt(i) & 0xFF) + return this.safeCheck(obj, 'assign', val); } - return byteArray - } - function utf16leToBytes (str, units) { - var c, hi, lo - var byteArray = [] - for (var i = 0; i < str.length; i++) { - if ((units -= 2) < 0) break + isKeyword(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - c = str.charCodeAt(i) - hi = c >> 8 - lo = c % 256 - byteArray.push(lo) - byteArray.push(hi) + return this.safeCheck(obj, 'keyword', val); } - return byteArray - } + isPunctuator(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - function base64ToBytes (str) { - return base64.toByteArray(base64clean(str)) - } + return this.safeCheck(obj, 'punctuator', val); + } - function blitBuffer (src, dst, offset, length) { - for (var i = 0; i < length; i++) { - if ((i + offset >= dst.length) || (i >= src.length)) break - dst[i + offset] = src[i] + isOperator(obj) { + return (this.safeCheck(obj, 'punctuator') || this.safeCheck(obj, 'identifier') || this.safeCheck(obj, 'keyword')) && (0, _operators.isOperator)(obj); } - return i - } - /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(59).Buffer, (function() { return this; }()))) + isUpdateOperator(obj) { + return this.safeCheck(obj, 'punctuator', '++') || this.safeCheck(obj, 'punctuator', '--'); + } -/***/ }, -/* 60 */ -/***/ function(module, exports, __webpack_require__) { + safeResolve(obj, phase) { + return obj && typeof obj.resolve === 'function' ? Just(obj.resolve(phase)) : Nothing(); + } - var lookup = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'; + isTransform(obj, trans) { + return this.safeResolve(obj, this.context.phase).map(name => this.context.env.get(name) === trans || this.context.store.get(name) === trans).getOrElse(false); + } - ;(function (exports) { - 'use strict'; + isTransformInstance(obj, trans) { + return this.safeResolve(obj, this.context.phase).map(name => this.context.env.get(name) instanceof trans || this.context.store.get(name) instanceof trans).getOrElse(false); + } - var Arr = (typeof Uint8Array !== 'undefined') - ? Uint8Array - : Array + isFnDeclTransform(obj) { + return this.isTransform(obj, _transforms.FunctionDeclTransform); + } - var PLUS = '+'.charCodeAt(0) - var SLASH = '/'.charCodeAt(0) - var NUMBER = '0'.charCodeAt(0) - var LOWER = 'a'.charCodeAt(0) - var UPPER = 'A'.charCodeAt(0) - var PLUS_URL_SAFE = '-'.charCodeAt(0) - var SLASH_URL_SAFE = '_'.charCodeAt(0) + isVarDeclTransform(obj) { + return this.isTransform(obj, _transforms.VariableDeclTransform); + } - function decode (elt) { - var code = elt.charCodeAt(0) - if (code === PLUS || - code === PLUS_URL_SAFE) - return 62 // '+' - if (code === SLASH || - code === SLASH_URL_SAFE) - return 63 // '/' - if (code < NUMBER) - return -1 //no match - if (code < NUMBER + 10) - return code - NUMBER + 26 + 26 - if (code < UPPER + 26) - return code - UPPER - if (code < LOWER + 26) - return code - LOWER + 26 - } + isLetDeclTransform(obj) { + return this.isTransform(obj, _transforms.LetDeclTransform); + } - function b64ToByteArray (b64) { - var i, j, l, tmp, placeHolders, arr + isConstDeclTransform(obj) { + return this.isTransform(obj, _transforms.ConstDeclTransform); + } - if (b64.length % 4 > 0) { - throw new Error('Invalid string. Length must be a multiple of 4') - } + isSyntaxDeclTransform(obj) { + return this.isTransform(obj, _transforms.SyntaxDeclTransform); + } - // the number of equal signs (place holders) - // if there are two placeholders, than the two characters before it - // represent one byte - // if there is only one, then the three characters before it represent 2 bytes - // this is just a cheap hack to not do indexOf twice - var len = b64.length - placeHolders = '=' === b64.charAt(len - 2) ? 2 : '=' === b64.charAt(len - 1) ? 1 : 0 + isSyntaxrecDeclTransform(obj) { + return this.isTransform(obj, _transforms.SyntaxrecDeclTransform); + } - // base64 is 4/3 + up to two characters of the original data - arr = new Arr(b64.length * 3 / 4 - placeHolders) + isSyntaxQuoteTransform(obj) { + return this.isTransform(obj, _transforms.SyntaxQuoteTransform); + } - // if there are placeholders, only get up to the last complete 4 chars - l = placeHolders > 0 ? b64.length - 4 : b64.length + isReturnStmtTransform(obj) { + return this.isTransform(obj, _transforms.ReturnStatementTransform); + } - var L = 0 + isWhileTransform(obj) { + return this.isTransform(obj, _transforms.WhileTransform); + } - function push (v) { - arr[L++] = v - } + isForTransform(obj) { + return this.isTransform(obj, _transforms.ForTransform); + } - for (i = 0, j = 0; i < l; i += 4, j += 3) { - tmp = (decode(b64.charAt(i)) << 18) | (decode(b64.charAt(i + 1)) << 12) | (decode(b64.charAt(i + 2)) << 6) | decode(b64.charAt(i + 3)) - push((tmp & 0xFF0000) >> 16) - push((tmp & 0xFF00) >> 8) - push(tmp & 0xFF) - } + isSwitchTransform(obj) { + return this.isTransform(obj, _transforms.SwitchTransform); + } - if (placeHolders === 2) { - tmp = (decode(b64.charAt(i)) << 2) | (decode(b64.charAt(i + 1)) >> 4) - push(tmp & 0xFF) - } else if (placeHolders === 1) { - tmp = (decode(b64.charAt(i)) << 10) | (decode(b64.charAt(i + 1)) << 4) | (decode(b64.charAt(i + 2)) >> 2) - push((tmp >> 8) & 0xFF) - push(tmp & 0xFF) - } + isBreakTransform(obj) { + return this.isTransform(obj, _transforms.BreakTransform); + } - return arr - } + isContinueTransform(obj) { + return this.isTransform(obj, _transforms.ContinueTransform); + } - function uint8ToBase64 (uint8) { - var i, - extraBytes = uint8.length % 3, // if we have 1 byte left, pad 2 bytes - output = "", - temp, length + isDoTransform(obj) { + return this.isTransform(obj, _transforms.DoTransform); + } - function encode (num) { - return lookup.charAt(num) - } + isDebuggerTransform(obj) { + return this.isTransform(obj, _transforms.DebuggerTransform); + } - function tripletToBase64 (num) { - return encode(num >> 18 & 0x3F) + encode(num >> 12 & 0x3F) + encode(num >> 6 & 0x3F) + encode(num & 0x3F) - } + isWithTransform(obj) { + return this.isTransform(obj, _transforms.WithTransform); + } - // go through the array every three bytes, we'll deal with trailing stuff later - for (i = 0, length = uint8.length - extraBytes; i < length; i += 3) { - temp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2]) - output += tripletToBase64(temp) - } + isTryTransform(obj) { + return this.isTransform(obj, _transforms.TryTransform); + } - // pad the end with zeros, but make sure to not forget the extra bytes - switch (extraBytes) { - case 1: - temp = uint8[uint8.length - 1] - output += encode(temp >> 2) - output += encode((temp << 4) & 0x3F) - output += '==' - break - case 2: - temp = (uint8[uint8.length - 2] << 8) + (uint8[uint8.length - 1]) - output += encode(temp >> 10) - output += encode((temp >> 4) & 0x3F) - output += encode((temp << 2) & 0x3F) - output += '=' - break - } + isThrowTransform(obj) { + return this.isTransform(obj, _transforms.ThrowTransform); + } - return output - } + isIfTransform(obj) { + return this.isTransform(obj, _transforms.IfTransform); + } - exports.toByteArray = b64ToByteArray - exports.fromByteArray = uint8ToBase64 - }( false ? (this.base64js = {}) : exports)) + isNewTransform(obj) { + return this.isTransform(obj, _transforms.NewTransform); + } + isCompiletimeTransform(obj) { + return this.isTransformInstance(obj, _transforms.CompiletimeTransform); + } -/***/ }, -/* 61 */ -/***/ function(module, exports) { + isVarBindingTransform(obj) { + return this.isTransformInstance(obj, _transforms.VarBindingTransform); + } - exports.read = function (buffer, offset, isLE, mLen, nBytes) { - var e, m - var eLen = nBytes * 8 - mLen - 1 - var eMax = (1 << eLen) - 1 - var eBias = eMax >> 1 - var nBits = -7 - var i = isLE ? (nBytes - 1) : 0 - var d = isLE ? -1 : 1 - var s = buffer[offset + i] + getFromCompiletimeEnvironment(term) { + if (this.context.env.has(term.resolve(this.context.phase))) { + return this.context.env.get(term.resolve(this.context.phase)); + } + return this.context.store.get(term.resolve(this.context.phase)); + } - i += d + lineNumberEq(a, b) { + if (!(a && b)) { + return false; + } + return a.lineNumber() === b.lineNumber(); + } - e = s & ((1 << (-nBits)) - 1) - s >>= (-nBits) - nBits += eLen - for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {} + matchIdentifier(val) { + let lookahead = this.advance(); + if (this.isIdentifier(lookahead, val)) { + return lookahead; + } + throw this.createError(lookahead, "expecting an identifier"); + } - m = e & ((1 << (-nBits)) - 1) - e >>= (-nBits) - nBits += mLen - for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {} + matchKeyword(val) { + let lookahead = this.advance(); + if (this.isKeyword(lookahead, val)) { + return lookahead; + } + throw this.createError(lookahead, 'expecting ' + val); + } - if (e === 0) { - e = 1 - eBias - } else if (e === eMax) { - return m ? NaN : ((s ? -1 : 1) * Infinity) - } else { - m = m + Math.pow(2, mLen) - e = e - eBias + matchLiteral() { + let lookahead = this.advance(); + if (this.isNumericLiteral(lookahead) || this.isStringLiteral(lookahead) || this.isBooleanLiteral(lookahead) || this.isNullLiteral(lookahead) || this.isTemplate(lookahead) || this.isRegularExpression(lookahead)) { + return lookahead; + } + throw this.createError(lookahead, "expecting a literal"); } - return (s ? -1 : 1) * m * Math.pow(2, e - mLen) - } - exports.write = function (buffer, value, offset, isLE, mLen, nBytes) { - var e, m, c - var eLen = nBytes * 8 - mLen - 1 - var eMax = (1 << eLen) - 1 - var eBias = eMax >> 1 - var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0) - var i = isLE ? 0 : (nBytes - 1) - var d = isLE ? 1 : -1 - var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0 + matchStringLiteral() { + let lookahead = this.advance(); + if (this.isStringLiteral(lookahead)) { + return lookahead; + } + throw this.createError(lookahead, 'expecting a string literal'); + } - value = Math.abs(value) + matchTemplate() { + let lookahead = this.advance(); + if (this.isTemplate(lookahead)) { + return lookahead; + } + throw this.createError(lookahead, 'expecting a template literal'); + } - if (isNaN(value) || value === Infinity) { - m = isNaN(value) ? 1 : 0 - e = eMax - } else { - e = Math.floor(Math.log(value) / Math.LN2) - if (value * (c = Math.pow(2, -e)) < 1) { - e-- - c *= 2 + matchParens() { + let lookahead = this.advance(); + if (this.isParens(lookahead)) { + return lookahead.inner(); } - if (e + eBias >= 1) { - value += rt / c - } else { - value += rt * Math.pow(2, 1 - eBias) + throw this.createError(lookahead, "expecting parens"); + } + + matchCurlies() { + let lookahead = this.advance(); + if (this.isBraces(lookahead)) { + return lookahead.inner(); } - if (value * c >= 2) { - e++ - c /= 2 + throw this.createError(lookahead, "expecting curly braces"); + } + matchSquares() { + let lookahead = this.advance(); + if (this.isBrackets(lookahead)) { + return lookahead.inner(); } + throw this.createError(lookahead, "expecting sqaure braces"); + } - if (e + eBias >= eMax) { - m = 0 - e = eMax - } else if (e + eBias >= 1) { - m = (value * c - 1) * Math.pow(2, mLen) - e = e + eBias + matchUnaryOperator() { + let lookahead = this.advance(); + if ((0, _operators.isUnaryOperator)(lookahead)) { + return lookahead; + } + throw this.createError(lookahead, "expecting a unary operator"); + } + + matchPunctuator(val) { + let lookahead = this.advance(); + if (this.isPunctuator(lookahead)) { + if (typeof val !== 'undefined') { + if (lookahead.val() === val) { + return lookahead; + } else { + throw this.createError(lookahead, "expecting a " + val + " punctuator"); + } + } + return lookahead; + } + throw this.createError(lookahead, "expecting a punctuator"); + } + + createError(stx, message) { + let ctx = ""; + let offending = stx; + if (this.rest.size > 0) { + ctx = this.rest.slice(0, 20).map(term => { + if (this.isDelimiter(term)) { + return term.inner(); + } + return _immutable.List.of(term); + }).flatten().map(s => { + if (s === offending) { + return "__" + s.val() + "__"; + } + return s.val(); + }).join(" "); } else { - m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen) - e = 0 + ctx = offending.toString(); } + return new Error(message + "\n" + ctx); + } + } + exports.Enforester = Enforester; + //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/enforester.js"],"names":[],"mappings":"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","file":"enforester.js","sourcesContent":["import Term, { isIdentifierExpression, isStaticMemberExpression, isComputedMemberExpression } from \"./terms\";\nimport { Maybe } from \"ramda-fantasy\";\nconst Just = Maybe.Just;\nconst Nothing = Maybe.Nothing;\n\nimport {\n  FunctionDeclTransform,\n  VariableDeclTransform,\n  NewTransform,\n  LetDeclTransform,\n  ConstDeclTransform,\n  SyntaxDeclTransform,\n  SyntaxrecDeclTransform,\n  SyntaxQuoteTransform,\n  ReturnStatementTransform,\n  WhileTransform,\n  IfTransform,\n  ForTransform,\n  SwitchTransform,\n  BreakTransform,\n  ContinueTransform,\n  DoTransform,\n  DebuggerTransform,\n  WithTransform,\n  TryTransform,\n  ThrowTransform,\n  CompiletimeTransform,\n  VarBindingTransform\n} from \"./transforms\";\nimport { List } from \"immutable\";\nimport { expect, assert } from \"./errors\";\nimport {\n  isOperator,\n  isUnaryOperator,\n  getOperatorAssoc,\n  getOperatorPrec,\n  operatorLt\n} from \"./operators\";\nimport Syntax, { ALL_PHASES } from \"./syntax\";\n\nimport { freshScope } from \"./scope\";\nimport { sanitizeReplacementValues } from './load-syntax';\n\nimport MacroContext from \"./macro-context\";\n\nconst EXPR_LOOP_OPERATOR = {};\nconst EXPR_LOOP_NO_CHANGE = {};\nconst EXPR_LOOP_EXPANSION = {};\n\nexport class Enforester {\n  constructor(stxl, prev, context) {\n    this.done = false;\n    assert(List.isList(stxl), \"expecting a list of terms to enforest\");\n    assert(List.isList(prev), \"expecting a list of terms to enforest\");\n    assert(context, \"expecting a context to enforest\");\n    this.term = null;\n\n    this.rest = stxl;\n    this.prev = prev;\n\n    this.context = context;\n  }\n\n  peek(n = 0) {\n    return this.rest.get(n);\n  }\n\n  advance() {\n    let ret = this.rest.first();\n    this.rest = this.rest.rest();\n    return ret;\n  }\n\n  /*\n   enforest works over:\n   prev - a list of the previously enforest Terms\n   term - the current term being enforested (initially null)\n   rest - remaining Terms to enforest\n   */\n  enforest(type = \"Module\") {\n    // initialize the term\n    this.term = null;\n\n    if (this.rest.size === 0) {\n      this.done = true;\n      return this.term;\n    }\n\n    if (this.isEOF(this.peek())) {\n      this.term = new Term(\"EOF\", {});\n      this.advance();\n      return this.term;\n    }\n\n    let result;\n    if (type === \"expression\") {\n      result = this.enforestExpressionLoop();\n    } else {\n      result = this.enforestModule();\n    }\n\n    if (this.rest.size === 0) {\n      this.done = true;\n    }\n    return result;\n  }\n\n  enforestModule() {\n    return this.enforestBody();\n  }\n\n  enforestBody() {\n    return this.enforestModuleItem();\n  }\n\n  enforestModuleItem() {\n    let lookahead = this.peek();\n    if (this.isKeyword(lookahead, 'import')) {\n      this.advance();\n      return this.enforestImportDeclaration();\n    } else if (this.isKeyword(lookahead, 'export')) {\n      this.advance();\n      return this.enforestExportDeclaration();\n    } else if (this.isIdentifier(lookahead, '#')) {\n      return this.enforestLanguagePragma();\n    }\n    return this.enforestStatement();\n  }\n\n  enforestLanguagePragma() {\n    this.matchIdentifier('#');\n    this.matchIdentifier('lang');\n    let path = this.matchStringLiteral();\n    this.consumeSemicolon();\n    return new Term('Pragma', {\n      kind: 'lang',\n      items: List.of(path)\n    });\n  }\n\n  enforestExportDeclaration() {\n    let lookahead = this.peek();\n    if (this.isPunctuator(lookahead, '*')) {\n      this.advance();\n      let moduleSpecifier = this.enforestFromClause();\n      return new Term('ExportAllFrom', { moduleSpecifier });\n    } else if (this.isBraces(lookahead)) {\n      let namedExports = this.enforestExportClause();\n      let moduleSpecifier = null;\n      if (this.isIdentifier(this.peek(), 'from')) {\n        moduleSpecifier = this.enforestFromClause();\n      }\n      return new Term('ExportFrom', { namedExports, moduleSpecifier });\n    } else if (this.isKeyword(lookahead, 'class')) {\n      return new Term('Export', {\n        declaration: this.enforestClass({ isExpr: false })\n      });\n    } else if (this.isFnDeclTransform(lookahead)) {\n      return new Term('Export', {\n        declaration: this.enforestFunction({isExpr: false, inDefault: false})\n      });\n    } else if (this.isKeyword(lookahead, 'default')) {\n      this.advance();\n      if (this.isFnDeclTransform(this.peek())) {\n        return new Term('ExportDefault', {\n          body: this.enforestFunction({isExpr: false, inDefault: true})\n        });\n      } else if (this.isKeyword(this.peek(), 'class')) {\n        return new Term('ExportDefault', {\n          body: this.enforestClass({isExpr: false, inDefault: true})\n        });\n      } else {\n        let body = this.enforestExpressionLoop();\n        this.consumeSemicolon();\n        return new Term('ExportDefault', { body });\n      }\n    } else if (this.isVarDeclTransform(lookahead) ||\n        this.isLetDeclTransform(lookahead) ||\n        this.isConstDeclTransform(lookahead) ||\n        this.isSyntaxrecDeclTransform(lookahead) ||\n        this.isSyntaxDeclTransform(lookahead)) {\n      return new Term('Export', {\n        declaration: this.enforestVariableDeclaration()\n      });\n    }\n    throw this.createError(lookahead, 'unexpected syntax');\n  }\n\n  enforestExportClause() {\n    let enf = new Enforester(this.matchCurlies(), List(), this.context);\n    let result = [];\n    while (enf.rest.size !== 0) {\n      result.push(enf.enforestExportSpecifier());\n      enf.consumeComma();\n    }\n    return List(result);\n  }\n\n  enforestExportSpecifier() {\n    let name = this.enforestIdentifier();\n    if (this.isIdentifier(this.peek(), 'as')) {\n      this.advance();\n      let exportedName = this.enforestIdentifier();\n      return new Term('ExportSpecifier', { name, exportedName });\n    }\n    return new Term('ExportSpecifier', {\n      name: null,\n      exportedName: name\n    });\n  }\n\n  enforestImportDeclaration() {\n    let lookahead = this.peek();\n    let defaultBinding = null;\n    let namedImports = List();\n    let forSyntax = false;\n\n    if (this.isStringLiteral(lookahead)) {\n      let moduleSpecifier = this.advance();\n      this.consumeSemicolon();\n      return new Term('Import', {\n        defaultBinding,\n        namedImports,\n        moduleSpecifier,\n        forSyntax\n      });\n    }\n\n    if (this.isIdentifier(lookahead) || this.isKeyword(lookahead)) {\n      defaultBinding = this.enforestBindingIdentifier();\n      if (!this.isPunctuator(this.peek(), ',')) {\n        let moduleSpecifier = this.enforestFromClause();\n        if (this.isKeyword(this.peek(), 'for') && this.isIdentifier(this.peek(1), 'syntax')) {\n          this.advance();\n          this.advance();\n          forSyntax = true;\n        }\n\n        return new Term('Import', {\n          defaultBinding, moduleSpecifier,\n          namedImports: List(),\n          forSyntax\n        });\n      }\n    }\n    this.consumeComma();\n    lookahead = this.peek();\n    if (this.isBraces(lookahead)) {\n      let imports = this.enforestNamedImports();\n      let fromClause = this.enforestFromClause();\n      if (this.isKeyword(this.peek(), 'for') && this.isIdentifier(this.peek(1), 'syntax')) {\n        this.advance();\n        this.advance();\n        forSyntax = true;\n      }\n\n      return new Term(\"Import\", {\n        defaultBinding,\n        forSyntax,\n        namedImports: imports,\n        moduleSpecifier: fromClause\n\n      });\n    } else if (this.isPunctuator(lookahead, '*')) {\n      let namespaceBinding = this.enforestNamespaceBinding();\n      let moduleSpecifier = this.enforestFromClause();\n      if (this.isKeyword(this.peek(), 'for') && this.isIdentifier(this.peek(1), 'syntax')) {\n        this.advance();\n        this.advance();\n        forSyntax = true;\n      }\n      return new Term('ImportNamespace', {\n        defaultBinding, forSyntax, namespaceBinding, moduleSpecifier\n      });\n    }\n    throw this.createError(lookahead, 'unexpected syntax');\n  }\n\n  enforestNamespaceBinding() {\n    this.matchPunctuator('*');\n    this.matchIdentifier('as');\n    return this.enforestBindingIdentifier();\n  }\n\n  enforestNamedImports() {\n    let enf = new Enforester(this.matchCurlies(), List(), this.context);\n    let result = [];\n    while (enf.rest.size !== 0) {\n      result.push(enf.enforestImportSpecifiers());\n      enf.consumeComma();\n    }\n    return List(result);\n  }\n\n  enforestImportSpecifiers() {\n    let lookahead = this.peek();\n    let name;\n    if (this.isIdentifier(lookahead) || this.isKeyword(lookahead)) {\n      name = this.advance();\n      if (!this.isIdentifier(this.peek(), 'as')) {\n        return new Term('ImportSpecifier', {\n          name: null,\n          binding: new Term('BindingIdentifier', {\n            name: name\n          })\n        });\n      } else {\n        this.matchIdentifier('as');\n      }\n    } else {\n      throw this.createError(lookahead, 'unexpected token in import specifier');\n    }\n    return new Term('ImportSpecifier', {\n      name, binding: this.enforestBindingIdentifier()\n    });\n  }\n\n  enforestFromClause() {\n    this.matchIdentifier('from');\n    let lookahead = this.matchStringLiteral();\n    this.consumeSemicolon();\n    return lookahead;\n  }\n\n  enforestStatementListItem() {\n    let lookahead = this.peek();\n\n    if (this.isFnDeclTransform(lookahead)) {\n      return this.enforestFunctionDeclaration({ isExpr: false });\n    } else if (this.isKeyword(lookahead, 'class')) {\n      return this.enforestClass({ isExpr: false });\n    } else {\n      return this.enforestStatement();\n    }\n  }\n\n  enforestStatement() {\n    let lookahead = this.peek();\n\n    if (this.term === null && this.isCompiletimeTransform(lookahead)) {\n      this.expandMacro();\n      lookahead = this.peek();\n    }\n\n    if (this.term === null && this.isTerm(lookahead)) {\n      // TODO: check that this is actually an statement\n      return this.advance();\n    }\n\n    if (this.term === null && this.isBraces(lookahead)) {\n      return this.enforestBlockStatement();\n    }\n\n    if (this.term === null && this.isWhileTransform(lookahead)) {\n      return this.enforestWhileStatement();\n    }\n\n    if (this.term === null && this.isIfTransform(lookahead)) {\n      return this.enforestIfStatement();\n    }\n    if (this.term === null && this.isForTransform(lookahead)) {\n      return this.enforestForStatement();\n    }\n    if (this.term === null && this.isSwitchTransform(lookahead)) {\n      return this.enforestSwitchStatement();\n    }\n    if (this.term === null && this.isBreakTransform(lookahead)) {\n      return this.enforestBreakStatement();\n    }\n    if (this.term === null && this.isContinueTransform(lookahead)) {\n      return this.enforestContinueStatement();\n    }\n    if (this.term === null && this.isDoTransform(lookahead)) {\n      return this.enforestDoStatement();\n    }\n    if (this.term === null && this.isDebuggerTransform(lookahead)) {\n      return this.enforestDebuggerStatement();\n    }\n    if (this.term === null && this.isWithTransform(lookahead)) {\n      return this.enforestWithStatement();\n    }\n    if (this.term === null && this.isTryTransform(lookahead)) {\n      return this.enforestTryStatement();\n    }\n    if (this.term === null && this.isThrowTransform(lookahead)) {\n      return this.enforestThrowStatement();\n    }\n\n    // TODO: put somewhere else\n    if (this.term === null && this.isKeyword(lookahead, \"class\")) {\n      return this.enforestClass({isExpr: false});\n    }\n\n    if (this.term === null && this.isFnDeclTransform(lookahead)) {\n      return this.enforestFunctionDeclaration();\n    }\n\n    if (this.term === null && this.isIdentifier(lookahead) &&\n        this.isPunctuator(this.peek(1), ':')) {\n      return this.enforestLabeledStatement();\n    }\n\n    if (this.term === null &&\n        (this.isVarDeclTransform(lookahead) ||\n         this.isLetDeclTransform(lookahead) ||\n         this.isConstDeclTransform(lookahead) ||\n         this.isSyntaxrecDeclTransform(lookahead) ||\n         this.isSyntaxDeclTransform(lookahead))) {\n      let stmt = new Term('VariableDeclarationStatement', {\n        declaration: this.enforestVariableDeclaration()\n      });\n      this.consumeSemicolon();\n      return stmt;\n    }\n\n    if (this.term === null && this.isReturnStmtTransform(lookahead)) {\n      return this.enforestReturnStatement();\n    }\n\n    if (this.term === null && this.isPunctuator(lookahead, \";\")) {\n      this.advance();\n      return new Term(\"EmptyStatement\", {});\n    }\n\n\n    return this.enforestExpressionStatement();\n  }\n\n  enforestLabeledStatement() {\n    let label = this.matchIdentifier();\n    this.matchPunctuator(':');\n    let stmt = this.enforestStatement();\n\n    return new Term('LabeledStatement', {\n      label: label,\n      body: stmt\n    });\n  }\n\n  enforestBreakStatement() {\n    this.matchKeyword('break');\n    let lookahead = this.peek();\n    let label = null;\n    if (this.rest.size === 0 || this.isPunctuator(lookahead, ';')) {\n      this.consumeSemicolon();\n      return new Term('BreakStatement', { label });\n    }\n    if (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'yield') || this.isKeyword(lookahead, 'let')) {\n      label = this.enforestIdentifier();\n    }\n    this.consumeSemicolon();\n\n    return new Term('BreakStatement', { label });\n  }\n\n  enforestTryStatement() {\n    this.matchKeyword('try');\n    let body = this.enforestBlock();\n    if (this.isKeyword(this.peek(), 'catch')) {\n      let catchClause = this.enforestCatchClause();\n      if (this.isKeyword(this.peek(), 'finally')) {\n        this.advance();\n        let finalizer = this.enforestBlock();\n        return new Term('TryFinallyStatement', {\n          body, catchClause, finalizer\n        });\n      }\n      return new Term('TryCatchStatement', { body, catchClause });\n    }\n    if (this.isKeyword(this.peek(), 'finally')) {\n      this.advance();\n      let finalizer = this.enforestBlock();\n      return new Term('TryFinallyStatement', { body, catchClause: null, finalizer });\n    }\n    throw this.createError(this.peek(), 'try with no catch or finally');\n  }\n\n  enforestCatchClause() {\n    this.matchKeyword('catch');\n    let bindingParens = this.matchParens();\n    let enf = new Enforester(bindingParens, List(), this.context);\n    let binding = enf.enforestBindingTarget();\n    let body = this.enforestBlock();\n    return new Term('CatchClause', { binding, body });\n  }\n\n  enforestThrowStatement() {\n    this.matchKeyword('throw');\n    let expression = this.enforestExpression();\n    this.consumeSemicolon();\n    return new Term('ThrowStatement', { expression });\n  }\n\n  enforestWithStatement() {\n    this.matchKeyword('with');\n    let objParens = this.matchParens();\n    let enf = new Enforester(objParens, List(), this.context);\n    let object = enf.enforestExpression();\n    let body = this.enforestStatement();\n    return new Term('WithStatement', { object, body });\n  }\n\n  enforestDebuggerStatement() {\n    this.matchKeyword('debugger');\n\n    return new Term('DebuggerStatement', {});\n  }\n\n  enforestDoStatement() {\n    this.matchKeyword('do');\n    let body = this.enforestStatement();\n    this.matchKeyword('while');\n    let testBody = this.matchParens();\n    let enf = new Enforester(testBody, List(), this.context);\n    let test = enf.enforestExpression();\n    this.consumeSemicolon();\n    return new Term('DoWhileStatement', { body, test });\n  }\n\n  enforestContinueStatement() {\n    let kwd = this.matchKeyword('continue');\n    let lookahead = this.peek();\n    let label = null;\n    if (this.rest.size === 0 || this.isPunctuator(lookahead, ';')) {\n      this.consumeSemicolon();\n      return new Term('ContinueStatement', { label });\n    }\n    if (this.lineNumberEq(kwd, lookahead) &&\n        (this.isIdentifier(lookahead) ||\n         this.isKeyword(lookahead, 'yield') ||\n         this.isKeyword(lookahead, 'let'))) {\n      label = this.enforestIdentifier();\n    }\n    this.consumeSemicolon();\n\n    return new Term('ContinueStatement', { label });\n  }\n\n  enforestSwitchStatement() {\n    this.matchKeyword('switch');\n    let cond = this.matchParens();\n    let enf = new Enforester(cond, List(), this.context);\n    let discriminant = enf.enforestExpression();\n    let body = this.matchCurlies();\n\n    if (body.size === 0) {\n      return new Term('SwitchStatement', {\n        discriminant: discriminant,\n        cases: List()\n      });\n    }\n    enf = new Enforester(body, List(), this.context);\n    let cases = enf.enforestSwitchCases();\n    let lookahead = enf.peek();\n    if (enf.isKeyword(lookahead, 'default')) {\n      let defaultCase = enf.enforestSwitchDefault();\n      let postDefaultCases = enf.enforestSwitchCases();\n      return new Term('SwitchStatementWithDefault', {\n        discriminant,\n        preDefaultCases: cases,\n        defaultCase,\n        postDefaultCases\n      });\n    }\n    return new Term('SwitchStatement', {  discriminant, cases });\n  }\n\n  enforestSwitchCases() {\n    let cases = [];\n    while (!(this.rest.size === 0 || this.isKeyword(this.peek(), 'default'))) {\n      cases.push(this.enforestSwitchCase());\n    }\n    return List(cases);\n  }\n\n  enforestSwitchCase() {\n    this.matchKeyword('case');\n    return new Term('SwitchCase', {\n      test: this.enforestExpression(),\n      consequent: this.enforestSwitchCaseBody()\n    });\n  }\n\n  enforestSwitchCaseBody() {\n    this.matchPunctuator(':');\n    return this.enforestStatementListInSwitchCaseBody();\n  }\n\n  enforestStatementListInSwitchCaseBody() {\n    let result = [];\n    while(!(this.rest.size === 0 || this.isKeyword(this.peek(), 'default') || this.isKeyword(this.peek(), 'case'))) {\n      result.push(this.enforestStatementListItem());\n    }\n    return List(result);\n  }\n\n  enforestSwitchDefault() {\n    this.matchKeyword('default');\n    return new Term('SwitchDefault', {\n      consequent: this.enforestSwitchCaseBody()\n    });\n  }\n\n  enforestForStatement() {\n    this.matchKeyword('for');\n    let cond = this.matchParens();\n    let enf = new Enforester(cond, List(), this.context);\n    let lookahead, test, init, right, type, left, update;\n\n    // case where init is null\n    if (enf.isPunctuator(enf.peek(), ';')) {\n      enf.advance();\n      if (!enf.isPunctuator(enf.peek(), ';')) {\n        test = enf.enforestExpression();\n      }\n      enf.matchPunctuator(';');\n      if (enf.rest.size !== 0) {\n        right = enf.enforestExpression();\n      }\n      return new Term('ForStatement', {\n        init: null,\n        test: test,\n        update: right,\n        body: this.enforestStatement()\n      });\n    // case where init is not null\n    } else {\n      // testing\n      lookahead = enf.peek();\n      if (enf.isVarDeclTransform(lookahead) ||\n          enf.isLetDeclTransform(lookahead) ||\n          enf.isConstDeclTransform(lookahead)) {\n        init = enf.enforestVariableDeclaration();\n        lookahead = enf.peek();\n        if (this.isKeyword(lookahead, 'in') || this.isIdentifier(lookahead, 'of')) {\n          if (this.isKeyword(lookahead, 'in')) {\n            enf.advance();\n            right = enf.enforestExpression();\n            type = 'ForInStatement';\n          } else if (this.isIdentifier(lookahead, 'of')) {\n            enf.advance();\n            right = enf.enforestExpression();\n            type = 'ForOfStatement';\n          }\n          return new Term(type, {\n            left: init, right, body: this.enforestStatement()\n          });\n        }\n        enf.matchPunctuator(';');\n        if (enf.isPunctuator(enf.peek(), ';')) {\n          enf.advance();\n          test = null;\n        } else {\n          test = enf.enforestExpression();\n          enf.matchPunctuator(';');\n        }\n        update = enf.enforestExpression();\n      } else {\n        if (this.isKeyword(enf.peek(1), 'in') || this.isIdentifier(enf.peek(1), 'of')) {\n          left = enf.enforestBindingIdentifier();\n          let kind = enf.advance();\n          if (this.isKeyword(kind, 'in')) {\n            type = 'ForInStatement';\n          } else {\n            type = 'ForOfStatement';\n          }\n          right = enf.enforestExpression();\n          return new Term(type, {\n            left: left, right, body: this.enforestStatement()\n          });\n        }\n        init = enf.enforestExpression();\n        enf.matchPunctuator(';');\n        if (enf.isPunctuator(enf.peek(), ';')) {\n          enf.advance();\n          test = null;\n        } else {\n          test = enf.enforestExpression();\n          enf.matchPunctuator(';');\n        }\n        update = enf.enforestExpression();\n      }\n      return new Term('ForStatement', { init, test, update, body: this.enforestStatement() });\n    }\n  }\n\n  enforestIfStatement() {\n    this.matchKeyword('if');\n    let cond = this.matchParens();\n    let enf = new Enforester(cond, List(), this.context);\n    let lookahead = enf.peek();\n    let test = enf.enforestExpression();\n    if (test === null) {\n      throw enf.createError(lookahead, 'expecting an expression');\n    }\n    let consequent = this.enforestStatement();\n    let alternate = null;\n    if (this.isKeyword(this.peek(), 'else')) {\n      this.advance();\n      alternate = this.enforestStatement();\n    }\n    return new Term('IfStatement', { test, consequent, alternate });\n  }\n\n  enforestWhileStatement() {\n    this.matchKeyword('while');\n    let cond = this.matchParens();\n    let enf = new Enforester(cond, List(), this.context);\n    let lookahead = enf.peek();\n    let test = enf.enforestExpression();\n    if (test === null) {\n      throw enf.createError(lookahead, 'expecting an expression');\n    }\n    let body = this.enforestStatement();\n\n    return new Term('WhileStatement', { test, body });\n  }\n\n  enforestBlockStatement() {\n    return new Term('BlockStatement', {\n      block: this.enforestBlock()\n    });\n  }\n\n  enforestBlock() {\n    return new Term('Block', {\n      statements: this.matchCurlies()\n    });\n  }\n\n  enforestClass({ isExpr, inDefault }) {\n    let kw = this.advance();\n    let name = null, supr = null;\n    let type = isExpr ? 'ClassExpression' : 'ClassDeclaration';\n\n    if (this.isIdentifier(this.peek())) {\n      name = this.enforestBindingIdentifier();\n    } else if (!isExpr) {\n      if (inDefault) {\n        name = new Term('BindingIdentifier', {\n          name: Syntax.fromIdentifier('_default', kw)\n        });\n      } else {\n        throw this.createError(this.peek(), 'unexpected syntax');\n      }\n    }\n\n    if (this.isKeyword(this.peek(), 'extends')) {\n      this.advance();\n      supr = this.enforestExpressionLoop();\n    }\n\n    let elements = [];\n    let enf = new Enforester(this.matchCurlies(), List(), this.context);\n    while (enf.rest.size !== 0) {\n      if (enf.isPunctuator(enf.peek(), ';')) {\n        enf.advance();\n        continue;\n      }\n\n      let isStatic = false;\n      let {methodOrKey, kind} = enf.enforestMethodDefinition();\n      if (kind === 'identifier' && methodOrKey.value.val() === 'static') {\n        isStatic = true;\n        ({methodOrKey, kind} = enf.enforestMethodDefinition());\n      }\n      if (kind === 'method') {\n        elements.push(new Term('ClassElement', {isStatic, method: methodOrKey}));\n      } else {\n        throw this.createError(enf.peek(), \"Only methods are allowed in classes\");\n      }\n    }\n\n    return new Term(type, {\n      name, super: supr,\n      elements: List(elements)\n    });\n  }\n\n  enforestBindingTarget({ allowPunctuator } = {}) {\n    let lookahead = this.peek();\n    if (this.isIdentifier(lookahead) || this.isKeyword(lookahead) || (allowPunctuator && this.isPunctuator(lookahead))) {\n      return this.enforestBindingIdentifier({ allowPunctuator });\n    } else if (this.isBrackets(lookahead)) {\n      return this.enforestArrayBinding();\n    } else if (this.isBraces(lookahead)) {\n      return this.enforestObjectBinding();\n    }\n    assert(false, 'not implemented yet');\n  }\n\n  enforestObjectBinding() {\n    let enf = new Enforester(this.matchCurlies(), List(), this.context);\n    let properties = [];\n    while (enf.rest.size !== 0) {\n      properties.push(enf.enforestBindingProperty());\n      enf.consumeComma();\n    }\n\n    return new Term('ObjectBinding', {\n      properties: List(properties)\n    });\n  }\n\n  enforestBindingProperty() {\n    let lookahead = this.peek();\n    let {name, binding} = this.enforestPropertyName();\n    if (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'let') || this.isKeyword(lookahead, 'yield')) {\n      if (!this.isPunctuator(this.peek(), ':')) {\n        let defaultValue = null;\n        if (this.isAssign(this.peek())) {\n          this.advance();\n          let expr = this.enforestExpressionLoop();\n          defaultValue = expr;\n        }\n        return new Term('BindingPropertyIdentifier', {\n          binding, init: defaultValue\n        });\n      }\n    }\n    this.matchPunctuator(':');\n    binding = this.enforestBindingElement();\n    return new Term('BindingPropertyProperty', {\n      name, binding\n    });\n  }\n\n  enforestArrayBinding() {\n    let bracket = this.matchSquares();\n    let enf = new Enforester(bracket, List(), this.context);\n    let elements = [], restElement = null;\n    while (enf.rest.size !== 0) {\n      let el;\n      if (enf.isPunctuator(enf.peek(), ',')) {\n        enf.consumeComma();\n        el = null;\n      } else {\n        if (enf.isPunctuator(enf.peek(), '...')) {\n          enf.advance();\n          restElement = enf.enforestBindingTarget();\n          break;\n        } else {\n          el = enf.enforestBindingElement();\n        }\n        enf.consumeComma();\n      }\n      elements.push(el);\n    }\n    return new Term('ArrayBinding', {\n      elements: List(elements),\n      restElement\n    });\n  }\n\n  enforestBindingElement() {\n    let binding = this.enforestBindingTarget();\n\n    if (this.isAssign(this.peek())) {\n      this.advance();\n      let init = this.enforestExpressionLoop();\n      binding = new Term('BindingWithDefault', { binding, init });\n    }\n    return binding;\n  }\n\n  enforestBindingIdentifier({ allowPunctuator } = {}) {\n    let name;\n    if (allowPunctuator && this.isPunctuator(this.peek())) {\n      name = this.enforestPunctuator();\n    } else {\n      name = this.enforestIdentifier();\n    }\n    return new Term(\"BindingIdentifier\", { name });\n  }\n\n  enforestPunctuator() {\n    let lookahead = this.peek();\n    if (this.isPunctuator(lookahead)) {\n      return this.advance();\n    }\n    throw this.createError(lookahead, \"expecting a punctuator\");\n  }\n\n  enforestIdentifier() {\n    let lookahead = this.peek();\n    if (this.isIdentifier(lookahead) || this.isKeyword(lookahead)) {\n      return this.advance();\n    }\n    throw this.createError(lookahead, \"expecting an identifier\");\n  }\n\n\n  enforestReturnStatement() {\n    let kw = this.advance();\n    let lookahead = this.peek();\n\n    // short circuit for the empty expression case\n    if (this.rest.size === 0 ||\n        (lookahead && !this.lineNumberEq(kw, lookahead))) {\n      return new Term(\"ReturnStatement\", {\n        expression: null\n      });\n    }\n\n    let term = null;\n    if (!this.isPunctuator(lookahead, ';')) {\n      term = this.enforestExpression();\n      expect(term != null, \"Expecting an expression to follow return keyword\", lookahead, this.rest);\n    }\n\n    this.consumeSemicolon();\n    return new Term(\"ReturnStatement\", {\n      expression: term\n    });\n  }\n\n  enforestVariableDeclaration() {\n    let kind;\n    let lookahead = this.advance();\n    let kindSyn = lookahead;\n    let phase = this.context.phase;\n\n    if (kindSyn &&\n        this.context.env.get(kindSyn.resolve(phase)) === VariableDeclTransform) {\n      kind = \"var\";\n    } else if (kindSyn &&\n               this.context.env.get(kindSyn.resolve(phase)) === LetDeclTransform) {\n      kind = \"let\";\n    } else if (kindSyn &&\n               this.context.env.get(kindSyn.resolve(phase)) === ConstDeclTransform) {\n      kind = \"const\";\n    } else if (kindSyn &&\n               this.context.env.get(kindSyn.resolve(phase)) === SyntaxDeclTransform) {\n      kind = \"syntax\";\n    } else if (kindSyn &&\n               this.context.env.get(kindSyn.resolve(phase)) === SyntaxrecDeclTransform) {\n      kind = \"syntaxrec\";\n    }\n\n    let decls = List();\n\n    while (true) {\n      let term = this.enforestVariableDeclarator({ isSyntax: kind === \"syntax\" || kind === 'syntaxrec' });\n      let lookahead = this.peek();\n      decls = decls.concat(term);\n\n      if (this.isPunctuator(lookahead, \",\")) {\n        this.advance();\n      } else {\n        break;\n      }\n    }\n\n    return new Term('VariableDeclaration', {\n      kind: kind,\n      declarators: decls\n    });\n  }\n\n  enforestVariableDeclarator({ isSyntax }) {\n    let id = this.enforestBindingTarget({ allowPunctuator: isSyntax });\n    let lookahead = this.peek();\n\n    let init;\n    if (this.isPunctuator(lookahead, '=')) {\n      this.advance();\n      let enf = new Enforester(this.rest, List(), this.context);\n      init = enf.enforest(\"expression\");\n      this.rest = enf.rest;\n    } else {\n      init = null;\n    }\n    return new Term(\"VariableDeclarator\", {\n      binding: id,\n      init: init\n    });\n  }\n\n  enforestExpressionStatement() {\n    let start = this.rest.get(0);\n    let expr = this.enforestExpression();\n    if (expr === null) {\n      throw this.createError(start, \"not a valid expression\");\n    }\n    this.consumeSemicolon();\n\n    return new Term(\"ExpressionStatement\", {\n      expression: expr\n    });\n  }\n\n  enforestExpression() {\n    let left = this.enforestExpressionLoop();\n    let lookahead = this.peek();\n    if (this.isPunctuator(lookahead, ',')) {\n      while (this.rest.size !== 0) {\n        if (!this.isPunctuator(this.peek(), ',')) {\n          break;\n        }\n        let operator = this.advance();\n        let right = this.enforestExpressionLoop();\n        left = new Term('BinaryExpression', {left, operator, right});\n      }\n    }\n    this.term = null;\n    return left;\n  }\n\n  enforestExpressionLoop() {\n    this.term = null;\n    this.opCtx = {\n      prec: 0,\n      combine: (x) => x,\n      stack: List()\n    };\n\n    do {\n      let term = this.enforestAssignmentExpression();\n      // no change means we've done as much enforesting as possible\n      // if nothing changed, maybe we just need to pop the expr stack\n      if (term === EXPR_LOOP_NO_CHANGE && this.opCtx.stack.size > 0) {\n        this.term = this.opCtx.combine(this.term);\n        let {prec, combine} = this.opCtx.stack.last();\n        this.opCtx.prec = prec;\n        this.opCtx.combine = combine;\n        this.opCtx.stack = this.opCtx.stack.pop();\n      } else if (term === EXPR_LOOP_NO_CHANGE) {\n        break;\n      } else if (term === EXPR_LOOP_OPERATOR || term === EXPR_LOOP_EXPANSION) {\n        // operator means an opCtx was pushed on the stack\n        this.term = null;\n      } else {\n        this.term = term;\n      }\n    } while (true);  // get a fixpoint\n    return this.term;\n  }\n\n  enforestAssignmentExpression() {\n    let lookahead = this.peek();\n\n    if (this.term === null && this.isCompiletimeTransform(lookahead)) {\n      this.expandMacro();\n      lookahead = this.peek();\n    }\n\n    if (this.term === null && this.isTerm(lookahead)) {\n      // TODO: check that this is actually an expression\n      return this.advance();\n    }\n\n    if (this.term === null && this.isKeyword(lookahead, 'yield')) {\n      return this.enforestYieldExpression();\n    }\n\n    if (this.term === null && this.isKeyword(lookahead, 'class')) {\n      return this.enforestClass({isExpr: true});\n    }\n    if (this.term === null &&\n      (this.isIdentifier(lookahead) || this.isParens(lookahead)) &&\n       this.isPunctuator(this.peek(1), '=>') &&\n       this.lineNumberEq(lookahead, this.peek(1))) {\n      return this.enforestArrowExpression();\n    }\n\n\n\n    if (this.term === null && this.isSyntaxTemplate(lookahead)) {\n      return this.enforestSyntaxTemplate();\n    }\n    // syntaxQuote ` ... `\n    if (this.term === null && this.isSyntaxQuoteTransform(lookahead)) {\n      return this.enforestSyntaxQuote();\n    }\n\n    // ($x:expr)\n    if (this.term === null && this.isParens(lookahead)) {\n      return new Term(\"ParenthesizedExpression\", {\n        inner: this.advance().inner()\n      });\n    }\n\n    if (this.term === null && (\n      this.isKeyword(lookahead, \"this\") ||\n      this.isIdentifier(lookahead) ||\n      this.isKeyword(lookahead, 'let') ||\n      this.isKeyword(lookahead, 'yield') ||\n      this.isNumericLiteral(lookahead) ||\n      this.isStringLiteral(lookahead) ||\n      this.isTemplate(lookahead) ||\n      this.isBooleanLiteral(lookahead) ||\n      this.isNullLiteral(lookahead) ||\n      this.isRegularExpression(lookahead) ||\n      this.isFnDeclTransform(lookahead) ||\n      this.isBraces(lookahead) ||\n      this.isBrackets(lookahead))) {\n      return this.enforestPrimaryExpression();\n    }\n\n    // prefix unary\n    if (this.term === null && this.isOperator(lookahead)) {\n      return this.enforestUnaryExpression();\n    }\n\n    if (this.term === null && this.isVarBindingTransform(lookahead)) {\n      let id = this.getFromCompiletimeEnvironment(lookahead).id;\n      if (id !== lookahead) {\n        this.advance();\n        this.rest = List.of(id).concat(this.rest);\n        return EXPR_LOOP_EXPANSION;\n      }\n    }\n\n    if ((this.term === null && (\n      this.isNewTransform(lookahead) ||\n        this.isKeyword(lookahead, 'super'))) ||\n        // and then check the cases where the term part of p is something...\n        (this.term && (\n          // $x:expr . $prop:ident\n          (this.isPunctuator(lookahead, '.') && (\n            this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1)))) ||\n            // $x:expr [ $b:expr ]\n            this.isBrackets(lookahead) ||\n            // $x:expr (...)\n            this.isParens(lookahead)\n        ))) {\n      return this.enforestLeftHandSideExpression({ allowCall: true });\n    }\n\n    // $x:id `...`\n    if(this.term && this.isTemplate(lookahead)) {\n      return this.enforestTemplateLiteral();\n    }\n\n    // postfix unary\n    if (this.term && this.isUpdateOperator(lookahead)) {\n      return this.enforestUpdateExpression();\n    }\n\n    // $l:expr $op:binaryOperator $r:expr\n    if (this.term && this.isOperator(lookahead)) {\n      return this.enforestBinaryExpression();\n    }\n\n    // $x:expr = $init:expr\n    if (this.term && this.isAssign(lookahead)) {\n      let binding = this.transformDestructuring(this.term);\n      let op = this.advance();\n\n      let enf = new Enforester(this.rest, List(), this.context);\n      let init = enf.enforest(\"expression\");\n      this.rest = enf.rest;\n\n      if (op.val() === '=') {\n        return new Term('AssignmentExpression', {\n          binding,\n          expression: init\n        });\n      } else {\n        return new Term('CompoundAssignmentExpression', {\n          binding,\n          operator: op.val(),\n          expression: init\n        });\n      }\n    }\n\n    if (this.term && this.isPunctuator(lookahead, '?')) {\n      return this.enforestConditionalExpression();\n    }\n\n    return EXPR_LOOP_NO_CHANGE;\n  }\n\n  enforestPrimaryExpression() {\n    let lookahead = this.peek();\n    // $x:ThisExpression\n    if (this.term === null && this.isKeyword(lookahead, \"this\")) {\n      return this.enforestThisExpression();\n    }\n    // $x:ident\n    if (this.term === null && (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'let') || this.isKeyword(lookahead, 'yield'))) {\n      return this.enforestIdentifierExpression();\n    }\n    if (this.term === null && this.isNumericLiteral(lookahead)) {\n      return this.enforestNumericLiteral();\n    }\n    if (this.term === null && this.isStringLiteral(lookahead)) {\n      return this.enforestStringLiteral();\n    }\n    if (this.term === null && this.isTemplate(lookahead)) {\n      return this.enforestTemplateLiteral();\n    }\n    if (this.term === null && this.isBooleanLiteral(lookahead)) {\n      return this.enforestBooleanLiteral();\n    }\n    if (this.term === null && this.isNullLiteral(lookahead)) {\n      return this.enforestNullLiteral();\n    }\n    if (this.term === null && this.isRegularExpression(lookahead)) {\n      return this.enforestRegularExpressionLiteral();\n    }\n    // $x:FunctionExpression\n    if (this.term === null && this.isFnDeclTransform(lookahead)) {\n      return this.enforestFunctionExpression();\n    }\n    // { $p:prop (,) ... }\n    if (this.term === null && this.isBraces(lookahead)) {\n      return this.enforestObjectExpression();\n    }\n    // [$x:expr (,) ...]\n    if (this.term === null && this.isBrackets(lookahead)) {\n      return this.enforestArrayExpression();\n    }\n    assert(false, 'Not a primary expression');\n  }\n\n  enforestLeftHandSideExpression({ allowCall }) {\n    let lookahead = this.peek();\n\n    if (this.isKeyword(lookahead, 'super')) {\n      this.advance();\n      this.term = new Term('Super', {});\n    } else if (this.isNewTransform(lookahead)) {\n      this.term = this.enforestNewExpression();\n    }\n\n    while (true) {\n      lookahead = this.peek();\n      if (this.isParens(lookahead)) {\n        if (!allowCall) {\n          // we're dealing with a new expression\n          if (this.term &&\n              (isIdentifierExpression(this.term) ||\n               isStaticMemberExpression(this.term) ||\n               isComputedMemberExpression(this.term))) {\n            return this.term;\n          }\n          this.term = this.enforestExpressionLoop();\n        } else {\n          this.term = this.enforestCallExpression();\n        }\n      } else if (this.isBrackets(lookahead)) {\n        this.term = this.term ? this.enforestComputedMemberExpression() : this.enforestPrimaryExpression();\n      } else if (this.isPunctuator(lookahead, '.') && (\n        this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1)))) {\n        this.term = this.enforestStaticMemberExpression();\n      } else if (this.isTemplate(lookahead)) {\n        this.term = this.enforestTemplateLiteral();\n      } else if (this.isBraces(lookahead)) {\n        this.term = this.enforestPrimaryExpression();\n      } else if (this.isIdentifier(lookahead)) {\n        this.term = new Term('IdentifierExpression', { name: this.enforestIdentifier() });\n      } else {\n        break;\n      }\n    }\n    return this.term;\n  }\n\n  enforestBooleanLiteral() {\n    return new Term(\"LiteralBooleanExpression\", {\n      value: this.advance()\n    });\n  }\n\n  enforestTemplateLiteral() {\n    return new Term('TemplateExpression', {\n      tag: this.term,\n      elements: this.enforestTemplateElements()\n    });\n  }\n\n  enforestStringLiteral() {\n    return new Term(\"LiteralStringExpression\", {\n      value: this.advance()\n    });\n  }\n\n  enforestNumericLiteral() {\n    let num = this.advance();\n    if (num.val() === 1 / 0) {\n      return new Term('LiteralInfinityExpression', {});\n    }\n    return new Term(\"LiteralNumericExpression\", {\n      value: num\n    });\n  }\n\n  enforestIdentifierExpression() {\n    return new Term(\"IdentifierExpression\", {\n      name: this.advance()\n    });\n  }\n\n  enforestRegularExpressionLiteral() {\n    let reStx = this.advance();\n\n    let lastSlash = reStx.token.value.lastIndexOf(\"/\");\n    let pattern = reStx.token.value.slice(1, lastSlash);\n    let flags = reStx.token.value.slice(lastSlash + 1);\n    return new Term(\"LiteralRegExpExpression\", {\n      pattern, flags\n    });\n  }\n\n  enforestNullLiteral() {\n    this.advance();\n    return new Term(\"LiteralNullExpression\", {});\n  }\n\n  enforestThisExpression() {\n    return new Term(\"ThisExpression\", {\n      stx: this.advance()\n    });\n  }\n\n  enforestArgumentList() {\n    let result = [];\n    while (this.rest.size > 0) {\n      let arg;\n      if (this.isPunctuator(this.peek(), '...')) {\n        this.advance();\n        arg = new Term('SpreadElement', {\n          expression: this.enforestExpressionLoop()\n        });\n      } else {\n        arg = this.enforestExpressionLoop();\n      }\n      if (this.rest.size > 0) {\n        this.matchPunctuator(',');\n      }\n      result.push(arg);\n    }\n    return List(result);\n  }\n\n  enforestNewExpression() {\n    this.matchKeyword('new');\n    if (this.isPunctuator(this.peek(), '.') && this.isIdentifier(this.peek(1), 'target')) {\n      this.advance();\n      this.advance();\n      return new Term('NewTargetExpression', {});\n    }\n\n    let callee = this.enforestLeftHandSideExpression({ allowCall: false });\n    let args;\n    if (this.isParens(this.peek())) {\n      args = this.matchParens();\n    } else {\n      args = List();\n    }\n    return new Term('NewExpression', {\n      callee,\n      arguments: args\n    });\n  }\n\n  enforestComputedMemberExpression() {\n    let enf = new Enforester(this.matchSquares(), List(), this.context);\n    return new Term('ComputedMemberExpression', {\n      object: this.term,\n      expression: enf.enforestExpression()\n    });\n  }\n\n  transformDestructuring(term) {\n    switch (term.type) {\n      case 'IdentifierExpression':\n        return new Term('BindingIdentifier', {name: term.name});\n\n      case 'ParenthesizedExpression':\n        if (term.inner.size === 1 && this.isIdentifier(term.inner.get(0))) {\n          return new Term('BindingIdentifier', { name: term.inner.get(0)});\n        }\n        return term;\n      case 'DataProperty':\n        return new Term('BindingPropertyProperty', {\n          name: term.name,\n          binding: this.transformDestructuringWithDefault(term.expression)\n        });\n      case 'ShorthandProperty':\n        return new Term('BindingPropertyIdentifier', {\n          binding: new Term('BindingIdentifier', { name: term.name }),\n          init: null\n        });\n      case 'ObjectExpression':\n        return new Term('ObjectBinding', {\n          properties: term.properties.map(t => this.transformDestructuring(t))\n        });\n      case 'ArrayExpression': {\n        let last = term.elements.last();\n        if (last != null && last.type === 'SpreadElement') {\n          return new Term('ArrayBinding', {\n            elements: term.elements.slice(0, -1).map(t => t && this.transformDestructuringWithDefault(t)),\n            restElement: this.transformDestructuringWithDefault(last.expression)\n          });\n        } else {\n          return new Term('ArrayBinding', {\n            elements: term.elements.map(t => t && this.transformDestructuringWithDefault(t)),\n            restElement: null\n          });\n        }\n      }\n      case 'StaticPropertyName':\n        return new Term('BindingIdentifier', {\n          name: term.value\n        });\n      case 'ComputedMemberExpression':\n      case 'StaticMemberExpression':\n      case 'ArrayBinding':\n      case 'BindingIdentifier':\n      case 'BindingPropertyIdentifier':\n      case 'BindingPropertyProperty':\n      case 'BindingWithDefault':\n      case 'ObjectBinding':\n        return term;\n    }\n    assert(false, 'not implemented yet for ' + term.type);\n  }\n\n  transformDestructuringWithDefault(term) {\n    switch (term.type) {\n      case \"AssignmentExpression\":\n        return new Term('BindingWithDefault', {\n          binding: this.transformDestructuring(term.binding),\n          init: term.expression,\n        });\n    }\n    return this.transformDestructuring(term);\n  }\n\n  enforestCallExpression() {\n    let paren = this.advance();\n    return new Term(\"CallExpression\", {\n      callee: this.term,\n      arguments: paren.inner()\n    });\n  }\n\n  enforestArrowExpression() {\n    let enf;\n    if (this.isIdentifier(this.peek())) {\n      enf = new Enforester(List.of(this.advance()), List(), this.context);\n    } else {\n      let p = this.matchParens();\n      enf = new Enforester(p, List(), this.context);\n    }\n    let params = enf.enforestFormalParameters();\n    this.matchPunctuator('=>');\n\n    let body;\n    if (this.isBraces(this.peek())) {\n      body = this.matchCurlies();\n    } else {\n      enf = new Enforester(this.rest, List(), this.context);\n      body = enf.enforestExpressionLoop();\n      this.rest = enf.rest;\n    }\n    return new Term('ArrowExpression', { params, body });\n  }\n\n\n  enforestYieldExpression() {\n    let kwd = this.matchKeyword('yield');\n    let lookahead = this.peek();\n\n    if (this.rest.size === 0 || (lookahead && !this.lineNumberEq(kwd, lookahead))) {\n      return new Term('YieldExpression', {\n        expression: null\n      });\n    } else {\n      let isGenerator = false;\n      if (this.isPunctuator(this.peek(), '*')) {\n          isGenerator = true;\n          this.advance();\n      }\n      let expr = this.enforestExpression();\n      let type = isGenerator ? 'YieldGeneratorExpression' : 'YieldExpression';\n      return new Term(type, {\n        expression: expr\n      });\n    }\n  }\n\n  enforestSyntaxTemplate() {\n    return new Term('SyntaxTemplate', {\n      template: this.advance()\n    });\n  }\n\n  enforestSyntaxQuote() {\n    let name = this.advance();\n    return new Term('SyntaxQuote', {\n      name: name,\n      template: new Term('TemplateExpression', {\n        tag: new Term('IdentifierExpression', {\n          name: name\n        }),\n        elements: this.enforestTemplateElements()\n      })\n    });\n  }\n\n  enforestStaticMemberExpression() {\n    let object = this.term;\n    this.advance();\n    let property = this.advance();\n\n    return new Term(\"StaticMemberExpression\", {\n      object: object,\n      property: property\n    });\n  }\n\n  enforestArrayExpression() {\n    let arr = this.advance();\n\n    let elements = [];\n\n    let enf = new Enforester(arr.inner(), List(), this.context);\n\n    while (enf.rest.size > 0) {\n      let lookahead = enf.peek();\n      if (enf.isPunctuator(lookahead, \",\")) {\n        enf.advance();\n        elements.push(null);\n      } else if (enf.isPunctuator(lookahead, '...')) {\n        enf.advance();\n        let expression = enf.enforestExpressionLoop();\n        if (expression == null) {\n          throw enf.createError(lookahead, 'expecting expression');\n        }\n        elements.push(new Term('SpreadElement', { expression }));\n      } else {\n        let term = enf.enforestExpressionLoop();\n        if (term == null) {\n          throw enf.createError(lookahead, \"expected expression\");\n        }\n        elements.push(term);\n        enf.consumeComma();\n      }\n    }\n\n    return new Term(\"ArrayExpression\", {\n      elements: List(elements)\n    });\n  }\n\n  enforestObjectExpression() {\n    let obj = this.advance();\n\n    let properties = List();\n\n    let enf = new Enforester(obj.inner(), List(), this.context);\n\n    let lastProp = null;\n    while (enf.rest.size > 0) {\n      let prop = enf.enforestPropertyDefinition();\n      enf.consumeComma();\n      properties = properties.concat(prop);\n\n      if (lastProp === prop) {\n        throw enf.createError(prop, \"invalid syntax in object\");\n      }\n      lastProp = prop;\n    }\n\n    return new Term(\"ObjectExpression\", {\n      properties: properties\n    });\n  }\n\n  enforestPropertyDefinition() {\n\n    let {methodOrKey, kind} = this.enforestMethodDefinition();\n\n    switch (kind) {\n      case 'method':\n        return methodOrKey;\n      case 'identifier':\n        if (this.isAssign(this.peek())) {\n          this.advance();\n          let init = this.enforestExpressionLoop();\n          return new Term('BindingPropertyIdentifier', {\n            init, binding: this.transformDestructuring(methodOrKey)\n          });\n        } else if (!this.isPunctuator(this.peek(), ':')) {\n          return new Term('ShorthandProperty', {\n            name: methodOrKey.value\n          });\n        }\n    }\n\n    this.matchPunctuator(':');\n    let expr = this.enforestExpressionLoop();\n\n    return new Term(\"DataProperty\", {\n      name: methodOrKey,\n      expression: expr\n    });\n  }\n\n  enforestMethodDefinition() {\n    let lookahead = this.peek();\n    let isGenerator = false;\n    if (this.isPunctuator(lookahead, '*')) {\n      isGenerator = true;\n      this.advance();\n    }\n\n    if (this.isIdentifier(lookahead, 'get') && this.isPropertyName(this.peek(1))) {\n      this.advance();\n      let {name} = this.enforestPropertyName();\n      this.matchParens();\n      let body = this.matchCurlies();\n      return {\n        methodOrKey: new Term('Getter', { name, body }),\n        kind: 'method'\n      };\n    } else if (this.isIdentifier(lookahead, 'set') && this.isPropertyName(this.peek(1))) {\n      this.advance();\n      let {name} = this.enforestPropertyName();\n      let enf = new Enforester(this.matchParens(), List(), this.context);\n      let param = enf.enforestBindingElement();\n      let body = this.matchCurlies();\n      return {\n        methodOrKey: new Term('Setter', { name, param, body }),\n        kind: 'method'\n      };\n    }\n    let {name} = this.enforestPropertyName();\n    if (this.isParens(this.peek())) {\n      let params = this.matchParens();\n      let enf = new Enforester(params, List(), this.context);\n      let formalParams = enf.enforestFormalParameters();\n\n      let body = this.matchCurlies();\n      return {\n        methodOrKey: new Term('Method', {\n          isGenerator,\n          name, params: formalParams, body\n        }),\n        kind: 'method'\n      };\n    }\n    return {\n      methodOrKey: name,\n      kind: this.isIdentifier(lookahead) || this.isKeyword(lookahead) ? 'identifier' : 'property'\n    };\n  }\n\n  enforestPropertyName() {\n    let lookahead = this.peek();\n\n    if (this.isStringLiteral(lookahead) || this.isNumericLiteral(lookahead)) {\n      return {\n        name: new Term('StaticPropertyName', {\n          value: this.advance()\n        }),\n        binding: null\n      };\n    } else if (this.isBrackets(lookahead)) {\n      let enf = new Enforester(this.matchSquares(), List(), this.context);\n      let expr = enf.enforestExpressionLoop();\n      return {\n        name: new Term('ComputedPropertyName', {\n          expression: expr\n        }),\n        binding: null\n      };\n    }\n    let name = this.advance();\n    return {\n      name: new Term('StaticPropertyName', { value: name }),\n      binding: new Term('BindingIdentifier', { name })\n    };\n  }\n\n  enforestFunction({isExpr, inDefault}) {\n    let name = null, params, body;\n    let isGenerator = false;\n    // eat the function keyword\n    let fnKeyword = this.advance();\n    let lookahead = this.peek();\n    let type = isExpr ? 'FunctionExpression' : 'FunctionDeclaration';\n\n    if (this.isPunctuator(lookahead, \"*\")) {\n      isGenerator = true;\n      this.advance();\n      lookahead = this.peek();\n    }\n\n    if (!this.isParens(lookahead)) {\n      name = this.enforestBindingIdentifier();\n    } else if (inDefault) {\n      name = new Term('BindingIdentifier', {\n        name: Syntax.fromIdentifier('*default*', fnKeyword)\n      });\n    }\n\n\n    params = this.matchParens();\n\n\n    body = this.matchCurlies();\n\n    let enf = new Enforester(params, List(), this.context);\n    let formalParams = enf.enforestFormalParameters();\n\n    return new Term(type, {\n      name: name,\n      isGenerator: isGenerator,\n      params: formalParams,\n      body: body\n    });\n  }\n\n  enforestFunctionExpression() {\n    let name = null, params, body;\n    let isGenerator = false;\n    // eat the function keyword\n    this.advance();\n    let lookahead = this.peek();\n\n    if (this.isPunctuator(lookahead, \"*\")) {\n      isGenerator = true;\n      this.advance();\n      lookahead = this.peek();\n    }\n\n    if (!this.isParens(lookahead)) {\n      name = this.enforestBindingIdentifier();\n    }\n\n    params = this.matchParens();\n    body = this.matchCurlies();\n\n    let enf = new Enforester(params, List(), this.context);\n    let formalParams = enf.enforestFormalParameters();\n\n    return new Term(\"FunctionExpression\", {\n      name: name,\n      isGenerator: isGenerator,\n      params: formalParams,\n      body: body\n    });\n  }\n\n  enforestFunctionDeclaration() {\n    let name, params, body;\n    let isGenerator = false;\n    // eat the function keyword\n    this.advance();\n    let lookahead = this.peek();\n\n    if (this.isPunctuator(lookahead, \"*\")) {\n      isGenerator = true;\n      this.advance();\n    }\n\n    name = this.enforestBindingIdentifier();\n\n    params = this.matchParens();\n    body = this.matchCurlies();\n\n    let enf = new Enforester(params, List(), this.context);\n    let formalParams = enf.enforestFormalParameters();\n\n    return new Term(\"FunctionDeclaration\", {\n      name: name,\n      isGenerator: isGenerator,\n      params: formalParams,\n      body: body\n    });\n  }\n\n  enforestFormalParameters() {\n    let items = [];\n    let rest = null;\n    while (this.rest.size !== 0) {\n      let lookahead = this.peek();\n      if (this.isPunctuator(lookahead, '...')) {\n        this.matchPunctuator('...');\n        rest = this.enforestBindingIdentifier();\n        break;\n      }\n      items.push(this.enforestParam());\n      this.consumeComma();\n    }\n    return new Term(\"FormalParameters\", {\n      items: List(items), rest\n    });\n  }\n\n  enforestParam() {\n    return this.enforestBindingElement();\n  }\n\n  enforestUpdateExpression() {\n    let operator = this.matchUnaryOperator();\n\n    return new Term('UpdateExpression', {\n      isPrefix: false,\n      operator: operator.val(),\n      operand: this.transformDestructuring(this.term)\n    });\n  }\n\n  enforestUnaryExpression() {\n    let operator = this.matchUnaryOperator();\n    this.opCtx.stack = this.opCtx.stack.push({\n      prec: this.opCtx.prec,\n      combine: this.opCtx.combine\n    });\n    // TODO: all builtins are 14, custom operators will change this\n    this.opCtx.prec = 14;\n    this.opCtx.combine = rightTerm => {\n      if (operator.val() === '++' || operator.val() === '--') {\n        return new Term('UpdateExpression', {\n          operator: operator.val(),\n          operand: this.transformDestructuring(rightTerm),\n          isPrefix: true\n        });\n      } else {\n        return new Term('UnaryExpression', {\n          operator: operator.val(),\n          operand: rightTerm\n        });\n      }\n    };\n    return EXPR_LOOP_OPERATOR;\n  }\n\n  enforestConditionalExpression() {\n    // first, pop the operator stack\n    let test = this.opCtx.combine(this.term);\n    if (this.opCtx.stack.size > 0) {\n      let { prec, combine } = this.opCtx.stack.last();\n      this.opCtx.stack = this.opCtx.stack.pop();\n      this.opCtx.prec = prec;\n      this.opCtx.combine = combine;\n    }\n\n    this.matchPunctuator('?');\n    let enf = new Enforester(this.rest, List(), this.context);\n    let consequent = enf.enforestExpressionLoop();\n    enf.matchPunctuator(':');\n    enf = new Enforester(enf.rest, List(), this.context);\n    let alternate = enf.enforestExpressionLoop();\n    this.rest = enf.rest;\n    return new Term('ConditionalExpression', {\n      test, consequent, alternate\n    });\n  }\n\n  enforestBinaryExpression() {\n\n    let leftTerm = this.term;\n    let opStx = this.peek();\n    let op = opStx.val();\n    let opPrec = getOperatorPrec(op);\n    let opAssoc = getOperatorAssoc(op);\n\n    if (operatorLt(this.opCtx.prec, opPrec, opAssoc)) {\n      this.opCtx.stack = this.opCtx.stack.push({\n        prec: this.opCtx.prec,\n        combine: this.opCtx.combine\n      });\n      this.opCtx.prec = opPrec;\n      this.opCtx.combine = (rightTerm) => {\n        return new Term(\"BinaryExpression\", {\n          left: leftTerm,\n          operator: opStx,\n          right: rightTerm\n        });\n      };\n      this.advance();\n      return EXPR_LOOP_OPERATOR;\n    } else {\n      let term = this.opCtx.combine(leftTerm);\n      // this.rest does not change\n      let { prec, combine } = this.opCtx.stack.last();\n      this.opCtx.stack = this.opCtx.stack.pop();\n      this.opCtx.prec = prec;\n      this.opCtx.combine = combine;\n      return term;\n    }\n  }\n\n  enforestTemplateElements() {\n    let lookahead = this.matchTemplate();\n    let elements = lookahead.token.items.map(it => {\n      if (this.isDelimiter(it)) {\n        let enf = new Enforester(it.inner(), List(), this.context);\n        return enf.enforest(\"expression\");\n      }\n      return new Term('TemplateElement', {\n        rawValue: it.slice.text\n      });\n    });\n    return elements;\n  }\n\n  expandMacro() {\n    let lookahead = this.peek();\n    while (this.isCompiletimeTransform(lookahead)) {\n      let name = this.advance();\n\n      let syntaxTransform = this.getFromCompiletimeEnvironment(name);\n      if (syntaxTransform == null || typeof syntaxTransform.value !== \"function\") {\n        throw this.createError(name,\n          \"the macro name was not bound to a value that could be invoked\");\n      }\n      let useSiteScope = freshScope(\"u\");\n      let introducedScope = freshScope(\"i\");\n      // TODO: needs to be a list of scopes I think\n      this.context.useScope = useSiteScope;\n\n      let ctx = new MacroContext(this, name, this.context, useSiteScope, introducedScope);\n\n      let result = sanitizeReplacementValues(syntaxTransform.value.call(null, ctx));\n      if (!List.isList(result)) {\n        throw this.createError(name, \"macro must return a list but got: \" + result);\n      }\n      result = result.map(stx => {\n        if (!(stx && typeof stx.addScope === 'function')) {\n          throw this.createError(name, 'macro must return syntax objects or terms but got: ' + stx);\n        }\n        return stx.addScope(introducedScope, this.context.bindings, ALL_PHASES, { flip: true });\n      });\n\n      this.rest = result.concat(ctx._rest(this));\n      lookahead = this.peek();\n    }\n  }\n\n  consumeSemicolon() {\n    let lookahead = this.peek();\n\n    if (lookahead && this.isPunctuator(lookahead, \";\")) {\n      this.advance();\n    }\n  }\n\n  consumeComma() {\n    let lookahead = this.peek();\n\n    if (lookahead && this.isPunctuator(lookahead, ',')) {\n      this.advance();\n    }\n  }\n\n  safeCheck(obj, type, val = null) {\n    return obj && (typeof obj.match === 'function' ? obj.match(type, val) : false);\n  }\n\n  isTerm(term) {\n    return term && (term instanceof Term);\n  }\n\n  isEOF(obj) {\n    return this.safeCheck(obj, 'eof');\n  }\n\n  isIdentifier(obj, val = null) {\n    return this.safeCheck(obj, 'identifier', val);\n  }\n\n  isPropertyName(obj) {\n    return this.isIdentifier(obj) || this.isKeyword(obj) ||\n           this.isNumericLiteral(obj) || this.isStringLiteral(obj) || this.isBrackets(obj);\n  }\n\n  isNumericLiteral(obj, val = null) {\n    return this.safeCheck(obj, 'number', val);\n  }\n\n  isStringLiteral(obj, val = null) {\n    return this.safeCheck(obj, 'string', val);\n  }\n\n  isTemplate(obj, val = null) {\n    return this.safeCheck(obj, 'template', val);\n  }\n\n  isSyntaxTemplate(obj) {\n    return this.safeCheck(obj, 'syntaxTemplate');\n  }\n\n  isBooleanLiteral(obj, val = null) {\n    return this.safeCheck(obj, 'boolean', val);\n  }\n\n  isNullLiteral(obj, val = null) {\n    return this.safeCheck(obj, 'null', val);\n  }\n\n  isRegularExpression(obj, val = null) {\n    return this.safeCheck(obj, 'regularExpression', val);\n  }\n\n  isDelimiter(obj) {\n    return this.safeCheck(obj, 'delimiter');\n  }\n\n  isParens(obj) {\n    return this.safeCheck(obj, 'parens');\n  }\n\n  isBraces(obj) {\n    return this.safeCheck(obj, 'braces');\n  }\n\n  isBrackets(obj) {\n    return this.safeCheck(obj, 'brackets');\n  }\n\n  isAssign(obj, val = null) {\n    return this.safeCheck(obj, 'assign', val);\n  }\n\n\n  isKeyword(obj, val = null) {\n    return this.safeCheck(obj, 'keyword', val);\n  }\n\n  isPunctuator(obj, val = null) {\n    return this.safeCheck(obj, 'punctuator', val);\n  }\n\n  isOperator(obj) {\n    return (this.safeCheck(obj, 'punctuator') ||\n            this.safeCheck(obj, 'identifier') ||\n            this.safeCheck(obj, 'keyword')) && isOperator(obj);\n  }\n\n  isUpdateOperator(obj) {\n    return this.safeCheck(obj, 'punctuator', '++') ||\n           this.safeCheck(obj, 'punctuator', '--');\n  }\n\n  safeResolve(obj, phase) {\n    return (obj && typeof obj.resolve === 'function') ? Just(obj.resolve(phase)) : Nothing();\n  }\n\n  isTransform(obj, trans) {\n    return this.safeResolve(obj, this.context.phase)\n               .map(name => this.context.env.get(name) === trans ||\n                            this.context.store.get(name) === trans)\n               .getOrElse(false);\n  }\n\n  isTransformInstance(obj, trans) {\n    return this.safeResolve(obj, this.context.phase)\n               .map(name => this.context.env.get(name) instanceof trans ||\n                            this.context.store.get(name) instanceof trans)\n               .getOrElse(false);\n  }\n\n  isFnDeclTransform(obj) {\n    return this.isTransform(obj, FunctionDeclTransform);\n  }\n\n  isVarDeclTransform(obj) {\n    return this.isTransform(obj, VariableDeclTransform);\n  }\n\n  isLetDeclTransform(obj) {\n    return this.isTransform(obj, LetDeclTransform);\n  }\n\n  isConstDeclTransform(obj) {\n    return this.isTransform(obj, ConstDeclTransform);\n  }\n\n  isSyntaxDeclTransform(obj) {\n    return this.isTransform(obj, SyntaxDeclTransform);\n  }\n\n  isSyntaxrecDeclTransform(obj) {\n    return this.isTransform(obj, SyntaxrecDeclTransform);\n  }\n\n  isSyntaxQuoteTransform(obj) {\n    return this.isTransform(obj, SyntaxQuoteTransform);\n  }\n\n  isReturnStmtTransform(obj) {\n    return this.isTransform(obj, ReturnStatementTransform);\n  }\n\n  isWhileTransform(obj) {\n    return this.isTransform(obj, WhileTransform);\n  }\n\n  isForTransform(obj) {\n    return this.isTransform(obj, ForTransform);\n  }\n\n  isSwitchTransform(obj) {\n    return this.isTransform(obj, SwitchTransform);\n  }\n\n  isBreakTransform(obj) {\n    return this.isTransform(obj, BreakTransform);\n  }\n\n  isContinueTransform(obj) {\n    return this.isTransform(obj, ContinueTransform);\n  }\n\n  isDoTransform(obj) {\n    return this.isTransform(obj, DoTransform);\n  }\n\n  isDebuggerTransform(obj) {\n    return this.isTransform(obj, DebuggerTransform);\n  }\n\n  isWithTransform(obj) {\n    return this.isTransform(obj, WithTransform);\n  }\n\n  isTryTransform(obj) {\n    return this.isTransform(obj, TryTransform);\n  }\n\n  isThrowTransform(obj) {\n    return this.isTransform(obj, ThrowTransform);\n  }\n\n  isIfTransform(obj) {\n    return this.isTransform(obj, IfTransform);\n  }\n\n  isNewTransform(obj) {\n    return this.isTransform(obj, NewTransform);\n  }\n\n  isCompiletimeTransform(obj) {\n    return this.isTransformInstance(obj, CompiletimeTransform);\n  }\n\n  isVarBindingTransform(obj) {\n    return this.isTransformInstance(obj, VarBindingTransform);\n  }\n\n  getFromCompiletimeEnvironment(term) {\n    if (this.context.env.has(term.resolve(this.context.phase))) {\n      return this.context.env.get(term.resolve(this.context.phase));\n    }\n    return this.context.store.get(term.resolve(this.context.phase));\n  }\n\n  lineNumberEq(a, b) {\n    if (!(a && b)) {\n      return false;\n    }\n    return a.lineNumber() === b.lineNumber();\n  }\n\n  matchIdentifier(val) {\n    let lookahead = this.advance();\n    if (this.isIdentifier(lookahead, val)) {\n      return lookahead;\n    }\n    throw this.createError(lookahead, \"expecting an identifier\");\n  }\n\n  matchKeyword(val) {\n    let lookahead = this.advance();\n    if (this.isKeyword(lookahead, val)) {\n      return lookahead;\n    }\n    throw this.createError(lookahead, 'expecting ' + val);\n  }\n\n  matchLiteral() {\n    let lookahead = this.advance();\n    if (this.isNumericLiteral(lookahead) ||\n        this.isStringLiteral(lookahead) ||\n        this.isBooleanLiteral(lookahead) ||\n        this.isNullLiteral(lookahead) ||\n        this.isTemplate(lookahead) ||\n        this.isRegularExpression(lookahead)) {\n      return lookahead;\n    }\n    throw this.createError(lookahead, \"expecting a literal\");\n  }\n\n  matchStringLiteral() {\n    let lookahead = this.advance();\n    if (this.isStringLiteral(lookahead)) {\n      return lookahead;\n    }\n    throw this.createError(lookahead, 'expecting a string literal');\n  }\n\n  matchTemplate() {\n    let lookahead = this.advance();\n    if (this.isTemplate(lookahead)) {\n      return lookahead;\n    }\n    throw this.createError(lookahead, 'expecting a template literal');\n  }\n\n  matchParens() {\n    let lookahead = this.advance();\n    if (this.isParens(lookahead)) {\n      return lookahead.inner();\n    }\n    throw this.createError(lookahead, \"expecting parens\");\n  }\n\n  matchCurlies() {\n    let lookahead = this.advance();\n    if (this.isBraces(lookahead)) {\n      return lookahead.inner();\n    }\n    throw this.createError(lookahead, \"expecting curly braces\");\n  }\n  matchSquares() {\n    let lookahead = this.advance();\n    if (this.isBrackets(lookahead)) {\n      return lookahead.inner();\n    }\n    throw this.createError(lookahead, \"expecting sqaure braces\");\n  }\n\n  matchUnaryOperator() {\n    let lookahead = this.advance();\n    if (isUnaryOperator(lookahead)) {\n      return lookahead;\n    }\n    throw this.createError(lookahead, \"expecting a unary operator\");\n  }\n\n  matchPunctuator(val) {\n    let lookahead = this.advance();\n    if (this.isPunctuator(lookahead)) {\n      if (typeof val !== 'undefined') {\n        if (lookahead.val() === val) {\n          return lookahead;\n        } else {\n          throw this.createError(lookahead,\n            \"expecting a \" + val + \" punctuator\");\n        }\n      }\n      return lookahead;\n    }\n    throw this.createError(lookahead, \"expecting a punctuator\");\n  }\n\n  createError(stx, message) {\n    let ctx = \"\";\n    let offending = stx;\n    if (this.rest.size > 0) {\n      ctx = this.rest.slice(0, 20).map(term => {\n        if (this.isDelimiter(term)) {\n          return term.inner();\n        }\n        return List.of(term);\n      }).flatten().map(s => {\n        if (s === offending) {\n          return \"__\" + s.val() + \"__\";\n        }\n        return s.val();\n      }).join(\" \");\n    } else {\n      ctx = offending.toString();\n    }\n    return new Error(message + \"\\n\" + ctx);\n\n  }\n}\n"]} + +/***/ }, +/* 57 */ +/***/ function(module, exports) { + + 'use strict'; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.operatorLt = operatorLt; + exports.getOperatorPrec = getOperatorPrec; + exports.getOperatorAssoc = getOperatorAssoc; + exports.isUnaryOperator = isUnaryOperator; + exports.isOperator = isOperator; + const unaryOperators = { + '+': true, + '-': true, + '!': true, + '~': true, + '++': true, + '--': true, + 'typeof': true, + 'void': true, + 'delete': true + }; + const binaryOperatorPrecedence = { + "*": 13, + "/": 13, + "%": 13, + "+": 12, + "-": 12, + ">>": 11, + "<<": 11, + ">>>": 11, + "<": 10, + "<=": 10, + ">": 10, + ">=": 10, + "in": 10, + "instanceof": 10, + "==": 9, + "!=": 9, + "===": 9, + "!==": 9, + "&": 8, + "^": 7, + "|": 6, + "&&": 5, + "||": 4 + }; + + var operatorAssoc = { + "*": "left", + "/": "left", + "%": "left", + "+": "left", + "-": "left", + ">>": "left", + "<<": "left", + ">>>": "left", + "<": "left", + "<=": "left", + ">": "left", + ">=": "left", + "in": "left", + "instanceof": "left", + "==": "left", + "!=": "left", + "===": "left", + "!==": "left", + "&": "left", + "^": "left", + "|": "left", + "&&": "left", + "||": "left" + }; + + function operatorLt(left, right, assoc) { + if (assoc === "left") { + return left < right; + } else { + return left <= right; + } + } + + function getOperatorPrec(op) { + return binaryOperatorPrecedence[op]; + } + function getOperatorAssoc(op) { + return operatorAssoc[op]; + } + + function isUnaryOperator(op) { + return (op.match("punctuator") || op.match("identifier") || op.match("keyword")) && unaryOperators.hasOwnProperty(op.val()); + } + + function isOperator(op) { + if (op.match("punctuator") || op.match("identifier") || op.match("keyword")) { + return binaryOperatorPrecedence.hasOwnProperty(op) || unaryOperators.hasOwnProperty(op.val()); } + return false; + } + //# sourceMappingURL=data:application/json;base64,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eEMsS0FBK0MsZUFBZSxjQUFmLENBQThCLEdBQUcsR0FBSCxFQUE5QixDQUF0RDtBQUNEO0FBQ0QsU0FBTyxLQUFQO0FBQ0QiLCJmaWxlIjoib3BlcmF0b3JzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgdW5hcnlPcGVyYXRvcnMgPSB7XG4gICcrJzogdHJ1ZSxcbiAgJy0nOiB0cnVlLFxuICAnISc6IHRydWUsXG4gICd+JzogdHJ1ZSxcbiAgJysrJzogdHJ1ZSxcbiAgJy0tJzogdHJ1ZSxcbiAgJ3R5cGVvZic6IHRydWUsXG4gICd2b2lkJzogdHJ1ZSxcbiAgJ2RlbGV0ZSc6IHRydWUsXG59O1xuY29uc3QgYmluYXJ5T3BlcmF0b3JQcmVjZWRlbmNlID0ge1xuICBcIipcIjogMTMsXG4gIFwiL1wiOiAxMyxcbiAgXCIlXCI6IDEzLFxuICBcIitcIjogMTIsXG4gIFwiLVwiOiAxMixcbiAgXCI+PlwiOiAxMSxcbiAgXCI8PFwiOiAxMSxcbiAgXCI+Pj5cIjogMTEsXG4gIFwiPFwiOiAxMCxcbiAgXCI8PVwiOiAxMCxcbiAgXCI+XCI6IDEwLFxuICBcIj49XCI6IDEwLFxuICBcImluXCI6IDEwLFxuICBcImluc3RhbmNlb2ZcIjogMTAsXG4gIFwiPT1cIjogOSxcbiAgXCIhPVwiOiA5LFxuICBcIj09PVwiOiA5LFxuICBcIiE9PVwiOiA5LFxuICBcIiZcIjogOCxcbiAgXCJeXCI6IDcsXG4gIFwifFwiOiA2LFxuICBcIiYmXCI6IDUsXG4gIFwifHxcIjogNCxcbn07XG5cbnZhciBvcGVyYXRvckFzc29jID0ge1xuICBcIipcIjogXCJsZWZ0XCIsXG4gIFwiL1wiOiBcImxlZnRcIixcbiAgXCIlXCI6IFwibGVmdFwiLFxuICBcIitcIjogXCJsZWZ0XCIsXG4gIFwiLVwiOiBcImxlZnRcIixcbiAgXCI+PlwiOiBcImxlZnRcIixcbiAgXCI8PFwiOiBcImxlZnRcIixcbiAgXCI+Pj5cIjogXCJsZWZ0XCIsXG4gIFwiPFwiOiBcImxlZnRcIixcbiAgXCI8PVwiOiBcImxlZnRcIixcbiAgXCI+XCI6IFwibGVmdFwiLFxuICBcIj49XCI6IFwibGVmdFwiLFxuICBcImluXCI6IFwibGVmdFwiLFxuICBcImluc3RhbmNlb2ZcIjogXCJsZWZ0XCIsXG4gIFwiPT1cIjogXCJsZWZ0XCIsXG4gIFwiIT1cIjogXCJsZWZ0XCIsXG4gIFwiPT09XCI6IFwibGVmdFwiLFxuICBcIiE9PVwiOiBcImxlZnRcIixcbiAgXCImXCI6IFwibGVmdFwiLFxuICBcIl5cIjogXCJsZWZ0XCIsXG4gIFwifFwiOiBcImxlZnRcIixcbiAgXCImJlwiOiBcImxlZnRcIixcbiAgXCJ8fFwiOiBcImxlZnRcIixcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBvcGVyYXRvckx0KGxlZnQsIHJpZ2h0LCBhc3NvYykge1xuICBpZiAoYXNzb2MgPT09IFwibGVmdFwiKSB7XG4gICAgcmV0dXJuIGxlZnQgPCByaWdodDtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gbGVmdCA8PSByaWdodDtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0T3BlcmF0b3JQcmVjKG9wKSB7XG4gIHJldHVybiBiaW5hcnlPcGVyYXRvclByZWNlZGVuY2Vbb3BdO1xufVxuZXhwb3J0IGZ1bmN0aW9uIGdldE9wZXJhdG9yQXNzb2Mob3ApIHtcbiAgcmV0dXJuIG9wZXJhdG9yQXNzb2Nbb3BdO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNVbmFyeU9wZXJhdG9yKG9wKSB7XG4gIHJldHVybiAob3AubWF0Y2goXCJwdW5jdHVhdG9yXCIpIHx8IG9wLm1hdGNoKFwiaWRlbnRpZmllclwiKSB8fCBvcC5tYXRjaChcImtleXdvcmRcIikpICYmXG4gICAgICAgIHVuYXJ5T3BlcmF0b3JzLmhhc093blByb3BlcnR5KG9wLnZhbCgpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzT3BlcmF0b3Iob3ApIHtcbiAgaWYgKG9wLm1hdGNoKFwicHVuY3R1YXRvclwiKSB8fCBvcC5tYXRjaChcImlkZW50aWZpZXJcIikgfHwgb3AubWF0Y2goXCJrZXl3b3JkXCIpKSB7XG4gICAgcmV0dXJuIGJpbmFyeU9wZXJhdG9yUHJlY2VkZW5jZS5oYXNPd25Qcm9wZXJ0eShvcCkgfHwgdW5hcnlPcGVyYXRvcnMuaGFzT3duUHJvcGVydHkob3AudmFsKCkpO1xuICB9XG4gIHJldHVybiBmYWxzZTtcbn1cbiJdfQ== - for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {} +/***/ }, +/* 58 */ +/***/ function(module, exports, __webpack_require__) { - e = (e << mLen) | m - eLen += mLen - for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {} + "use strict"; - buffer[offset + i - d] |= s * 128 - } + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.freshScope = freshScope; + exports.Scope = Scope; + var _symbol = __webpack_require__(47); -/***/ }, -/* 62 */ -/***/ function(module, exports) { + let scopeIndex = 0; - var toString = {}.toString; + function freshScope() { + let name = arguments.length <= 0 || arguments[0] === undefined ? "scope" : arguments[0]; - module.exports = Array.isArray || function (arr) { - return toString.call(arr) == '[object Array]'; - }; + scopeIndex++; + return (0, _symbol.Symbol)(name + "_" + scopeIndex); + } + function Scope(name) { + return (0, _symbol.Symbol)(name); + } + //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY29wZS5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztRQUlnQixVLEdBQUEsVTtRQUtBLEssR0FBQSxLOztBQVRoQjs7QUFFQSxJQUFJLGFBQWEsQ0FBakI7O0FBRU8sU0FBUyxVQUFULEdBQW9DO0FBQUEsTUFBaEIsSUFBZ0IseURBQVQsT0FBUzs7QUFDekM7QUFDQSxTQUFPLG9CQUFPLE9BQU8sR0FBUCxHQUFhLFVBQXBCLENBQVA7QUFDRDs7QUFFTSxTQUFTLEtBQVQsQ0FBZSxJQUFmLEVBQXFCO0FBQzFCLFNBQU8sb0JBQU8sSUFBUCxDQUFQO0FBQ0QiLCJmaWxlIjoic2NvcGUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTeW1ib2wgfSBmcm9tIFwiLi9zeW1ib2xcIjtcblxubGV0IHNjb3BlSW5kZXggPSAwO1xuXG5leHBvcnQgZnVuY3Rpb24gZnJlc2hTY29wZShuYW1lID0gXCJzY29wZVwiKSB7XG4gIHNjb3BlSW5kZXgrKztcbiAgcmV0dXJuIFN5bWJvbChuYW1lICsgXCJfXCIgKyBzY29wZUluZGV4KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIFNjb3BlKG5hbWUpIHtcbiAgcmV0dXJuIFN5bWJvbChuYW1lKTtcbn1cbiJdfQ== /***/ }, -/* 63 */ +/* 59 */ /***/ function(module, exports, __webpack_require__) { - "use strict"; + 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); - exports.replaceTemplate = exports.processTemplate = undefined; + exports.processTemplate = processTemplate; + exports.replaceTemplate = replaceTemplate; - var _immutable = __webpack_require__(11); + var _immutable = __webpack_require__(3); - var _ramdaFantasy = __webpack_require__(15); - - var _ramda = __webpack_require__(27); + var _ramda = __webpack_require__(10); var _ramda2 = _interopRequireDefault(_ramda); - var _syntax = __webpack_require__(12); + var _syntax = __webpack_require__(46); var _syntax2 = _interopRequireDefault(_syntax); - var _errors = __webpack_require__(13); + var _errors = __webpack_require__(23); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - const isDolar_964 = s_975 => s_975 && typeof s_975.match === "function" && s_975.match("identifier") && s_975.val() === "$"; - const isDelimiter_965 = s_976 => s_976 && typeof s_976.match === "function" && s_976.match("delimiter"); - const isBraces_966 = s_977 => s_977 && typeof s_977.match === "function" && s_977.match("braces"); - const isParens_967 = s_978 => s_978 && typeof s_978.match === "function" && s_978.match("parens"); - const isBrackets_968 = s_979 => s_979 && typeof s_979.match === "function" && s_979.match("brackets"); - const insertIntoDelimiter_969 = _ramda2.default.cond([[isBraces_966, (s_980, r_981) => _syntax2.default.from("braces", r_981, s_980)], [isParens_967, (s_982, r_983) => _syntax2.default.from("parens", r_983, s_982)], [isBrackets_968, (s_984, r_985) => _syntax2.default.from("brackets", r_985, s_984)]]); - const process_970 = (acc_986, s_987) => { - if (isBraces_966(s_987) && isDolar_964(acc_986.template.last())) { - return { template: acc_986.template.push(_syntax2.default.from("braces", _immutable.List.of(_syntax2.default.from("number", acc_986.interp.size)), s_987)), interp: acc_986.interp.push(s_987.inner()) }; - } else if (isDelimiter_965(s_987)) { - let innerResult = processTemplate_973(s_987.inner(), acc_986.interp); - return { template: acc_986.template.push(insertIntoDelimiter_969(s_987, innerResult.template)), interp: innerResult.interp }; + /* + Given a syntax list like: + + [foo, bar, $, { 42, +, 24 }, baz] + + convert it to: + + [foo, bar, $, { 0 }, baz] + + and return another list with the interpolated values at the corresponding + positions. + + Requires either lookahead/lookbehind of one (to see the $). + */ + + const isDolar = s => s && typeof s.match === 'function' && s.match("identifier") && s.val() === '$'; + const isDelimiter = s => s && typeof s.match === 'function' && s.match("delimiter"); + const isBraces = s => s && typeof s.match === 'function' && s.match("braces"); + const isParens = s => s && typeof s.match === 'function' && s.match("parens"); + const isBrackets = s => s && typeof s.match === 'function' && s.match("brackets"); + + const insertIntoDelimiter = _ramda2.default.cond([[isBraces, (s, r) => _syntax2.default.from("braces", r, s)], [isParens, (s, r) => _syntax2.default.from("parens", r, s)], [isBrackets, (s, r) => _syntax2.default.from("brackets", r, s)]]); + + const process = (acc, s) => { + if (isBraces(s) && isDolar(acc.template.last())) { + return { + template: acc.template.push(_syntax2.default.from("braces", _immutable.List.of(_syntax2.default.from("number", acc.interp.size)), s)), + interp: acc.interp.push(s.inner()) + }; + } else if (isDelimiter(s)) { + let innerResult = processTemplate(s.inner(), acc.interp); + return { + template: acc.template.push(insertIntoDelimiter(s, innerResult.template)), + interp: innerResult.interp + }; } else { - return { template: acc_986.template.push(s_987), interp: acc_986.interp }; + return { + template: acc.template.push(s), + interp: acc.interp + }; } }; - function cloneLineNumber_971(to_988, from_989) { - if (from_989 && to_988) { - if (typeof to_988.setLineNumber === "function") { - return to_988.setLineNumber(from_989.lineNumber()); - } else if (_immutable.List.isList(to_988)) { - return to_988.map(x_990 => cloneLineNumber_971(x_990, from_989)); + + function cloneLineNumber(to, from) { + if (from && to) { + if (typeof to.setLineNumber === 'function') { + return to.setLineNumber(from.lineNumber()); + } else if (_immutable.List.isList(to)) { + return to.map(x => cloneLineNumber(x, from)); } } - return to_988; + return to; } - const replace_972 = (acc_991, s_992) => { - let last_993 = acc_991.template.get(-1); - let beforeLast_994 = acc_991.template.get(-2); - if (isBraces_966(s_992) && isDolar_964(last_993)) { - let index = s_992.inner().first().val(); - (0, _errors.assert)(acc_991.rep.size > index, "unknown replacement value"); - let replacement = cloneLineNumber_971(acc_991.rep.get(index), beforeLast_994); - return { template: acc_991.template.pop().concat(replacement), rep: acc_991.rep }; - } else if (isDelimiter_965(s_992)) { - let innerResult = replaceTemplate_974(s_992.inner(), acc_991.rep); - return { template: acc_991.template.push(insertIntoDelimiter_969(s_992, innerResult)), rep: acc_991.rep }; + + const replace = (acc, s) => { + let last = acc.template.get(-1); + let beforeLast = acc.template.get(-2); + if (isBraces(s) && isDolar(last)) { + let index = s.inner().first().val(); + (0, _errors.assert)(acc.rep.size > index, "unknown replacement value"); + let replacement = cloneLineNumber(acc.rep.get(index), beforeLast); + return { + template: acc.template.pop().concat(replacement), + rep: acc.rep + }; + } else if (isDelimiter(s)) { + let innerResult = replaceTemplate(s.inner(), acc.rep); + return { + template: acc.template.push(insertIntoDelimiter(s, innerResult)), + rep: acc.rep + }; } else { - return { template: acc_991.template.push(s_992), rep: acc_991.rep }; + return { + template: acc.template.push(s), + rep: acc.rep + }; } }; - function processTemplate_973(temp_995) { - let interp_996 = arguments.length <= 1 || arguments[1] === undefined ? (0, _immutable.List)() : arguments[1]; - return temp_995.reduce(process_970, { template: (0, _immutable.List)(), interp: interp_996 }); + function processTemplate(temp) { + let interp = arguments.length <= 1 || arguments[1] === undefined ? (0, _immutable.List)() : arguments[1]; + + return temp.reduce(process, { template: (0, _immutable.List)(), interp: interp }); } - function replaceTemplate_974(temp_997, rep_998) { - return temp_997.reduce(replace_972, { template: (0, _immutable.List)(), rep: rep_998 }).template; + + function replaceTemplate(temp, rep) { + return temp.reduce(replace, { template: (0, _immutable.List)(), rep: rep }).template; } - exports.processTemplate = processTemplate_973; - exports.replaceTemplate = replaceTemplate_974; - //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/template-processor.js"],"names":[],"mappings":"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","file":"template-processor.js","sourcesContent":["import {List} from \"immutable\";\nimport {Maybe} from \"ramda-fantasy\";\nimport _ from \"ramda\";\nimport Syntax from \"./syntax\";\nimport {assert} from \"./errors\";\nconst isDolar_964 = s_975 => s_975 && typeof s_975.match === \"function\" && s_975.match(\"identifier\") && s_975.val() === \"$\";\nconst isDelimiter_965 = s_976 => s_976 && typeof s_976.match === \"function\" && s_976.match(\"delimiter\");\nconst isBraces_966 = s_977 => s_977 && typeof s_977.match === \"function\" && s_977.match(\"braces\");\nconst isParens_967 = s_978 => s_978 && typeof s_978.match === \"function\" && s_978.match(\"parens\");\nconst isBrackets_968 = s_979 => s_979 && typeof s_979.match === \"function\" && s_979.match(\"brackets\");\nconst insertIntoDelimiter_969 = _.cond([[isBraces_966, (s_980, r_981) => Syntax.from(\"braces\", r_981, s_980)], [isParens_967, (s_982, r_983) => Syntax.from(\"parens\", r_983, s_982)], [isBrackets_968, (s_984, r_985) => Syntax.from(\"brackets\", r_985, s_984)]]);\nconst process_970 = (acc_986, s_987) => {\n  if (isBraces_966(s_987) && isDolar_964(acc_986.template.last())) {\n    return {template: acc_986.template.push(Syntax.from(\"braces\", List.of(Syntax.from(\"number\", acc_986.interp.size)), s_987)), interp: acc_986.interp.push(s_987.inner())};\n  } else if (isDelimiter_965(s_987)) {\n    let innerResult = processTemplate_973(s_987.inner(), acc_986.interp);\n    return {template: acc_986.template.push(insertIntoDelimiter_969(s_987, innerResult.template)), interp: innerResult.interp};\n  } else {\n    return {template: acc_986.template.push(s_987), interp: acc_986.interp};\n  }\n};\nfunction cloneLineNumber_971(to_988, from_989) {\n  if (from_989 && to_988) {\n    if (typeof to_988.setLineNumber === \"function\") {\n      return to_988.setLineNumber(from_989.lineNumber());\n    } else if (List.isList(to_988)) {\n      return to_988.map(x_990 => cloneLineNumber_971(x_990, from_989));\n    }\n  }\n  return to_988;\n}\nconst replace_972 = (acc_991, s_992) => {\n  let last_993 = acc_991.template.get(-1);\n  let beforeLast_994 = acc_991.template.get(-2);\n  if (isBraces_966(s_992) && isDolar_964(last_993)) {\n    let index = s_992.inner().first().val();\n    assert(acc_991.rep.size > index, \"unknown replacement value\");\n    let replacement = cloneLineNumber_971(acc_991.rep.get(index), beforeLast_994);\n    return {template: acc_991.template.pop().concat(replacement), rep: acc_991.rep};\n  } else if (isDelimiter_965(s_992)) {\n    let innerResult = replaceTemplate_974(s_992.inner(), acc_991.rep);\n    return {template: acc_991.template.push(insertIntoDelimiter_969(s_992, innerResult)), rep: acc_991.rep};\n  } else {\n    return {template: acc_991.template.push(s_992), rep: acc_991.rep};\n  }\n};\nfunction processTemplate_973(temp_995, interp_996 = List()) {\n  return temp_995.reduce(process_970, {template: List(), interp: interp_996});\n}\nfunction replaceTemplate_974(temp_997, rep_998) {\n  return temp_997.reduce(replace_972, {template: List(), rep: rep_998}).template;\n}\nexport {processTemplate_973 as processTemplate};\nexport {replaceTemplate_974 as replaceTemplate}"]} + //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/template-processor.js"],"names":[],"mappings":";;;;;QAwFgB,e,GAAA,e;QAIA,e,GAAA,e;;AA5FhB;;AACA;;;;AACA;;;;AACA;;;;AAEA;;;;;;;;;;;;;;;AAeA,MAAM,UAAc,KAAK,KAAK,OAAO,EAAE,KAAT,KAAmB,UAAxB,IAAsC,EAAE,KAAF,CAAQ,YAAR,CAAtC,IAA+D,EAAE,GAAF,OAAY,GAApG;AACA,MAAM,cAAc,KAAK,KAAK,OAAO,EAAE,KAAT,KAAmB,UAAxB,IAAsC,EAAE,KAAF,CAAQ,WAAR,CAA/D;AACA,MAAM,WAAc,KAAK,KAAK,OAAO,EAAE,KAAT,KAAmB,UAAxB,IAAsC,EAAE,KAAF,CAAQ,QAAR,CAA/D;AACA,MAAM,WAAc,KAAK,KAAK,OAAO,EAAE,KAAT,KAAmB,UAAxB,IAAsC,EAAE,KAAF,CAAQ,QAAR,CAA/D;AACA,MAAM,aAAc,KAAK,KAAK,OAAO,EAAE,KAAT,KAAmB,UAAxB,IAAsC,EAAE,KAAF,CAAQ,UAAR,CAA/D;;AAEA,MAAM,sBAAsB,gBAAE,IAAF,CAAO,CACjC,CAAC,QAAD,EAAW,CAAC,CAAD,EAAI,CAAJ,KAAU,iBAAO,IAAP,CAAY,QAAZ,EAAsB,CAAtB,EAAyB,CAAzB,CAArB,CADiC,EAEjC,CAAC,QAAD,EAAW,CAAC,CAAD,EAAI,CAAJ,KAAU,iBAAO,IAAP,CAAY,QAAZ,EAAsB,CAAtB,EAAyB,CAAzB,CAArB,CAFiC,EAGjC,CAAC,UAAD,EAAa,CAAC,CAAD,EAAI,CAAJ,KAAU,iBAAO,IAAP,CAAY,UAAZ,EAAwB,CAAxB,EAA2B,CAA3B,CAAvB,CAHiC,CAAP,CAA5B;;AAMA,MAAM,UAAU,CAAC,GAAD,EAAM,CAAN,KAAY;AAC1B,MAAI,SAAS,CAAT,KAAe,QAAQ,IAAI,QAAJ,CAAa,IAAb,EAAR,CAAnB,EAAiD;AAC/C,WAAO;AACL,gBAAU,IAAI,QAAJ,CAAa,IAAb,CAAkB,iBAAO,IAAP,CAAY,QAAZ,EAAsB,gBAAK,EAAL,CAAQ,iBAAO,IAAP,CAAY,QAAZ,EAAsB,IAAI,MAAJ,CAAW,IAAjC,CAAR,CAAtB,EAAuE,CAAvE,CAAlB,CADL;AAEL,cAAQ,IAAI,MAAJ,CAAW,IAAX,CAAgB,EAAE,KAAF,EAAhB;AAFH,KAAP;AAID,GALD,MAKO,IAAI,YAAY,CAAZ,CAAJ,EAAoB;AACzB,QAAI,cAAc,gBAAgB,EAAE,KAAF,EAAhB,EAA2B,IAAI,MAA/B,CAAlB;AACA,WAAO;AACL,gBAAU,IAAI,QAAJ,CAAa,IAAb,CAAkB,oBAAoB,CAApB,EAAuB,YAAY,QAAnC,CAAlB,CADL;AAEL,cAAQ,YAAY;AAFf,KAAP;AAID,GANM,MAMA;AACL,WAAO;AACL,gBAAU,IAAI,QAAJ,CAAa,IAAb,CAAkB,CAAlB,CADL;AAEL,cAAQ,IAAI;AAFP,KAAP;AAID;AACF,CAlBD;;AAoBA,SAAS,eAAT,CAAyB,EAAzB,EAA6B,IAA7B,EAAmC;AACjC,MAAI,QAAQ,EAAZ,EAAiB;AACf,QAAI,OAAO,GAAG,aAAV,KAA4B,UAAhC,EAA4C;AAC1C,aAAO,GAAG,aAAH,CAAiB,KAAK,UAAL,EAAjB,CAAP;AACD,KAFD,MAEO,IAAI,gBAAK,MAAL,CAAY,EAAZ,CAAJ,EAAqB;AAC1B,aAAO,GAAG,GAAH,CAAO,KAAK,gBAAgB,CAAhB,EAAmB,IAAnB,CAAZ,CAAP;AACD;AACF;AACD,SAAO,EAAP;AACD;;AAED,MAAM,UAAU,CAAC,GAAD,EAAM,CAAN,KAAY;AAC1B,MAAI,OAAO,IAAI,QAAJ,CAAa,GAAb,CAAiB,CAAC,CAAlB,CAAX;AACA,MAAI,aAAa,IAAI,QAAJ,CAAa,GAAb,CAAiB,CAAC,CAAlB,CAAjB;AACA,MAAI,SAAS,CAAT,KAAe,QAAQ,IAAR,CAAnB,EAAkC;AAChC,QAAI,QAAQ,EAAE,KAAF,GAAU,KAAV,GAAkB,GAAlB,EAAZ;AACA,wBAAO,IAAI,GAAJ,CAAQ,IAAR,GAAe,KAAtB,EAA6B,2BAA7B;AACA,QAAI,cAAc,gBAAgB,IAAI,GAAJ,CAAQ,GAAR,CAAY,KAAZ,CAAhB,EAAoC,UAApC,CAAlB;AACA,WAAO;AACL,gBAAU,IAAI,QAAJ,CAAa,GAAb,GAAmB,MAAnB,CAA0B,WAA1B,CADL;AAEL,WAAK,IAAI;AAFJ,KAAP;AAID,GARD,MAQO,IAAI,YAAY,CAAZ,CAAJ,EAAoB;AACzB,QAAI,cAAc,gBAAgB,EAAE,KAAF,EAAhB,EAA2B,IAAI,GAA/B,CAAlB;AACA,WAAO;AACL,gBAAU,IAAI,QAAJ,CAAa,IAAb,CAAkB,oBAAoB,CAApB,EAAuB,WAAvB,CAAlB,CADL;AAEL,WAAK,IAAI;AAFJ,KAAP;AAID,GANM,MAMA;AACL,WAAO;AACL,gBAAU,IAAI,QAAJ,CAAa,IAAb,CAAkB,CAAlB,CADL;AAEL,WAAK,IAAI;AAFJ,KAAP;AAID;AACF,CAvBD;;AAyBO,SAAS,eAAT,CAAyB,IAAzB,EAAgD;AAAA,MAAjB,MAAiB,yDAAR,sBAAQ;;AACrD,SAAO,KAAK,MAAL,CAAY,OAAZ,EAAqB,EAAE,UAAU,sBAAZ,EAAoB,cAApB,EAArB,CAAP;AACD;;AAEM,SAAS,eAAT,CAAyB,IAAzB,EAA+B,GAA/B,EAAoC;AACzC,SAAO,KAAK,MAAL,CAAY,OAAZ,EAAqB,EAAE,UAAU,sBAAZ,EAAoB,QAApB,EAArB,EAAgD,QAAvD;AACD","file":"template-processor.js","sourcesContent":["import { List } from 'immutable';\nimport _ from 'ramda';\nimport Syntax from './syntax';\nimport { assert } from './errors';\n\n/*\nGiven a syntax list like:\n\n  [foo, bar, $, { 42, +, 24 }, baz]\n\nconvert it to:\n\n  [foo, bar, $, { 0 }, baz]\n\nand return another list with the interpolated values at the corresponding\npositions.\n\nRequires either lookahead/lookbehind of one (to see the $).\n*/\n\nconst isDolar     = s => s && typeof s.match === 'function' && s.match(\"identifier\") && s.val() === '$';\nconst isDelimiter = s => s && typeof s.match === 'function' && s.match(\"delimiter\");\nconst isBraces    = s => s && typeof s.match === 'function' && s.match(\"braces\");\nconst isParens    = s => s && typeof s.match === 'function' && s.match(\"parens\");\nconst isBrackets  = s => s && typeof s.match === 'function' && s.match(\"brackets\");\n\nconst insertIntoDelimiter = _.cond([\n  [isBraces, (s, r) => Syntax.from(\"braces\", r, s)],\n  [isParens, (s, r) => Syntax.from(\"parens\", r, s)],\n  [isBrackets, (s, r) => Syntax.from(\"brackets\", r, s)]\n]);\n\nconst process = (acc, s) => {\n  if (isBraces(s) && isDolar(acc.template.last())) {\n    return {\n      template: acc.template.push(Syntax.from(\"braces\", List.of(Syntax.from(\"number\", acc.interp.size)), s)),\n      interp: acc.interp.push(s.inner())\n    };\n  } else if (isDelimiter(s)) {\n    let innerResult = processTemplate(s.inner(), acc.interp);\n    return {\n      template: acc.template.push(insertIntoDelimiter(s, innerResult.template)),\n      interp: innerResult.interp\n    };\n  } else {\n    return {\n      template: acc.template.push(s),\n      interp: acc.interp\n    };\n  }\n};\n\nfunction cloneLineNumber(to, from) {\n  if (from && to ) {\n    if (typeof to.setLineNumber === 'function') {\n      return to.setLineNumber(from.lineNumber());\n    } else if (List.isList(to)) {\n      return to.map(x => cloneLineNumber(x, from));\n    }\n  }\n  return to;\n}\n\nconst replace = (acc, s) => {\n  let last = acc.template.get(-1);\n  let beforeLast = acc.template.get(-2);\n  if (isBraces(s) && isDolar(last)) {\n    let index = s.inner().first().val();\n    assert(acc.rep.size > index, \"unknown replacement value\");\n    let replacement = cloneLineNumber(acc.rep.get(index), beforeLast);\n    return {\n      template: acc.template.pop().concat(replacement),\n      rep: acc.rep\n    };\n  } else if (isDelimiter(s)) {\n    let innerResult = replaceTemplate(s.inner(), acc.rep);\n    return {\n      template: acc.template.push(insertIntoDelimiter(s, innerResult)),\n      rep: acc.rep\n    };\n  } else {\n    return {\n      template: acc.template.push(s),\n      rep: acc.rep\n    };\n  }\n};\n\nexport function processTemplate(temp, interp = List()) {\n  return temp.reduce(process, { template: List(), interp });\n}\n\nexport function replaceTemplate(temp, rep) {\n  return temp.reduce(replace, { template: List(), rep }).template;\n}\n"]} /***/ }, -/* 64 */ -/***/ function(module, exports) { +/* 60 */ +/***/ function(module, exports, __webpack_require__) { - "use strict"; + 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); - class ASTDispatcher { - constructor(prefix_16, errorIfMissing_17) { - this.errorIfMissing = errorIfMissing_17; - this.prefix = prefix_16; - } - dispatch(term_18) { - let field_19 = this.prefix + term_18.type; - if (typeof this[field_19] === "function") { - return this[field_19](term_18); - } else if (!this.errorIfMissing) { - return term_18; - } - throw new Error(`Missing implementation for: ${ field_19 }`); + + var _termExpander = __webpack_require__(61); + + var _termExpander2 = _interopRequireDefault(_termExpander); + + var _tokenExpander = __webpack_require__(64); + + var _tokenExpander2 = _interopRequireDefault(_tokenExpander); + + var _ramda = __webpack_require__(10); + + var _ = _interopRequireWildcard(_ramda); + + function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + + class Compiler { + constructor(phase, env, store, context) { + this.phase = phase; + this.env = env; + this.store = store; + this.context = context; + } + + compile(stxl) { + let tokenExpander = new _tokenExpander2.default(_.merge(this.context, { + phase: this.phase, + env: this.env, + store: this.store + })); + let termExpander = new _termExpander2.default(_.merge(this.context, { + phase: this.phase, + env: this.env, + store: this.store + })); + + return _.pipe(_.bind(tokenExpander.expand, tokenExpander), _.map(t => termExpander.expand(t)))(stxl); } } - exports.default = ASTDispatcher; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2FzdC1kaXNwYXRjaGVyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQWUsTUFBTSxhQUFOLENBQW9CO0FBQ2pDLGNBQVksU0FBWixFQUF1QixpQkFBdkIsRUFBMEM7QUFDeEMsU0FBSyxjQUFMLEdBQXNCLGlCQUF0QjtBQUNBLFNBQUssTUFBTCxHQUFjLFNBQWQ7QUFDRDtBQUNELFdBQVMsT0FBVCxFQUFrQjtBQUNoQixRQUFJLFdBQVcsS0FBSyxNQUFMLEdBQWMsUUFBUSxJQUFyQztBQUNBLFFBQUksT0FBTyxLQUFLLFFBQUwsQ0FBUCxLQUEwQixVQUE5QixFQUEwQztBQUN4QyxhQUFPLEtBQUssUUFBTCxFQUFlLE9BQWYsQ0FBUDtBQUNELEtBRkQsTUFFTyxJQUFJLENBQUMsS0FBSyxjQUFWLEVBQTBCO0FBQy9CLGFBQU8sT0FBUDtBQUNEO0FBQ0QsVUFBTSxJQUFJLEtBQUosQ0FBVyxnQ0FBOEIsUUFBUyxHQUFsRCxDQUFOO0FBQ0Q7QUFiZ0M7a0JBQWQsYSIsImZpbGUiOiJhc3QtZGlzcGF0Y2hlci5qcyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWZhdWx0IGNsYXNzIEFTVERpc3BhdGNoZXIge1xuICBjb25zdHJ1Y3RvcihwcmVmaXhfMTYsIGVycm9ySWZNaXNzaW5nXzE3KSB7XG4gICAgdGhpcy5lcnJvcklmTWlzc2luZyA9IGVycm9ySWZNaXNzaW5nXzE3O1xuICAgIHRoaXMucHJlZml4ID0gcHJlZml4XzE2O1xuICB9XG4gIGRpc3BhdGNoKHRlcm1fMTgpIHtcbiAgICBsZXQgZmllbGRfMTkgPSB0aGlzLnByZWZpeCArIHRlcm1fMTgudHlwZTtcbiAgICBpZiAodHlwZW9mIHRoaXNbZmllbGRfMTldID09PSBcImZ1bmN0aW9uXCIpIHtcbiAgICAgIHJldHVybiB0aGlzW2ZpZWxkXzE5XSh0ZXJtXzE4KTtcbiAgICB9IGVsc2UgaWYgKCF0aGlzLmVycm9ySWZNaXNzaW5nKSB7XG4gICAgICByZXR1cm4gdGVybV8xODtcbiAgICB9XG4gICAgdGhyb3cgbmV3IEVycm9yKGBNaXNzaW5nIGltcGxlbWVudGF0aW9uIGZvcjogJHtmaWVsZF8xOX1gKTtcbiAgfVxufVxuIl19 + exports.default = Compiler; + //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21waWxlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7OztBQUNBOzs7O0FBQ0E7O0lBQVksQzs7Ozs7O0FBR0csTUFBTSxRQUFOLENBQWU7QUFDNUIsY0FBWSxLQUFaLEVBQW1CLEdBQW5CLEVBQXdCLEtBQXhCLEVBQStCLE9BQS9CLEVBQXdDO0FBQ3RDLFNBQUssS0FBTCxHQUFhLEtBQWI7QUFDQSxTQUFLLEdBQUwsR0FBVyxHQUFYO0FBQ0EsU0FBSyxLQUFMLEdBQWEsS0FBYjtBQUNBLFNBQUssT0FBTCxHQUFlLE9BQWY7QUFDRDs7QUFFRCxVQUFRLElBQVIsRUFBYztBQUNaLFFBQUksZ0JBQWdCLDRCQUFrQixFQUFFLEtBQUYsQ0FBUSxLQUFLLE9BQWIsRUFBc0I7QUFDMUQsYUFBTyxLQUFLLEtBRDhDO0FBRTFELFdBQUssS0FBSyxHQUZnRDtBQUcxRCxhQUFPLEtBQUs7QUFIOEMsS0FBdEIsQ0FBbEIsQ0FBcEI7QUFLQSxRQUFJLGVBQWUsMkJBQWlCLEVBQUUsS0FBRixDQUFRLEtBQUssT0FBYixFQUFzQjtBQUN4RCxhQUFPLEtBQUssS0FENEM7QUFFeEQsV0FBSyxLQUFLLEdBRjhDO0FBR3hELGFBQU8sS0FBSztBQUg0QyxLQUF0QixDQUFqQixDQUFuQjs7QUFNQSxXQUFPLEVBQUUsSUFBRixDQUNMLEVBQUUsSUFBRixDQUFPLGNBQWMsTUFBckIsRUFBNkIsYUFBN0IsQ0FESyxFQUVMLEVBQUUsR0FBRixDQUFNLEtBQUssYUFBYSxNQUFiLENBQW9CLENBQXBCLENBQVgsQ0FGSyxFQUdMLElBSEssQ0FBUDtBQUlEO0FBeEIyQjtrQkFBVCxRIiwiZmlsZSI6ImNvbXBpbGVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFRlcm1FeHBhbmRlciBmcm9tIFwiLi90ZXJtLWV4cGFuZGVyLmpzXCI7XG5pbXBvcnQgVG9rZW5FeHBhbmRlciBmcm9tICcuL3Rva2VuLWV4cGFuZGVyJztcbmltcG9ydCAqIGFzIF8gZnJvbSAncmFtZGEnO1xuXG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENvbXBpbGVyIHtcbiAgY29uc3RydWN0b3IocGhhc2UsIGVudiwgc3RvcmUsIGNvbnRleHQpIHtcbiAgICB0aGlzLnBoYXNlID0gcGhhc2U7XG4gICAgdGhpcy5lbnYgPSBlbnY7XG4gICAgdGhpcy5zdG9yZSA9IHN0b3JlO1xuICAgIHRoaXMuY29udGV4dCA9IGNvbnRleHQ7XG4gIH1cblxuICBjb21waWxlKHN0eGwpIHtcbiAgICBsZXQgdG9rZW5FeHBhbmRlciA9IG5ldyBUb2tlbkV4cGFuZGVyKF8ubWVyZ2UodGhpcy5jb250ZXh0LCB7XG4gICAgICBwaGFzZTogdGhpcy5waGFzZSxcbiAgICAgIGVudjogdGhpcy5lbnYsXG4gICAgICBzdG9yZTogdGhpcy5zdG9yZVxuICAgIH0pKTtcbiAgICBsZXQgdGVybUV4cGFuZGVyID0gbmV3IFRlcm1FeHBhbmRlcihfLm1lcmdlKHRoaXMuY29udGV4dCwge1xuICAgICAgcGhhc2U6IHRoaXMucGhhc2UsXG4gICAgICBlbnY6IHRoaXMuZW52LFxuICAgICAgc3RvcmU6IHRoaXMuc3RvcmVcbiAgICB9KSk7XG5cbiAgICByZXR1cm4gXy5waXBlKFxuICAgICAgXy5iaW5kKHRva2VuRXhwYW5kZXIuZXhwYW5kLCB0b2tlbkV4cGFuZGVyKSxcbiAgICAgIF8ubWFwKHQgPT4gdGVybUV4cGFuZGVyLmV4cGFuZCh0KSlcbiAgICApKHN0eGwpO1xuICB9XG59XG4iXX0= /***/ }, -/* 65 */ +/* 61 */ /***/ function(module, exports, __webpack_require__) { "use strict"; @@ -38198,350 +39423,666 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack Object.defineProperty(exports, "__esModule", { value: true }); - exports.unwrap = exports.SyntaxOrTermWrapper = undefined; - var _mapSyntaxReducer = __webpack_require__(66); + var _immutable = __webpack_require__(3); - var _mapSyntaxReducer2 = _interopRequireDefault(_mapSyntaxReducer); + var _terms = __webpack_require__(9); - var _shiftReducer = __webpack_require__(33); + var _terms2 = _interopRequireDefault(_terms); - var _shiftReducer2 = _interopRequireDefault(_shiftReducer); + var _scope = __webpack_require__(58); - var _errors = __webpack_require__(13); + var _applyScopeInParamsReducer = __webpack_require__(62); + + var _applyScopeInParamsReducer2 = _interopRequireDefault(_applyScopeInParamsReducer); - var _immutable = __webpack_require__(11); + var _compiler = __webpack_require__(60); - var _enforester = __webpack_require__(51); + var _compiler2 = _interopRequireDefault(_compiler); - var _syntax = __webpack_require__(12); + var _syntax = __webpack_require__(46); var _syntax2 = _interopRequireDefault(_syntax); - var _ramdaFantasy = __webpack_require__(15); + var _serializer = __webpack_require__(49); - var _ramda = __webpack_require__(27); + var _enforester = __webpack_require__(56); - var _ = _interopRequireWildcard(_ramda); + var _templateProcessor = __webpack_require__(59); - function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + var _astDispatcher = __webpack_require__(63); + + var _astDispatcher2 = _interopRequireDefault(_astDispatcher); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - const Just_396 = _ramdaFantasy.Maybe.Just; - const Nothing_397 = _ramdaFantasy.Maybe.Nothing; - const symWrap_398 = Symbol("wrapper"); - const privateData_399 = new WeakMap(); - const getVal_400 = t_405 => { - if (t_405.match("delimiter")) { - return null; + class TermExpander extends _astDispatcher2.default { + constructor(context) { + super('expand', true); + this.context = context; } - if (typeof t_405.val === "function") { - return t_405.val(); + + expand(term) { + return this.dispatch(term); } - return null; - }; - class SyntaxOrTermWrapper_401 { - constructor(s_406) { - let context_407 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - this[symWrap_398] = s_406; - this.context = context_407; + expandPragma(term) { + return term; } - from(type_408, value_409) { - let stx_410 = this[symWrap_398]; - if (typeof stx_410.from === "function") { - return stx_410.from(type_408, value_409); - } + + expandTemplateExpression(term) { + return new _terms2.default('TemplateExpression', { + tag: term.tag == null ? null : this.expand(term.tag), + elements: term.elements.toArray() + }); } - fromNull() { - return this.from("null", null); + + expandBreakStatement(term) { + return new _terms2.default('BreakStatement', { + label: term.label ? term.label.val() : null + }); } - fromNumber(value_411) { - return this.from("number", value_411); + + expandDoWhileStatement(term) { + return new _terms2.default('DoWhileStatement', { + body: this.expand(term.body), + test: this.expand(term.test) + }); } - fromString(value_412) { - return this.from("string", value_412); + + expandWithStatement(term) { + return new _terms2.default('WithStatement', { + body: this.expand(term.body), + object: this.expand(term.object) + }); } - fromPunctuator(value_413) { - return this.from("punctuator", value_413); + + expandDebuggerStatement(term) { + return term; } - fromKeyword(value_414) { - return this.from("keyword"); + + expandContinueStatement(term) { + return new _terms2.default('ContinueStatement', { + label: term.label ? term.label.val() : null + }); } - fromIdentifier(value_415) { - return this.from("identifier", value_415); + + expandSwitchStatementWithDefault(term) { + return new _terms2.default('SwitchStatementWithDefault', { + discriminant: this.expand(term.discriminant), + preDefaultCases: term.preDefaultCases.map(c => this.expand(c)).toArray(), + defaultCase: this.expand(term.defaultCase), + postDefaultCases: term.postDefaultCases.map(c => this.expand(c)).toArray() + }); } - fromRegularExpression(value_416) { - return this.from("regularExpression", value_416); + + expandComputedMemberExpression(term) { + return new _terms2.default('ComputedMemberExpression', { + object: this.expand(term.object), + expression: this.expand(term.expression) + }); } - fromBraces(inner_417) { - return this.from("braces", inner_417); + + expandSwitchStatement(term) { + return new _terms2.default('SwitchStatement', { + discriminant: this.expand(term.discriminant), + cases: term.cases.map(c => this.expand(c)).toArray() + }); } - fromBrackets(inner_418) { - return this.from("brackets", inner_418); + + expandFormalParameters(term) { + let rest = term.rest == null ? null : this.expand(term.rest); + return new _terms2.default('FormalParameters', { + items: term.items.map(i => this.expand(i)), + rest: rest + }); } - fromParens(inner_419) { - return this.from("parens", inner_419); + + expandArrowExpression(term) { + return this.doFunctionExpansion(term, 'ArrowExpression'); } - match(type_420, value_421) { - let stx_422 = this[symWrap_398]; - if (typeof stx_422.match === "function") { - return stx_422.match(type_420, value_421); - } + + expandSwitchDefault(term) { + return new _terms2.default('SwitchDefault', { + consequent: term.consequent.map(c => this.expand(c)).toArray() + }); } - isIdentifier(value_423) { - return this.match("identifier", value_423); + + expandSwitchCase(term) { + return new _terms2.default('SwitchCase', { + test: this.expand(term.test), + consequent: term.consequent.map(c => this.expand(c)).toArray() + }); } - isAssign(value_424) { - return this.match("assign", value_424); + + expandForInStatement(term) { + return new _terms2.default('ForInStatement', { + left: this.expand(term.left), + right: this.expand(term.right), + body: this.expand(term.body) + }); } - isBooleanLiteral(value_425) { - return this.match("boolean", value_425); + + expandTryCatchStatement(term) { + return new _terms2.default('TryCatchStatement', { + body: this.expand(term.body), + catchClause: this.expand(term.catchClause) + }); } - isKeyword(value_426) { - return this.match("keyword", value_426); + + expandTryFinallyStatement(term) { + let catchClause = term.catchClause == null ? null : this.expand(term.catchClause); + return new _terms2.default('TryFinallyStatement', { + body: this.expand(term.body), + catchClause: catchClause, + finalizer: this.expand(term.finalizer) + }); } - isNullLiteral(value_427) { - return this.match("null", value_427); + + expandCatchClause(term) { + return new _terms2.default('CatchClause', { + binding: this.expand(term.binding), + body: this.expand(term.body) + }); } - isNumericLiteral(value_428) { - return this.match("number", value_428); + + expandThrowStatement(term) { + return new _terms2.default('ThrowStatement', { + expression: this.expand(term.expression) + }); } - isPunctuator(value_429) { - return this.match("punctuator", value_429); + + expandForOfStatement(term) { + return new _terms2.default('ForOfStatement', { + left: this.expand(term.left), + right: this.expand(term.right), + body: this.expand(term.body) + }); } - isStringLiteral(value_430) { - return this.match("string", value_430); + + expandBindingIdentifier(term) { + return term; } - isRegularExpression(value_431) { - return this.match("regularExpression", value_431); + + expandBindingPropertyIdentifier(term) { + return term; } - isTemplate(value_432) { - return this.match("template", value_432); + expandBindingPropertyProperty(term) { + return new _terms2.default('BindingPropertyProperty', { + name: this.expand(term.name), + binding: this.expand(term.binding) + }); } - isDelimiter(value_433) { - return this.match("delimiter", value_433); + + expandComputedPropertyName(term) { + return new _terms2.default('ComputedPropertyName', { + expression: this.expand(term.expression) + }); } - isParens(value_434) { - return this.match("parens", value_434); + + expandObjectBinding(term) { + return new _terms2.default('ObjectBinding', { + properties: term.properties.map(t => this.expand(t)).toArray() + }); } - isBraces(value_435) { - return this.match("braces", value_435); + + expandArrayBinding(term) { + let restElement = term.restElement == null ? null : this.expand(term.restElement); + return new _terms2.default('ArrayBinding', { + elements: term.elements.map(t => t == null ? null : this.expand(t)).toArray(), + restElement: restElement + }); } - isBrackets(value_436) { - return this.match("brackets", value_436); + + expandBindingWithDefault(term) { + return new _terms2.default('BindingWithDefault', { + binding: this.expand(term.binding), + init: this.expand(term.init) + }); } - isSyntaxTemplate(value_437) { - return this.match("syntaxTemplate", value_437); + + expandShorthandProperty(term) { + // because hygiene, shorthand properties must turn into DataProperties + return new _terms2.default('DataProperty', { + name: new _terms2.default('StaticPropertyName', { + value: term.name + }), + expression: new _terms2.default('IdentifierExpression', { + name: term.name + }) + }); } - isEOF(value_438) { - return this.match("eof", value_438); + + expandForStatement(term) { + let init = term.init == null ? null : this.expand(term.init); + let test = term.test == null ? null : this.expand(term.test); + let update = term.update == null ? null : this.expand(term.update); + let body = this.expand(term.body); + return new _terms2.default('ForStatement', { init: init, test: test, update: update, body: body }); } - lineNumber() { - return this[symWrap_398].lineNumber(); + + expandYieldExpression(term) { + let expr = term.expression == null ? null : this.expand(term.expression); + return new _terms2.default('YieldExpression', { + expression: expr + }); } - val() { - return getVal_400(this[symWrap_398]); + + expandYieldGeneratorExpression(term) { + let expr = term.expression == null ? null : this.expand(term.expression); + return new _terms2.default('YieldGeneratorExpression', { + expression: expr + }); } - inner() { - let stx_439 = this[symWrap_398]; - if (!stx_439.match("delimiter")) { - throw new Error("Can only get inner syntax on a delimiter"); - } - let enf_440 = new _enforester.Enforester(stx_439.inner(), (0, _immutable.List)(), this.context); - return new MacroContext(enf_440, "inner", this.context); + + expandWhileStatement(term) { + return new _terms2.default('WhileStatement', { + test: this.expand(term.test), + body: this.expand(term.body) + }); } - } - function unwrap_402(x_441) { - if (x_441 instanceof SyntaxOrTermWrapper_401) { - return x_441[symWrap_398]; + + expandIfStatement(term) { + let consequent = term.consequent == null ? null : this.expand(term.consequent); + let alternate = term.alternate == null ? null : this.expand(term.alternate); + return new _terms2.default('IfStatement', { + test: this.expand(term.test), + consequent: consequent, + alternate: alternate + }); } - return x_441; - } - function cloneEnforester_403(enf_442) { - const rest = enf_442.rest; - const prev = enf_442.prev; - const context = enf_442.context; - return new _enforester.Enforester(rest, prev, context); - } - function Marker_404() {} - class MacroContext { - constructor(enf_443, name_444, context_445, useScope_446, introducedScope_447) { - const startMarker_448 = new Marker_404(); - const startEnf_449 = cloneEnforester_403(enf_443); - const priv_450 = { name: name_444, context: context_445, startMarker: startMarker_448, markers: new Map([[startMarker_448, enf_443]]) }; - if (useScope_446 && introducedScope_447) { - priv_450.noScopes = false; - priv_450.useScope = useScope_446; - priv_450.introducedScope = introducedScope_447; - } else { - priv_450.noScopes = true; + expandBlockStatement(term) { + return new _terms2.default('BlockStatement', { + block: this.expand(term.block) + }); + } + + expandBlock(term) { + let scope = (0, _scope.freshScope)('block'); + this.context.currentScope.push(scope); + let compiler = new _compiler2.default(this.context.phase, this.context.env, this.context.store, this.context); + + let markedBody, bodyTerm; + markedBody = term.statements.map(b => b.addScope(scope, this.context.bindings, _syntax.ALL_PHASES)); + bodyTerm = new _terms2.default('Block', { + statements: compiler.compile(markedBody) + }); + this.context.currentScope.pop(); + return bodyTerm; + } + + expandVariableDeclarationStatement(term) { + return new _terms2.default('VariableDeclarationStatement', { + declaration: this.expand(term.declaration) + }); + } + expandReturnStatement(term) { + if (term.expression == null) { + return term; } - privateData_399.set(this, priv_450); - this.reset(); - this[Symbol.iterator] = () => this; + return new _terms2.default("ReturnStatement", { + expression: this.expand(term.expression) + }); + } + + expandClassDeclaration(term) { + return new _terms2.default('ClassDeclaration', { + name: term.name == null ? null : this.expand(term.name), + super: term.super == null ? null : this.expand(term.super), + elements: term.elements.map(el => this.expand(el)).toArray() + }); + } + + expandClassExpression(term) { + return new _terms2.default('ClassExpression', { + name: term.name == null ? null : this.expand(term.name), + super: term.super == null ? null : this.expand(term.super), + elements: term.elements.map(el => this.expand(el)).toArray() + }); } - name() { - var _privateData_399$get = privateData_399.get(this); - const name = _privateData_399$get.name; - const context = _privateData_399$get.context; + expandClassElement(term) { + return new _terms2.default('ClassElement', { + isStatic: term.isStatic, + method: this.expand(term.method) + }); + } - return new SyntaxOrTermWrapper_401(name, context); + expandThisExpression(term) { + return term; } - expand(type_451) { - var _privateData_399$get2 = privateData_399.get(this); - const enf = _privateData_399$get2.enf; - const context = _privateData_399$get2.context; + expandSyntaxTemplate(term) { + let r = (0, _templateProcessor.processTemplate)(term.template.inner()); + let str = _syntax2.default.from("string", _serializer.serializer.write(r.template)); + let callee = new _terms2.default('IdentifierExpression', { name: _syntax2.default.from("identifier", 'syntaxTemplate') }); - if (enf.rest.size === 0) { - return { done: true, value: null }; - } - enf.expandMacro(); - let originalRest_452 = enf.rest; - let value_453; - switch (type_451) { - case "AssignmentExpression": - case "expr": - value_453 = enf.enforestExpressionLoop(); - break; - case "Expression": - value_453 = enf.enforestExpression(); - break; - case "Statement": - case "stmt": - value_453 = enf.enforestStatement(); - break; - case "BlockStatement": - case "WhileStatement": - case "IfStatement": - case "ForStatement": - case "SwitchStatement": - case "BreakStatement": - case "ContinueStatement": - case "DebuggerStatement": - case "WithStatement": - case "TryStatement": - case "ThrowStatement": - case "ClassDeclaration": - case "FunctionDeclaration": - case "LabeledStatement": - case "VariableDeclarationStatement": - case "ReturnStatement": - case "ExpressionStatement": - value_453 = enf.enforestStatement(); - (0, _errors.expect)(_.whereEq({ type: type_451 }, value_453), `Expecting a ${ type_451 }`, value_453, originalRest_452); - break; - case "YieldExpression": - value_453 = enf.enforestYieldExpression(); - break; - case "ClassExpression": - value_453 = enf.enforestClass({ isExpr: true }); - break; - case "ArrowExpression": - value_453 = enf.enforestArrowExpression(); - break; - case "NewExpression": - value_453 = enf.enforestNewExpression(); - break; - case "ThisExpression": - case "FunctionExpression": - case "IdentifierExpression": - case "LiteralNumericExpression": - case "LiteralInfinityExpression": - case "LiteralStringExpression": - case "TemplateExpression": - case "LiteralBooleanExpression": - case "LiteralNullExpression": - case "LiteralRegExpExpression": - case "ObjectExpression": - case "ArrayExpression": - value_453 = enf.enforestPrimaryExpression(); - break; - case "UnaryExpression": - case "UpdateExpression": - case "BinaryExpression": - case "StaticMemberExpression": - case "ComputedMemberExpression": - case "AssignmentExpression": - case "CompoundAssignmentExpression": - case "ConditionalExpression": - value_453 = enf.enforestExpressionLoop(); - (0, _errors.expect)(_.whereEq({ type: type_451 }, value_453), `Expecting a ${ type_451 }`, value_453, originalRest_452); - break; - default: - throw new Error("Unknown term type: " + type_451); - } - return { done: false, value: new SyntaxOrTermWrapper_401(value_453, context) }; + let expandedInterps = r.interp.map(i => { + let enf = new _enforester.Enforester(i, (0, _immutable.List)(), this.context); + return this.expand(enf.enforest('expression')); + }); + + let args = _immutable.List.of(new _terms2.default('LiteralStringExpression', { value: str })).concat(expandedInterps); + + return new _terms2.default('CallExpression', { + callee: callee, arguments: args + }); + } + + expandSyntaxQuote(term) { + let str = new _terms2.default("LiteralStringExpression", { + value: _syntax2.default.from("string", _serializer.serializer.write(term.name)) + }); + + return new _terms2.default("TemplateExpression", { + tag: term.template.tag, + elements: term.template.elements.push(str).push(new _terms2.default('TemplateElement', { + rawValue: '' + })).toArray() + }); + } + + expandStaticMemberExpression(term) { + return new _terms2.default("StaticMemberExpression", { + object: this.expand(term.object), + property: term.property + }); + } + + expandArrayExpression(term) { + return new _terms2.default("ArrayExpression", { + elements: term.elements.map(t => t == null ? t : this.expand(t)) + }); + } + + expandImport(term) { + return term; + } + + expandImportNamespace(term) { + return term; + } + + expandExport(term) { + return new _terms2.default('Export', { + declaration: this.expand(term.declaration) + }); + } + + expandExportDefault(term) { + return new _terms2.default('ExportDefault', { + body: this.expand(term.body) + }); + } + + expandExportFrom(term) { + return term; } - _rest(enf_454) { - const priv_455 = privateData_399.get(this); - if (priv_455.markers.get(priv_455.startMarker) === enf_454) { - return priv_455.enf.rest; + + expandExportAllFrom(term) { + return term; + } + + expandExportSpecifier(term) { + return term; + } + + expandStaticPropertyName(term) { + return term; + } + + expandDataProperty(term) { + return new _terms2.default("DataProperty", { + name: this.expand(term.name), + expression: this.expand(term.expression) + }); + } + + expandObjectExpression(term) { + return new _terms2.default("ObjectExpression", { + properties: term.properties.map(t => this.expand(t)) + }); + } + + expandVariableDeclarator(term) { + let init = term.init == null ? null : this.expand(term.init); + return new _terms2.default("VariableDeclarator", { + binding: this.expand(term.binding), + init: init + }); + } + + expandVariableDeclaration(term) { + if (term.kind === 'syntax' || term.kind === 'syntaxrec') { + return term; } - throw Error("Unauthorized access!"); + return new _terms2.default("VariableDeclaration", { + kind: term.kind, + declarators: term.declarators.map(d => this.expand(d)) + }); } - reset(marker_456) { - const priv_457 = privateData_399.get(this); - let enf_458; - if (marker_456 == null) { - enf_458 = priv_457.markers.get(priv_457.startMarker); - } else if (marker_456 && marker_456 instanceof Marker_404) { - if (priv_457.markers.has(marker_456)) { - enf_458 = priv_457.markers.get(marker_456); - } else { - throw new Error("marker must originate from this context"); - } - } else { - throw new Error("marker must be an instance of Marker"); + + expandParenthesizedExpression(term) { + if (term.inner.size === 0) { + throw new Error("unexpected end of input"); } - priv_457.enf = cloneEnforester_403(enf_458); + let enf = new _enforester.Enforester(term.inner, (0, _immutable.List)(), this.context); + let lookahead = enf.peek(); + let t = enf.enforestExpression(); + if (t == null || enf.rest.size > 0) { + throw enf.createError(lookahead, "unexpected syntax"); + } + return this.expand(t); } - mark() { - const priv_459 = privateData_399.get(this); - let marker_460; - if (priv_459.enf.rest === priv_459.markers.get(priv_459.startMarker).rest) { - marker_460 = priv_459.startMarker; - } else if (priv_459.enf.rest.isEmpty()) { - if (!priv_459.endMarker) priv_459.endMarker = new Marker_404(); - marker_460 = priv_459.endMarker; + + expandUnaryExpression(term) { + return new _terms2.default('UnaryExpression', { + operator: term.operator, + operand: this.expand(term.operand) + }); + } + + expandUpdateExpression(term) { + return new _terms2.default('UpdateExpression', { + isPrefix: term.isPrefix, + operator: term.operator, + operand: this.expand(term.operand) + }); + } + + expandBinaryExpression(term) { + let left = this.expand(term.left); + let right = this.expand(term.right); + return new _terms2.default("BinaryExpression", { + left: left, + operator: term.operator, + right: right + }); + } + + expandConditionalExpression(term) { + return new _terms2.default('ConditionalExpression', { + test: this.expand(term.test), + consequent: this.expand(term.consequent), + alternate: this.expand(term.alternate) + }); + } + + expandNewTargetExpression(term) { + return term; + } + + expandNewExpression(term) { + let callee = this.expand(term.callee); + let enf = new _enforester.Enforester(term.arguments, (0, _immutable.List)(), this.context); + let args = enf.enforestArgumentList().map(arg => this.expand(arg)); + return new _terms2.default('NewExpression', { + callee: callee, + arguments: args.toArray() + }); + } + + expandSuper(term) { + return term; + } + + expandCallExpression(term) { + let callee = this.expand(term.callee); + let enf = new _enforester.Enforester(term.arguments, (0, _immutable.List)(), this.context); + let args = enf.enforestArgumentList().map(arg => this.expand(arg)); + return new _terms2.default("CallExpression", { + callee: callee, + arguments: args + }); + } + + expandSpreadElement(term) { + return new _terms2.default('SpreadElement', { + expression: this.expand(term.expression) + }); + } + + expandExpressionStatement(term) { + let child = this.expand(term.expression); + return new _terms2.default("ExpressionStatement", { + expression: child + }); + } + + expandLabeledStatement(term) { + return new _terms2.default('LabeledStatement', { + label: term.label.val(), + body: this.expand(term.body) + }); + } + + doFunctionExpansion(term, type) { + let scope = (0, _scope.freshScope)("fun"); + let red = new _applyScopeInParamsReducer2.default(scope, this.context); + let params; + if (type !== 'Getter' && type !== 'Setter') { + params = red.transform(term.params); + params = this.expand(params); + } + this.context.currentScope.push(scope); + let compiler = new _compiler2.default(this.context.phase, this.context.env, this.context.store, this.context); + + let markedBody, bodyTerm; + if (term.body instanceof _terms2.default) { + // Arrow functions have a single term as their body + bodyTerm = this.expand(term.body.addScope(scope, this.context.bindings, _syntax.ALL_PHASES)); } else { - marker_460 = new Marker_404(); + markedBody = term.body.map(b => b.addScope(scope, this.context.bindings, _syntax.ALL_PHASES)); + bodyTerm = new _terms2.default("FunctionBody", { + directives: (0, _immutable.List)(), + statements: compiler.compile(markedBody) + }); } - if (!priv_459.markers.has(marker_460)) { - priv_459.markers.set(marker_460, cloneEnforester_403(priv_459.enf)); + this.context.currentScope.pop(); + + if (type === 'Getter') { + return new _terms2.default(type, { + name: this.expand(term.name), + body: bodyTerm + }); + } else if (type === 'Setter') { + return new _terms2.default(type, { + name: this.expand(term.name), + param: term.param, + body: bodyTerm + }); + } else if (type === 'ArrowExpression') { + return new _terms2.default(type, { + params: params, + body: bodyTerm + }); } - return marker_460; + return new _terms2.default(type, { + name: term.name, + isGenerator: term.isGenerator, + params: params, + body: bodyTerm + }); } - next() { - var _privateData_399$get3 = privateData_399.get(this); - const enf = _privateData_399$get3.enf; - const noScopes = _privateData_399$get3.noScopes; - const useScope = _privateData_399$get3.useScope; - const introducedScope = _privateData_399$get3.introducedScope; - const context = _privateData_399$get3.context; + expandMethod(term) { + return this.doFunctionExpansion(term, 'Method'); + } - if (enf.rest.size === 0) { - return { done: true, value: null }; - } - let value_461 = enf.advance(); - if (!noScopes) { - value_461 = value_461.addScope(useScope, context.bindings, _syntax.ALL_PHASES).addScope(introducedScope, context.bindings, _syntax.ALL_PHASES, { flip: true }); + expandSetter(term) { + return this.doFunctionExpansion(term, 'Setter'); + } + + expandGetter(term) { + return this.doFunctionExpansion(term, 'Getter'); + } + + expandFunctionDeclaration(term) { + return this.doFunctionExpansion(term, "FunctionDeclaration"); + } + + expandFunctionExpression(term) { + return this.doFunctionExpansion(term, "FunctionExpression"); + } + + expandCompoundAssignmentExpression(term) { + return new _terms2.default("CompoundAssignmentExpression", { + binding: this.expand(term.binding), + operator: term.operator, + expression: this.expand(term.expression) + }); + } + + expandAssignmentExpression(term) { + return new _terms2.default("AssignmentExpression", { + binding: this.expand(term.binding), + expression: this.expand(term.expression) + }); + } + + expandEmptyStatement(term) { + return term; + } + + expandLiteralBooleanExpression(term) { + return term; + } + + expandLiteralNumericExpression(term) { + return term; + } + expandLiteralInfinityExpression(term) { + return term; + } + + expandIdentifierExpression(term) { + let trans = this.context.env.get(term.name.resolve(this.context.phase)); + if (trans) { + return new _terms2.default("IdentifierExpression", { + name: trans.id + }); } - return { done: false, value: new SyntaxOrTermWrapper_401(value_461, context) }; + return term; + } + + expandLiteralNullExpression(term) { + return term; + } + + expandLiteralStringExpression(term) { + return term; + } + + expandLiteralRegExpExpression(term) { + return term; } } - exports.default = MacroContext; - exports.SyntaxOrTermWrapper = SyntaxOrTermWrapper_401; - exports.unwrap = unwrap_402; - //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/macro-context.js"],"names":[],"mappings":";;;;;;;AAAA;;;;AACA;;;;AACA;;AACA;;AACA;;AACA;;;;AACA;;AACA;;IAAa,C;;;;;;AACb,MAAM,WAAW,oBAAM,IAAvB;AACA,MAAM,cAAc,oBAAM,OAA1B;AACA,MAAM,cAAc,OAAO,SAAP,CAApB;AACA,MAAM,kBAAkB,IAAI,OAAJ,EAAxB;AACA,MAAM,aAAa,SAAS;AAC1B,MAAI,MAAM,KAAN,CAAY,WAAZ,CAAJ,EAA8B;AAC5B,WAAO,IAAP;AACD;AACD,MAAI,OAAO,MAAM,GAAb,KAAqB,UAAzB,EAAqC;AACnC,WAAO,MAAM,GAAN,EAAP;AACD;AACD,SAAO,IAAP;AACD,CARD;AASA,MAAM,uBAAN,CAA8B;AAC5B,cAAY,KAAZ,EAAqC;AAAA,QAAlB,WAAkB,yDAAJ,EAAI;;AACnC,SAAK,WAAL,IAAoB,KAApB;AACA,SAAK,OAAL,GAAe,WAAf;AACD;AACD,OAAK,QAAL,EAAe,SAAf,EAA0B;AACxB,QAAI,UAAU,KAAK,WAAL,CAAd;AACA,QAAI,OAAO,QAAQ,IAAf,KAAwB,UAA5B,EAAwC;AACtC,aAAO,QAAQ,IAAR,CAAa,QAAb,EAAuB,SAAvB,CAAP;AACD;AACF;AACD,aAAW;AACT,WAAO,KAAK,IAAL,CAAU,MAAV,EAAkB,IAAlB,CAAP;AACD;AACD,aAAW,SAAX,EAAsB;AACpB,WAAO,KAAK,IAAL,CAAU,QAAV,EAAoB,SAApB,CAAP;AACD;AACD,aAAW,SAAX,EAAsB;AACpB,WAAO,KAAK,IAAL,CAAU,QAAV,EAAoB,SAApB,CAAP;AACD;AACD,iBAAe,SAAf,EAA0B;AACxB,WAAO,KAAK,IAAL,CAAU,YAAV,EAAwB,SAAxB,CAAP;AACD;AACD,cAAY,SAAZ,EAAuB;AACrB,WAAO,KAAK,IAAL,CAAU,SAAV,CAAP;AACD;AACD,iBAAe,SAAf,EAA0B;AACxB,WAAO,KAAK,IAAL,CAAU,YAAV,EAAwB,SAAxB,CAAP;AACD;AACD,wBAAsB,SAAtB,EAAiC;AAC/B,WAAO,KAAK,IAAL,CAAU,mBAAV,EAA+B,SAA/B,CAAP;AACD;AACD,aAAW,SAAX,EAAsB;AACpB,WAAO,KAAK,IAAL,CAAU,QAAV,EAAoB,SAApB,CAAP;AACD;AACD,eAAa,SAAb,EAAwB;AACtB,WAAO,KAAK,IAAL,CAAU,UAAV,EAAsB,SAAtB,CAAP;AACD;AACD,aAAW,SAAX,EAAsB;AACpB,WAAO,KAAK,IAAL,CAAU,QAAV,EAAoB,SAApB,CAAP;AACD;AACD,QAAM,QAAN,EAAgB,SAAhB,EAA2B;AACzB,QAAI,UAAU,KAAK,WAAL,CAAd;AACA,QAAI,OAAO,QAAQ,KAAf,KAAyB,UAA7B,EAAyC;AACvC,aAAO,QAAQ,KAAR,CAAc,QAAd,EAAwB,SAAxB,CAAP;AACD;AACF;AACD,eAAa,SAAb,EAAwB;AACtB,WAAO,KAAK,KAAL,CAAW,YAAX,EAAyB,SAAzB,CAAP;AACD;AACD,WAAS,SAAT,EAAoB;AAClB,WAAO,KAAK,KAAL,CAAW,QAAX,EAAqB,SAArB,CAAP;AACD;AACD,mBAAiB,SAAjB,EAA4B;AAC1B,WAAO,KAAK,KAAL,CAAW,SAAX,EAAsB,SAAtB,CAAP;AACD;AACD,YAAU,SAAV,EAAqB;AACnB,WAAO,KAAK,KAAL,CAAW,SAAX,EAAsB,SAAtB,CAAP;AACD;AACD,gBAAc,SAAd,EAAyB;AACvB,WAAO,KAAK,KAAL,CAAW,MAAX,EAAmB,SAAnB,CAAP;AACD;AACD,mBAAiB,SAAjB,EAA4B;AAC1B,WAAO,KAAK,KAAL,CAAW,QAAX,EAAqB,SAArB,CAAP;AACD;AACD,eAAa,SAAb,EAAwB;AACtB,WAAO,KAAK,KAAL,CAAW,YAAX,EAAyB,SAAzB,CAAP;AACD;AACD,kBAAgB,SAAhB,EAA2B;AACzB,WAAO,KAAK,KAAL,CAAW,QAAX,EAAqB,SAArB,CAAP;AACD;AACD,sBAAoB,SAApB,EAA+B;AAC7B,WAAO,KAAK,KAAL,CAAW,mBAAX,EAAgC,SAAhC,CAAP;AACD;AACD,aAAW,SAAX,EAAsB;AACpB,WAAO,KAAK,KAAL,CAAW,UAAX,EAAuB,SAAvB,CAAP;AACD;AACD,cAAY,SAAZ,EAAuB;AACrB,WAAO,KAAK,KAAL,CAAW,WAAX,EAAwB,SAAxB,CAAP;AACD;AACD,WAAS,SAAT,EAAoB;AAClB,WAAO,KAAK,KAAL,CAAW,QAAX,EAAqB,SAArB,CAAP;AACD;AACD,WAAS,SAAT,EAAoB;AAClB,WAAO,KAAK,KAAL,CAAW,QAAX,EAAqB,SAArB,CAAP;AACD;AACD,aAAW,SAAX,EAAsB;AACpB,WAAO,KAAK,KAAL,CAAW,UAAX,EAAuB,SAAvB,CAAP;AACD;AACD,mBAAiB,SAAjB,EAA4B;AAC1B,WAAO,KAAK,KAAL,CAAW,gBAAX,EAA6B,SAA7B,CAAP;AACD;AACD,QAAM,SAAN,EAAiB;AACf,WAAO,KAAK,KAAL,CAAW,KAAX,EAAkB,SAAlB,CAAP;AACD;AACD,eAAa;AACX,WAAO,KAAK,WAAL,EAAkB,UAAlB,EAAP;AACD;AACD,QAAM;AACJ,WAAO,WAAW,KAAK,WAAL,CAAX,CAAP;AACD;AACD,UAAQ;AACN,QAAI,UAAU,KAAK,WAAL,CAAd;AACA,QAAI,CAAC,QAAQ,KAAR,CAAc,WAAd,CAAL,EAAiC;AAC/B,YAAM,IAAI,KAAJ,CAAU,0CAAV,CAAN;AACD;AACD,QAAI,UAAU,2BAAe,QAAQ,KAAR,EAAf,EAAgC,sBAAhC,EAAwC,KAAK,OAA7C,CAAd;AACA,WAAO,IAAI,YAAJ,CAAiB,OAAjB,EAA0B,OAA1B,EAAmC,KAAK,OAAxC,CAAP;AACD;AA5G2B;AA8G9B,SAAS,UAAT,CAAoB,KAApB,EAA2B;AACzB,MAAI,iBAAiB,uBAArB,EAA8C;AAC5C,WAAO,MAAM,WAAN,CAAP;AACD;AACD,SAAO,KAAP;AACD;AACD,SAAS,mBAAT,CAA6B,OAA7B,EAAsC;AAAA,QAC7B,IAD6B,GACN,OADM,CAC7B,IAD6B;AAAA,QACvB,IADuB,GACN,OADM,CACvB,IADuB;AAAA,QACjB,OADiB,GACN,OADM,CACjB,OADiB;;AAEpC,SAAO,2BAAe,IAAf,EAAqB,IAArB,EAA2B,OAA3B,CAAP;AACD;AACD,SAAS,UAAT,GAAsB,CAAE;AACT,MAAM,YAAN,CAAmB;AAChC,cAAY,OAAZ,EAAqB,QAArB,EAA+B,WAA/B,EAA4C,YAA5C,EAA0D,mBAA1D,EAA+E;AAC7E,UAAM,kBAAkB,IAAI,UAAJ,EAAxB;AACA,UAAM,eAAe,oBAAoB,OAApB,CAArB;AACA,UAAM,WAAW,EAAC,MAAM,QAAP,EAAiB,SAAS,WAA1B,EAAuC,aAAa,eAApD,EAAqE,SAAS,IAAI,GAAJ,CAAQ,CAAC,CAAC,eAAD,EAAkB,OAAlB,CAAD,CAAR,CAA9E,EAAjB;AACA,QAAI,gBAAgB,mBAApB,EAAyC;AACvC,eAAS,QAAT,GAAoB,KAApB;AACA,eAAS,QAAT,GAAoB,YAApB;AACA,eAAS,eAAT,GAA2B,mBAA3B;AACD,KAJD,MAIO;AACL,eAAS,QAAT,GAAoB,IAApB;AACD;AACD,oBAAgB,GAAhB,CAAoB,IAApB,EAA0B,QAA1B;AACA,SAAK,KAAL;AACA,SAAK,OAAO,QAAZ,IAAwB,MAAM,IAA9B;AACD;AACD,SAAO;AAAA,+BACmB,gBAAgB,GAAhB,CAAoB,IAApB,CADnB;;AAAA,UACE,IADF,wBACE,IADF;AAAA,UACQ,OADR,wBACQ,OADR;;AAEL,WAAO,IAAI,uBAAJ,CAA4B,IAA5B,EAAkC,OAAlC,CAAP;AACD;AACD,SAAO,QAAP,EAAiB;AAAA,gCACQ,gBAAgB,GAAhB,CAAoB,IAApB,CADR;;AAAA,UACR,GADQ,yBACR,GADQ;AAAA,UACH,OADG,yBACH,OADG;;AAEf,QAAI,IAAI,IAAJ,CAAS,IAAT,KAAkB,CAAtB,EAAyB;AACvB,aAAO,EAAC,MAAM,IAAP,EAAa,OAAO,IAApB,EAAP;AACD;AACD,QAAI,WAAJ;AACA,QAAI,mBAAmB,IAAI,IAA3B;AACA,QAAI,SAAJ;AACA,YAAQ,QAAR;AACE,WAAK,sBAAL;AACA,WAAK,MAAL;AACE,oBAAY,IAAI,sBAAJ,EAAZ;AACA;AACF,WAAK,YAAL;AACE,oBAAY,IAAI,kBAAJ,EAAZ;AACA;AACF,WAAK,WAAL;AACA,WAAK,MAAL;AACE,oBAAY,IAAI,iBAAJ,EAAZ;AACA;AACF,WAAK,gBAAL;AACA,WAAK,gBAAL;AACA,WAAK,aAAL;AACA,WAAK,cAAL;AACA,WAAK,iBAAL;AACA,WAAK,gBAAL;AACA,WAAK,mBAAL;AACA,WAAK,mBAAL;AACA,WAAK,eAAL;AACA,WAAK,cAAL;AACA,WAAK,gBAAL;AACA,WAAK,kBAAL;AACA,WAAK,qBAAL;AACA,WAAK,kBAAL;AACA,WAAK,8BAAL;AACA,WAAK,iBAAL;AACA,WAAK,qBAAL;AACE,oBAAY,IAAI,iBAAJ,EAAZ;AACA,4BAAO,EAAE,OAAF,CAAU,EAAC,MAAM,QAAP,EAAV,EAA4B,SAA5B,CAAP,EAAgD,gBAAc,QAAS,GAAvE,EAA0E,SAA1E,EAAqF,gBAArF;AACA;AACF,WAAK,iBAAL;AACE,oBAAY,IAAI,uBAAJ,EAAZ;AACA;AACF,WAAK,iBAAL;AACE,oBAAY,IAAI,aAAJ,CAAkB,EAAC,QAAQ,IAAT,EAAlB,CAAZ;AACA;AACF,WAAK,iBAAL;AACE,oBAAY,IAAI,uBAAJ,EAAZ;AACA;AACF,WAAK,eAAL;AACE,oBAAY,IAAI,qBAAJ,EAAZ;AACA;AACF,WAAK,gBAAL;AACA,WAAK,oBAAL;AACA,WAAK,sBAAL;AACA,WAAK,0BAAL;AACA,WAAK,2BAAL;AACA,WAAK,yBAAL;AACA,WAAK,oBAAL;AACA,WAAK,0BAAL;AACA,WAAK,uBAAL;AACA,WAAK,yBAAL;AACA,WAAK,kBAAL;AACA,WAAK,iBAAL;AACE,oBAAY,IAAI,yBAAJ,EAAZ;AACA;AACF,WAAK,iBAAL;AACA,WAAK,kBAAL;AACA,WAAK,kBAAL;AACA,WAAK,wBAAL;AACA,WAAK,0BAAL;AACA,WAAK,sBAAL;AACA,WAAK,8BAAL;AACA,WAAK,uBAAL;AACE,oBAAY,IAAI,sBAAJ,EAAZ;AACA,4BAAO,EAAE,OAAF,CAAU,EAAC,MAAM,QAAP,EAAV,EAA4B,SAA5B,CAAP,EAAgD,gBAAc,QAAS,GAAvE,EAA0E,SAA1E,EAAqF,gBAArF;AACA;AACF;AACE,cAAM,IAAI,KAAJ,CAAU,wBAAwB,QAAlC,CAAN;AAtEJ;AAwEA,WAAO,EAAC,MAAM,KAAP,EAAc,OAAO,IAAI,uBAAJ,CAA4B,SAA5B,EAAuC,OAAvC,CAArB,EAAP;AACD;AACD,QAAM,OAAN,EAAe;AACb,UAAM,WAAW,gBAAgB,GAAhB,CAAoB,IAApB,CAAjB;AACA,QAAI,SAAS,OAAT,CAAiB,GAAjB,CAAqB,SAAS,WAA9B,MAA+C,OAAnD,EAA4D;AAC1D,aAAO,SAAS,GAAT,CAAa,IAApB;AACD;AACD,UAAM,MAAM,sBAAN,CAAN;AACD;AACD,QAAM,UAAN,EAAkB;AAChB,UAAM,WAAW,gBAAgB,GAAhB,CAAoB,IAApB,CAAjB;AACA,QAAI,OAAJ;AACA,QAAI,cAAc,IAAlB,EAAwB;AACtB,gBAAU,SAAS,OAAT,CAAiB,GAAjB,CAAqB,SAAS,WAA9B,CAAV;AACD,KAFD,MAEO,IAAI,cAAc,sBAAsB,UAAxC,EAAoD;AACzD,UAAI,SAAS,OAAT,CAAiB,GAAjB,CAAqB,UAArB,CAAJ,EAAsC;AACpC,kBAAU,SAAS,OAAT,CAAiB,GAAjB,CAAqB,UAArB,CAAV;AACD,OAFD,MAEO;AACL,cAAM,IAAI,KAAJ,CAAU,yCAAV,CAAN;AACD;AACF,KANM,MAMA;AACL,YAAM,IAAI,KAAJ,CAAU,sCAAV,CAAN;AACD;AACD,aAAS,GAAT,GAAe,oBAAoB,OAApB,CAAf;AACD;AACD,SAAO;AACL,UAAM,WAAW,gBAAgB,GAAhB,CAAoB,IAApB,CAAjB;AACA,QAAI,UAAJ;AACA,QAAI,SAAS,GAAT,CAAa,IAAb,KAAsB,SAAS,OAAT,CAAiB,GAAjB,CAAqB,SAAS,WAA9B,EAA2C,IAArE,EAA2E;AACzE,mBAAa,SAAS,WAAtB;AACD,KAFD,MAEO,IAAI,SAAS,GAAT,CAAa,IAAb,CAAkB,OAAlB,EAAJ,EAAiC;AACtC,UAAI,CAAC,SAAS,SAAd,EAAyB,SAAS,SAAT,GAAqB,IAAI,UAAJ,EAArB;AACzB,mBAAa,SAAS,SAAtB;AACD,KAHM,MAGA;AACL,mBAAa,IAAI,UAAJ,EAAb;AACD;AACD,QAAI,CAAC,SAAS,OAAT,CAAiB,GAAjB,CAAqB,UAArB,CAAL,EAAuC;AACrC,eAAS,OAAT,CAAiB,GAAjB,CAAqB,UAArB,EAAiC,oBAAoB,SAAS,GAA7B,CAAjC;AACD;AACD,WAAO,UAAP;AACD;AACD,SAAO;AAAA,gCACuD,gBAAgB,GAAhB,CAAoB,IAApB,CADvD;;AAAA,UACE,GADF,yBACE,GADF;AAAA,UACO,QADP,yBACO,QADP;AAAA,UACiB,QADjB,yBACiB,QADjB;AAAA,UAC2B,eAD3B,yBAC2B,eAD3B;AAAA,UAC4C,OAD5C,yBAC4C,OAD5C;;AAEL,QAAI,IAAI,IAAJ,CAAS,IAAT,KAAkB,CAAtB,EAAyB;AACvB,aAAO,EAAC,MAAM,IAAP,EAAa,OAAO,IAApB,EAAP;AACD;AACD,QAAI,YAAY,IAAI,OAAJ,EAAhB;AACA,QAAI,CAAC,QAAL,EAAe;AACb,kBAAY,UAAU,QAAV,CAAmB,QAAnB,EAA6B,QAAQ,QAArC,sBAA2D,QAA3D,CAAoE,eAApE,EAAqF,QAAQ,QAA7F,sBAAmH,EAAC,MAAM,IAAP,EAAnH,CAAZ;AACD;AACD,WAAO,EAAC,MAAM,KAAP,EAAc,OAAO,IAAI,uBAAJ,CAA4B,SAA5B,EAAuC,OAAvC,CAArB,EAAP;AACD;AAvJ+B;kBAAb,Y;QAyJc,mB,GAA3B,uB;QACc,M,GAAd,U","file":"macro-context.js","sourcesContent":["import MapSyntaxReducer from \"./map-syntax-reducer\";\nimport reducer from \"shift-reducer\";\nimport {expect} from \"./errors\";\nimport {List} from \"immutable\";\nimport {Enforester} from \"./enforester\";\nimport Syntax, {ALL_PHASES} from \"./syntax\";\nimport {Maybe} from \"ramda-fantasy\";\nimport  * as _ from \"ramda\";\nconst Just_396 = Maybe.Just;\nconst Nothing_397 = Maybe.Nothing;\nconst symWrap_398 = Symbol(\"wrapper\");\nconst privateData_399 = new WeakMap;\nconst getVal_400 = t_405 => {\n  if (t_405.match(\"delimiter\")) {\n    return null;\n  }\n  if (typeof t_405.val === \"function\") {\n    return t_405.val();\n  }\n  return null;\n};\nclass SyntaxOrTermWrapper_401 {\n  constructor(s_406, context_407 = {}) {\n    this[symWrap_398] = s_406;\n    this.context = context_407;\n  }\n  from(type_408, value_409) {\n    let stx_410 = this[symWrap_398];\n    if (typeof stx_410.from === \"function\") {\n      return stx_410.from(type_408, value_409);\n    }\n  }\n  fromNull() {\n    return this.from(\"null\", null);\n  }\n  fromNumber(value_411) {\n    return this.from(\"number\", value_411);\n  }\n  fromString(value_412) {\n    return this.from(\"string\", value_412);\n  }\n  fromPunctuator(value_413) {\n    return this.from(\"punctuator\", value_413);\n  }\n  fromKeyword(value_414) {\n    return this.from(\"keyword\");\n  }\n  fromIdentifier(value_415) {\n    return this.from(\"identifier\", value_415);\n  }\n  fromRegularExpression(value_416) {\n    return this.from(\"regularExpression\", value_416);\n  }\n  fromBraces(inner_417) {\n    return this.from(\"braces\", inner_417);\n  }\n  fromBrackets(inner_418) {\n    return this.from(\"brackets\", inner_418);\n  }\n  fromParens(inner_419) {\n    return this.from(\"parens\", inner_419);\n  }\n  match(type_420, value_421) {\n    let stx_422 = this[symWrap_398];\n    if (typeof stx_422.match === \"function\") {\n      return stx_422.match(type_420, value_421);\n    }\n  }\n  isIdentifier(value_423) {\n    return this.match(\"identifier\", value_423);\n  }\n  isAssign(value_424) {\n    return this.match(\"assign\", value_424);\n  }\n  isBooleanLiteral(value_425) {\n    return this.match(\"boolean\", value_425);\n  }\n  isKeyword(value_426) {\n    return this.match(\"keyword\", value_426);\n  }\n  isNullLiteral(value_427) {\n    return this.match(\"null\", value_427);\n  }\n  isNumericLiteral(value_428) {\n    return this.match(\"number\", value_428);\n  }\n  isPunctuator(value_429) {\n    return this.match(\"punctuator\", value_429);\n  }\n  isStringLiteral(value_430) {\n    return this.match(\"string\", value_430);\n  }\n  isRegularExpression(value_431) {\n    return this.match(\"regularExpression\", value_431);\n  }\n  isTemplate(value_432) {\n    return this.match(\"template\", value_432);\n  }\n  isDelimiter(value_433) {\n    return this.match(\"delimiter\", value_433);\n  }\n  isParens(value_434) {\n    return this.match(\"parens\", value_434);\n  }\n  isBraces(value_435) {\n    return this.match(\"braces\", value_435);\n  }\n  isBrackets(value_436) {\n    return this.match(\"brackets\", value_436);\n  }\n  isSyntaxTemplate(value_437) {\n    return this.match(\"syntaxTemplate\", value_437);\n  }\n  isEOF(value_438) {\n    return this.match(\"eof\", value_438);\n  }\n  lineNumber() {\n    return this[symWrap_398].lineNumber();\n  }\n  val() {\n    return getVal_400(this[symWrap_398]);\n  }\n  inner() {\n    let stx_439 = this[symWrap_398];\n    if (!stx_439.match(\"delimiter\")) {\n      throw new Error(\"Can only get inner syntax on a delimiter\");\n    }\n    let enf_440 = new Enforester(stx_439.inner(), List(), this.context);\n    return new MacroContext(enf_440, \"inner\", this.context);\n  }\n}\nfunction unwrap_402(x_441) {\n  if (x_441 instanceof SyntaxOrTermWrapper_401) {\n    return x_441[symWrap_398];\n  }\n  return x_441;\n}\nfunction cloneEnforester_403(enf_442) {\n  const {rest, prev, context} = enf_442;\n  return new Enforester(rest, prev, context);\n}\nfunction Marker_404() {}\nexport default class MacroContext {\n  constructor(enf_443, name_444, context_445, useScope_446, introducedScope_447) {\n    const startMarker_448 = new Marker_404;\n    const startEnf_449 = cloneEnforester_403(enf_443);\n    const priv_450 = {name: name_444, context: context_445, startMarker: startMarker_448, markers: new Map([[startMarker_448, enf_443]])};\n    if (useScope_446 && introducedScope_447) {\n      priv_450.noScopes = false;\n      priv_450.useScope = useScope_446;\n      priv_450.introducedScope = introducedScope_447;\n    } else {\n      priv_450.noScopes = true;\n    }\n    privateData_399.set(this, priv_450);\n    this.reset();\n    this[Symbol.iterator] = () => this;\n  }\n  name() {\n    const {name, context} = privateData_399.get(this);\n    return new SyntaxOrTermWrapper_401(name, context);\n  }\n  expand(type_451) {\n    const {enf, context} = privateData_399.get(this);\n    if (enf.rest.size === 0) {\n      return {done: true, value: null};\n    }\n    enf.expandMacro();\n    let originalRest_452 = enf.rest;\n    let value_453;\n    switch (type_451) {\n      case \"AssignmentExpression\":\n      case \"expr\":\n        value_453 = enf.enforestExpressionLoop();\n        break;\n      case \"Expression\":\n        value_453 = enf.enforestExpression();\n        break;\n      case \"Statement\":\n      case \"stmt\":\n        value_453 = enf.enforestStatement();\n        break;\n      case \"BlockStatement\":\n      case \"WhileStatement\":\n      case \"IfStatement\":\n      case \"ForStatement\":\n      case \"SwitchStatement\":\n      case \"BreakStatement\":\n      case \"ContinueStatement\":\n      case \"DebuggerStatement\":\n      case \"WithStatement\":\n      case \"TryStatement\":\n      case \"ThrowStatement\":\n      case \"ClassDeclaration\":\n      case \"FunctionDeclaration\":\n      case \"LabeledStatement\":\n      case \"VariableDeclarationStatement\":\n      case \"ReturnStatement\":\n      case \"ExpressionStatement\":\n        value_453 = enf.enforestStatement();\n        expect(_.whereEq({type: type_451}, value_453), `Expecting a ${type_451}`, value_453, originalRest_452);\n        break;\n      case \"YieldExpression\":\n        value_453 = enf.enforestYieldExpression();\n        break;\n      case \"ClassExpression\":\n        value_453 = enf.enforestClass({isExpr: true});\n        break;\n      case \"ArrowExpression\":\n        value_453 = enf.enforestArrowExpression();\n        break;\n      case \"NewExpression\":\n        value_453 = enf.enforestNewExpression();\n        break;\n      case \"ThisExpression\":\n      case \"FunctionExpression\":\n      case \"IdentifierExpression\":\n      case \"LiteralNumericExpression\":\n      case \"LiteralInfinityExpression\":\n      case \"LiteralStringExpression\":\n      case \"TemplateExpression\":\n      case \"LiteralBooleanExpression\":\n      case \"LiteralNullExpression\":\n      case \"LiteralRegExpExpression\":\n      case \"ObjectExpression\":\n      case \"ArrayExpression\":\n        value_453 = enf.enforestPrimaryExpression();\n        break;\n      case \"UnaryExpression\":\n      case \"UpdateExpression\":\n      case \"BinaryExpression\":\n      case \"StaticMemberExpression\":\n      case \"ComputedMemberExpression\":\n      case \"AssignmentExpression\":\n      case \"CompoundAssignmentExpression\":\n      case \"ConditionalExpression\":\n        value_453 = enf.enforestExpressionLoop();\n        expect(_.whereEq({type: type_451}, value_453), `Expecting a ${type_451}`, value_453, originalRest_452);\n        break;\n      default:\n        throw new Error(\"Unknown term type: \" + type_451);\n    }\n    return {done: false, value: new SyntaxOrTermWrapper_401(value_453, context)};\n  }\n  _rest(enf_454) {\n    const priv_455 = privateData_399.get(this);\n    if (priv_455.markers.get(priv_455.startMarker) === enf_454) {\n      return priv_455.enf.rest;\n    }\n    throw Error(\"Unauthorized access!\");\n  }\n  reset(marker_456) {\n    const priv_457 = privateData_399.get(this);\n    let enf_458;\n    if (marker_456 == null) {\n      enf_458 = priv_457.markers.get(priv_457.startMarker);\n    } else if (marker_456 && marker_456 instanceof Marker_404) {\n      if (priv_457.markers.has(marker_456)) {\n        enf_458 = priv_457.markers.get(marker_456);\n      } else {\n        throw new Error(\"marker must originate from this context\");\n      }\n    } else {\n      throw new Error(\"marker must be an instance of Marker\");\n    }\n    priv_457.enf = cloneEnforester_403(enf_458);\n  }\n  mark() {\n    const priv_459 = privateData_399.get(this);\n    let marker_460;\n    if (priv_459.enf.rest === priv_459.markers.get(priv_459.startMarker).rest) {\n      marker_460 = priv_459.startMarker;\n    } else if (priv_459.enf.rest.isEmpty()) {\n      if (!priv_459.endMarker) priv_459.endMarker = new Marker_404;\n      marker_460 = priv_459.endMarker;\n    } else {\n      marker_460 = new Marker_404;\n    }\n    if (!priv_459.markers.has(marker_460)) {\n      priv_459.markers.set(marker_460, cloneEnforester_403(priv_459.enf));\n    }\n    return marker_460;\n  }\n  next() {\n    const {enf, noScopes, useScope, introducedScope, context} = privateData_399.get(this);\n    if (enf.rest.size === 0) {\n      return {done: true, value: null};\n    }\n    let value_461 = enf.advance();\n    if (!noScopes) {\n      value_461 = value_461.addScope(useScope, context.bindings, ALL_PHASES).addScope(introducedScope, context.bindings, ALL_PHASES, {flip: true});\n    }\n    return {done: false, value: new SyntaxOrTermWrapper_401(value_461, context)};\n  }\n}\nexport {SyntaxOrTermWrapper_401 as SyntaxOrTermWrapper};\nexport {unwrap_402 as unwrap}"]} + exports.default = TermExpander; + //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/term-expander.js"],"names":[],"mappings":"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","file":"term-expander.js","sourcesContent":["import { List } from 'immutable';\nimport Term from \"./terms\";\nimport { freshScope } from \"./scope\";\nimport ApplyScopeInParamsReducer from \"./apply-scope-in-params-reducer\";\nimport Compiler from './compiler';\nimport Syntax, { ALL_PHASES } from \"./syntax\";\nimport { serializer } from \"./serializer\";\nimport { Enforester } from \"./enforester\";\nimport { processTemplate } from './template-processor.js';\nimport ASTDispatcher from './ast-dispatcher';\n\nexport default class TermExpander extends ASTDispatcher {\n  constructor(context) {\n    super('expand', true);\n    this.context = context;\n  }\n\n  expand(term) {\n    return this.dispatch(term);\n  }\n\n  expandPragma(term) {\n    return term;\n  }\n\n  expandTemplateExpression(term) {\n    return new Term('TemplateExpression', {\n      tag: term.tag == null ? null : this.expand(term.tag),\n      elements: term.elements.toArray()\n    });\n  }\n\n  expandBreakStatement(term) {\n    return new Term('BreakStatement', {\n      label: term.label ? term.label.val() : null\n    });\n  }\n\n  expandDoWhileStatement(term) {\n    return new Term('DoWhileStatement', {\n      body: this.expand(term.body),\n      test: this.expand(term.test)\n    });\n  }\n\n  expandWithStatement(term) {\n    return new Term('WithStatement', {\n      body: this.expand(term.body),\n      object: this.expand(term.object)\n    });\n  }\n\n  expandDebuggerStatement(term) { return term;}\n\n  expandContinueStatement(term) {\n    return new Term('ContinueStatement', {\n      label: term.label ? term.label.val() : null\n    });\n  }\n\n  expandSwitchStatementWithDefault(term) {\n    return new Term('SwitchStatementWithDefault', {\n      discriminant: this.expand(term.discriminant),\n      preDefaultCases: term.preDefaultCases.map(c => this.expand(c)).toArray(),\n      defaultCase: this.expand(term.defaultCase),\n      postDefaultCases: term.postDefaultCases.map(c => this.expand(c)).toArray()\n    });\n  }\n\n  expandComputedMemberExpression(term) {\n    return new Term('ComputedMemberExpression', {\n      object: this.expand(term.object),\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandSwitchStatement(term) {\n    return new Term('SwitchStatement', {\n      discriminant: this.expand(term.discriminant),\n      cases: term.cases.map(c => this.expand(c)).toArray()\n    });\n  }\n\n  expandFormalParameters(term) {\n    let rest = term.rest == null ? null : this.expand(term.rest);\n    return new Term('FormalParameters', {\n      items: term.items.map(i => this.expand(i)),\n      rest\n    });\n  }\n\n  expandArrowExpression(term) {\n    return this.doFunctionExpansion(term, 'ArrowExpression');\n  }\n\n  expandSwitchDefault(term) {\n    return new Term('SwitchDefault', {\n      consequent: term.consequent.map(c => this.expand(c)).toArray()\n    });\n  }\n\n  expandSwitchCase(term) {\n    return new Term('SwitchCase', {\n      test: this.expand(term.test),\n      consequent: term.consequent.map(c => this.expand(c)).toArray()\n    });\n  }\n\n  expandForInStatement(term) {\n    return new Term('ForInStatement', {\n      left: this.expand(term.left),\n      right: this.expand(term.right),\n      body: this.expand(term.body)\n    });\n  }\n\n  expandTryCatchStatement(term) {\n    return new Term('TryCatchStatement', {\n      body: this.expand(term.body),\n      catchClause: this.expand(term.catchClause)\n    });\n  }\n\n  expandTryFinallyStatement(term) {\n    let catchClause = term.catchClause == null ? null : this.expand(term.catchClause);\n    return new Term('TryFinallyStatement', {\n      body: this.expand(term.body),\n      catchClause,\n      finalizer: this.expand(term.finalizer)\n    });\n  }\n\n  expandCatchClause(term) {\n    return new Term('CatchClause', {\n      binding: this.expand(term.binding),\n      body: this.expand(term.body)\n    });\n  }\n\n  expandThrowStatement(term) {\n    return new Term('ThrowStatement', {\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandForOfStatement(term) {\n    return new Term('ForOfStatement', {\n      left: this.expand(term.left),\n      right: this.expand(term.right),\n      body: this.expand(term.body)\n    });\n  }\n\n  expandBindingIdentifier(term) {\n    return term;\n  }\n\n  expandBindingPropertyIdentifier(term) {\n    return term;\n  }\n  expandBindingPropertyProperty(term) {\n    return new Term('BindingPropertyProperty', {\n      name: this.expand(term.name),\n      binding: this.expand(term.binding)\n    });\n  }\n\n  expandComputedPropertyName(term) {\n    return new Term('ComputedPropertyName', {\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandObjectBinding(term) {\n    return new Term('ObjectBinding', {\n      properties: term.properties.map(t => this.expand(t)).toArray()\n    });\n  }\n\n  expandArrayBinding(term) {\n    let restElement = term.restElement == null ? null : this.expand(term.restElement);\n    return new Term('ArrayBinding', {\n      elements: term.elements.map(t => t == null ? null : this.expand(t)).toArray(),\n      restElement\n    });\n  }\n\n  expandBindingWithDefault(term) {\n    return new Term('BindingWithDefault', {\n      binding: this.expand(term.binding),\n      init: this.expand(term.init)\n    });\n  }\n\n  expandShorthandProperty(term) {\n    // because hygiene, shorthand properties must turn into DataProperties\n    return new Term('DataProperty', {\n      name: new Term('StaticPropertyName', {\n        value: term.name\n      }),\n      expression: new Term('IdentifierExpression', {\n        name: term.name\n      })\n    });\n  }\n\n\n  expandForStatement(term) {\n    let init = term.init == null ? null : this.expand(term.init);\n    let test = term.test == null ? null : this.expand(term.test);\n    let update = term.update == null ? null : this.expand(term.update);\n    let body = this.expand(term.body);\n    return new Term('ForStatement', { init, test, update, body });\n  }\n\n  expandYieldExpression(term) {\n    let expr = term.expression == null ? null : this.expand(term.expression);\n    return new Term('YieldExpression', {\n      expression: expr\n    });\n  }\n\n  expandYieldGeneratorExpression(term) {\n    let expr = term.expression == null ? null : this.expand(term.expression);\n    return new Term('YieldGeneratorExpression', {\n      expression: expr\n    });\n  }\n\n  expandWhileStatement(term) {\n    return new Term('WhileStatement', {\n      test: this.expand(term.test),\n      body: this.expand(term.body)\n    });\n  }\n\n  expandIfStatement(term) {\n    let consequent = term.consequent == null ? null : this.expand(term.consequent);\n    let alternate = term.alternate == null ? null : this.expand(term.alternate);\n    return new Term('IfStatement', {\n      test: this.expand(term.test),\n      consequent: consequent,\n      alternate: alternate\n    });\n  }\n\n  expandBlockStatement(term) {\n    return new Term('BlockStatement', {\n      block: this.expand(term.block)\n    });\n  }\n\n  expandBlock(term) {\n    let scope = freshScope('block');\n    this.context.currentScope.push(scope);\n    let compiler = new Compiler(this.context.phase, this.context.env, this.context.store, this.context);\n\n    let markedBody, bodyTerm;\n    markedBody = term.statements.map(b => b.addScope(scope, this.context.bindings, ALL_PHASES));\n    bodyTerm = new Term('Block', {\n      statements: compiler.compile(markedBody)\n    });\n    this.context.currentScope.pop();\n    return bodyTerm;\n  }\n\n  expandVariableDeclarationStatement(term) {\n    return new Term('VariableDeclarationStatement', {\n      declaration: this.expand(term.declaration)\n    });\n  }\n  expandReturnStatement(term) {\n    if (term.expression == null) {\n      return term;\n    }\n    return new Term(\"ReturnStatement\", {\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandClassDeclaration(term) {\n    return new Term('ClassDeclaration', {\n      name: term.name == null ? null : this.expand(term.name),\n      super: term.super == null ? null : this.expand(term.super),\n      elements: term.elements.map(el => this.expand(el)).toArray()\n    });\n  }\n\n  expandClassExpression(term) {\n    return new Term('ClassExpression', {\n      name: term.name == null ? null : this.expand(term.name),\n      super: term.super == null ? null : this.expand(term.super),\n      elements: term.elements.map(el => this.expand(el)).toArray()\n    });\n  }\n\n  expandClassElement(term) {\n    return new Term('ClassElement', {\n      isStatic: term.isStatic,\n      method: this.expand(term.method)\n    });\n  }\n\n  expandThisExpression(term) {\n    return term;\n  }\n\n  expandSyntaxTemplate(term) {\n    let r = processTemplate(term.template.inner());\n    let str = Syntax.from(\"string\", serializer.write(r.template));\n    let callee = new Term('IdentifierExpression', { name: Syntax.from(\"identifier\", 'syntaxTemplate') });\n\n    let expandedInterps = r.interp.map(i => {\n      let enf = new Enforester(i, List(), this.context);\n      return this.expand(enf.enforest('expression'));\n    });\n\n    let args = List.of(new Term('LiteralStringExpression', {value: str }))\n                   .concat(expandedInterps);\n\n    return new Term('CallExpression', {\n      callee, arguments: args\n    });\n  }\n\n  expandSyntaxQuote(term) {\n    let str = new Term(\"LiteralStringExpression\", {\n      value: Syntax.from(\"string\", serializer.write(term.name))\n    });\n\n    return new Term(\"TemplateExpression\", {\n      tag: term.template.tag,\n      elements: term.template.elements.push(str).push(new Term('TemplateElement', {\n        rawValue: ''\n      })).toArray()\n    });\n  }\n\n  expandStaticMemberExpression(term) {\n    return new Term(\"StaticMemberExpression\", {\n      object: this.expand(term.object),\n      property: term.property\n    });\n  }\n\n  expandArrayExpression(term) {\n    return new Term(\"ArrayExpression\", {\n      elements: term.elements.map(t => t == null ? t : this.expand(t))\n    });\n  }\n\n  expandImport(term) {\n    return term;\n  }\n\n  expandImportNamespace(term) {\n    return term;\n  }\n\n  expandExport(term) {\n    return new Term('Export', {\n      declaration: this.expand(term.declaration)\n    });\n  }\n\n  expandExportDefault(term) {\n    return new Term('ExportDefault', {\n      body: this.expand(term.body)\n    });\n  }\n\n\n  expandExportFrom(term) {\n    return term;\n  }\n\n  expandExportAllFrom(term) {\n    return term;\n  }\n\n  expandExportSpecifier(term) {\n    return term;\n  }\n\n  expandStaticPropertyName(term) {\n    return term;\n  }\n\n  expandDataProperty(term) {\n    return new Term(\"DataProperty\", {\n      name: this.expand(term.name),\n      expression: this.expand(term.expression)\n    });\n  }\n\n\n  expandObjectExpression(term) {\n    return new Term(\"ObjectExpression\", {\n      properties: term.properties.map(t => this.expand(t))\n    });\n  }\n\n  expandVariableDeclarator(term) {\n    let init = term.init == null ? null : this.expand(term.init);\n    return new Term(\"VariableDeclarator\", {\n      binding: this.expand(term.binding),\n      init: init\n    });\n  }\n\n  expandVariableDeclaration(term) {\n    if (term.kind === 'syntax' || term.kind === 'syntaxrec') {\n      return term;\n    }\n    return new Term(\"VariableDeclaration\", {\n      kind: term.kind,\n      declarators: term.declarators.map(d => this.expand(d))\n    });\n  }\n\n  expandParenthesizedExpression(term) {\n    if (term.inner.size === 0) {\n      throw new Error(\"unexpected end of input\");\n    }\n    let enf = new Enforester(term.inner, List(), this.context);\n    let lookahead = enf.peek();\n    let t = enf.enforestExpression();\n    if (t == null || enf.rest.size > 0) {\n      throw enf.createError(lookahead, \"unexpected syntax\");\n    }\n    return this.expand(t);\n  }\n\n  expandUnaryExpression(term) {\n    return new Term('UnaryExpression', {\n      operator: term.operator,\n      operand: this.expand(term.operand)\n    });\n  }\n\n  expandUpdateExpression(term) {\n    return new Term('UpdateExpression', {\n      isPrefix: term.isPrefix,\n      operator: term.operator,\n      operand: this.expand(term.operand)\n    });\n  }\n\n  expandBinaryExpression(term) {\n    let left = this.expand(term.left);\n    let right = this.expand(term.right);\n    return new Term(\"BinaryExpression\", {\n      left: left,\n      operator: term.operator,\n      right: right\n    });\n  }\n\n  expandConditionalExpression(term) {\n    return new Term('ConditionalExpression', {\n      test: this.expand(term.test),\n      consequent: this.expand(term.consequent),\n      alternate: this.expand(term.alternate)\n    });\n  }\n\n  expandNewTargetExpression(term) { return term; }\n\n  expandNewExpression(term) {\n    let callee = this.expand(term.callee);\n    let enf = new Enforester(term.arguments, List(), this.context);\n    let args = enf.enforestArgumentList().map(arg => this.expand(arg));\n    return new Term('NewExpression', {\n      callee,\n      arguments: args.toArray()\n    });\n  }\n\n  expandSuper(term) { return term; }\n\n  expandCallExpression(term) {\n    let callee = this.expand(term.callee);\n    let enf = new Enforester(term.arguments, List(), this.context);\n    let args = enf.enforestArgumentList().map(arg => this.expand(arg));\n    return new Term(\"CallExpression\", {\n      callee: callee,\n      arguments: args\n    });\n  }\n\n  expandSpreadElement(term) {\n    return new Term('SpreadElement', {\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandExpressionStatement(term) {\n    let child = this.expand(term.expression);\n    return new Term(\"ExpressionStatement\", {\n      expression: child\n    });\n  }\n\n  expandLabeledStatement(term) {\n    return new Term('LabeledStatement', {\n      label: term.label.val(),\n      body: this.expand(term.body)\n    });\n  }\n\n  doFunctionExpansion(term, type) {\n    let scope = freshScope(\"fun\");\n    let red = new ApplyScopeInParamsReducer(scope, this.context);\n    let params;\n    if (type !== 'Getter' && type !== 'Setter') {\n      params = red.transform(term.params);\n      params = this.expand(params);\n    }\n    this.context.currentScope.push(scope);\n    let compiler = new Compiler(this.context.phase, this.context.env, this.context.store, this.context);\n\n    let markedBody, bodyTerm;\n    if (term.body instanceof Term) {\n      // Arrow functions have a single term as their body\n      bodyTerm = this.expand(term.body.addScope(scope, this.context.bindings, ALL_PHASES));\n    } else {\n      markedBody = term.body.map(b => b.addScope(scope, this.context.bindings, ALL_PHASES));\n      bodyTerm = new Term(\"FunctionBody\", {\n        directives: List(),\n        statements: compiler.compile(markedBody)\n      });\n    }\n    this.context.currentScope.pop();\n\n    if (type === 'Getter') {\n      return new Term(type, {\n        name: this.expand(term.name),\n        body: bodyTerm\n      });\n    } else if (type === 'Setter') {\n      return new Term(type, {\n        name: this.expand(term.name),\n        param: term.param,\n        body: bodyTerm\n      });\n    } else if (type === 'ArrowExpression') {\n      return new Term(type, {\n        params: params,\n        body: bodyTerm\n      });\n    }\n    return new Term(type, {\n      name: term.name,\n      isGenerator: term.isGenerator,\n      params: params,\n      body: bodyTerm\n    });\n  }\n\n  expandMethod(term) {\n    return this.doFunctionExpansion(term, 'Method');\n  }\n\n  expandSetter(term) {\n    return this.doFunctionExpansion(term, 'Setter');\n  }\n\n  expandGetter(term) {\n    return this.doFunctionExpansion(term, 'Getter');\n  }\n\n  expandFunctionDeclaration(term) {\n    return this.doFunctionExpansion(term, \"FunctionDeclaration\");\n  }\n\n  expandFunctionExpression(term) {\n    return this.doFunctionExpansion(term, \"FunctionExpression\");\n  }\n\n  expandCompoundAssignmentExpression(term) {\n    return new Term(\"CompoundAssignmentExpression\", {\n      binding: this.expand(term.binding),\n      operator: term.operator,\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandAssignmentExpression(term) {\n    return new Term(\"AssignmentExpression\", {\n      binding: this.expand(term.binding),\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandEmptyStatement(term) {\n    return term;\n  }\n\n  expandLiteralBooleanExpression(term) {\n    return term;\n  }\n\n  expandLiteralNumericExpression(term) {\n    return term;\n  }\n  expandLiteralInfinityExpression(term) {\n    return term;\n  }\n\n  expandIdentifierExpression(term) {\n    let trans = this.context.env.get(term.name.resolve(this.context.phase));\n    if (trans) {\n      return new Term(\"IdentifierExpression\", {\n        name: trans.id\n      });\n    }\n    return term;\n  }\n\n  expandLiteralNullExpression(term) {\n    return term;\n  }\n\n  expandLiteralStringExpression(term) {\n    return term;\n  }\n\n  expandLiteralRegExpExpression(term) {\n    return term;\n  }\n}\n"]} /***/ }, -/* 66 */ +/* 62 */ /***/ function(module, exports, __webpack_require__) { "use strict"; @@ -38550,33 +40091,125 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack value: true }); - var _terms = __webpack_require__(28); + var _terms = __webpack_require__(9); var _terms2 = _interopRequireDefault(_terms); - var _shiftReducer = __webpack_require__(33); + var _symbol = __webpack_require__(47); + + var _transforms = __webpack_require__(38); + + var _errors = __webpack_require__(23); + + var _syntax = __webpack_require__(46); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - class MapSyntaxReducer extends _shiftReducer.CloneReducer { - constructor(fn_462) { - super(); - this.fn = fn_462; + class ScopeApplyingReducer { + constructor(scope, context) { + this.context = context; + this.scope = scope; + } + + transform(term) { + let field = "transform" + term.type; + if (typeof this[field] === 'function') { + return this[field](term); + } + (0, _errors.assert)(false, "transform not implemented yet for: " + term.type); } - reduceBindingIdentifier(node_463, state_464) { - let name_465 = this.fn(node_463.name); - return new _terms2.default("BindingIdentifier", { name: name_465 }); + + transformFormalParameters(term) { + let rest = term.rest == null ? null : this.transform(term.rest); + return new _terms2.default('FormalParameters', { + items: term.items.map(it => this.transform(it)), + rest: rest + }); + } + + transformBindingWithDefault(term) { + return new _terms2.default('BindingWithDefault', { + binding: this.transform(term.binding), + init: term.init + }); + } + + transformObjectBinding(term) { + // TODO: much more complicated logic here + return term; + // return new Term('ObjectBinding', { + // properties: term.properties.map(prop => this.transform(prop)) + // }); + } + + transformBindingPropertyIdentifier(term) { + return new _terms2.default('BindingPropertyIdentifier', { + binding: this.transform(term.binding), + init: term.init + }); + } + + transformBindingPropertyProperty(term) { + return new _terms2.default('BindingPropertyProperty', { + name: term.name, + binding: this.transform(term.binding) + }); + } + + transformArrayBinding(term) { + return new _terms2.default('ArrayBinding', { + elements: term.elements.map(el => this.transform(el)), + restElement: term.restElement == null ? null : this.transform(term.restElement) + }); } - reduceIdentifierExpression(node_466, state_467) { - let name_468 = this.fn(node_466.name); - return new _terms2.default("IdentifierExpression", { name: name_468 }); + + transformBindingIdentifier(term) { + let name = term.name.addScope(this.scope, this.context.bindings, _syntax.ALL_PHASES); + let newBinding = (0, _symbol.gensym)(name.val()); + + this.context.env.set(newBinding.toString(), new _transforms.VarBindingTransform(name)); + this.context.bindings.add(name, { + binding: newBinding, + phase: this.context.phase, + skipDup: true + }); + + return new _terms2.default("BindingIdentifier", { name: name }); } } - exports.default = MapSyntaxReducer; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L21hcC1zeW50YXgtcmVkdWNlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7OztBQUNBOzs7O0FBQ2UsTUFBTSxnQkFBTixvQ0FBNEM7QUFDekQsY0FBWSxNQUFaLEVBQW9CO0FBQ2xCO0FBQ0EsU0FBSyxFQUFMLEdBQVUsTUFBVjtBQUNEO0FBQ0QsMEJBQXdCLFFBQXhCLEVBQWtDLFNBQWxDLEVBQTZDO0FBQzNDLFFBQUksV0FBVyxLQUFLLEVBQUwsQ0FBUSxTQUFTLElBQWpCLENBQWY7QUFDQSxXQUFPLG9CQUFTLG1CQUFULEVBQThCLEVBQUMsTUFBTSxRQUFQLEVBQTlCLENBQVA7QUFDRDtBQUNELDZCQUEyQixRQUEzQixFQUFxQyxTQUFyQyxFQUFnRDtBQUM5QyxRQUFJLFdBQVcsS0FBSyxFQUFMLENBQVEsU0FBUyxJQUFqQixDQUFmO0FBQ0EsV0FBTyxvQkFBUyxzQkFBVCxFQUFpQyxFQUFDLE1BQU0sUUFBUCxFQUFqQyxDQUFQO0FBQ0Q7QUFad0Q7a0JBQXRDLGdCIiwiZmlsZSI6Im1hcC1zeW50YXgtcmVkdWNlci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBUZXJtIGZyb20gXCIuL3Rlcm1zXCI7XG5pbXBvcnQge0Nsb25lUmVkdWNlcn0gZnJvbSBcInNoaWZ0LXJlZHVjZXJcIjtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIE1hcFN5bnRheFJlZHVjZXIgZXh0ZW5kcyBDbG9uZVJlZHVjZXIge1xuICBjb25zdHJ1Y3Rvcihmbl80NjIpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMuZm4gPSBmbl80NjI7XG4gIH1cbiAgcmVkdWNlQmluZGluZ0lkZW50aWZpZXIobm9kZV80NjMsIHN0YXRlXzQ2NCkge1xuICAgIGxldCBuYW1lXzQ2NSA9IHRoaXMuZm4obm9kZV80NjMubmFtZSk7XG4gICAgcmV0dXJuIG5ldyBUZXJtKFwiQmluZGluZ0lkZW50aWZpZXJcIiwge25hbWU6IG5hbWVfNDY1fSk7XG4gIH1cbiAgcmVkdWNlSWRlbnRpZmllckV4cHJlc3Npb24obm9kZV80NjYsIHN0YXRlXzQ2Nykge1xuICAgIGxldCBuYW1lXzQ2OCA9IHRoaXMuZm4obm9kZV80NjYubmFtZSk7XG4gICAgcmV0dXJuIG5ldyBUZXJtKFwiSWRlbnRpZmllckV4cHJlc3Npb25cIiwge25hbWU6IG5hbWVfNDY4fSk7XG4gIH1cbn1cbiJdfQ== + exports.default = ScopeApplyingReducer; + //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hcHBseS1zY29wZS1pbi1wYXJhbXMtcmVkdWNlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7OztBQUNBOztBQUNBOztBQUNBOztBQUNBOzs7O0FBRWUsTUFBTSxvQkFBTixDQUEyQjtBQUN4QyxjQUFZLEtBQVosRUFBbUIsT0FBbkIsRUFBNEI7QUFDMUIsU0FBSyxPQUFMLEdBQWUsT0FBZjtBQUNBLFNBQUssS0FBTCxHQUFhLEtBQWI7QUFDRDs7QUFFRCxZQUFVLElBQVYsRUFBZ0I7QUFDZCxRQUFJLFFBQVEsY0FBYyxLQUFLLElBQS9CO0FBQ0EsUUFBSSxPQUFPLEtBQUssS0FBTCxDQUFQLEtBQXVCLFVBQTNCLEVBQXVDO0FBQ3JDLGFBQU8sS0FBSyxLQUFMLEVBQVksSUFBWixDQUFQO0FBQ0Q7QUFDRCx3QkFBTyxLQUFQLEVBQWMsd0NBQXdDLEtBQUssSUFBM0Q7QUFDRDs7QUFFRCw0QkFBMEIsSUFBMUIsRUFBZ0M7QUFDOUIsUUFBSSxPQUFPLEtBQUssSUFBTCxJQUFhLElBQWIsR0FBb0IsSUFBcEIsR0FBMkIsS0FBSyxTQUFMLENBQWUsS0FBSyxJQUFwQixDQUF0QztBQUNBLFdBQU8sb0JBQVMsa0JBQVQsRUFBNkI7QUFDbEMsYUFBTyxLQUFLLEtBQUwsQ0FBVyxHQUFYLENBQWUsTUFBTSxLQUFLLFNBQUwsQ0FBZSxFQUFmLENBQXJCLENBRDJCO0FBRWxDO0FBRmtDLEtBQTdCLENBQVA7QUFJRDs7QUFHRCw4QkFBNEIsSUFBNUIsRUFBa0M7QUFDaEMsV0FBTyxvQkFBUyxvQkFBVCxFQUErQjtBQUNwQyxlQUFTLEtBQUssU0FBTCxDQUFlLEtBQUssT0FBcEIsQ0FEMkI7QUFFcEMsWUFBTSxLQUFLO0FBRnlCLEtBQS9CLENBQVA7QUFJRDs7QUFFRCx5QkFBdUIsSUFBdkIsRUFBNkI7QUFDM0I7QUFDQSxXQUFPLElBQVA7QUFDQTtBQUNBO0FBQ0E7QUFDRDs7QUFFRCxxQ0FBbUMsSUFBbkMsRUFBeUM7QUFDdkMsV0FBTyxvQkFBUywyQkFBVCxFQUFzQztBQUMzQyxlQUFTLEtBQUssU0FBTCxDQUFlLEtBQUssT0FBcEIsQ0FEa0M7QUFFM0MsWUFBTSxLQUFLO0FBRmdDLEtBQXRDLENBQVA7QUFJRDs7QUFFRCxtQ0FBaUMsSUFBakMsRUFBdUM7QUFDckMsV0FBTyxvQkFBUyx5QkFBVCxFQUFvQztBQUN6QyxZQUFNLEtBQUssSUFEOEI7QUFFekMsZUFBUyxLQUFLLFNBQUwsQ0FBZSxLQUFLLE9BQXBCO0FBRmdDLEtBQXBDLENBQVA7QUFJRDs7QUFFRCx3QkFBc0IsSUFBdEIsRUFBNEI7QUFDMUIsV0FBTyxvQkFBUyxjQUFULEVBQXlCO0FBQzlCLGdCQUFVLEtBQUssUUFBTCxDQUFjLEdBQWQsQ0FBa0IsTUFBTSxLQUFLLFNBQUwsQ0FBZSxFQUFmLENBQXhCLENBRG9CO0FBRTlCLG1CQUFhLEtBQUssV0FBTCxJQUFvQixJQUFwQixHQUEyQixJQUEzQixHQUFrQyxLQUFLLFNBQUwsQ0FBZSxLQUFLLFdBQXBCO0FBRmpCLEtBQXpCLENBQVA7QUFJRDs7QUFFRCw2QkFBMkIsSUFBM0IsRUFBaUM7QUFDL0IsUUFBSSxPQUFPLEtBQUssSUFBTCxDQUFVLFFBQVYsQ0FBbUIsS0FBSyxLQUF4QixFQUErQixLQUFLLE9BQUwsQ0FBYSxRQUE1QyxxQkFBWDtBQUNBLFFBQUksYUFBYSxvQkFBTyxLQUFLLEdBQUwsRUFBUCxDQUFqQjs7QUFFQSxTQUFLLE9BQUwsQ0FBYSxHQUFiLENBQWlCLEdBQWpCLENBQXFCLFdBQVcsUUFBWCxFQUFyQixFQUE0QyxvQ0FBd0IsSUFBeEIsQ0FBNUM7QUFDQSxTQUFLLE9BQUwsQ0FBYSxRQUFiLENBQXNCLEdBQXRCLENBQTBCLElBQTFCLEVBQWdDO0FBQzlCLGVBQVMsVUFEcUI7QUFFOUIsYUFBTyxLQUFLLE9BQUwsQ0FBYSxLQUZVO0FBRzlCLGVBQVM7QUFIcUIsS0FBaEM7O0FBTUEsV0FBTyxvQkFBUyxtQkFBVCxFQUE4QixFQUFFLFVBQUYsRUFBOUIsQ0FBUDtBQUNEO0FBdkV1QztrQkFBckIsb0IiLCJmaWxlIjoiYXBwbHktc2NvcGUtaW4tcGFyYW1zLXJlZHVjZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgVGVybSBmcm9tIFwiLi90ZXJtc1wiO1xuaW1wb3J0IHsgZ2Vuc3ltIH0gZnJvbSBcIi4vc3ltYm9sXCI7XG5pbXBvcnQgeyBWYXJCaW5kaW5nVHJhbnNmb3JtIH0gZnJvbSBcIi4vdHJhbnNmb3Jtc1wiO1xuaW1wb3J0IHthc3NlcnR9IGZyb20gJy4vZXJyb3JzJztcbmltcG9ydCB7IEFMTF9QSEFTRVMgfSBmcm9tICcuL3N5bnRheCc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFNjb3BlQXBwbHlpbmdSZWR1Y2VyIHtcbiAgY29uc3RydWN0b3Ioc2NvcGUsIGNvbnRleHQpIHtcbiAgICB0aGlzLmNvbnRleHQgPSBjb250ZXh0O1xuICAgIHRoaXMuc2NvcGUgPSBzY29wZTtcbiAgfVxuXG4gIHRyYW5zZm9ybSh0ZXJtKSB7XG4gICAgbGV0IGZpZWxkID0gXCJ0cmFuc2Zvcm1cIiArIHRlcm0udHlwZTtcbiAgICBpZiAodHlwZW9mIHRoaXNbZmllbGRdID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICByZXR1cm4gdGhpc1tmaWVsZF0odGVybSk7XG4gICAgfVxuICAgIGFzc2VydChmYWxzZSwgXCJ0cmFuc2Zvcm0gbm90IGltcGxlbWVudGVkIHlldCBmb3I6IFwiICsgdGVybS50eXBlKTtcbiAgfVxuXG4gIHRyYW5zZm9ybUZvcm1hbFBhcmFtZXRlcnModGVybSkge1xuICAgIGxldCByZXN0ID0gdGVybS5yZXN0ID09IG51bGwgPyBudWxsIDogdGhpcy50cmFuc2Zvcm0odGVybS5yZXN0KTtcbiAgICByZXR1cm4gbmV3IFRlcm0oJ0Zvcm1hbFBhcmFtZXRlcnMnLCB7XG4gICAgICBpdGVtczogdGVybS5pdGVtcy5tYXAoaXQgPT4gdGhpcy50cmFuc2Zvcm0oaXQpKSxcbiAgICAgIHJlc3RcbiAgICB9KTtcbiAgfVxuXG5cbiAgdHJhbnNmb3JtQmluZGluZ1dpdGhEZWZhdWx0KHRlcm0pIHtcbiAgICByZXR1cm4gbmV3IFRlcm0oJ0JpbmRpbmdXaXRoRGVmYXVsdCcsIHtcbiAgICAgIGJpbmRpbmc6IHRoaXMudHJhbnNmb3JtKHRlcm0uYmluZGluZyksXG4gICAgICBpbml0OiB0ZXJtLmluaXRcbiAgICB9KTtcbiAgfVxuXG4gIHRyYW5zZm9ybU9iamVjdEJpbmRpbmcodGVybSkge1xuICAgIC8vIFRPRE86IG11Y2ggbW9yZSBjb21wbGljYXRlZCBsb2dpYyBoZXJlXG4gICAgcmV0dXJuIHRlcm07XG4gICAgLy8gcmV0dXJuIG5ldyBUZXJtKCdPYmplY3RCaW5kaW5nJywge1xuICAgIC8vICAgcHJvcGVydGllczogdGVybS5wcm9wZXJ0aWVzLm1hcChwcm9wID0+IHRoaXMudHJhbnNmb3JtKHByb3ApKVxuICAgIC8vIH0pO1xuICB9XG5cbiAgdHJhbnNmb3JtQmluZGluZ1Byb3BlcnR5SWRlbnRpZmllcih0ZXJtKSB7XG4gICAgcmV0dXJuIG5ldyBUZXJtKCdCaW5kaW5nUHJvcGVydHlJZGVudGlmaWVyJywge1xuICAgICAgYmluZGluZzogdGhpcy50cmFuc2Zvcm0odGVybS5iaW5kaW5nKSxcbiAgICAgIGluaXQ6IHRlcm0uaW5pdFxuICAgIH0pO1xuICB9XG5cbiAgdHJhbnNmb3JtQmluZGluZ1Byb3BlcnR5UHJvcGVydHkodGVybSkge1xuICAgIHJldHVybiBuZXcgVGVybSgnQmluZGluZ1Byb3BlcnR5UHJvcGVydHknLCB7XG4gICAgICBuYW1lOiB0ZXJtLm5hbWUsXG4gICAgICBiaW5kaW5nOiB0aGlzLnRyYW5zZm9ybSh0ZXJtLmJpbmRpbmcpXG4gICAgfSk7XG4gIH1cblxuICB0cmFuc2Zvcm1BcnJheUJpbmRpbmcodGVybSkge1xuICAgIHJldHVybiBuZXcgVGVybSgnQXJyYXlCaW5kaW5nJywge1xuICAgICAgZWxlbWVudHM6IHRlcm0uZWxlbWVudHMubWFwKGVsID0+IHRoaXMudHJhbnNmb3JtKGVsKSksXG4gICAgICByZXN0RWxlbWVudDogdGVybS5yZXN0RWxlbWVudCA9PSBudWxsID8gbnVsbCA6IHRoaXMudHJhbnNmb3JtKHRlcm0ucmVzdEVsZW1lbnQpXG4gICAgfSk7XG4gIH1cblxuICB0cmFuc2Zvcm1CaW5kaW5nSWRlbnRpZmllcih0ZXJtKSB7XG4gICAgbGV0IG5hbWUgPSB0ZXJtLm5hbWUuYWRkU2NvcGUodGhpcy5zY29wZSwgdGhpcy5jb250ZXh0LmJpbmRpbmdzLCBBTExfUEhBU0VTKTtcbiAgICBsZXQgbmV3QmluZGluZyA9IGdlbnN5bShuYW1lLnZhbCgpKTtcblxuICAgIHRoaXMuY29udGV4dC5lbnYuc2V0KG5ld0JpbmRpbmcudG9TdHJpbmcoKSwgbmV3IFZhckJpbmRpbmdUcmFuc2Zvcm0obmFtZSkpO1xuICAgIHRoaXMuY29udGV4dC5iaW5kaW5ncy5hZGQobmFtZSwge1xuICAgICAgYmluZGluZzogbmV3QmluZGluZyxcbiAgICAgIHBoYXNlOiB0aGlzLmNvbnRleHQucGhhc2UsXG4gICAgICBza2lwRHVwOiB0cnVlXG4gICAgfSk7XG5cbiAgICByZXR1cm4gbmV3IFRlcm0oXCJCaW5kaW5nSWRlbnRpZmllclwiLCB7IG5hbWUgfSk7XG4gIH1cbn1cbiJdfQ== /***/ }, -/* 67 */ +/* 63 */ +/***/ function(module, exports) { + + 'use strict'; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + class ASTDispatcher { + constructor(prefix, errorIfMissing) { + this.errorIfMissing = errorIfMissing; + this.prefix = prefix; + } + + dispatch(term) { + let field = this.prefix + term.type; + if (typeof this[field] === 'function') { + return this[field](term); + } else if (!this.errorIfMissing) { + return term; + } + throw new Error(`Missing implementation for: ${ field }`); + } + } + exports.default = ASTDispatcher; + //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hc3QtZGlzcGF0Y2hlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFlLE1BQU0sYUFBTixDQUFvQjtBQUNqQyxjQUFZLE1BQVosRUFBb0IsY0FBcEIsRUFBb0M7QUFDbEMsU0FBSyxjQUFMLEdBQXNCLGNBQXRCO0FBQ0EsU0FBSyxNQUFMLEdBQWMsTUFBZDtBQUNEOztBQUVELFdBQVMsSUFBVCxFQUFlO0FBQ2IsUUFBSSxRQUFRLEtBQUssTUFBTCxHQUFjLEtBQUssSUFBL0I7QUFDQSxRQUFJLE9BQU8sS0FBSyxLQUFMLENBQVAsS0FBdUIsVUFBM0IsRUFBdUM7QUFDckMsYUFBTyxLQUFLLEtBQUwsRUFBWSxJQUFaLENBQVA7QUFDRCxLQUZELE1BRU8sSUFBSSxDQUFDLEtBQUssY0FBVixFQUEwQjtBQUMvQixhQUFPLElBQVA7QUFDRDtBQUNELFVBQU0sSUFBSSxLQUFKLENBQVcsZ0NBQThCLEtBQU0sR0FBL0MsQ0FBTjtBQUNEO0FBZGdDO2tCQUFkLGEiLCJmaWxlIjoiYXN0LWRpc3BhdGNoZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZGVmYXVsdCBjbGFzcyBBU1REaXNwYXRjaGVyIHtcbiAgY29uc3RydWN0b3IocHJlZml4LCBlcnJvcklmTWlzc2luZykge1xuICAgIHRoaXMuZXJyb3JJZk1pc3NpbmcgPSBlcnJvcklmTWlzc2luZztcbiAgICB0aGlzLnByZWZpeCA9IHByZWZpeDtcbiAgfVxuXG4gIGRpc3BhdGNoKHRlcm0pIHtcbiAgICBsZXQgZmllbGQgPSB0aGlzLnByZWZpeCArIHRlcm0udHlwZTtcbiAgICBpZiAodHlwZW9mIHRoaXNbZmllbGRdID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICByZXR1cm4gdGhpc1tmaWVsZF0odGVybSk7XG4gICAgfSBlbHNlIGlmICghdGhpcy5lcnJvcklmTWlzc2luZykge1xuICAgICAgcmV0dXJuIHRlcm07XG4gICAgfVxuICAgIHRocm93IG5ldyBFcnJvcihgTWlzc2luZyBpbXBsZW1lbnRhdGlvbiBmb3I6ICR7ZmllbGR9YCk7XG4gIH1cbn1cbiJdfQ== + +/***/ }, +/* 64 */ /***/ function(module, exports, __webpack_require__) { "use strict"; @@ -38584,77 +40217,382 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack Object.defineProperty(exports, "__esModule", { value: true }); - exports.collectBindings = exports.CollectBindingSyntax = undefined; - var _symbol = __webpack_require__(45); + var _immutable = __webpack_require__(3); - var _transforms = __webpack_require__(32); + var _enforester = __webpack_require__(56); - var _errors = __webpack_require__(13); + var _termExpander = __webpack_require__(61); - var _terms = __webpack_require__(28); + var _termExpander2 = _interopRequireDefault(_termExpander); - var _terms2 = _interopRequireDefault(_terms); + var _env = __webpack_require__(37); - var _immutable = __webpack_require__(11); + var _env2 = _interopRequireDefault(_env); - var _astDispatcher = __webpack_require__(64); + var _ramda = __webpack_require__(10); - var _astDispatcher2 = _interopRequireDefault(_astDispatcher); + var _ = _interopRequireWildcard(_ramda); - var _ramda = __webpack_require__(27); + var _terms = __webpack_require__(9); - var _ = _interopRequireWildcard(_ramda); + var T = _interopRequireWildcard(_terms); + + var _symbol = __webpack_require__(47); + + var _transforms = __webpack_require__(38); + + var _errors = __webpack_require__(23); + + var _loadSyntax = __webpack_require__(48); + + var _scope = __webpack_require__(58); + + var _syntax = __webpack_require__(46); + + var _astDispatcher = __webpack_require__(63); + + var _astDispatcher2 = _interopRequireDefault(_astDispatcher); + + var _hygieneUtils = __webpack_require__(65); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - class CollectBindingSyntax_346 extends _astDispatcher2.default { + function bindImports(impTerm, exModule, context) { + let names = []; + let phase = impTerm.forSyntax ? context.phase + 1 : context.phase; + impTerm.namedImports.forEach(specifier => { + let name = specifier.binding.name; + let exportName = findNameInExports(name, exModule.exportEntries); + if (exportName != null) { + let newBinding = (0, _symbol.gensym)(name.val()); + context.store.set(newBinding.toString(), new _transforms.VarBindingTransform(name)); + context.bindings.addForward(name, exportName, newBinding, phase); + names.push(name); + } + }); + return (0, _immutable.List)(names); + } + + function findNameInExports(name, exp) { + let foundNames = exp.reduce((acc, e) => { + if (T.isExportFrom(e)) { + return acc.concat(e.namedExports.reduce((acc, specifier) => { + if (specifier.exportedName.val() === name.val()) { + return acc.concat(specifier.exportedName); + } + return acc; + }, (0, _immutable.List)())); + } else if (T.isExport(e)) { + return acc.concat(e.declaration.declarators.reduce((acc, decl) => { + if (decl.binding.name.val() === name.val()) { + return acc.concat(decl.binding.name); + } + return acc; + }, (0, _immutable.List)())); + } + return acc; + }, (0, _immutable.List)()); + (0, _errors.assert)(foundNames.size <= 1, 'expecting no more than 1 matching name in exports'); + return foundNames.get(0); + } + + function removeNames(impTerm, names) { + let namedImports = impTerm.namedImports.filter(specifier => !names.contains(specifier.binding.name)); + return impTerm.extend({ namedImports: namedImports }); + } + + // function bindAllSyntaxExports(exModule, toSynth, context) { + // let phase = context.phase; + // exModule.exportEntries.forEach(ex => { + // if (isExportSyntax(ex)) { + // ex.declaration.declarators.forEach(decl => { + // let name = decl.binding.name; + // let newBinding = gensym(name.val()); + // let storeName = exModule.moduleSpecifier + ":" + name.val() + ":" + phase; + // let synthStx = Syntax.fromIdentifier(name.val(), toSynth); + // let storeStx = Syntax.fromIdentifier(storeName, toSynth); + // context.bindings.addForward(synthStx, storeStx, newBinding, phase); + // }); + // } + // }); + // } + + class TokenExpander extends _astDispatcher2.default { + constructor(context) { + super('expand', false); + this.context = context; + } + + expand(stxl) { + let result = []; + if (stxl.size === 0) { + return (0, _immutable.List)(result); + } + let prev = (0, _immutable.List)(); + let enf = new _enforester.Enforester(stxl, prev, this.context); + + while (!enf.done) { + result.push(this.dispatch(enf.enforest())); + } + + return (0, _immutable.List)(result); + } + + expandVariableDeclarationStatement(term) { + return term.extend({ + declaration: this.registerVariableDeclaration(term.declaration) + }); + } + + expandFunctionDeclaration(term) { + let registeredTerm = this.registerFunctionOrClass(term); + let stx = registeredTerm.name.name; + this.context.env.set(stx.resolve(this.context.phase), new _transforms.VarBindingTransform(stx)); + return registeredTerm; + } + + // TODO: think about function expressions + + expandImport(term) { + let path = term.moduleSpecifier.val(); + let mod; + if (term.forSyntax) { + mod = this.context.modules.getAtPhase(path, this.context.phase + 1, this.context.cwd); + this.context.store = this.context.modules.visit(mod, this.context.phase + 1, this.context.store); + this.context.store = this.context.modules.invoke(mod, this.context.phase + 1, this.context.store); + } else { + mod = this.context.modules.getAtPhase(path, this.context.phase, this.context.cwd); + this.context.store = this.context.modules.visit(mod, this.context.phase, this.context.store); + } + let boundNames = bindImports(term, mod, this.context); + return removeNames(term, boundNames); + } + + expandExport(term) { + if (T.isFunctionDeclaration(term.declaration) || T.isClassDeclaration(term.declaration)) { + return term.extend({ + declaration: this.registerFunctionOrClass(term.declaration) + }); + } else if (T.isVariableDeclaration(term.declaration)) { + return term.extend({ + declaration: this.registerVariableDeclaration(term.declaration) + }); + } + return term; + } + + // [isPragma, term => { + // let pathStx = term.items.get(0); + // if (pathStx.val() === 'base') { + // return term; + // } + // let mod = this.context.modules.loadAndCompile(pathStx.val()); + // store = this.context.modules.visit(mod, phase, store); + // bindAllSyntaxExports(mod, pathStx, this.context); + // return term; + // }], + + registerFunctionOrClass(term) { + let name = term.name.removeScope(this.context.useScope, this.context.phase); + (0, _hygieneUtils.collectBindings)(term.name).forEach(stx => { + let newBinding = (0, _symbol.gensym)(stx.val()); + this.context.bindings.add(stx, { + binding: newBinding, + phase: this.context.phase, + skipDup: false + }); + // the meaning of a function declaration name is a runtime var binding + this.context.env.set(newBinding.toString(), new _transforms.VarBindingTransform(stx)); + }); + return term.extend({ name: name }); + } + + registerVariableDeclaration(term) { + if (T.isSyntaxDeclaration(term) || T.isSyntaxrecDeclaration(term)) { + return this.registerSyntaxDeclaration(term); + } + return term.extend({ + declarators: term.declarators.map(decl => { + let binding = decl.binding.removeScope(this.context.useScope, this.context.phase); + (0, _hygieneUtils.collectBindings)(binding).forEach(stx => { + let newBinding = (0, _symbol.gensym)(stx.val()); + this.context.bindings.add(stx, { + binding: newBinding, + phase: this.context.phase, + skipDup: term.kind === 'var' + }); + // the meaning of a var/let/const declaration is a var binding + this.context.env.set(newBinding.toString(), new _transforms.VarBindingTransform(stx)); + }); + return decl.extend({ binding: binding }); + }) + }); + } + + registerSyntaxDeclaration(term) { + // syntax id^{a, b} = ^{a, b} + // -> + // syntaxrec id^{a,b,c} = function() { return <> } + // syntaxrec id^{a,b} = ^{a,b,c} + if (T.isSyntaxDeclaration(term)) { + let scope = (0, _scope.freshScope)('nonrec'); + term = term.extend({ + declarators: term.declarators.map(decl => { + let name = decl.binding.name; + let nameAdded = name.addScope(scope, this.context.bindings, _syntax.ALL_PHASES); + let nameRemoved = name.removeScope(this.context.currentScope[this.context.currentScope.length - 1], this.context.phase); + let newBinding = (0, _symbol.gensym)(name.val()); + this.context.bindings.addForward(nameAdded, nameRemoved, newBinding, this.context.phase); + return decl.extend({ + init: decl.init.addScope(scope, this.context.bindings, _syntax.ALL_PHASES) + }); + }) + }); + } + + // for syntax declarations we need to load the compiletime value + // into the environment + return term.extend({ + declarators: term.declarators.map(decl => { + let binding = decl.binding.removeScope(this.context.useScope, this.context.phase); + // each compiletime value needs to be expanded with a fresh + // environment and in the next higher phase + let syntaxExpander = new _termExpander2.default(_.merge(this.context, { + phase: this.context.phase + 1, + env: new _env2.default(), + store: this.context.store + })); + let init = syntaxExpander.expand(decl.init); + let val = (0, _loadSyntax.evalCompiletimeValue)(init.gen(), _.merge(this.context, { + phase: this.context.phase + 1 + })); + (0, _hygieneUtils.collectBindings)(binding).forEach(stx => { + let newBinding = (0, _symbol.gensym)(stx.val()); + this.context.bindings.add(stx, { + binding: newBinding, + phase: this.context.phase, + skipDup: false + }); + let resolvedName = stx.resolve(this.context.phase); + this.context.env.set(resolvedName, new _transforms.CompiletimeTransform(val)); + }); + return decl.extend({ binding: binding, init: init }); + }) + }); + } + } + exports.default = TokenExpander; + //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/token-expander.js"],"names":[],"mappings":"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","file":"token-expander.js","sourcesContent":["import { List } from 'immutable';\nimport {  Enforester } from \"./enforester\";\nimport TermExpander from \"./term-expander.js\";\nimport Env from \"./env\";\nimport * as _ from \"ramda\";\nimport * as T from \"./terms\";\nimport { gensym } from './symbol';\nimport { VarBindingTransform, CompiletimeTransform } from './transforms';\nimport {  assert } from \"./errors\";\nimport { evalCompiletimeValue } from './load-syntax';\nimport {  freshScope } from \"./scope\";\nimport { ALL_PHASES } from './syntax';\nimport ASTDispatcher from './ast-dispatcher';\nimport { collectBindings } from './hygiene-utils';\n\nfunction bindImports(impTerm, exModule, context) {\n  let names = [];\n  let phase = impTerm.forSyntax ? context.phase + 1 : context.phase;\n  impTerm.namedImports.forEach(specifier => {\n    let name = specifier.binding.name;\n    let exportName = findNameInExports(name, exModule.exportEntries);\n    if (exportName != null) {\n      let newBinding = gensym(name.val());\n      context.store.set(newBinding.toString(), new VarBindingTransform(name));\n      context.bindings.addForward(name, exportName, newBinding, phase);\n      names.push(name);\n    }\n  });\n  return List(names);\n}\n\n\nfunction findNameInExports(name, exp) {\n  let foundNames = exp.reduce((acc, e) => {\n    if (T.isExportFrom(e)) {\n      return acc.concat(e.namedExports.reduce((acc, specifier) => {\n        if (specifier.exportedName.val() === name.val()) {\n          return acc.concat(specifier.exportedName);\n        }\n        return acc;\n      }, List()));\n    } else if (T.isExport(e)) {\n      return acc.concat(e.declaration.declarators.reduce((acc, decl) => {\n        if (decl.binding.name.val() === name.val()) {\n          return acc.concat(decl.binding.name);\n        }\n        return acc;\n      }, List()));\n    }\n    return acc;\n  }, List());\n  assert(foundNames.size <= 1, 'expecting no more than 1 matching name in exports');\n  return foundNames.get(0);\n}\n\nfunction removeNames(impTerm, names) {\n  let namedImports = impTerm.namedImports.filter(specifier => !names.contains(specifier.binding.name));\n  return impTerm.extend({ namedImports });\n}\n\n// function bindAllSyntaxExports(exModule, toSynth, context) {\n//   let phase = context.phase;\n//   exModule.exportEntries.forEach(ex => {\n//     if (isExportSyntax(ex)) {\n//       ex.declaration.declarators.forEach(decl => {\n//         let name = decl.binding.name;\n//         let newBinding = gensym(name.val());\n//         let storeName = exModule.moduleSpecifier + \":\" + name.val() + \":\" + phase;\n//         let synthStx = Syntax.fromIdentifier(name.val(), toSynth);\n//         let storeStx = Syntax.fromIdentifier(storeName, toSynth);\n//         context.bindings.addForward(synthStx, storeStx, newBinding, phase);\n//       });\n//     }\n//   });\n// }\n\nexport default class TokenExpander extends ASTDispatcher {\n  constructor(context) {\n    super('expand', false);\n    this.context = context;\n  }\n\n  expand(stxl) {\n    let result = [];\n    if (stxl.size === 0) {\n      return List(result);\n    }\n    let prev = List();\n    let enf = new Enforester(stxl, prev, this.context);\n\n    while(!enf.done) {\n      result.push(this.dispatch(enf.enforest()));\n    }\n\n    return List(result);\n  }\n\n  expandVariableDeclarationStatement(term) {\n    return term.extend({\n      declaration: this.registerVariableDeclaration(term.declaration)\n    });\n  }\n\n  expandFunctionDeclaration(term) {\n    let registeredTerm = this.registerFunctionOrClass(term);\n    let stx = registeredTerm.name.name;\n    this.context.env.set(stx.resolve(this.context.phase),\n                         new VarBindingTransform(stx));\n    return registeredTerm;\n  }\n\n  // TODO: think about function expressions\n\n  expandImport(term) {\n    let path = term.moduleSpecifier.val();\n    let mod;\n    if (term.forSyntax) {\n      mod = this.context.modules.getAtPhase(path, this.context.phase + 1, this.context.cwd);\n      this.context.store = this.context.modules.visit(mod, this.context.phase + 1, this.context.store);\n      this.context.store = this.context.modules.invoke(mod, this.context.phase + 1, this.context.store);\n    } else {\n      mod = this.context.modules.getAtPhase(path, this.context.phase, this.context.cwd);\n      this.context.store = this.context.modules.visit(mod, this.context.phase, this.context.store);\n    }\n    let boundNames = bindImports(term, mod, this.context);\n    return removeNames(term, boundNames);\n  }\n\n  expandExport(term) {\n    if (T.isFunctionDeclaration(term.declaration) || T.isClassDeclaration(term.declaration)) {\n      return term.extend({\n        declaration: this.registerFunctionOrClass(term.declaration)\n      });\n    } else if (T.isVariableDeclaration(term.declaration)) {\n      return term.extend({\n        declaration: this.registerVariableDeclaration(term.declaration)\n      });\n    }\n    return term;\n  }\n\n  // [isPragma, term => {\n  //   let pathStx = term.items.get(0);\n  //   if (pathStx.val() === 'base') {\n  //     return term;\n  //   }\n  //   let mod = this.context.modules.loadAndCompile(pathStx.val());\n  //   store = this.context.modules.visit(mod, phase, store);\n  //   bindAllSyntaxExports(mod, pathStx, this.context);\n  //   return term;\n  // }],\n\n\n  registerFunctionOrClass(term) {\n    let name = term.name.removeScope(this.context.useScope, this.context.phase);\n    collectBindings(term.name).forEach(stx => {\n      let newBinding = gensym(stx.val());\n      this.context.bindings.add(stx, {\n        binding: newBinding,\n        phase: this.context.phase,\n        skipDup: false\n      });\n      // the meaning of a function declaration name is a runtime var binding\n      this.context.env.set(newBinding.toString(), new VarBindingTransform(stx));\n    });\n    return term.extend({ name });\n  }\n\n  registerVariableDeclaration(term) {\n    if (T.isSyntaxDeclaration(term) || T.isSyntaxrecDeclaration(term)) {\n      return this.registerSyntaxDeclaration(term);\n    }\n    return term.extend({\n      declarators: term.declarators.map(decl => {\n        let binding = decl.binding.removeScope(this.context.useScope, this.context.phase);\n        collectBindings(binding).forEach(stx => {\n          let newBinding = gensym(stx.val());\n          this.context.bindings.add(stx, {\n            binding: newBinding,\n            phase: this.context.phase,\n            skipDup: term.kind === 'var'\n          });\n          // the meaning of a var/let/const declaration is a var binding\n          this.context.env.set(newBinding.toString(), new VarBindingTransform(stx));\n        });\n        return decl.extend({ binding });\n      })\n    });\n  }\n\n  registerSyntaxDeclaration(term) {\n    // syntax id^{a, b} = <init>^{a, b}\n    // ->\n    // syntaxrec id^{a,b,c} = function() { return <<id^{a}>> }\n    // syntaxrec id^{a,b} = <init>^{a,b,c}\n    if (T.isSyntaxDeclaration(term)) {\n      let scope = freshScope('nonrec');\n      term = term.extend({\n        declarators: term.declarators.map(decl => {\n          let name = decl.binding.name;\n          let nameAdded = name.addScope(scope, this.context.bindings, ALL_PHASES);\n          let nameRemoved = name.removeScope(this.context.currentScope[this.context.currentScope.length - 1], this.context.phase);\n          let newBinding = gensym(name.val());\n          this.context.bindings.addForward(nameAdded, nameRemoved, newBinding, this.context.phase);\n          return decl.extend({\n            init: decl.init.addScope(scope, this.context.bindings, ALL_PHASES)\n          });\n        })\n      });\n    }\n\n    // for syntax declarations we need to load the compiletime value\n    // into the environment\n    return term.extend({\n      declarators: term.declarators.map(decl => {\n        let binding = decl.binding.removeScope(this.context.useScope, this.context.phase);\n        // each compiletime value needs to be expanded with a fresh\n        // environment and in the next higher phase\n        let syntaxExpander = new TermExpander(_.merge(this.context, {\n          phase: this.context.phase + 1,\n          env: new Env(),\n          store: this.context.store\n        }));\n        let init = syntaxExpander.expand(decl.init);\n        let val = evalCompiletimeValue(init.gen(), _.merge(this.context, {\n          phase: this.context.phase + 1\n        }));\n        collectBindings(binding).forEach(stx => {\n          let newBinding = gensym(stx.val());\n          this.context.bindings.add(stx, {\n            binding: newBinding,\n            phase: this.context.phase,\n            skipDup: false\n          });\n          let resolvedName = stx.resolve(this.context.phase);\n          this.context.env.set(resolvedName, new CompiletimeTransform(val));\n        });\n        return decl.extend({ binding, init });\n      })\n    });\n  }\n}\n"]} + +/***/ }, +/* 65 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.CollectBindingSyntax = undefined; + exports.collectBindings = collectBindings; + + var _immutable = __webpack_require__(3); + + var _astDispatcher = __webpack_require__(63); + + var _astDispatcher2 = _interopRequireDefault(_astDispatcher); + + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + + class CollectBindingSyntax extends _astDispatcher2.default { constructor() { - super("collect", true); + super('collect', true); this.names = (0, _immutable.List)(); } - collect(term_348) { - return this.dispatch(term_348); + + // registerSyntax(stx) { + // let newBinding = gensym(stx.val()); + // this.context.bindings.add(stx, { + // binding: newBinding, + // phase: this.context.phase, + // // skip dup because js allows variable redeclarations + // // (technically only for `var` but we can let later stages of the pipeline + // // handle incorrect redeclarations of `const` and `let`) + // skipDup: true + // }); + // return stx; + // } + + collect(term) { + return this.dispatch(term); } - collectBindingIdentifier(term_349) { - return this.names.concat(term_349.name); + + collectBindingIdentifier(term) { + return this.names.concat(term.name); } - collectBindingPropertyIdentifier(term_350) { - return this.collect(term_350.binding); + + collectBindingPropertyIdentifier(term) { + return this.collect(term.binding); } - collectBindingPropertyProperty(term_351) { - return this.collect(term_351.binding); + + collectBindingPropertyProperty(term) { + return this.collect(term.binding); } - collectArrayBinding(term_352) { - let restElement_353 = null; - if (term_352.restElement != null) { - restElement_353 = this.collect(term_352.restElement); + + collectArrayBinding(term) { + let restElement = null; + if (term.restElement != null) { + restElement = this.collect(term.restElement); } - return this.names.concat(restElement_353).concat(term_352.elements.filter(el_354 => el_354 != null).flatMap(el_355 => this.collect(el_355))); + return this.names.concat(restElement).concat(term.elements.filter(el => el != null).flatMap(el => this.collect(el))); } - collectObjectBinding(term_356) { + + collectObjectBinding() { + // return term.properties.flatMap(prop => this.collect(prop)); return (0, _immutable.List)(); } + + // registerVariableDeclaration(term) { + // let declarators = term.declarators.map(decl => { + // return decl.extend({ + // binding: this.register(decl.binding) + // }); + // }); + // return term.extend({ declarators }); + // } + // + // registerFunctionDeclaration(term) { + // return term.extend({ + // name: this.register(term.name) + // }); + // } + // + // registerExport(term) { + // return term.extend({ + // declaration: this.register(term.declaration) + // }); + // } } - function collectBindings_347(term_357) { - return new CollectBindingSyntax_346().collect(term_357); + + exports.CollectBindingSyntax = CollectBindingSyntax; + function collectBindings(term) { + return new CollectBindingSyntax().collect(term); } - exports.CollectBindingSyntax = CollectBindingSyntax_346; - exports.collectBindings = collectBindings_347; - //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2h5Z2llbmUtdXRpbHMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOzs7O0FBQ0E7O0FBQ0E7Ozs7QUFDQTs7SUFBYSxDOzs7Ozs7QUFDYixNQUFNLHdCQUFOLGlDQUFxRDtBQUNuRCxnQkFBYztBQUNaLFVBQU0sU0FBTixFQUFpQixJQUFqQjtBQUNBLFNBQUssS0FBTCxHQUFhLHNCQUFiO0FBQ0Q7QUFDRCxVQUFRLFFBQVIsRUFBa0I7QUFDaEIsV0FBTyxLQUFLLFFBQUwsQ0FBYyxRQUFkLENBQVA7QUFDRDtBQUNELDJCQUF5QixRQUF6QixFQUFtQztBQUNqQyxXQUFPLEtBQUssS0FBTCxDQUFXLE1BQVgsQ0FBa0IsU0FBUyxJQUEzQixDQUFQO0FBQ0Q7QUFDRCxtQ0FBaUMsUUFBakMsRUFBMkM7QUFDekMsV0FBTyxLQUFLLE9BQUwsQ0FBYSxTQUFTLE9BQXRCLENBQVA7QUFDRDtBQUNELGlDQUErQixRQUEvQixFQUF5QztBQUN2QyxXQUFPLEtBQUssT0FBTCxDQUFhLFNBQVMsT0FBdEIsQ0FBUDtBQUNEO0FBQ0Qsc0JBQW9CLFFBQXBCLEVBQThCO0FBQzVCLFFBQUksa0JBQWtCLElBQXRCO0FBQ0EsUUFBSSxTQUFTLFdBQVQsSUFBd0IsSUFBNUIsRUFBa0M7QUFDaEMsd0JBQWtCLEtBQUssT0FBTCxDQUFhLFNBQVMsV0FBdEIsQ0FBbEI7QUFDRDtBQUNELFdBQU8sS0FBSyxLQUFMLENBQVcsTUFBWCxDQUFrQixlQUFsQixFQUFtQyxNQUFuQyxDQUEwQyxTQUFTLFFBQVQsQ0FBa0IsTUFBbEIsQ0FBeUIsVUFBVSxVQUFVLElBQTdDLEVBQW1ELE9BQW5ELENBQTJELFVBQVUsS0FBSyxPQUFMLENBQWEsTUFBYixDQUFyRSxDQUExQyxDQUFQO0FBQ0Q7QUFDRCx1QkFBcUIsUUFBckIsRUFBK0I7QUFDN0IsV0FBTyxzQkFBUDtBQUNEO0FBMUJrRDtBQTRCckQsU0FBUyxtQkFBVCxDQUE2QixRQUE3QixFQUF1QztBQUNyQyxTQUFRLElBQUksd0JBQUosRUFBRCxDQUErQixPQUEvQixDQUF1QyxRQUF2QyxDQUFQO0FBQ0Q7UUFDbUMsb0IsR0FBNUIsd0I7UUFDdUIsZSxHQUF2QixtQiIsImZpbGUiOiJoeWdpZW5lLXV0aWxzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtnZW5zeW19IGZyb20gXCIuL3N5bWJvbFwiO1xuaW1wb3J0IHtWYXJCaW5kaW5nVHJhbnNmb3JtLCBDb21waWxldGltZVRyYW5zZm9ybX0gZnJvbSBcIi4vdHJhbnNmb3Jtc1wiO1xuaW1wb3J0IHtleHBlY3QsIGFzc2VydH0gZnJvbSBcIi4vZXJyb3JzXCI7XG5pbXBvcnQgVGVybSwge2lzRU9GLCBpc0JpbmRpbmdJZGVudGlmaWVyLCBpc0JpbmRpbmdQcm9wZXJ0eVByb3BlcnR5LCBpc0JpbmRpbmdQcm9wZXJ0eUlkZW50aWZpZXIsIGlzT2JqZWN0QmluZGluZywgaXNBcnJheUJpbmRpbmcsIGlzRnVuY3Rpb25EZWNsYXJhdGlvbiwgaXNGdW5jdGlvbkV4cHJlc3Npb24sIGlzRnVuY3Rpb25UZXJtLCBpc0Z1bmN0aW9uV2l0aE5hbWUsIGlzU3ludGF4RGVjbGFyYXRpb24sIGlzU3ludGF4cmVjRGVjbGFyYXRpb24sIGlzVmFyaWFibGVEZWNsYXJhdGlvbiwgaXNWYXJpYWJsZURlY2xhcmF0aW9uU3RhdGVtZW50LCBpc0ltcG9ydCwgaXNFeHBvcnQsIGlzUHJhZ21hLCBpc0V4cG9ydFN5bnRheH0gZnJvbSBcIi4vdGVybXNcIjtcbmltcG9ydCB7TGlzdH0gZnJvbSBcImltbXV0YWJsZVwiO1xuaW1wb3J0IEFTVERpc3BhdGNoZXIgZnJvbSBcIi4vYXN0LWRpc3BhdGNoZXJcIjtcbmltcG9ydCAgKiBhcyBfIGZyb20gXCJyYW1kYVwiO1xuY2xhc3MgQ29sbGVjdEJpbmRpbmdTeW50YXhfMzQ2IGV4dGVuZHMgQVNURGlzcGF0Y2hlciB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKFwiY29sbGVjdFwiLCB0cnVlKTtcbiAgICB0aGlzLm5hbWVzID0gTGlzdCgpO1xuICB9XG4gIGNvbGxlY3QodGVybV8zNDgpIHtcbiAgICByZXR1cm4gdGhpcy5kaXNwYXRjaCh0ZXJtXzM0OCk7XG4gIH1cbiAgY29sbGVjdEJpbmRpbmdJZGVudGlmaWVyKHRlcm1fMzQ5KSB7XG4gICAgcmV0dXJuIHRoaXMubmFtZXMuY29uY2F0KHRlcm1fMzQ5Lm5hbWUpO1xuICB9XG4gIGNvbGxlY3RCaW5kaW5nUHJvcGVydHlJZGVudGlmaWVyKHRlcm1fMzUwKSB7XG4gICAgcmV0dXJuIHRoaXMuY29sbGVjdCh0ZXJtXzM1MC5iaW5kaW5nKTtcbiAgfVxuICBjb2xsZWN0QmluZGluZ1Byb3BlcnR5UHJvcGVydHkodGVybV8zNTEpIHtcbiAgICByZXR1cm4gdGhpcy5jb2xsZWN0KHRlcm1fMzUxLmJpbmRpbmcpO1xuICB9XG4gIGNvbGxlY3RBcnJheUJpbmRpbmcodGVybV8zNTIpIHtcbiAgICBsZXQgcmVzdEVsZW1lbnRfMzUzID0gbnVsbDtcbiAgICBpZiAodGVybV8zNTIucmVzdEVsZW1lbnQgIT0gbnVsbCkge1xuICAgICAgcmVzdEVsZW1lbnRfMzUzID0gdGhpcy5jb2xsZWN0KHRlcm1fMzUyLnJlc3RFbGVtZW50KTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMubmFtZXMuY29uY2F0KHJlc3RFbGVtZW50XzM1MykuY29uY2F0KHRlcm1fMzUyLmVsZW1lbnRzLmZpbHRlcihlbF8zNTQgPT4gZWxfMzU0ICE9IG51bGwpLmZsYXRNYXAoZWxfMzU1ID0+IHRoaXMuY29sbGVjdChlbF8zNTUpKSk7XG4gIH1cbiAgY29sbGVjdE9iamVjdEJpbmRpbmcodGVybV8zNTYpIHtcbiAgICByZXR1cm4gTGlzdCgpO1xuICB9XG59XG5mdW5jdGlvbiBjb2xsZWN0QmluZGluZ3NfMzQ3KHRlcm1fMzU3KSB7XG4gIHJldHVybiAobmV3IENvbGxlY3RCaW5kaW5nU3ludGF4XzM0NikuY29sbGVjdCh0ZXJtXzM1Nyk7XG59XG5leHBvcnQge0NvbGxlY3RCaW5kaW5nU3ludGF4XzM0NiBhcyBDb2xsZWN0QmluZGluZ1N5bnRheH07XG5leHBvcnQge2NvbGxlY3RCaW5kaW5nc18zNDcgYXMgY29sbGVjdEJpbmRpbmdzfSJdfQ== + //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9oeWdpZW5lLXV0aWxzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztRQTZFZ0IsZSxHQUFBLGU7O0FBN0VoQjs7QUFFQTs7Ozs7O0FBRU8sTUFBTSxvQkFBTixpQ0FBaUQ7QUFDdEQsZ0JBQWM7QUFDWixVQUFNLFNBQU4sRUFBaUIsSUFBakI7QUFDQSxTQUFLLEtBQUwsR0FBYSxzQkFBYjtBQUNEOztBQUVEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFRLElBQVIsRUFBYztBQUNaLFdBQU8sS0FBSyxRQUFMLENBQWMsSUFBZCxDQUFQO0FBQ0Q7O0FBRUQsMkJBQXlCLElBQXpCLEVBQStCO0FBQzdCLFdBQU8sS0FBSyxLQUFMLENBQVcsTUFBWCxDQUFrQixLQUFLLElBQXZCLENBQVA7QUFDRDs7QUFFRCxtQ0FBaUMsSUFBakMsRUFBdUM7QUFDckMsV0FBTyxLQUFLLE9BQUwsQ0FBYSxLQUFLLE9BQWxCLENBQVA7QUFDRDs7QUFFRCxpQ0FBZ0MsSUFBaEMsRUFBc0M7QUFDcEMsV0FBTyxLQUFLLE9BQUwsQ0FBYSxLQUFLLE9BQWxCLENBQVA7QUFDRDs7QUFFRCxzQkFBcUIsSUFBckIsRUFBMkI7QUFDekIsUUFBSSxjQUFjLElBQWxCO0FBQ0EsUUFBSSxLQUFLLFdBQUwsSUFBb0IsSUFBeEIsRUFBOEI7QUFDNUIsb0JBQWMsS0FBSyxPQUFMLENBQWEsS0FBSyxXQUFsQixDQUFkO0FBQ0Q7QUFDRCxXQUFPLEtBQUssS0FBTCxDQUFXLE1BQVgsQ0FBa0IsV0FBbEIsRUFBK0IsTUFBL0IsQ0FDTCxLQUFLLFFBQUwsQ0FBYyxNQUFkLENBQXFCLE1BQU0sTUFBTSxJQUFqQyxFQUNjLE9BRGQsQ0FDc0IsTUFBTSxLQUFLLE9BQUwsQ0FBYSxFQUFiLENBRDVCLENBREssQ0FBUDtBQUlEOztBQUVELHlCQUF3QjtBQUN0QjtBQUNBLFdBQU8sc0JBQVA7QUFDRDs7QUFFRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBdEVzRDs7UUFBM0Msb0IsR0FBQSxvQjtBQXlFTixTQUFTLGVBQVQsQ0FBeUIsSUFBekIsRUFBK0I7QUFDcEMsU0FBTyxJQUFJLG9CQUFKLEdBQTJCLE9BQTNCLENBQW1DLElBQW5DLENBQVA7QUFDRCIsImZpbGUiOiJoeWdpZW5lLXV0aWxzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTGlzdCB9IGZyb20gJ2ltbXV0YWJsZSc7XG5cbmltcG9ydCBBU1REaXNwYXRjaGVyIGZyb20gJy4vYXN0LWRpc3BhdGNoZXInO1xuXG5leHBvcnQgY2xhc3MgQ29sbGVjdEJpbmRpbmdTeW50YXggZXh0ZW5kcyBBU1REaXNwYXRjaGVyIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoJ2NvbGxlY3QnLCB0cnVlKTtcbiAgICB0aGlzLm5hbWVzID0gTGlzdCgpO1xuICB9XG5cbiAgLy8gcmVnaXN0ZXJTeW50YXgoc3R4KSB7XG4gIC8vICAgbGV0IG5ld0JpbmRpbmcgPSBnZW5zeW0oc3R4LnZhbCgpKTtcbiAgLy8gICB0aGlzLmNvbnRleHQuYmluZGluZ3MuYWRkKHN0eCwge1xuICAvLyAgICAgYmluZGluZzogbmV3QmluZGluZyxcbiAgLy8gICAgIHBoYXNlOiB0aGlzLmNvbnRleHQucGhhc2UsXG4gIC8vICAgICAvLyBza2lwIGR1cCBiZWNhdXNlIGpzIGFsbG93cyB2YXJpYWJsZSByZWRlY2xhcmF0aW9uc1xuICAvLyAgICAgLy8gKHRlY2huaWNhbGx5IG9ubHkgZm9yIGB2YXJgIGJ1dCB3ZSBjYW4gbGV0IGxhdGVyIHN0YWdlcyBvZiB0aGUgcGlwZWxpbmVcbiAgLy8gICAgIC8vIGhhbmRsZSBpbmNvcnJlY3QgcmVkZWNsYXJhdGlvbnMgb2YgYGNvbnN0YCBhbmQgYGxldGApXG4gIC8vICAgICBza2lwRHVwOiB0cnVlXG4gIC8vICAgfSk7XG4gIC8vICAgcmV0dXJuIHN0eDtcbiAgLy8gfVxuXG4gIGNvbGxlY3QodGVybSkge1xuICAgIHJldHVybiB0aGlzLmRpc3BhdGNoKHRlcm0pO1xuICB9XG5cbiAgY29sbGVjdEJpbmRpbmdJZGVudGlmaWVyKHRlcm0pIHtcbiAgICByZXR1cm4gdGhpcy5uYW1lcy5jb25jYXQodGVybS5uYW1lKTtcbiAgfVxuXG4gIGNvbGxlY3RCaW5kaW5nUHJvcGVydHlJZGVudGlmaWVyKHRlcm0pIHtcbiAgICByZXR1cm4gdGhpcy5jb2xsZWN0KHRlcm0uYmluZGluZyk7XG4gIH1cblxuICBjb2xsZWN0QmluZGluZ1Byb3BlcnR5UHJvcGVydHkgKHRlcm0pIHtcbiAgICByZXR1cm4gdGhpcy5jb2xsZWN0KHRlcm0uYmluZGluZyk7XG4gIH1cblxuICBjb2xsZWN0QXJyYXlCaW5kaW5nICh0ZXJtKSB7XG4gICAgbGV0IHJlc3RFbGVtZW50ID0gbnVsbDtcbiAgICBpZiAodGVybS5yZXN0RWxlbWVudCAhPSBudWxsKSB7XG4gICAgICByZXN0RWxlbWVudCA9IHRoaXMuY29sbGVjdCh0ZXJtLnJlc3RFbGVtZW50KTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMubmFtZXMuY29uY2F0KHJlc3RFbGVtZW50KS5jb25jYXQoXG4gICAgICB0ZXJtLmVsZW1lbnRzLmZpbHRlcihlbCA9PiBlbCAhPSBudWxsKVxuICAgICAgICAgICAgICAgICAgIC5mbGF0TWFwKGVsID0+IHRoaXMuY29sbGVjdChlbCkpXG4gICAgKTtcbiAgfVxuXG4gIGNvbGxlY3RPYmplY3RCaW5kaW5nICgpIHtcbiAgICAvLyByZXR1cm4gdGVybS5wcm9wZXJ0aWVzLmZsYXRNYXAocHJvcCA9PiB0aGlzLmNvbGxlY3QocHJvcCkpO1xuICAgIHJldHVybiBMaXN0KCk7XG4gIH1cblxuICAvLyByZWdpc3RlclZhcmlhYmxlRGVjbGFyYXRpb24odGVybSkge1xuICAvLyAgIGxldCBkZWNsYXJhdG9ycyA9IHRlcm0uZGVjbGFyYXRvcnMubWFwKGRlY2wgPT4ge1xuICAvLyAgICAgcmV0dXJuIGRlY2wuZXh0ZW5kKHtcbiAgLy8gICAgICAgYmluZGluZzogdGhpcy5yZWdpc3RlcihkZWNsLmJpbmRpbmcpXG4gIC8vICAgICB9KTtcbiAgLy8gICB9KTtcbiAgLy8gICByZXR1cm4gdGVybS5leHRlbmQoeyBkZWNsYXJhdG9ycyB9KTtcbiAgLy8gfVxuICAvL1xuICAvLyByZWdpc3RlckZ1bmN0aW9uRGVjbGFyYXRpb24odGVybSkge1xuICAvLyAgIHJldHVybiB0ZXJtLmV4dGVuZCh7XG4gIC8vICAgICBuYW1lOiB0aGlzLnJlZ2lzdGVyKHRlcm0ubmFtZSlcbiAgLy8gICB9KTtcbiAgLy8gfVxuICAvL1xuICAvLyByZWdpc3RlckV4cG9ydCh0ZXJtKSB7XG4gIC8vICAgcmV0dXJuIHRlcm0uZXh0ZW5kKHtcbiAgLy8gICAgIGRlY2xhcmF0aW9uOiB0aGlzLnJlZ2lzdGVyKHRlcm0uZGVjbGFyYXRpb24pXG4gIC8vICAgfSk7XG4gIC8vIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNvbGxlY3RCaW5kaW5ncyh0ZXJtKSB7XG4gIHJldHVybiBuZXcgQ29sbGVjdEJpbmRpbmdTeW50YXgoKS5jb2xsZWN0KHRlcm0pO1xufVxuIl19 /***/ }, -/* 68 */ +/* 66 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; // MODULES // - var isString = __webpack_require__( 69 ), - re = __webpack_require__( 70 ); + var isString = __webpack_require__( 67 ), + re = __webpack_require__( 68 ); // DIRNAME // @@ -38680,7 +40618,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /***/ }, -/* 69 */ +/* 67 */ /***/ function(module, exports) { /** @@ -38731,14 +40669,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /***/ }, -/* 70 */ +/* 68 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; // MODULES // - var isWindows = __webpack_require__( 71 ); + var isWindows = __webpack_require__( 69 ); // REGEX // @@ -38747,8 +40685,8 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack win32, re; - posix = __webpack_require__( 73 ); - win32 = __webpack_require__( 74 ); + posix = __webpack_require__( 71 ); + win32 = __webpack_require__( 72 ); if ( isWindows ) { re = win32; @@ -38765,14 +40703,14 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /***/ }, -/* 71 */ +/* 69 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; // MODULES // - var platform = __webpack_require__( 72 ); + var platform = __webpack_require__( 70 ); // EXPORTS // @@ -38781,7 +40719,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /***/ }, -/* 72 */ +/* 70 */ /***/ function(module, exports, __webpack_require__) { /* WEBPACK VAR INJECTION */(function(process) {'use strict'; @@ -38793,7 +40731,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(2))) /***/ }, -/* 73 */ +/* 71 */ /***/ function(module, exports) { 'use strict'; @@ -38870,7 +40808,7 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /***/ }, -/* 74 */ +/* 72 */ /***/ function(module, exports) { 'use strict'; @@ -38955,19 +40893,19 @@ define("sweet", [], function() { return /******/ (function(modules) { // webpack /***/ }, -/* 75 */ +/* 73 */ /***/ function(module, exports) { /* (ignored) */ /***/ }, -/* 76 */ +/* 74 */ /***/ function(module, exports) { /* (ignored) */ /***/ }, -/* 77 */ +/* 75 */ /***/ function(module, exports) { /* (ignored) */ diff --git a/dist/apply-scope-in-params-reducer.js b/dist/apply-scope-in-params-reducer.js index 87e57650..351161c7 100644 --- a/dist/apply-scope-in-params-reducer.js +++ b/dist/apply-scope-in-params-reducer.js @@ -19,43 +19,76 @@ var _syntax = require("./syntax"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } class ScopeApplyingReducer { - constructor(scope_0, context_1) { - this.context = context_1; - this.scope = scope_0; - } - transform(term_2) { - let field_3 = "transform" + term_2.type; - if (typeof this[field_3] === "function") { - return this[field_3](term_2); + constructor(scope, context) { + this.context = context; + this.scope = scope; + } + + transform(term) { + let field = "transform" + term.type; + if (typeof this[field] === 'function') { + return this[field](term); } - (0, _errors.assert)(false, "transform not implemented yet for: " + term_2.type); + (0, _errors.assert)(false, "transform not implemented yet for: " + term.type); } - transformFormalParameters(term_4) { - let rest_5 = term_4.rest == null ? null : this.transform(term_4.rest); - return new _terms2.default("FormalParameters", { items: term_4.items.map(it_6 => this.transform(it_6)), rest: rest_5 }); + + transformFormalParameters(term) { + let rest = term.rest == null ? null : this.transform(term.rest); + return new _terms2.default('FormalParameters', { + items: term.items.map(it => this.transform(it)), + rest: rest + }); } - transformBindingWithDefault(term_7) { - return new _terms2.default("BindingWithDefault", { binding: this.transform(term_7.binding), init: term_7.init }); + + transformBindingWithDefault(term) { + return new _terms2.default('BindingWithDefault', { + binding: this.transform(term.binding), + init: term.init + }); } - transformObjectBinding(term_8) { - return term_8; + + transformObjectBinding(term) { + // TODO: much more complicated logic here + return term; + // return new Term('ObjectBinding', { + // properties: term.properties.map(prop => this.transform(prop)) + // }); } - transformBindingPropertyIdentifier(term_9) { - return new _terms2.default("BindingPropertyIdentifier", { binding: this.transform(term_9.binding), init: term_9.init }); + + transformBindingPropertyIdentifier(term) { + return new _terms2.default('BindingPropertyIdentifier', { + binding: this.transform(term.binding), + init: term.init + }); } - transformBindingPropertyProperty(term_10) { - return new _terms2.default("BindingPropertyProperty", { name: term_10.name, binding: this.transform(term_10.binding) }); + + transformBindingPropertyProperty(term) { + return new _terms2.default('BindingPropertyProperty', { + name: term.name, + binding: this.transform(term.binding) + }); } - transformArrayBinding(term_11) { - return new _terms2.default("ArrayBinding", { elements: term_11.elements.map(el_12 => this.transform(el_12)), restElement: term_11.restElement == null ? null : this.transform(term_11.restElement) }); + + transformArrayBinding(term) { + return new _terms2.default('ArrayBinding', { + elements: term.elements.map(el => this.transform(el)), + restElement: term.restElement == null ? null : this.transform(term.restElement) + }); } - transformBindingIdentifier(term_13) { - let name_14 = term_13.name.addScope(this.scope, this.context.bindings, _syntax.ALL_PHASES); - let newBinding_15 = (0, _symbol.gensym)(name_14.val()); - this.context.env.set(newBinding_15.toString(), new _transforms.VarBindingTransform(name_14)); - this.context.bindings.add(name_14, { binding: newBinding_15, phase: this.context.phase, skipDup: true }); - return new _terms2.default("BindingIdentifier", { name: name_14 }); + + transformBindingIdentifier(term) { + let name = term.name.addScope(this.scope, this.context.bindings, _syntax.ALL_PHASES); + let newBinding = (0, _symbol.gensym)(name.val()); + + this.context.env.set(newBinding.toString(), new _transforms.VarBindingTransform(name)); + this.context.bindings.add(name, { + binding: newBinding, + phase: this.context.phase, + skipDup: true + }); + + return new _terms2.default("BindingIdentifier", { name: name }); } } exports.default = ScopeApplyingReducer; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2FwcGx5LXNjb3BlLWluLXBhcmFtcy1yZWR1Y2VyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOzs7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7QUFDZSxNQUFNLG9CQUFOLENBQTJCO0FBQ3hDLGNBQVksT0FBWixFQUFxQixTQUFyQixFQUFnQztBQUM5QixTQUFLLE9BQUwsR0FBZSxTQUFmO0FBQ0EsU0FBSyxLQUFMLEdBQWEsT0FBYjtBQUNEO0FBQ0QsWUFBVSxNQUFWLEVBQWtCO0FBQ2hCLFFBQUksVUFBVSxjQUFjLE9BQU8sSUFBbkM7QUFDQSxRQUFJLE9BQU8sS0FBSyxPQUFMLENBQVAsS0FBeUIsVUFBN0IsRUFBeUM7QUFDdkMsYUFBTyxLQUFLLE9BQUwsRUFBYyxNQUFkLENBQVA7QUFDRDtBQUNELHdCQUFPLEtBQVAsRUFBYyx3Q0FBd0MsT0FBTyxJQUE3RDtBQUNEO0FBQ0QsNEJBQTBCLE1BQTFCLEVBQWtDO0FBQ2hDLFFBQUksU0FBUyxPQUFPLElBQVAsSUFBZSxJQUFmLEdBQXNCLElBQXRCLEdBQTZCLEtBQUssU0FBTCxDQUFlLE9BQU8sSUFBdEIsQ0FBMUM7QUFDQSxXQUFPLG9CQUFTLGtCQUFULEVBQTZCLEVBQUMsT0FBTyxPQUFPLEtBQVAsQ0FBYSxHQUFiLENBQWlCLFFBQVEsS0FBSyxTQUFMLENBQWUsSUFBZixDQUF6QixDQUFSLEVBQXdELE1BQU0sTUFBOUQsRUFBN0IsQ0FBUDtBQUNEO0FBQ0QsOEJBQTRCLE1BQTVCLEVBQW9DO0FBQ2xDLFdBQU8sb0JBQVMsb0JBQVQsRUFBK0IsRUFBQyxTQUFTLEtBQUssU0FBTCxDQUFlLE9BQU8sT0FBdEIsQ0FBVixFQUEwQyxNQUFNLE9BQU8sSUFBdkQsRUFBL0IsQ0FBUDtBQUNEO0FBQ0QseUJBQXVCLE1BQXZCLEVBQStCO0FBQzdCLFdBQU8sTUFBUDtBQUNEO0FBQ0QscUNBQW1DLE1BQW5DLEVBQTJDO0FBQ3pDLFdBQU8sb0JBQVMsMkJBQVQsRUFBc0MsRUFBQyxTQUFTLEtBQUssU0FBTCxDQUFlLE9BQU8sT0FBdEIsQ0FBVixFQUEwQyxNQUFNLE9BQU8sSUFBdkQsRUFBdEMsQ0FBUDtBQUNEO0FBQ0QsbUNBQWlDLE9BQWpDLEVBQTBDO0FBQ3hDLFdBQU8sb0JBQVMseUJBQVQsRUFBb0MsRUFBQyxNQUFNLFFBQVEsSUFBZixFQUFxQixTQUFTLEtBQUssU0FBTCxDQUFlLFFBQVEsT0FBdkIsQ0FBOUIsRUFBcEMsQ0FBUDtBQUNEO0FBQ0Qsd0JBQXNCLE9BQXRCLEVBQStCO0FBQzdCLFdBQU8sb0JBQVMsY0FBVCxFQUF5QixFQUFDLFVBQVUsUUFBUSxRQUFSLENBQWlCLEdBQWpCLENBQXFCLFNBQVMsS0FBSyxTQUFMLENBQWUsS0FBZixDQUE5QixDQUFYLEVBQWlFLGFBQWEsUUFBUSxXQUFSLElBQXVCLElBQXZCLEdBQThCLElBQTlCLEdBQXFDLEtBQUssU0FBTCxDQUFlLFFBQVEsV0FBdkIsQ0FBbkgsRUFBekIsQ0FBUDtBQUNEO0FBQ0QsNkJBQTJCLE9BQTNCLEVBQW9DO0FBQ2xDLFFBQUksVUFBVSxRQUFRLElBQVIsQ0FBYSxRQUFiLENBQXNCLEtBQUssS0FBM0IsRUFBa0MsS0FBSyxPQUFMLENBQWEsUUFBL0MscUJBQWQ7QUFDQSxRQUFJLGdCQUFnQixvQkFBTyxRQUFRLEdBQVIsRUFBUCxDQUFwQjtBQUNBLFNBQUssT0FBTCxDQUFhLEdBQWIsQ0FBaUIsR0FBakIsQ0FBcUIsY0FBYyxRQUFkLEVBQXJCLEVBQStDLG9DQUF3QixPQUF4QixDQUEvQztBQUNBLFNBQUssT0FBTCxDQUFhLFFBQWIsQ0FBc0IsR0FBdEIsQ0FBMEIsT0FBMUIsRUFBbUMsRUFBQyxTQUFTLGFBQVYsRUFBeUIsT0FBTyxLQUFLLE9BQUwsQ0FBYSxLQUE3QyxFQUFvRCxTQUFTLElBQTdELEVBQW5DO0FBQ0EsV0FBTyxvQkFBUyxtQkFBVCxFQUE4QixFQUFDLE1BQU0sT0FBUCxFQUE5QixDQUFQO0FBQ0Q7QUFyQ3VDO2tCQUFyQixvQiIsImZpbGUiOiJhcHBseS1zY29wZS1pbi1wYXJhbXMtcmVkdWNlci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBUZXJtIGZyb20gXCIuL3Rlcm1zXCI7XG5pbXBvcnQge2dlbnN5bX0gZnJvbSBcIi4vc3ltYm9sXCI7XG5pbXBvcnQge1ZhckJpbmRpbmdUcmFuc2Zvcm19IGZyb20gXCIuL3RyYW5zZm9ybXNcIjtcbmltcG9ydCB7YXNzZXJ0fSBmcm9tIFwiLi9lcnJvcnNcIjtcbmltcG9ydCB7QUxMX1BIQVNFU30gZnJvbSBcIi4vc3ludGF4XCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBTY29wZUFwcGx5aW5nUmVkdWNlciB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlXzAsIGNvbnRleHRfMSkge1xuICAgIHRoaXMuY29udGV4dCA9IGNvbnRleHRfMTtcbiAgICB0aGlzLnNjb3BlID0gc2NvcGVfMDtcbiAgfVxuICB0cmFuc2Zvcm0odGVybV8yKSB7XG4gICAgbGV0IGZpZWxkXzMgPSBcInRyYW5zZm9ybVwiICsgdGVybV8yLnR5cGU7XG4gICAgaWYgKHR5cGVvZiB0aGlzW2ZpZWxkXzNdID09PSBcImZ1bmN0aW9uXCIpIHtcbiAgICAgIHJldHVybiB0aGlzW2ZpZWxkXzNdKHRlcm1fMik7XG4gICAgfVxuICAgIGFzc2VydChmYWxzZSwgXCJ0cmFuc2Zvcm0gbm90IGltcGxlbWVudGVkIHlldCBmb3I6IFwiICsgdGVybV8yLnR5cGUpO1xuICB9XG4gIHRyYW5zZm9ybUZvcm1hbFBhcmFtZXRlcnModGVybV80KSB7XG4gICAgbGV0IHJlc3RfNSA9IHRlcm1fNC5yZXN0ID09IG51bGwgPyBudWxsIDogdGhpcy50cmFuc2Zvcm0odGVybV80LnJlc3QpO1xuICAgIHJldHVybiBuZXcgVGVybShcIkZvcm1hbFBhcmFtZXRlcnNcIiwge2l0ZW1zOiB0ZXJtXzQuaXRlbXMubWFwKGl0XzYgPT4gdGhpcy50cmFuc2Zvcm0oaXRfNikpLCByZXN0OiByZXN0XzV9KTtcbiAgfVxuICB0cmFuc2Zvcm1CaW5kaW5nV2l0aERlZmF1bHQodGVybV83KSB7XG4gICAgcmV0dXJuIG5ldyBUZXJtKFwiQmluZGluZ1dpdGhEZWZhdWx0XCIsIHtiaW5kaW5nOiB0aGlzLnRyYW5zZm9ybSh0ZXJtXzcuYmluZGluZyksIGluaXQ6IHRlcm1fNy5pbml0fSk7XG4gIH1cbiAgdHJhbnNmb3JtT2JqZWN0QmluZGluZyh0ZXJtXzgpIHtcbiAgICByZXR1cm4gdGVybV84O1xuICB9XG4gIHRyYW5zZm9ybUJpbmRpbmdQcm9wZXJ0eUlkZW50aWZpZXIodGVybV85KSB7XG4gICAgcmV0dXJuIG5ldyBUZXJtKFwiQmluZGluZ1Byb3BlcnR5SWRlbnRpZmllclwiLCB7YmluZGluZzogdGhpcy50cmFuc2Zvcm0odGVybV85LmJpbmRpbmcpLCBpbml0OiB0ZXJtXzkuaW5pdH0pO1xuICB9XG4gIHRyYW5zZm9ybUJpbmRpbmdQcm9wZXJ0eVByb3BlcnR5KHRlcm1fMTApIHtcbiAgICByZXR1cm4gbmV3IFRlcm0oXCJCaW5kaW5nUHJvcGVydHlQcm9wZXJ0eVwiLCB7bmFtZTogdGVybV8xMC5uYW1lLCBiaW5kaW5nOiB0aGlzLnRyYW5zZm9ybSh0ZXJtXzEwLmJpbmRpbmcpfSk7XG4gIH1cbiAgdHJhbnNmb3JtQXJyYXlCaW5kaW5nKHRlcm1fMTEpIHtcbiAgICByZXR1cm4gbmV3IFRlcm0oXCJBcnJheUJpbmRpbmdcIiwge2VsZW1lbnRzOiB0ZXJtXzExLmVsZW1lbnRzLm1hcChlbF8xMiA9PiB0aGlzLnRyYW5zZm9ybShlbF8xMikpLCByZXN0RWxlbWVudDogdGVybV8xMS5yZXN0RWxlbWVudCA9PSBudWxsID8gbnVsbCA6IHRoaXMudHJhbnNmb3JtKHRlcm1fMTEucmVzdEVsZW1lbnQpfSk7XG4gIH1cbiAgdHJhbnNmb3JtQmluZGluZ0lkZW50aWZpZXIodGVybV8xMykge1xuICAgIGxldCBuYW1lXzE0ID0gdGVybV8xMy5uYW1lLmFkZFNjb3BlKHRoaXMuc2NvcGUsIHRoaXMuY29udGV4dC5iaW5kaW5ncywgQUxMX1BIQVNFUyk7XG4gICAgbGV0IG5ld0JpbmRpbmdfMTUgPSBnZW5zeW0obmFtZV8xNC52YWwoKSk7XG4gICAgdGhpcy5jb250ZXh0LmVudi5zZXQobmV3QmluZGluZ18xNS50b1N0cmluZygpLCBuZXcgVmFyQmluZGluZ1RyYW5zZm9ybShuYW1lXzE0KSk7XG4gICAgdGhpcy5jb250ZXh0LmJpbmRpbmdzLmFkZChuYW1lXzE0LCB7YmluZGluZzogbmV3QmluZGluZ18xNSwgcGhhc2U6IHRoaXMuY29udGV4dC5waGFzZSwgc2tpcER1cDogdHJ1ZX0pO1xuICAgIHJldHVybiBuZXcgVGVybShcIkJpbmRpbmdJZGVudGlmaWVyXCIsIHtuYW1lOiBuYW1lXzE0fSk7XG4gIH1cbn1cbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hcHBseS1zY29wZS1pbi1wYXJhbXMtcmVkdWNlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7OztBQUNBOztBQUNBOztBQUNBOztBQUNBOzs7O0FBRWUsTUFBTSxvQkFBTixDQUEyQjtBQUN4QyxjQUFZLEtBQVosRUFBbUIsT0FBbkIsRUFBNEI7QUFDMUIsU0FBSyxPQUFMLEdBQWUsT0FBZjtBQUNBLFNBQUssS0FBTCxHQUFhLEtBQWI7QUFDRDs7QUFFRCxZQUFVLElBQVYsRUFBZ0I7QUFDZCxRQUFJLFFBQVEsY0FBYyxLQUFLLElBQS9CO0FBQ0EsUUFBSSxPQUFPLEtBQUssS0FBTCxDQUFQLEtBQXVCLFVBQTNCLEVBQXVDO0FBQ3JDLGFBQU8sS0FBSyxLQUFMLEVBQVksSUFBWixDQUFQO0FBQ0Q7QUFDRCx3QkFBTyxLQUFQLEVBQWMsd0NBQXdDLEtBQUssSUFBM0Q7QUFDRDs7QUFFRCw0QkFBMEIsSUFBMUIsRUFBZ0M7QUFDOUIsUUFBSSxPQUFPLEtBQUssSUFBTCxJQUFhLElBQWIsR0FBb0IsSUFBcEIsR0FBMkIsS0FBSyxTQUFMLENBQWUsS0FBSyxJQUFwQixDQUF0QztBQUNBLFdBQU8sb0JBQVMsa0JBQVQsRUFBNkI7QUFDbEMsYUFBTyxLQUFLLEtBQUwsQ0FBVyxHQUFYLENBQWUsTUFBTSxLQUFLLFNBQUwsQ0FBZSxFQUFmLENBQXJCLENBRDJCO0FBRWxDO0FBRmtDLEtBQTdCLENBQVA7QUFJRDs7QUFHRCw4QkFBNEIsSUFBNUIsRUFBa0M7QUFDaEMsV0FBTyxvQkFBUyxvQkFBVCxFQUErQjtBQUNwQyxlQUFTLEtBQUssU0FBTCxDQUFlLEtBQUssT0FBcEIsQ0FEMkI7QUFFcEMsWUFBTSxLQUFLO0FBRnlCLEtBQS9CLENBQVA7QUFJRDs7QUFFRCx5QkFBdUIsSUFBdkIsRUFBNkI7QUFDM0I7QUFDQSxXQUFPLElBQVA7QUFDQTtBQUNBO0FBQ0E7QUFDRDs7QUFFRCxxQ0FBbUMsSUFBbkMsRUFBeUM7QUFDdkMsV0FBTyxvQkFBUywyQkFBVCxFQUFzQztBQUMzQyxlQUFTLEtBQUssU0FBTCxDQUFlLEtBQUssT0FBcEIsQ0FEa0M7QUFFM0MsWUFBTSxLQUFLO0FBRmdDLEtBQXRDLENBQVA7QUFJRDs7QUFFRCxtQ0FBaUMsSUFBakMsRUFBdUM7QUFDckMsV0FBTyxvQkFBUyx5QkFBVCxFQUFvQztBQUN6QyxZQUFNLEtBQUssSUFEOEI7QUFFekMsZUFBUyxLQUFLLFNBQUwsQ0FBZSxLQUFLLE9BQXBCO0FBRmdDLEtBQXBDLENBQVA7QUFJRDs7QUFFRCx3QkFBc0IsSUFBdEIsRUFBNEI7QUFDMUIsV0FBTyxvQkFBUyxjQUFULEVBQXlCO0FBQzlCLGdCQUFVLEtBQUssUUFBTCxDQUFjLEdBQWQsQ0FBa0IsTUFBTSxLQUFLLFNBQUwsQ0FBZSxFQUFmLENBQXhCLENBRG9CO0FBRTlCLG1CQUFhLEtBQUssV0FBTCxJQUFvQixJQUFwQixHQUEyQixJQUEzQixHQUFrQyxLQUFLLFNBQUwsQ0FBZSxLQUFLLFdBQXBCO0FBRmpCLEtBQXpCLENBQVA7QUFJRDs7QUFFRCw2QkFBMkIsSUFBM0IsRUFBaUM7QUFDL0IsUUFBSSxPQUFPLEtBQUssSUFBTCxDQUFVLFFBQVYsQ0FBbUIsS0FBSyxLQUF4QixFQUErQixLQUFLLE9BQUwsQ0FBYSxRQUE1QyxxQkFBWDtBQUNBLFFBQUksYUFBYSxvQkFBTyxLQUFLLEdBQUwsRUFBUCxDQUFqQjs7QUFFQSxTQUFLLE9BQUwsQ0FBYSxHQUFiLENBQWlCLEdBQWpCLENBQXFCLFdBQVcsUUFBWCxFQUFyQixFQUE0QyxvQ0FBd0IsSUFBeEIsQ0FBNUM7QUFDQSxTQUFLLE9BQUwsQ0FBYSxRQUFiLENBQXNCLEdBQXRCLENBQTBCLElBQTFCLEVBQWdDO0FBQzlCLGVBQVMsVUFEcUI7QUFFOUIsYUFBTyxLQUFLLE9BQUwsQ0FBYSxLQUZVO0FBRzlCLGVBQVM7QUFIcUIsS0FBaEM7O0FBTUEsV0FBTyxvQkFBUyxtQkFBVCxFQUE4QixFQUFFLFVBQUYsRUFBOUIsQ0FBUDtBQUNEO0FBdkV1QztrQkFBckIsb0IiLCJmaWxlIjoiYXBwbHktc2NvcGUtaW4tcGFyYW1zLXJlZHVjZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgVGVybSBmcm9tIFwiLi90ZXJtc1wiO1xuaW1wb3J0IHsgZ2Vuc3ltIH0gZnJvbSBcIi4vc3ltYm9sXCI7XG5pbXBvcnQgeyBWYXJCaW5kaW5nVHJhbnNmb3JtIH0gZnJvbSBcIi4vdHJhbnNmb3Jtc1wiO1xuaW1wb3J0IHthc3NlcnR9IGZyb20gJy4vZXJyb3JzJztcbmltcG9ydCB7IEFMTF9QSEFTRVMgfSBmcm9tICcuL3N5bnRheCc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFNjb3BlQXBwbHlpbmdSZWR1Y2VyIHtcbiAgY29uc3RydWN0b3Ioc2NvcGUsIGNvbnRleHQpIHtcbiAgICB0aGlzLmNvbnRleHQgPSBjb250ZXh0O1xuICAgIHRoaXMuc2NvcGUgPSBzY29wZTtcbiAgfVxuXG4gIHRyYW5zZm9ybSh0ZXJtKSB7XG4gICAgbGV0IGZpZWxkID0gXCJ0cmFuc2Zvcm1cIiArIHRlcm0udHlwZTtcbiAgICBpZiAodHlwZW9mIHRoaXNbZmllbGRdID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICByZXR1cm4gdGhpc1tmaWVsZF0odGVybSk7XG4gICAgfVxuICAgIGFzc2VydChmYWxzZSwgXCJ0cmFuc2Zvcm0gbm90IGltcGxlbWVudGVkIHlldCBmb3I6IFwiICsgdGVybS50eXBlKTtcbiAgfVxuXG4gIHRyYW5zZm9ybUZvcm1hbFBhcmFtZXRlcnModGVybSkge1xuICAgIGxldCByZXN0ID0gdGVybS5yZXN0ID09IG51bGwgPyBudWxsIDogdGhpcy50cmFuc2Zvcm0odGVybS5yZXN0KTtcbiAgICByZXR1cm4gbmV3IFRlcm0oJ0Zvcm1hbFBhcmFtZXRlcnMnLCB7XG4gICAgICBpdGVtczogdGVybS5pdGVtcy5tYXAoaXQgPT4gdGhpcy50cmFuc2Zvcm0oaXQpKSxcbiAgICAgIHJlc3RcbiAgICB9KTtcbiAgfVxuXG5cbiAgdHJhbnNmb3JtQmluZGluZ1dpdGhEZWZhdWx0KHRlcm0pIHtcbiAgICByZXR1cm4gbmV3IFRlcm0oJ0JpbmRpbmdXaXRoRGVmYXVsdCcsIHtcbiAgICAgIGJpbmRpbmc6IHRoaXMudHJhbnNmb3JtKHRlcm0uYmluZGluZyksXG4gICAgICBpbml0OiB0ZXJtLmluaXRcbiAgICB9KTtcbiAgfVxuXG4gIHRyYW5zZm9ybU9iamVjdEJpbmRpbmcodGVybSkge1xuICAgIC8vIFRPRE86IG11Y2ggbW9yZSBjb21wbGljYXRlZCBsb2dpYyBoZXJlXG4gICAgcmV0dXJuIHRlcm07XG4gICAgLy8gcmV0dXJuIG5ldyBUZXJtKCdPYmplY3RCaW5kaW5nJywge1xuICAgIC8vICAgcHJvcGVydGllczogdGVybS5wcm9wZXJ0aWVzLm1hcChwcm9wID0+IHRoaXMudHJhbnNmb3JtKHByb3ApKVxuICAgIC8vIH0pO1xuICB9XG5cbiAgdHJhbnNmb3JtQmluZGluZ1Byb3BlcnR5SWRlbnRpZmllcih0ZXJtKSB7XG4gICAgcmV0dXJuIG5ldyBUZXJtKCdCaW5kaW5nUHJvcGVydHlJZGVudGlmaWVyJywge1xuICAgICAgYmluZGluZzogdGhpcy50cmFuc2Zvcm0odGVybS5iaW5kaW5nKSxcbiAgICAgIGluaXQ6IHRlcm0uaW5pdFxuICAgIH0pO1xuICB9XG5cbiAgdHJhbnNmb3JtQmluZGluZ1Byb3BlcnR5UHJvcGVydHkodGVybSkge1xuICAgIHJldHVybiBuZXcgVGVybSgnQmluZGluZ1Byb3BlcnR5UHJvcGVydHknLCB7XG4gICAgICBuYW1lOiB0ZXJtLm5hbWUsXG4gICAgICBiaW5kaW5nOiB0aGlzLnRyYW5zZm9ybSh0ZXJtLmJpbmRpbmcpXG4gICAgfSk7XG4gIH1cblxuICB0cmFuc2Zvcm1BcnJheUJpbmRpbmcodGVybSkge1xuICAgIHJldHVybiBuZXcgVGVybSgnQXJyYXlCaW5kaW5nJywge1xuICAgICAgZWxlbWVudHM6IHRlcm0uZWxlbWVudHMubWFwKGVsID0+IHRoaXMudHJhbnNmb3JtKGVsKSksXG4gICAgICByZXN0RWxlbWVudDogdGVybS5yZXN0RWxlbWVudCA9PSBudWxsID8gbnVsbCA6IHRoaXMudHJhbnNmb3JtKHRlcm0ucmVzdEVsZW1lbnQpXG4gICAgfSk7XG4gIH1cblxuICB0cmFuc2Zvcm1CaW5kaW5nSWRlbnRpZmllcih0ZXJtKSB7XG4gICAgbGV0IG5hbWUgPSB0ZXJtLm5hbWUuYWRkU2NvcGUodGhpcy5zY29wZSwgdGhpcy5jb250ZXh0LmJpbmRpbmdzLCBBTExfUEhBU0VTKTtcbiAgICBsZXQgbmV3QmluZGluZyA9IGdlbnN5bShuYW1lLnZhbCgpKTtcblxuICAgIHRoaXMuY29udGV4dC5lbnYuc2V0KG5ld0JpbmRpbmcudG9TdHJpbmcoKSwgbmV3IFZhckJpbmRpbmdUcmFuc2Zvcm0obmFtZSkpO1xuICAgIHRoaXMuY29udGV4dC5iaW5kaW5ncy5hZGQobmFtZSwge1xuICAgICAgYmluZGluZzogbmV3QmluZGluZyxcbiAgICAgIHBoYXNlOiB0aGlzLmNvbnRleHQucGhhc2UsXG4gICAgICBza2lwRHVwOiB0cnVlXG4gICAgfSk7XG5cbiAgICByZXR1cm4gbmV3IFRlcm0oXCJCaW5kaW5nSWRlbnRpZmllclwiLCB7IG5hbWUgfSk7XG4gIH1cbn1cbiJdfQ== \ No newline at end of file diff --git a/dist/ast-dispatcher.js b/dist/ast-dispatcher.js index 5d99c509..2387dd39 100644 --- a/dist/ast-dispatcher.js +++ b/dist/ast-dispatcher.js @@ -1,22 +1,23 @@ -"use strict"; +'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); class ASTDispatcher { - constructor(prefix_16, errorIfMissing_17) { - this.errorIfMissing = errorIfMissing_17; - this.prefix = prefix_16; + constructor(prefix, errorIfMissing) { + this.errorIfMissing = errorIfMissing; + this.prefix = prefix; } - dispatch(term_18) { - let field_19 = this.prefix + term_18.type; - if (typeof this[field_19] === "function") { - return this[field_19](term_18); + + dispatch(term) { + let field = this.prefix + term.type; + if (typeof this[field] === 'function') { + return this[field](term); } else if (!this.errorIfMissing) { - return term_18; + return term; } - throw new Error(`Missing implementation for: ${ field_19 }`); + throw new Error(`Missing implementation for: ${ field }`); } } exports.default = ASTDispatcher; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2FzdC1kaXNwYXRjaGVyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQWUsTUFBTSxhQUFOLENBQW9CO0FBQ2pDLGNBQVksU0FBWixFQUF1QixpQkFBdkIsRUFBMEM7QUFDeEMsU0FBSyxjQUFMLEdBQXNCLGlCQUF0QjtBQUNBLFNBQUssTUFBTCxHQUFjLFNBQWQ7QUFDRDtBQUNELFdBQVMsT0FBVCxFQUFrQjtBQUNoQixRQUFJLFdBQVcsS0FBSyxNQUFMLEdBQWMsUUFBUSxJQUFyQztBQUNBLFFBQUksT0FBTyxLQUFLLFFBQUwsQ0FBUCxLQUEwQixVQUE5QixFQUEwQztBQUN4QyxhQUFPLEtBQUssUUFBTCxFQUFlLE9BQWYsQ0FBUDtBQUNELEtBRkQsTUFFTyxJQUFJLENBQUMsS0FBSyxjQUFWLEVBQTBCO0FBQy9CLGFBQU8sT0FBUDtBQUNEO0FBQ0QsVUFBTSxJQUFJLEtBQUosQ0FBVyxnQ0FBOEIsUUFBUyxHQUFsRCxDQUFOO0FBQ0Q7QUFiZ0M7a0JBQWQsYSIsImZpbGUiOiJhc3QtZGlzcGF0Y2hlci5qcyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWZhdWx0IGNsYXNzIEFTVERpc3BhdGNoZXIge1xuICBjb25zdHJ1Y3RvcihwcmVmaXhfMTYsIGVycm9ySWZNaXNzaW5nXzE3KSB7XG4gICAgdGhpcy5lcnJvcklmTWlzc2luZyA9IGVycm9ySWZNaXNzaW5nXzE3O1xuICAgIHRoaXMucHJlZml4ID0gcHJlZml4XzE2O1xuICB9XG4gIGRpc3BhdGNoKHRlcm1fMTgpIHtcbiAgICBsZXQgZmllbGRfMTkgPSB0aGlzLnByZWZpeCArIHRlcm1fMTgudHlwZTtcbiAgICBpZiAodHlwZW9mIHRoaXNbZmllbGRfMTldID09PSBcImZ1bmN0aW9uXCIpIHtcbiAgICAgIHJldHVybiB0aGlzW2ZpZWxkXzE5XSh0ZXJtXzE4KTtcbiAgICB9IGVsc2UgaWYgKCF0aGlzLmVycm9ySWZNaXNzaW5nKSB7XG4gICAgICByZXR1cm4gdGVybV8xODtcbiAgICB9XG4gICAgdGhyb3cgbmV3IEVycm9yKGBNaXNzaW5nIGltcGxlbWVudGF0aW9uIGZvcjogJHtmaWVsZF8xOX1gKTtcbiAgfVxufVxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hc3QtZGlzcGF0Y2hlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFlLE1BQU0sYUFBTixDQUFvQjtBQUNqQyxjQUFZLE1BQVosRUFBb0IsY0FBcEIsRUFBb0M7QUFDbEMsU0FBSyxjQUFMLEdBQXNCLGNBQXRCO0FBQ0EsU0FBSyxNQUFMLEdBQWMsTUFBZDtBQUNEOztBQUVELFdBQVMsSUFBVCxFQUFlO0FBQ2IsUUFBSSxRQUFRLEtBQUssTUFBTCxHQUFjLEtBQUssSUFBL0I7QUFDQSxRQUFJLE9BQU8sS0FBSyxLQUFMLENBQVAsS0FBdUIsVUFBM0IsRUFBdUM7QUFDckMsYUFBTyxLQUFLLEtBQUwsRUFBWSxJQUFaLENBQVA7QUFDRCxLQUZELE1BRU8sSUFBSSxDQUFDLEtBQUssY0FBVixFQUEwQjtBQUMvQixhQUFPLElBQVA7QUFDRDtBQUNELFVBQU0sSUFBSSxLQUFKLENBQVcsZ0NBQThCLEtBQU0sR0FBL0MsQ0FBTjtBQUNEO0FBZGdDO2tCQUFkLGEiLCJmaWxlIjoiYXN0LWRpc3BhdGNoZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZGVmYXVsdCBjbGFzcyBBU1REaXNwYXRjaGVyIHtcbiAgY29uc3RydWN0b3IocHJlZml4LCBlcnJvcklmTWlzc2luZykge1xuICAgIHRoaXMuZXJyb3JJZk1pc3NpbmcgPSBlcnJvcklmTWlzc2luZztcbiAgICB0aGlzLnByZWZpeCA9IHByZWZpeDtcbiAgfVxuXG4gIGRpc3BhdGNoKHRlcm0pIHtcbiAgICBsZXQgZmllbGQgPSB0aGlzLnByZWZpeCArIHRlcm0udHlwZTtcbiAgICBpZiAodHlwZW9mIHRoaXNbZmllbGRdID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICByZXR1cm4gdGhpc1tmaWVsZF0odGVybSk7XG4gICAgfSBlbHNlIGlmICghdGhpcy5lcnJvcklmTWlzc2luZykge1xuICAgICAgcmV0dXJuIHRlcm07XG4gICAgfVxuICAgIHRocm93IG5ldyBFcnJvcihgTWlzc2luZyBpbXBsZW1lbnRhdGlvbiBmb3I6ICR7ZmllbGR9YCk7XG4gIH1cbn1cbiJdfQ== \ No newline at end of file diff --git a/dist/binding-map.js b/dist/binding-map.js index 57e0adbf..a07f99a7 100644 --- a/dist/binding-map.js +++ b/dist/binding-map.js @@ -10,49 +10,73 @@ var _errors = require("./errors"); var _ramdaFantasy = require("ramda-fantasy"); -var _syntax = require("./syntax"); - class BindingMap { constructor() { this._map = new Map(); } - add(stx_20, _ref) { + + // given a syntax object and a binding, + // add the binding to the map associating the binding with the syntax object's + // scope set + add(stx, _ref) { let binding = _ref.binding; let phase = _ref.phase; var _ref$skipDup = _ref.skipDup; let skipDup = _ref$skipDup === undefined ? false : _ref$skipDup; - let stxName_21 = stx_20.val(); - let allScopeset_22 = stx_20.scopesets.all; - let scopeset_23 = stx_20.scopesets.phase.has(phase) ? stx_20.scopesets.phase.get(phase) : (0, _immutable.List)(); - scopeset_23 = allScopeset_22.concat(scopeset_23); + let stxName = stx.val(); + let allScopeset = stx.scopesets.all; + let scopeset = stx.scopesets.phase.has(phase) ? stx.scopesets.phase.get(phase) : (0, _immutable.List)(); + scopeset = allScopeset.concat(scopeset); (0, _errors.assert)(phase != null, "must provide a phase for binding add"); - if (this._map.has(stxName_21)) { - let scopesetBindingList = this._map.get(stxName_21); - if (skipDup && scopesetBindingList.some(s_24 => s_24.scopes.equals(scopeset_23))) { + + if (this._map.has(stxName)) { + let scopesetBindingList = this._map.get(stxName); + if (skipDup && scopesetBindingList.some(s => s.scopes.equals(scopeset))) { return; } - this._map.set(stxName_21, scopesetBindingList.push({ scopes: scopeset_23, binding: binding, alias: _ramdaFantasy.Maybe.Nothing() })); + this._map.set(stxName, scopesetBindingList.push({ + scopes: scopeset, + binding: binding, + alias: _ramdaFantasy.Maybe.Nothing() + })); } else { - this._map.set(stxName_21, _immutable.List.of({ scopes: scopeset_23, binding: binding, alias: _ramdaFantasy.Maybe.Nothing() })); + this._map.set(stxName, _immutable.List.of({ + scopes: scopeset, + binding: binding, + alias: _ramdaFantasy.Maybe.Nothing() + })); } } - addForward(stx_25, forwardStx_26, binding_27, phase_28) { - let stxName_29 = stx_25.token.value; - let allScopeset_30 = stx_25.scopesets.all; - let scopeset_31 = stx_25.scopesets.phase.has(phase_28) ? stx_25.scopesets.phase.get(phase_28) : (0, _immutable.List)(); - scopeset_31 = allScopeset_30.concat(scopeset_31); - (0, _errors.assert)(phase_28 != null, "must provide a phase for binding add"); - if (this._map.has(stxName_29)) { - let scopesetBindingList = this._map.get(stxName_29); - this._map.set(stxName_29, scopesetBindingList.push({ scopes: scopeset_31, binding: binding_27, alias: _ramdaFantasy.Maybe.of(forwardStx_26) })); + + addForward(stx, forwardStx, binding, phase) { + let stxName = stx.token.value; + let allScopeset = stx.scopesets.all; + let scopeset = stx.scopesets.phase.has(phase) ? stx.scopesets.phase.get(phase) : (0, _immutable.List)(); + scopeset = allScopeset.concat(scopeset); + (0, _errors.assert)(phase != null, "must provide a phase for binding add"); + + if (this._map.has(stxName)) { + let scopesetBindingList = this._map.get(stxName); + this._map.set(stxName, scopesetBindingList.push({ + scopes: scopeset, + binding: binding, + alias: _ramdaFantasy.Maybe.of(forwardStx) + })); } else { - this._map.set(stxName_29, _immutable.List.of({ scopes: scopeset_31, binding: binding_27, alias: _ramdaFantasy.Maybe.of(forwardStx_26) })); + this._map.set(stxName, _immutable.List.of({ + scopes: scopeset, + binding: binding, + alias: _ramdaFantasy.Maybe.of(forwardStx) + })); } } - get(stx_32) { - return this._map.get(stx_32.token.value); + + // Syntax -> ?List<{ scopes: ScopeSet, binding: Binding }> + get(stx) { + return this._map.get(stx.token.value); } + } exports.default = BindingMap; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2JpbmRpbmctbWFwLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNlLE1BQU0sVUFBTixDQUFpQjtBQUM5QixnQkFBYztBQUNaLFNBQUssSUFBTCxHQUFZLElBQUksR0FBSixFQUFaO0FBQ0Q7QUFDRCxNQUFJLE1BQUosUUFBK0M7QUFBQSxRQUFsQyxPQUFrQyxRQUFsQyxPQUFrQztBQUFBLFFBQXpCLEtBQXlCLFFBQXpCLEtBQXlCO0FBQUEsNEJBQWxCLE9BQWtCO0FBQUEsUUFBbEIsT0FBa0IsZ0NBQVIsS0FBUTs7QUFDN0MsUUFBSSxhQUFhLE9BQU8sR0FBUCxFQUFqQjtBQUNBLFFBQUksaUJBQWlCLE9BQU8sU0FBUCxDQUFpQixHQUF0QztBQUNBLFFBQUksY0FBYyxPQUFPLFNBQVAsQ0FBaUIsS0FBakIsQ0FBdUIsR0FBdkIsQ0FBMkIsS0FBM0IsSUFBb0MsT0FBTyxTQUFQLENBQWlCLEtBQWpCLENBQXVCLEdBQXZCLENBQTJCLEtBQTNCLENBQXBDLEdBQXdFLHNCQUExRjtBQUNBLGtCQUFjLGVBQWUsTUFBZixDQUFzQixXQUF0QixDQUFkO0FBQ0Esd0JBQU8sU0FBUyxJQUFoQixFQUFzQixzQ0FBdEI7QUFDQSxRQUFJLEtBQUssSUFBTCxDQUFVLEdBQVYsQ0FBYyxVQUFkLENBQUosRUFBK0I7QUFDN0IsVUFBSSxzQkFBc0IsS0FBSyxJQUFMLENBQVUsR0FBVixDQUFjLFVBQWQsQ0FBMUI7QUFDQSxVQUFJLFdBQVcsb0JBQW9CLElBQXBCLENBQXlCLFFBQVEsS0FBSyxNQUFMLENBQVksTUFBWixDQUFtQixXQUFuQixDQUFqQyxDQUFmLEVBQWtGO0FBQ2hGO0FBQ0Q7QUFDRCxXQUFLLElBQUwsQ0FBVSxHQUFWLENBQWMsVUFBZCxFQUEwQixvQkFBb0IsSUFBcEIsQ0FBeUIsRUFBQyxRQUFRLFdBQVQsRUFBc0IsU0FBUyxPQUEvQixFQUF3QyxPQUFPLG9CQUFNLE9BQU4sRUFBL0MsRUFBekIsQ0FBMUI7QUFDRCxLQU5ELE1BTU87QUFDTCxXQUFLLElBQUwsQ0FBVSxHQUFWLENBQWMsVUFBZCxFQUEwQixnQkFBSyxFQUFMLENBQVEsRUFBQyxRQUFRLFdBQVQsRUFBc0IsU0FBUyxPQUEvQixFQUF3QyxPQUFPLG9CQUFNLE9BQU4sRUFBL0MsRUFBUixDQUExQjtBQUNEO0FBQ0Y7QUFDRCxhQUFXLE1BQVgsRUFBbUIsYUFBbkIsRUFBa0MsVUFBbEMsRUFBOEMsUUFBOUMsRUFBd0Q7QUFDdEQsUUFBSSxhQUFhLE9BQU8sS0FBUCxDQUFhLEtBQTlCO0FBQ0EsUUFBSSxpQkFBaUIsT0FBTyxTQUFQLENBQWlCLEdBQXRDO0FBQ0EsUUFBSSxjQUFjLE9BQU8sU0FBUCxDQUFpQixLQUFqQixDQUF1QixHQUF2QixDQUEyQixRQUEzQixJQUF1QyxPQUFPLFNBQVAsQ0FBaUIsS0FBakIsQ0FBdUIsR0FBdkIsQ0FBMkIsUUFBM0IsQ0FBdkMsR0FBOEUsc0JBQWhHO0FBQ0Esa0JBQWMsZUFBZSxNQUFmLENBQXNCLFdBQXRCLENBQWQ7QUFDQSx3QkFBTyxZQUFZLElBQW5CLEVBQXlCLHNDQUF6QjtBQUNBLFFBQUksS0FBSyxJQUFMLENBQVUsR0FBVixDQUFjLFVBQWQsQ0FBSixFQUErQjtBQUM3QixVQUFJLHNCQUFzQixLQUFLLElBQUwsQ0FBVSxHQUFWLENBQWMsVUFBZCxDQUExQjtBQUNBLFdBQUssSUFBTCxDQUFVLEdBQVYsQ0FBYyxVQUFkLEVBQTBCLG9CQUFvQixJQUFwQixDQUF5QixFQUFDLFFBQVEsV0FBVCxFQUFzQixTQUFTLFVBQS9CLEVBQTJDLE9BQU8sb0JBQU0sRUFBTixDQUFTLGFBQVQsQ0FBbEQsRUFBekIsQ0FBMUI7QUFDRCxLQUhELE1BR087QUFDTCxXQUFLLElBQUwsQ0FBVSxHQUFWLENBQWMsVUFBZCxFQUEwQixnQkFBSyxFQUFMLENBQVEsRUFBQyxRQUFRLFdBQVQsRUFBc0IsU0FBUyxVQUEvQixFQUEyQyxPQUFPLG9CQUFNLEVBQU4sQ0FBUyxhQUFULENBQWxELEVBQVIsQ0FBMUI7QUFDRDtBQUNGO0FBQ0QsTUFBSSxNQUFKLEVBQVk7QUFDVixXQUFPLEtBQUssSUFBTCxDQUFVLEdBQVYsQ0FBYyxPQUFPLEtBQVAsQ0FBYSxLQUEzQixDQUFQO0FBQ0Q7QUFuQzZCO2tCQUFYLFUiLCJmaWxlIjoiYmluZGluZy1tYXAuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0xpc3R9IGZyb20gXCJpbW11dGFibGVcIjtcbmltcG9ydCB7ZXhwZWN0LCBhc3NlcnR9IGZyb20gXCIuL2Vycm9yc1wiO1xuaW1wb3J0IHtNYXliZX0gZnJvbSBcInJhbWRhLWZhbnRhc3lcIjtcbmltcG9ydCB7QUxMX1BIQVNFU30gZnJvbSBcIi4vc3ludGF4XCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBCaW5kaW5nTWFwIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5fbWFwID0gbmV3IE1hcDtcbiAgfVxuICBhZGQoc3R4XzIwLCB7YmluZGluZywgcGhhc2UsIHNraXBEdXAgPSBmYWxzZX0pIHtcbiAgICBsZXQgc3R4TmFtZV8yMSA9IHN0eF8yMC52YWwoKTtcbiAgICBsZXQgYWxsU2NvcGVzZXRfMjIgPSBzdHhfMjAuc2NvcGVzZXRzLmFsbDtcbiAgICBsZXQgc2NvcGVzZXRfMjMgPSBzdHhfMjAuc2NvcGVzZXRzLnBoYXNlLmhhcyhwaGFzZSkgPyBzdHhfMjAuc2NvcGVzZXRzLnBoYXNlLmdldChwaGFzZSkgOiBMaXN0KCk7XG4gICAgc2NvcGVzZXRfMjMgPSBhbGxTY29wZXNldF8yMi5jb25jYXQoc2NvcGVzZXRfMjMpO1xuICAgIGFzc2VydChwaGFzZSAhPSBudWxsLCBcIm11c3QgcHJvdmlkZSBhIHBoYXNlIGZvciBiaW5kaW5nIGFkZFwiKTtcbiAgICBpZiAodGhpcy5fbWFwLmhhcyhzdHhOYW1lXzIxKSkge1xuICAgICAgbGV0IHNjb3Blc2V0QmluZGluZ0xpc3QgPSB0aGlzLl9tYXAuZ2V0KHN0eE5hbWVfMjEpO1xuICAgICAgaWYgKHNraXBEdXAgJiYgc2NvcGVzZXRCaW5kaW5nTGlzdC5zb21lKHNfMjQgPT4gc18yNC5zY29wZXMuZXF1YWxzKHNjb3Blc2V0XzIzKSkpIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuICAgICAgdGhpcy5fbWFwLnNldChzdHhOYW1lXzIxLCBzY29wZXNldEJpbmRpbmdMaXN0LnB1c2goe3Njb3Blczogc2NvcGVzZXRfMjMsIGJpbmRpbmc6IGJpbmRpbmcsIGFsaWFzOiBNYXliZS5Ob3RoaW5nKCl9KSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX21hcC5zZXQoc3R4TmFtZV8yMSwgTGlzdC5vZih7c2NvcGVzOiBzY29wZXNldF8yMywgYmluZGluZzogYmluZGluZywgYWxpYXM6IE1heWJlLk5vdGhpbmcoKX0pKTtcbiAgICB9XG4gIH1cbiAgYWRkRm9yd2FyZChzdHhfMjUsIGZvcndhcmRTdHhfMjYsIGJpbmRpbmdfMjcsIHBoYXNlXzI4KSB7XG4gICAgbGV0IHN0eE5hbWVfMjkgPSBzdHhfMjUudG9rZW4udmFsdWU7XG4gICAgbGV0IGFsbFNjb3Blc2V0XzMwID0gc3R4XzI1LnNjb3Blc2V0cy5hbGw7XG4gICAgbGV0IHNjb3Blc2V0XzMxID0gc3R4XzI1LnNjb3Blc2V0cy5waGFzZS5oYXMocGhhc2VfMjgpID8gc3R4XzI1LnNjb3Blc2V0cy5waGFzZS5nZXQocGhhc2VfMjgpIDogTGlzdCgpO1xuICAgIHNjb3Blc2V0XzMxID0gYWxsU2NvcGVzZXRfMzAuY29uY2F0KHNjb3Blc2V0XzMxKTtcbiAgICBhc3NlcnQocGhhc2VfMjggIT0gbnVsbCwgXCJtdXN0IHByb3ZpZGUgYSBwaGFzZSBmb3IgYmluZGluZyBhZGRcIik7XG4gICAgaWYgKHRoaXMuX21hcC5oYXMoc3R4TmFtZV8yOSkpIHtcbiAgICAgIGxldCBzY29wZXNldEJpbmRpbmdMaXN0ID0gdGhpcy5fbWFwLmdldChzdHhOYW1lXzI5KTtcbiAgICAgIHRoaXMuX21hcC5zZXQoc3R4TmFtZV8yOSwgc2NvcGVzZXRCaW5kaW5nTGlzdC5wdXNoKHtzY29wZXM6IHNjb3Blc2V0XzMxLCBiaW5kaW5nOiBiaW5kaW5nXzI3LCBhbGlhczogTWF5YmUub2YoZm9yd2FyZFN0eF8yNil9KSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX21hcC5zZXQoc3R4TmFtZV8yOSwgTGlzdC5vZih7c2NvcGVzOiBzY29wZXNldF8zMSwgYmluZGluZzogYmluZGluZ18yNywgYWxpYXM6IE1heWJlLm9mKGZvcndhcmRTdHhfMjYpfSkpO1xuICAgIH1cbiAgfVxuICBnZXQoc3R4XzMyKSB7XG4gICAgcmV0dXJuIHRoaXMuX21hcC5nZXQoc3R4XzMyLnRva2VuLnZhbHVlKTtcbiAgfVxufVxuIl19 \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,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VDtBQUhzQixPQUFSLENBQXZCO0FBS0Q7QUFFRjs7QUFFRDtBQUNBLE1BQUksR0FBSixFQUFTO0FBQ1AsV0FBTyxLQUFLLElBQUwsQ0FBVSxHQUFWLENBQWMsSUFBSSxLQUFKLENBQVUsS0FBeEIsQ0FBUDtBQUNEOztBQTdENkI7a0JBQVgsVSIsImZpbGUiOiJiaW5kaW5nLW1hcC5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExpc3QgfSBmcm9tIFwiaW1tdXRhYmxlXCI7XG5pbXBvcnQgeyBhc3NlcnQgfSBmcm9tIFwiLi9lcnJvcnNcIjtcbmltcG9ydCB7IE1heWJlIH0gZnJvbSAncmFtZGEtZmFudGFzeSc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEJpbmRpbmdNYXAge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLl9tYXAgPSBuZXcgTWFwKCk7XG4gIH1cblxuICAvLyBnaXZlbiBhIHN5bnRheCBvYmplY3QgYW5kIGEgYmluZGluZyxcbiAgLy8gYWRkIHRoZSBiaW5kaW5nIHRvIHRoZSBtYXAgYXNzb2NpYXRpbmcgdGhlIGJpbmRpbmcgd2l0aCB0aGUgc3ludGF4IG9iamVjdCdzXG4gIC8vIHNjb3BlIHNldFxuICBhZGQoc3R4LCB7IGJpbmRpbmcsIHBoYXNlLCBza2lwRHVwID0gZmFsc2UgfSkge1xuICAgIGxldCBzdHhOYW1lID0gc3R4LnZhbCgpO1xuICAgIGxldCBhbGxTY29wZXNldCA9IHN0eC5zY29wZXNldHMuYWxsO1xuICAgIGxldCBzY29wZXNldCA9IHN0eC5zY29wZXNldHMucGhhc2UuaGFzKHBoYXNlKSA/IHN0eC5zY29wZXNldHMucGhhc2UuZ2V0KHBoYXNlKSA6IExpc3QoKTtcbiAgICBzY29wZXNldCA9IGFsbFNjb3Blc2V0LmNvbmNhdChzY29wZXNldCk7XG4gICAgYXNzZXJ0KHBoYXNlICE9IG51bGwsIFwibXVzdCBwcm92aWRlIGEgcGhhc2UgZm9yIGJpbmRpbmcgYWRkXCIpO1xuXG4gICAgaWYgKHRoaXMuX21hcC5oYXMoc3R4TmFtZSkpIHtcbiAgICAgIGxldCBzY29wZXNldEJpbmRpbmdMaXN0ID0gdGhpcy5fbWFwLmdldChzdHhOYW1lKTtcbiAgICAgIGlmIChza2lwRHVwICYmIHNjb3Blc2V0QmluZGluZ0xpc3Quc29tZShzID0+IHMuc2NvcGVzLmVxdWFscyhzY29wZXNldCkpKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cbiAgICAgIHRoaXMuX21hcC5zZXQoc3R4TmFtZSwgc2NvcGVzZXRCaW5kaW5nTGlzdC5wdXNoKHtcbiAgICAgICAgc2NvcGVzOiBzY29wZXNldCxcbiAgICAgICAgYmluZGluZzogYmluZGluZyxcbiAgICAgICAgYWxpYXM6IE1heWJlLk5vdGhpbmcoKVxuICAgICAgfSkpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLl9tYXAuc2V0KHN0eE5hbWUsIExpc3Qub2Yoe1xuICAgICAgICBzY29wZXM6IHNjb3Blc2V0LFxuICAgICAgICBiaW5kaW5nOiBiaW5kaW5nLFxuICAgICAgICBhbGlhczogTWF5YmUuTm90aGluZygpXG4gICAgICB9KSk7XG4gICAgfVxuICB9XG5cbiAgYWRkRm9yd2FyZChzdHgsIGZvcndhcmRTdHgsIGJpbmRpbmcsIHBoYXNlKSB7XG4gICAgbGV0IHN0eE5hbWUgPSBzdHgudG9rZW4udmFsdWU7XG4gICAgbGV0IGFsbFNjb3Blc2V0ID0gc3R4LnNjb3Blc2V0cy5hbGw7XG4gICAgbGV0IHNjb3Blc2V0ID0gc3R4LnNjb3Blc2V0cy5waGFzZS5oYXMocGhhc2UpID8gc3R4LnNjb3Blc2V0cy5waGFzZS5nZXQocGhhc2UpIDogTGlzdCgpO1xuICAgIHNjb3Blc2V0ID0gYWxsU2NvcGVzZXQuY29uY2F0KHNjb3Blc2V0KTtcbiAgICBhc3NlcnQocGhhc2UgIT0gbnVsbCwgXCJtdXN0IHByb3ZpZGUgYSBwaGFzZSBmb3IgYmluZGluZyBhZGRcIik7XG5cbiAgICBpZiAodGhpcy5fbWFwLmhhcyhzdHhOYW1lKSkge1xuICAgICAgbGV0IHNjb3Blc2V0QmluZGluZ0xpc3QgPSB0aGlzLl9tYXAuZ2V0KHN0eE5hbWUpO1xuICAgICAgdGhpcy5fbWFwLnNldChzdHhOYW1lLCBzY29wZXNldEJpbmRpbmdMaXN0LnB1c2goe1xuICAgICAgICBzY29wZXM6IHNjb3Blc2V0LFxuICAgICAgICBiaW5kaW5nOiBiaW5kaW5nLFxuICAgICAgICBhbGlhczogTWF5YmUub2YoZm9yd2FyZFN0eClcbiAgICAgIH0pKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5fbWFwLnNldChzdHhOYW1lLCBMaXN0Lm9mKHtcbiAgICAgICAgc2NvcGVzOiBzY29wZXNldCxcbiAgICAgICAgYmluZGluZzogYmluZGluZyxcbiAgICAgICAgYWxpYXM6IE1heWJlLm9mKGZvcndhcmRTdHgpXG4gICAgICB9KSk7XG4gICAgfVxuXG4gIH1cblxuICAvLyBTeW50YXggLT4gP0xpc3Q8eyBzY29wZXM6IFNjb3BlU2V0LCBiaW5kaW5nOiBCaW5kaW5nIH0+XG4gIGdldChzdHgpIHtcbiAgICByZXR1cm4gdGhpcy5fbWFwLmdldChzdHgudG9rZW4udmFsdWUpO1xuICB9XG5cbn1cbiJdfQ== \ No newline at end of file diff --git a/dist/compiler.js b/dist/compiler.js index 2be7637b..5893a789 100644 --- a/dist/compiler.js +++ b/dist/compiler.js @@ -1,22 +1,18 @@ -"use strict"; +'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); -var _immutable = require("immutable"); - -var _termExpander = require("./term-expander.js"); +var _termExpander = require('./term-expander.js'); var _termExpander2 = _interopRequireDefault(_termExpander); -var _tokenExpander = require("./token-expander"); +var _tokenExpander = require('./token-expander'); var _tokenExpander2 = _interopRequireDefault(_tokenExpander); -var _scope = require("./scope"); - -var _ramda = require("ramda"); +var _ramda = require('ramda'); var _ = _interopRequireWildcard(_ramda); @@ -25,17 +21,27 @@ function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } class Compiler { - constructor(phase_33, env_34, store_35, context_36) { - this.phase = phase_33; - this.env = env_34; - this.store = store_35; - this.context = context_36; + constructor(phase, env, store, context) { + this.phase = phase; + this.env = env; + this.store = store; + this.context = context; } - compile(stxl_37) { - let tokenExpander_38 = new _tokenExpander2.default(_.merge(this.context, { phase: this.phase, env: this.env, store: this.store })); - let termExpander_39 = new _termExpander2.default(_.merge(this.context, { phase: this.phase, env: this.env, store: this.store })); - return _.pipe(_.bind(tokenExpander_38.expand, tokenExpander_38), _.map(t_40 => termExpander_39.expand(t_40)))(stxl_37); + + compile(stxl) { + let tokenExpander = new _tokenExpander2.default(_.merge(this.context, { + phase: this.phase, + env: this.env, + store: this.store + })); + let termExpander = new _termExpander2.default(_.merge(this.context, { + phase: this.phase, + env: this.env, + store: this.store + })); + + return _.pipe(_.bind(tokenExpander.expand, tokenExpander), _.map(t => termExpander.expand(t)))(stxl); } } exports.default = Compiler; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2NvbXBpbGVyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOztBQUNBOzs7O0FBQ0E7Ozs7QUFDQTs7QUFDQTs7SUFBYSxDOzs7Ozs7QUFDRSxNQUFNLFFBQU4sQ0FBZTtBQUM1QixjQUFZLFFBQVosRUFBc0IsTUFBdEIsRUFBOEIsUUFBOUIsRUFBd0MsVUFBeEMsRUFBb0Q7QUFDbEQsU0FBSyxLQUFMLEdBQWEsUUFBYjtBQUNBLFNBQUssR0FBTCxHQUFXLE1BQVg7QUFDQSxTQUFLLEtBQUwsR0FBYSxRQUFiO0FBQ0EsU0FBSyxPQUFMLEdBQWUsVUFBZjtBQUNEO0FBQ0QsVUFBUSxPQUFSLEVBQWlCO0FBQ2YsUUFBSSxtQkFBbUIsNEJBQWtCLEVBQUUsS0FBRixDQUFRLEtBQUssT0FBYixFQUFzQixFQUFDLE9BQU8sS0FBSyxLQUFiLEVBQW9CLEtBQUssS0FBSyxHQUE5QixFQUFtQyxPQUFPLEtBQUssS0FBL0MsRUFBdEIsQ0FBbEIsQ0FBdkI7QUFDQSxRQUFJLGtCQUFrQiwyQkFBaUIsRUFBRSxLQUFGLENBQVEsS0FBSyxPQUFiLEVBQXNCLEVBQUMsT0FBTyxLQUFLLEtBQWIsRUFBb0IsS0FBSyxLQUFLLEdBQTlCLEVBQW1DLE9BQU8sS0FBSyxLQUEvQyxFQUF0QixDQUFqQixDQUF0QjtBQUNBLFdBQU8sRUFBRSxJQUFGLENBQU8sRUFBRSxJQUFGLENBQU8saUJBQWlCLE1BQXhCLEVBQWdDLGdCQUFoQyxDQUFQLEVBQTBELEVBQUUsR0FBRixDQUFNLFFBQVEsZ0JBQWdCLE1BQWhCLENBQXVCLElBQXZCLENBQWQsQ0FBMUQsRUFBdUcsT0FBdkcsQ0FBUDtBQUNEO0FBWDJCO2tCQUFULFEiLCJmaWxlIjoiY29tcGlsZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0xpc3R9IGZyb20gXCJpbW11dGFibGVcIjtcbmltcG9ydCBUZXJtRXhwYW5kZXIgZnJvbSBcIi4vdGVybS1leHBhbmRlci5qc1wiO1xuaW1wb3J0IFRva2VuRXhwYW5kZXIgZnJvbSBcIi4vdG9rZW4tZXhwYW5kZXJcIjtcbmltcG9ydCB7U2NvcGUsIGZyZXNoU2NvcGV9IGZyb20gXCIuL3Njb3BlXCI7XG5pbXBvcnQgICogYXMgXyBmcm9tIFwicmFtZGFcIjtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENvbXBpbGVyIHtcbiAgY29uc3RydWN0b3IocGhhc2VfMzMsIGVudl8zNCwgc3RvcmVfMzUsIGNvbnRleHRfMzYpIHtcbiAgICB0aGlzLnBoYXNlID0gcGhhc2VfMzM7XG4gICAgdGhpcy5lbnYgPSBlbnZfMzQ7XG4gICAgdGhpcy5zdG9yZSA9IHN0b3JlXzM1O1xuICAgIHRoaXMuY29udGV4dCA9IGNvbnRleHRfMzY7XG4gIH1cbiAgY29tcGlsZShzdHhsXzM3KSB7XG4gICAgbGV0IHRva2VuRXhwYW5kZXJfMzggPSBuZXcgVG9rZW5FeHBhbmRlcihfLm1lcmdlKHRoaXMuY29udGV4dCwge3BoYXNlOiB0aGlzLnBoYXNlLCBlbnY6IHRoaXMuZW52LCBzdG9yZTogdGhpcy5zdG9yZX0pKTtcbiAgICBsZXQgdGVybUV4cGFuZGVyXzM5ID0gbmV3IFRlcm1FeHBhbmRlcihfLm1lcmdlKHRoaXMuY29udGV4dCwge3BoYXNlOiB0aGlzLnBoYXNlLCBlbnY6IHRoaXMuZW52LCBzdG9yZTogdGhpcy5zdG9yZX0pKTtcbiAgICByZXR1cm4gXy5waXBlKF8uYmluZCh0b2tlbkV4cGFuZGVyXzM4LmV4cGFuZCwgdG9rZW5FeHBhbmRlcl8zOCksIF8ubWFwKHRfNDAgPT4gdGVybUV4cGFuZGVyXzM5LmV4cGFuZCh0XzQwKSkpKHN0eGxfMzcpO1xuICB9XG59XG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21waWxlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7OztBQUNBOzs7O0FBQ0E7O0lBQVksQzs7Ozs7O0FBR0csTUFBTSxRQUFOLENBQWU7QUFDNUIsY0FBWSxLQUFaLEVBQW1CLEdBQW5CLEVBQXdCLEtBQXhCLEVBQStCLE9BQS9CLEVBQXdDO0FBQ3RDLFNBQUssS0FBTCxHQUFhLEtBQWI7QUFDQSxTQUFLLEdBQUwsR0FBVyxHQUFYO0FBQ0EsU0FBSyxLQUFMLEdBQWEsS0FBYjtBQUNBLFNBQUssT0FBTCxHQUFlLE9BQWY7QUFDRDs7QUFFRCxVQUFRLElBQVIsRUFBYztBQUNaLFFBQUksZ0JBQWdCLDRCQUFrQixFQUFFLEtBQUYsQ0FBUSxLQUFLLE9BQWIsRUFBc0I7QUFDMUQsYUFBTyxLQUFLLEtBRDhDO0FBRTFELFdBQUssS0FBSyxHQUZnRDtBQUcxRCxhQUFPLEtBQUs7QUFIOEMsS0FBdEIsQ0FBbEIsQ0FBcEI7QUFLQSxRQUFJLGVBQWUsMkJBQWlCLEVBQUUsS0FBRixDQUFRLEtBQUssT0FBYixFQUFzQjtBQUN4RCxhQUFPLEtBQUssS0FENEM7QUFFeEQsV0FBSyxLQUFLLEdBRjhDO0FBR3hELGFBQU8sS0FBSztBQUg0QyxLQUF0QixDQUFqQixDQUFuQjs7QUFNQSxXQUFPLEVBQUUsSUFBRixDQUNMLEVBQUUsSUFBRixDQUFPLGNBQWMsTUFBckIsRUFBNkIsYUFBN0IsQ0FESyxFQUVMLEVBQUUsR0FBRixDQUFNLEtBQUssYUFBYSxNQUFiLENBQW9CLENBQXBCLENBQVgsQ0FGSyxFQUdMLElBSEssQ0FBUDtBQUlEO0FBeEIyQjtrQkFBVCxRIiwiZmlsZSI6ImNvbXBpbGVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFRlcm1FeHBhbmRlciBmcm9tIFwiLi90ZXJtLWV4cGFuZGVyLmpzXCI7XG5pbXBvcnQgVG9rZW5FeHBhbmRlciBmcm9tICcuL3Rva2VuLWV4cGFuZGVyJztcbmltcG9ydCAqIGFzIF8gZnJvbSAncmFtZGEnO1xuXG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENvbXBpbGVyIHtcbiAgY29uc3RydWN0b3IocGhhc2UsIGVudiwgc3RvcmUsIGNvbnRleHQpIHtcbiAgICB0aGlzLnBoYXNlID0gcGhhc2U7XG4gICAgdGhpcy5lbnYgPSBlbnY7XG4gICAgdGhpcy5zdG9yZSA9IHN0b3JlO1xuICAgIHRoaXMuY29udGV4dCA9IGNvbnRleHQ7XG4gIH1cblxuICBjb21waWxlKHN0eGwpIHtcbiAgICBsZXQgdG9rZW5FeHBhbmRlciA9IG5ldyBUb2tlbkV4cGFuZGVyKF8ubWVyZ2UodGhpcy5jb250ZXh0LCB7XG4gICAgICBwaGFzZTogdGhpcy5waGFzZSxcbiAgICAgIGVudjogdGhpcy5lbnYsXG4gICAgICBzdG9yZTogdGhpcy5zdG9yZVxuICAgIH0pKTtcbiAgICBsZXQgdGVybUV4cGFuZGVyID0gbmV3IFRlcm1FeHBhbmRlcihfLm1lcmdlKHRoaXMuY29udGV4dCwge1xuICAgICAgcGhhc2U6IHRoaXMucGhhc2UsXG4gICAgICBlbnY6IHRoaXMuZW52LFxuICAgICAgc3RvcmU6IHRoaXMuc3RvcmVcbiAgICB9KSk7XG5cbiAgICByZXR1cm4gXy5waXBlKFxuICAgICAgXy5iaW5kKHRva2VuRXhwYW5kZXIuZXhwYW5kLCB0b2tlbkV4cGFuZGVyKSxcbiAgICAgIF8ubWFwKHQgPT4gdGVybUV4cGFuZGVyLmV4cGFuZCh0KSlcbiAgICApKHN0eGwpO1xuICB9XG59XG4iXX0= \ No newline at end of file diff --git a/dist/enforester.js b/dist/enforester.js index cbb36991..15310e67 100644 --- a/dist/enforester.js +++ b/dist/enforester.js @@ -33,775 +33,995 @@ var _macroContext2 = _interopRequireDefault(_macroContext); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } -const Just_41 = _ramdaFantasy.Maybe.Just; -const Nothing_42 = _ramdaFantasy.Maybe.Nothing; -const EXPR_LOOP_OPERATOR_43 = {}; -const EXPR_LOOP_NO_CHANGE_44 = {}; -const EXPR_LOOP_EXPANSION_45 = {}; -class Enforester_46 { - constructor(stxl_47, prev_48, context_49) { +const Just = _ramdaFantasy.Maybe.Just; +const Nothing = _ramdaFantasy.Maybe.Nothing; + +const EXPR_LOOP_OPERATOR = {}; +const EXPR_LOOP_NO_CHANGE = {}; +const EXPR_LOOP_EXPANSION = {}; + +class Enforester { + constructor(stxl, prev, context) { this.done = false; - (0, _errors.assert)(_immutable.List.isList(stxl_47), "expecting a list of terms to enforest"); - (0, _errors.assert)(_immutable.List.isList(prev_48), "expecting a list of terms to enforest"); - (0, _errors.assert)(context_49, "expecting a context to enforest"); + (0, _errors.assert)(_immutable.List.isList(stxl), "expecting a list of terms to enforest"); + (0, _errors.assert)(_immutable.List.isList(prev), "expecting a list of terms to enforest"); + (0, _errors.assert)(context, "expecting a context to enforest"); this.term = null; - this.rest = stxl_47; - this.prev = prev_48; - this.context = context_49; + + this.rest = stxl; + this.prev = prev; + + this.context = context; } + peek() { - let n_50 = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0]; + let n = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0]; - return this.rest.get(n_50); + return this.rest.get(n); } + advance() { - let ret_51 = this.rest.first(); + let ret = this.rest.first(); this.rest = this.rest.rest(); - return ret_51; + return ret; } + + /* + enforest works over: + prev - a list of the previously enforest Terms + term - the current term being enforested (initially null) + rest - remaining Terms to enforest + */ enforest() { - let type_52 = arguments.length <= 0 || arguments[0] === undefined ? "Module" : arguments[0]; + let type = arguments.length <= 0 || arguments[0] === undefined ? "Module" : arguments[0]; + // initialize the term this.term = null; + if (this.rest.size === 0) { this.done = true; return this.term; } + if (this.isEOF(this.peek())) { this.term = new _terms2.default("EOF", {}); this.advance(); return this.term; } - let result_53; - if (type_52 === "expression") { - result_53 = this.enforestExpressionLoop(); + + let result; + if (type === "expression") { + result = this.enforestExpressionLoop(); } else { - result_53 = this.enforestModule(); + result = this.enforestModule(); } + if (this.rest.size === 0) { this.done = true; } - return result_53; + return result; } + enforestModule() { return this.enforestBody(); } + enforestBody() { return this.enforestModuleItem(); } + enforestModuleItem() { - let lookahead_54 = this.peek(); - if (this.isKeyword(lookahead_54, "import")) { + let lookahead = this.peek(); + if (this.isKeyword(lookahead, 'import')) { this.advance(); return this.enforestImportDeclaration(); - } else if (this.isKeyword(lookahead_54, "export")) { + } else if (this.isKeyword(lookahead, 'export')) { this.advance(); return this.enforestExportDeclaration(); - } else if (this.isIdentifier(lookahead_54, "#")) { + } else if (this.isIdentifier(lookahead, '#')) { return this.enforestLanguagePragma(); } return this.enforestStatement(); } + enforestLanguagePragma() { - this.matchIdentifier("#"); - this.matchIdentifier("lang"); - let path_55 = this.matchStringLiteral(); + this.matchIdentifier('#'); + this.matchIdentifier('lang'); + let path = this.matchStringLiteral(); this.consumeSemicolon(); - return new _terms2.default("Pragma", { kind: "lang", items: _immutable.List.of(path_55) }); + return new _terms2.default('Pragma', { + kind: 'lang', + items: _immutable.List.of(path) + }); } + enforestExportDeclaration() { - let lookahead_56 = this.peek(); - if (this.isPunctuator(lookahead_56, "*")) { + let lookahead = this.peek(); + if (this.isPunctuator(lookahead, '*')) { this.advance(); let moduleSpecifier = this.enforestFromClause(); - return new _terms2.default("ExportAllFrom", { moduleSpecifier: moduleSpecifier }); - } else if (this.isBraces(lookahead_56)) { + return new _terms2.default('ExportAllFrom', { moduleSpecifier: moduleSpecifier }); + } else if (this.isBraces(lookahead)) { let namedExports = this.enforestExportClause(); let moduleSpecifier = null; - if (this.isIdentifier(this.peek(), "from")) { + if (this.isIdentifier(this.peek(), 'from')) { moduleSpecifier = this.enforestFromClause(); } - return new _terms2.default("ExportFrom", { namedExports: namedExports, moduleSpecifier: moduleSpecifier }); - } else if (this.isKeyword(lookahead_56, "class")) { - return new _terms2.default("Export", { declaration: this.enforestClass({ isExpr: false }) }); - } else if (this.isFnDeclTransform(lookahead_56)) { - return new _terms2.default("Export", { declaration: this.enforestFunction({ isExpr: false, inDefault: false }) }); - } else if (this.isKeyword(lookahead_56, "default")) { + return new _terms2.default('ExportFrom', { namedExports: namedExports, moduleSpecifier: moduleSpecifier }); + } else if (this.isKeyword(lookahead, 'class')) { + return new _terms2.default('Export', { + declaration: this.enforestClass({ isExpr: false }) + }); + } else if (this.isFnDeclTransform(lookahead)) { + return new _terms2.default('Export', { + declaration: this.enforestFunction({ isExpr: false, inDefault: false }) + }); + } else if (this.isKeyword(lookahead, 'default')) { this.advance(); if (this.isFnDeclTransform(this.peek())) { - return new _terms2.default("ExportDefault", { body: this.enforestFunction({ isExpr: false, inDefault: true }) }); - } else if (this.isKeyword(this.peek(), "class")) { - return new _terms2.default("ExportDefault", { body: this.enforestClass({ isExpr: false, inDefault: true }) }); + return new _terms2.default('ExportDefault', { + body: this.enforestFunction({ isExpr: false, inDefault: true }) + }); + } else if (this.isKeyword(this.peek(), 'class')) { + return new _terms2.default('ExportDefault', { + body: this.enforestClass({ isExpr: false, inDefault: true }) + }); } else { let body = this.enforestExpressionLoop(); this.consumeSemicolon(); - return new _terms2.default("ExportDefault", { body: body }); + return new _terms2.default('ExportDefault', { body: body }); } - } else if (this.isVarDeclTransform(lookahead_56) || this.isLetDeclTransform(lookahead_56) || this.isConstDeclTransform(lookahead_56) || this.isSyntaxrecDeclTransform(lookahead_56) || this.isSyntaxDeclTransform(lookahead_56)) { - return new _terms2.default("Export", { declaration: this.enforestVariableDeclaration() }); + } else if (this.isVarDeclTransform(lookahead) || this.isLetDeclTransform(lookahead) || this.isConstDeclTransform(lookahead) || this.isSyntaxrecDeclTransform(lookahead) || this.isSyntaxDeclTransform(lookahead)) { + return new _terms2.default('Export', { + declaration: this.enforestVariableDeclaration() + }); } - throw this.createError(lookahead_56, "unexpected syntax"); + throw this.createError(lookahead, 'unexpected syntax'); } + enforestExportClause() { - let enf_57 = new Enforester_46(this.matchCurlies(), (0, _immutable.List)(), this.context); - let result_58 = []; - while (enf_57.rest.size !== 0) { - result_58.push(enf_57.enforestExportSpecifier()); - enf_57.consumeComma(); + let enf = new Enforester(this.matchCurlies(), (0, _immutable.List)(), this.context); + let result = []; + while (enf.rest.size !== 0) { + result.push(enf.enforestExportSpecifier()); + enf.consumeComma(); } - return (0, _immutable.List)(result_58); + return (0, _immutable.List)(result); } + enforestExportSpecifier() { - let name_59 = this.enforestIdentifier(); - if (this.isIdentifier(this.peek(), "as")) { + let name = this.enforestIdentifier(); + if (this.isIdentifier(this.peek(), 'as')) { this.advance(); let exportedName = this.enforestIdentifier(); - return new _terms2.default("ExportSpecifier", { name: name_59, exportedName: exportedName }); + return new _terms2.default('ExportSpecifier', { name: name, exportedName: exportedName }); } - return new _terms2.default("ExportSpecifier", { name: null, exportedName: name_59 }); + return new _terms2.default('ExportSpecifier', { + name: null, + exportedName: name + }); } + enforestImportDeclaration() { - let lookahead_60 = this.peek(); - let defaultBinding_61 = null; - let namedImports_62 = (0, _immutable.List)(); - let forSyntax_63 = false; - if (this.isStringLiteral(lookahead_60)) { + let lookahead = this.peek(); + let defaultBinding = null; + let namedImports = (0, _immutable.List)(); + let forSyntax = false; + + if (this.isStringLiteral(lookahead)) { let moduleSpecifier = this.advance(); this.consumeSemicolon(); - return new _terms2.default("Import", { defaultBinding: defaultBinding_61, namedImports: namedImports_62, moduleSpecifier: moduleSpecifier }); + return new _terms2.default('Import', { + defaultBinding: defaultBinding, + namedImports: namedImports, + moduleSpecifier: moduleSpecifier, + forSyntax: forSyntax + }); } - if (this.isIdentifier(lookahead_60) || this.isKeyword(lookahead_60)) { - defaultBinding_61 = this.enforestBindingIdentifier(); - if (!this.isPunctuator(this.peek(), ",")) { + + if (this.isIdentifier(lookahead) || this.isKeyword(lookahead)) { + defaultBinding = this.enforestBindingIdentifier(); + if (!this.isPunctuator(this.peek(), ',')) { let moduleSpecifier = this.enforestFromClause(); - if (this.isKeyword(this.peek(), "for") && this.isIdentifier(this.peek(1), "syntax")) { + if (this.isKeyword(this.peek(), 'for') && this.isIdentifier(this.peek(1), 'syntax')) { this.advance(); this.advance(); - forSyntax_63 = true; + forSyntax = true; } - return new _terms2.default("Import", { defaultBinding: defaultBinding_61, moduleSpecifier: moduleSpecifier, namedImports: (0, _immutable.List)(), forSyntax: forSyntax_63 }); + + return new _terms2.default('Import', { + defaultBinding: defaultBinding, moduleSpecifier: moduleSpecifier, + namedImports: (0, _immutable.List)(), + forSyntax: forSyntax + }); } } this.consumeComma(); - lookahead_60 = this.peek(); - if (this.isBraces(lookahead_60)) { + lookahead = this.peek(); + if (this.isBraces(lookahead)) { let imports = this.enforestNamedImports(); let fromClause = this.enforestFromClause(); - if (this.isKeyword(this.peek(), "for") && this.isIdentifier(this.peek(1), "syntax")) { + if (this.isKeyword(this.peek(), 'for') && this.isIdentifier(this.peek(1), 'syntax')) { this.advance(); this.advance(); - forSyntax_63 = true; + forSyntax = true; } - return new _terms2.default("Import", { defaultBinding: defaultBinding_61, forSyntax: forSyntax_63, namedImports: imports, moduleSpecifier: fromClause }); - } else if (this.isPunctuator(lookahead_60, "*")) { + + return new _terms2.default("Import", { + defaultBinding: defaultBinding, + forSyntax: forSyntax, + namedImports: imports, + moduleSpecifier: fromClause + + }); + } else if (this.isPunctuator(lookahead, '*')) { let namespaceBinding = this.enforestNamespaceBinding(); let moduleSpecifier = this.enforestFromClause(); - if (this.isKeyword(this.peek(), "for") && this.isIdentifier(this.peek(1), "syntax")) { + if (this.isKeyword(this.peek(), 'for') && this.isIdentifier(this.peek(1), 'syntax')) { this.advance(); this.advance(); - forSyntax_63 = true; + forSyntax = true; } - return new _terms2.default("ImportNamespace", { defaultBinding: defaultBinding_61, forSyntax: forSyntax_63, namespaceBinding: namespaceBinding, moduleSpecifier: moduleSpecifier }); + return new _terms2.default('ImportNamespace', { + defaultBinding: defaultBinding, forSyntax: forSyntax, namespaceBinding: namespaceBinding, moduleSpecifier: moduleSpecifier + }); } - throw this.createError(lookahead_60, "unexpected syntax"); + throw this.createError(lookahead, 'unexpected syntax'); } + enforestNamespaceBinding() { - this.matchPunctuator("*"); - this.matchIdentifier("as"); + this.matchPunctuator('*'); + this.matchIdentifier('as'); return this.enforestBindingIdentifier(); } + enforestNamedImports() { - let enf_64 = new Enforester_46(this.matchCurlies(), (0, _immutable.List)(), this.context); - let result_65 = []; - while (enf_64.rest.size !== 0) { - result_65.push(enf_64.enforestImportSpecifiers()); - enf_64.consumeComma(); + let enf = new Enforester(this.matchCurlies(), (0, _immutable.List)(), this.context); + let result = []; + while (enf.rest.size !== 0) { + result.push(enf.enforestImportSpecifiers()); + enf.consumeComma(); } - return (0, _immutable.List)(result_65); + return (0, _immutable.List)(result); } + enforestImportSpecifiers() { - let lookahead_66 = this.peek(); - let name_67; - if (this.isIdentifier(lookahead_66) || this.isKeyword(lookahead_66)) { - name_67 = this.advance(); - if (!this.isIdentifier(this.peek(), "as")) { - return new _terms2.default("ImportSpecifier", { name: null, binding: new _terms2.default("BindingIdentifier", { name: name_67 }) }); + let lookahead = this.peek(); + let name; + if (this.isIdentifier(lookahead) || this.isKeyword(lookahead)) { + name = this.advance(); + if (!this.isIdentifier(this.peek(), 'as')) { + return new _terms2.default('ImportSpecifier', { + name: null, + binding: new _terms2.default('BindingIdentifier', { + name: name + }) + }); } else { - this.matchIdentifier("as"); + this.matchIdentifier('as'); } } else { - throw this.createError(lookahead_66, "unexpected token in import specifier"); + throw this.createError(lookahead, 'unexpected token in import specifier'); } - return new _terms2.default("ImportSpecifier", { name: name_67, binding: this.enforestBindingIdentifier() }); + return new _terms2.default('ImportSpecifier', { + name: name, binding: this.enforestBindingIdentifier() + }); } + enforestFromClause() { - this.matchIdentifier("from"); - let lookahead_68 = this.matchStringLiteral(); + this.matchIdentifier('from'); + let lookahead = this.matchStringLiteral(); this.consumeSemicolon(); - return lookahead_68; + return lookahead; } + enforestStatementListItem() { - let lookahead_69 = this.peek(); - if (this.isFnDeclTransform(lookahead_69)) { + let lookahead = this.peek(); + + if (this.isFnDeclTransform(lookahead)) { return this.enforestFunctionDeclaration({ isExpr: false }); - } else if (this.isKeyword(lookahead_69, "class")) { + } else if (this.isKeyword(lookahead, 'class')) { return this.enforestClass({ isExpr: false }); } else { return this.enforestStatement(); } } + enforestStatement() { - let lookahead_70 = this.peek(); - if (this.term === null && this.isCompiletimeTransform(lookahead_70)) { + let lookahead = this.peek(); + + if (this.term === null && this.isCompiletimeTransform(lookahead)) { this.expandMacro(); - lookahead_70 = this.peek(); + lookahead = this.peek(); } - if (this.term === null && this.isTerm(lookahead_70)) { + + if (this.term === null && this.isTerm(lookahead)) { + // TODO: check that this is actually an statement return this.advance(); } - if (this.term === null && this.isBraces(lookahead_70)) { + + if (this.term === null && this.isBraces(lookahead)) { return this.enforestBlockStatement(); } - if (this.term === null && this.isWhileTransform(lookahead_70)) { + + if (this.term === null && this.isWhileTransform(lookahead)) { return this.enforestWhileStatement(); } - if (this.term === null && this.isIfTransform(lookahead_70)) { + + if (this.term === null && this.isIfTransform(lookahead)) { return this.enforestIfStatement(); } - if (this.term === null && this.isForTransform(lookahead_70)) { + if (this.term === null && this.isForTransform(lookahead)) { return this.enforestForStatement(); } - if (this.term === null && this.isSwitchTransform(lookahead_70)) { + if (this.term === null && this.isSwitchTransform(lookahead)) { return this.enforestSwitchStatement(); } - if (this.term === null && this.isBreakTransform(lookahead_70)) { + if (this.term === null && this.isBreakTransform(lookahead)) { return this.enforestBreakStatement(); } - if (this.term === null && this.isContinueTransform(lookahead_70)) { + if (this.term === null && this.isContinueTransform(lookahead)) { return this.enforestContinueStatement(); } - if (this.term === null && this.isDoTransform(lookahead_70)) { + if (this.term === null && this.isDoTransform(lookahead)) { return this.enforestDoStatement(); } - if (this.term === null && this.isDebuggerTransform(lookahead_70)) { + if (this.term === null && this.isDebuggerTransform(lookahead)) { return this.enforestDebuggerStatement(); } - if (this.term === null && this.isWithTransform(lookahead_70)) { + if (this.term === null && this.isWithTransform(lookahead)) { return this.enforestWithStatement(); } - if (this.term === null && this.isTryTransform(lookahead_70)) { + if (this.term === null && this.isTryTransform(lookahead)) { return this.enforestTryStatement(); } - if (this.term === null && this.isThrowTransform(lookahead_70)) { + if (this.term === null && this.isThrowTransform(lookahead)) { return this.enforestThrowStatement(); } - if (this.term === null && this.isKeyword(lookahead_70, "class")) { + + // TODO: put somewhere else + if (this.term === null && this.isKeyword(lookahead, "class")) { return this.enforestClass({ isExpr: false }); } - if (this.term === null && this.isFnDeclTransform(lookahead_70)) { + + if (this.term === null && this.isFnDeclTransform(lookahead)) { return this.enforestFunctionDeclaration(); } - if (this.term === null && this.isIdentifier(lookahead_70) && this.isPunctuator(this.peek(1), ":")) { + + if (this.term === null && this.isIdentifier(lookahead) && this.isPunctuator(this.peek(1), ':')) { return this.enforestLabeledStatement(); } - if (this.term === null && (this.isVarDeclTransform(lookahead_70) || this.isLetDeclTransform(lookahead_70) || this.isConstDeclTransform(lookahead_70) || this.isSyntaxrecDeclTransform(lookahead_70) || this.isSyntaxDeclTransform(lookahead_70))) { - let stmt = new _terms2.default("VariableDeclarationStatement", { declaration: this.enforestVariableDeclaration() }); + + if (this.term === null && (this.isVarDeclTransform(lookahead) || this.isLetDeclTransform(lookahead) || this.isConstDeclTransform(lookahead) || this.isSyntaxrecDeclTransform(lookahead) || this.isSyntaxDeclTransform(lookahead))) { + let stmt = new _terms2.default('VariableDeclarationStatement', { + declaration: this.enforestVariableDeclaration() + }); this.consumeSemicolon(); return stmt; } - if (this.term === null && this.isReturnStmtTransform(lookahead_70)) { + + if (this.term === null && this.isReturnStmtTransform(lookahead)) { return this.enforestReturnStatement(); } - if (this.term === null && this.isPunctuator(lookahead_70, ";")) { + + if (this.term === null && this.isPunctuator(lookahead, ";")) { this.advance(); return new _terms2.default("EmptyStatement", {}); } + return this.enforestExpressionStatement(); } + enforestLabeledStatement() { - let label_71 = this.matchIdentifier(); - let punc_72 = this.matchPunctuator(":"); - let stmt_73 = this.enforestStatement(); - return new _terms2.default("LabeledStatement", { label: label_71, body: stmt_73 }); + let label = this.matchIdentifier(); + this.matchPunctuator(':'); + let stmt = this.enforestStatement(); + + return new _terms2.default('LabeledStatement', { + label: label, + body: stmt + }); } + enforestBreakStatement() { - this.matchKeyword("break"); - let lookahead_74 = this.peek(); - let label_75 = null; - if (this.rest.size === 0 || this.isPunctuator(lookahead_74, ";")) { + this.matchKeyword('break'); + let lookahead = this.peek(); + let label = null; + if (this.rest.size === 0 || this.isPunctuator(lookahead, ';')) { this.consumeSemicolon(); - return new _terms2.default("BreakStatement", { label: label_75 }); + return new _terms2.default('BreakStatement', { label: label }); } - if (this.isIdentifier(lookahead_74) || this.isKeyword(lookahead_74, "yield") || this.isKeyword(lookahead_74, "let")) { - label_75 = this.enforestIdentifier(); + if (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'yield') || this.isKeyword(lookahead, 'let')) { + label = this.enforestIdentifier(); } this.consumeSemicolon(); - return new _terms2.default("BreakStatement", { label: label_75 }); + + return new _terms2.default('BreakStatement', { label: label }); } + enforestTryStatement() { - this.matchKeyword("try"); - let body_76 = this.enforestBlock(); - if (this.isKeyword(this.peek(), "catch")) { + this.matchKeyword('try'); + let body = this.enforestBlock(); + if (this.isKeyword(this.peek(), 'catch')) { let catchClause = this.enforestCatchClause(); - if (this.isKeyword(this.peek(), "finally")) { + if (this.isKeyword(this.peek(), 'finally')) { this.advance(); let finalizer = this.enforestBlock(); - return new _terms2.default("TryFinallyStatement", { body: body_76, catchClause: catchClause, finalizer: finalizer }); + return new _terms2.default('TryFinallyStatement', { + body: body, catchClause: catchClause, finalizer: finalizer + }); } - return new _terms2.default("TryCatchStatement", { body: body_76, catchClause: catchClause }); + return new _terms2.default('TryCatchStatement', { body: body, catchClause: catchClause }); } - if (this.isKeyword(this.peek(), "finally")) { + if (this.isKeyword(this.peek(), 'finally')) { this.advance(); let finalizer = this.enforestBlock(); - return new _terms2.default("TryFinallyStatement", { body: body_76, catchClause: null, finalizer: finalizer }); + return new _terms2.default('TryFinallyStatement', { body: body, catchClause: null, finalizer: finalizer }); } - throw this.createError(this.peek(), "try with no catch or finally"); + throw this.createError(this.peek(), 'try with no catch or finally'); } + enforestCatchClause() { - this.matchKeyword("catch"); - let bindingParens_77 = this.matchParens(); - let enf_78 = new Enforester_46(bindingParens_77, (0, _immutable.List)(), this.context); - let binding_79 = enf_78.enforestBindingTarget(); - let body_80 = this.enforestBlock(); - return new _terms2.default("CatchClause", { binding: binding_79, body: body_80 }); + this.matchKeyword('catch'); + let bindingParens = this.matchParens(); + let enf = new Enforester(bindingParens, (0, _immutable.List)(), this.context); + let binding = enf.enforestBindingTarget(); + let body = this.enforestBlock(); + return new _terms2.default('CatchClause', { binding: binding, body: body }); } + enforestThrowStatement() { - this.matchKeyword("throw"); - let expression_81 = this.enforestExpression(); + this.matchKeyword('throw'); + let expression = this.enforestExpression(); this.consumeSemicolon(); - return new _terms2.default("ThrowStatement", { expression: expression_81 }); + return new _terms2.default('ThrowStatement', { expression: expression }); } + enforestWithStatement() { - this.matchKeyword("with"); - let objParens_82 = this.matchParens(); - let enf_83 = new Enforester_46(objParens_82, (0, _immutable.List)(), this.context); - let object_84 = enf_83.enforestExpression(); - let body_85 = this.enforestStatement(); - return new _terms2.default("WithStatement", { object: object_84, body: body_85 }); + this.matchKeyword('with'); + let objParens = this.matchParens(); + let enf = new Enforester(objParens, (0, _immutable.List)(), this.context); + let object = enf.enforestExpression(); + let body = this.enforestStatement(); + return new _terms2.default('WithStatement', { object: object, body: body }); } + enforestDebuggerStatement() { - this.matchKeyword("debugger"); - return new _terms2.default("DebuggerStatement", {}); + this.matchKeyword('debugger'); + + return new _terms2.default('DebuggerStatement', {}); } + enforestDoStatement() { - this.matchKeyword("do"); - let body_86 = this.enforestStatement(); - this.matchKeyword("while"); - let testBody_87 = this.matchParens(); - let enf_88 = new Enforester_46(testBody_87, (0, _immutable.List)(), this.context); - let test_89 = enf_88.enforestExpression(); + this.matchKeyword('do'); + let body = this.enforestStatement(); + this.matchKeyword('while'); + let testBody = this.matchParens(); + let enf = new Enforester(testBody, (0, _immutable.List)(), this.context); + let test = enf.enforestExpression(); this.consumeSemicolon(); - return new _terms2.default("DoWhileStatement", { body: body_86, test: test_89 }); + return new _terms2.default('DoWhileStatement', { body: body, test: test }); } + enforestContinueStatement() { - let kwd_90 = this.matchKeyword("continue"); - let lookahead_91 = this.peek(); - let label_92 = null; - if (this.rest.size === 0 || this.isPunctuator(lookahead_91, ";")) { + let kwd = this.matchKeyword('continue'); + let lookahead = this.peek(); + let label = null; + if (this.rest.size === 0 || this.isPunctuator(lookahead, ';')) { this.consumeSemicolon(); - return new _terms2.default("ContinueStatement", { label: label_92 }); + return new _terms2.default('ContinueStatement', { label: label }); } - if (this.lineNumberEq(kwd_90, lookahead_91) && (this.isIdentifier(lookahead_91) || this.isKeyword(lookahead_91, "yield") || this.isKeyword(lookahead_91, "let"))) { - label_92 = this.enforestIdentifier(); + if (this.lineNumberEq(kwd, lookahead) && (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'yield') || this.isKeyword(lookahead, 'let'))) { + label = this.enforestIdentifier(); } this.consumeSemicolon(); - return new _terms2.default("ContinueStatement", { label: label_92 }); + + return new _terms2.default('ContinueStatement', { label: label }); } + enforestSwitchStatement() { - this.matchKeyword("switch"); - let cond_93 = this.matchParens(); - let enf_94 = new Enforester_46(cond_93, (0, _immutable.List)(), this.context); - let discriminant_95 = enf_94.enforestExpression(); - let body_96 = this.matchCurlies(); - if (body_96.size === 0) { - return new _terms2.default("SwitchStatement", { discriminant: discriminant_95, cases: (0, _immutable.List)() }); - } - enf_94 = new Enforester_46(body_96, (0, _immutable.List)(), this.context); - let cases_97 = enf_94.enforestSwitchCases(); - let lookahead_98 = enf_94.peek(); - if (enf_94.isKeyword(lookahead_98, "default")) { - let defaultCase = enf_94.enforestSwitchDefault(); - let postDefaultCases = enf_94.enforestSwitchCases(); - return new _terms2.default("SwitchStatementWithDefault", { discriminant: discriminant_95, preDefaultCases: cases_97, defaultCase: defaultCase, postDefaultCases: postDefaultCases }); - } - return new _terms2.default("SwitchStatement", { discriminant: discriminant_95, cases: cases_97 }); + this.matchKeyword('switch'); + let cond = this.matchParens(); + let enf = new Enforester(cond, (0, _immutable.List)(), this.context); + let discriminant = enf.enforestExpression(); + let body = this.matchCurlies(); + + if (body.size === 0) { + return new _terms2.default('SwitchStatement', { + discriminant: discriminant, + cases: (0, _immutable.List)() + }); + } + enf = new Enforester(body, (0, _immutable.List)(), this.context); + let cases = enf.enforestSwitchCases(); + let lookahead = enf.peek(); + if (enf.isKeyword(lookahead, 'default')) { + let defaultCase = enf.enforestSwitchDefault(); + let postDefaultCases = enf.enforestSwitchCases(); + return new _terms2.default('SwitchStatementWithDefault', { + discriminant: discriminant, + preDefaultCases: cases, + defaultCase: defaultCase, + postDefaultCases: postDefaultCases + }); + } + return new _terms2.default('SwitchStatement', { discriminant: discriminant, cases: cases }); } + enforestSwitchCases() { - let cases_99 = []; - while (!(this.rest.size === 0 || this.isKeyword(this.peek(), "default"))) { - cases_99.push(this.enforestSwitchCase()); + let cases = []; + while (!(this.rest.size === 0 || this.isKeyword(this.peek(), 'default'))) { + cases.push(this.enforestSwitchCase()); } - return (0, _immutable.List)(cases_99); + return (0, _immutable.List)(cases); } + enforestSwitchCase() { - this.matchKeyword("case"); - return new _terms2.default("SwitchCase", { test: this.enforestExpression(), consequent: this.enforestSwitchCaseBody() }); + this.matchKeyword('case'); + return new _terms2.default('SwitchCase', { + test: this.enforestExpression(), + consequent: this.enforestSwitchCaseBody() + }); } + enforestSwitchCaseBody() { - this.matchPunctuator(":"); + this.matchPunctuator(':'); return this.enforestStatementListInSwitchCaseBody(); } + enforestStatementListInSwitchCaseBody() { - let result_100 = []; - while (!(this.rest.size === 0 || this.isKeyword(this.peek(), "default") || this.isKeyword(this.peek(), "case"))) { - result_100.push(this.enforestStatementListItem()); + let result = []; + while (!(this.rest.size === 0 || this.isKeyword(this.peek(), 'default') || this.isKeyword(this.peek(), 'case'))) { + result.push(this.enforestStatementListItem()); } - return (0, _immutable.List)(result_100); + return (0, _immutable.List)(result); } + enforestSwitchDefault() { - this.matchKeyword("default"); - return new _terms2.default("SwitchDefault", { consequent: this.enforestSwitchCaseBody() }); + this.matchKeyword('default'); + return new _terms2.default('SwitchDefault', { + consequent: this.enforestSwitchCaseBody() + }); } + enforestForStatement() { - this.matchKeyword("for"); - let cond_101 = this.matchParens(); - let enf_102 = new Enforester_46(cond_101, (0, _immutable.List)(), this.context); - let lookahead_103, test_104, init_105, right_106, type_107, left_108, update_109; - if (enf_102.isPunctuator(enf_102.peek(), ";")) { - enf_102.advance(); - if (!enf_102.isPunctuator(enf_102.peek(), ";")) { - test_104 = enf_102.enforestExpression(); + this.matchKeyword('for'); + let cond = this.matchParens(); + let enf = new Enforester(cond, (0, _immutable.List)(), this.context); + let lookahead, test, init, right, type, left, update; + + // case where init is null + if (enf.isPunctuator(enf.peek(), ';')) { + enf.advance(); + if (!enf.isPunctuator(enf.peek(), ';')) { + test = enf.enforestExpression(); } - enf_102.matchPunctuator(";"); - if (enf_102.rest.size !== 0) { - right_106 = enf_102.enforestExpression(); + enf.matchPunctuator(';'); + if (enf.rest.size !== 0) { + right = enf.enforestExpression(); } - return new _terms2.default("ForStatement", { init: null, test: test_104, update: right_106, body: this.enforestStatement() }); + return new _terms2.default('ForStatement', { + init: null, + test: test, + update: right, + body: this.enforestStatement() + }); + // case where init is not null } else { - lookahead_103 = enf_102.peek(); - if (enf_102.isVarDeclTransform(lookahead_103) || enf_102.isLetDeclTransform(lookahead_103) || enf_102.isConstDeclTransform(lookahead_103)) { - init_105 = enf_102.enforestVariableDeclaration(); - lookahead_103 = enf_102.peek(); - if (this.isKeyword(lookahead_103, "in") || this.isIdentifier(lookahead_103, "of")) { - if (this.isKeyword(lookahead_103, "in")) { - enf_102.advance(); - right_106 = enf_102.enforestExpression(); - type_107 = "ForInStatement"; - } else if (this.isIdentifier(lookahead_103, "of")) { - enf_102.advance(); - right_106 = enf_102.enforestExpression(); - type_107 = "ForOfStatement"; + // testing + lookahead = enf.peek(); + if (enf.isVarDeclTransform(lookahead) || enf.isLetDeclTransform(lookahead) || enf.isConstDeclTransform(lookahead)) { + init = enf.enforestVariableDeclaration(); + lookahead = enf.peek(); + if (this.isKeyword(lookahead, 'in') || this.isIdentifier(lookahead, 'of')) { + if (this.isKeyword(lookahead, 'in')) { + enf.advance(); + right = enf.enforestExpression(); + type = 'ForInStatement'; + } else if (this.isIdentifier(lookahead, 'of')) { + enf.advance(); + right = enf.enforestExpression(); + type = 'ForOfStatement'; } - return new _terms2.default(type_107, { left: init_105, right: right_106, body: this.enforestStatement() }); + return new _terms2.default(type, { + left: init, right: right, body: this.enforestStatement() + }); } - enf_102.matchPunctuator(";"); - if (enf_102.isPunctuator(enf_102.peek(), ";")) { - enf_102.advance(); - test_104 = null; + enf.matchPunctuator(';'); + if (enf.isPunctuator(enf.peek(), ';')) { + enf.advance(); + test = null; } else { - test_104 = enf_102.enforestExpression(); - enf_102.matchPunctuator(";"); + test = enf.enforestExpression(); + enf.matchPunctuator(';'); } - update_109 = enf_102.enforestExpression(); + update = enf.enforestExpression(); } else { - if (this.isKeyword(enf_102.peek(1), "in") || this.isIdentifier(enf_102.peek(1), "of")) { - left_108 = enf_102.enforestBindingIdentifier(); - let kind = enf_102.advance(); - if (this.isKeyword(kind, "in")) { - type_107 = "ForInStatement"; + if (this.isKeyword(enf.peek(1), 'in') || this.isIdentifier(enf.peek(1), 'of')) { + left = enf.enforestBindingIdentifier(); + let kind = enf.advance(); + if (this.isKeyword(kind, 'in')) { + type = 'ForInStatement'; } else { - type_107 = "ForOfStatement"; + type = 'ForOfStatement'; } - right_106 = enf_102.enforestExpression(); - return new _terms2.default(type_107, { left: left_108, right: right_106, body: this.enforestStatement() }); + right = enf.enforestExpression(); + return new _terms2.default(type, { + left: left, right: right, body: this.enforestStatement() + }); } - init_105 = enf_102.enforestExpression(); - enf_102.matchPunctuator(";"); - if (enf_102.isPunctuator(enf_102.peek(), ";")) { - enf_102.advance(); - test_104 = null; + init = enf.enforestExpression(); + enf.matchPunctuator(';'); + if (enf.isPunctuator(enf.peek(), ';')) { + enf.advance(); + test = null; } else { - test_104 = enf_102.enforestExpression(); - enf_102.matchPunctuator(";"); + test = enf.enforestExpression(); + enf.matchPunctuator(';'); } - update_109 = enf_102.enforestExpression(); + update = enf.enforestExpression(); } - return new _terms2.default("ForStatement", { init: init_105, test: test_104, update: update_109, body: this.enforestStatement() }); + return new _terms2.default('ForStatement', { init: init, test: test, update: update, body: this.enforestStatement() }); } } + enforestIfStatement() { - this.matchKeyword("if"); - let cond_110 = this.matchParens(); - let enf_111 = new Enforester_46(cond_110, (0, _immutable.List)(), this.context); - let lookahead_112 = enf_111.peek(); - let test_113 = enf_111.enforestExpression(); - if (test_113 === null) { - throw enf_111.createError(lookahead_112, "expecting an expression"); - } - let consequent_114 = this.enforestStatement(); - let alternate_115 = null; - if (this.isKeyword(this.peek(), "else")) { + this.matchKeyword('if'); + let cond = this.matchParens(); + let enf = new Enforester(cond, (0, _immutable.List)(), this.context); + let lookahead = enf.peek(); + let test = enf.enforestExpression(); + if (test === null) { + throw enf.createError(lookahead, 'expecting an expression'); + } + let consequent = this.enforestStatement(); + let alternate = null; + if (this.isKeyword(this.peek(), 'else')) { this.advance(); - alternate_115 = this.enforestStatement(); + alternate = this.enforestStatement(); } - return new _terms2.default("IfStatement", { test: test_113, consequent: consequent_114, alternate: alternate_115 }); + return new _terms2.default('IfStatement', { test: test, consequent: consequent, alternate: alternate }); } + enforestWhileStatement() { - this.matchKeyword("while"); - let cond_116 = this.matchParens(); - let enf_117 = new Enforester_46(cond_116, (0, _immutable.List)(), this.context); - let lookahead_118 = enf_117.peek(); - let test_119 = enf_117.enforestExpression(); - if (test_119 === null) { - throw enf_117.createError(lookahead_118, "expecting an expression"); + this.matchKeyword('while'); + let cond = this.matchParens(); + let enf = new Enforester(cond, (0, _immutable.List)(), this.context); + let lookahead = enf.peek(); + let test = enf.enforestExpression(); + if (test === null) { + throw enf.createError(lookahead, 'expecting an expression'); } - let body_120 = this.enforestStatement(); - return new _terms2.default("WhileStatement", { test: test_119, body: body_120 }); + let body = this.enforestStatement(); + + return new _terms2.default('WhileStatement', { test: test, body: body }); } + enforestBlockStatement() { - return new _terms2.default("BlockStatement", { block: this.enforestBlock() }); + return new _terms2.default('BlockStatement', { + block: this.enforestBlock() + }); } + enforestBlock() { - return new _terms2.default("Block", { statements: this.matchCurlies() }); + return new _terms2.default('Block', { + statements: this.matchCurlies() + }); } + enforestClass(_ref) { let isExpr = _ref.isExpr; let inDefault = _ref.inDefault; - let kw_121 = this.advance(); - let name_122 = null, - supr_123 = null; - let type_124 = isExpr ? "ClassExpression" : "ClassDeclaration"; + let kw = this.advance(); + let name = null, + supr = null; + let type = isExpr ? 'ClassExpression' : 'ClassDeclaration'; + if (this.isIdentifier(this.peek())) { - name_122 = this.enforestBindingIdentifier(); + name = this.enforestBindingIdentifier(); } else if (!isExpr) { if (inDefault) { - name_122 = new _terms2.default("BindingIdentifier", { name: _syntax2.default.fromIdentifier("_default", kw_121) }); + name = new _terms2.default('BindingIdentifier', { + name: _syntax2.default.fromIdentifier('_default', kw) + }); } else { - throw this.createError(this.peek(), "unexpected syntax"); + throw this.createError(this.peek(), 'unexpected syntax'); } } - if (this.isKeyword(this.peek(), "extends")) { + + if (this.isKeyword(this.peek(), 'extends')) { this.advance(); - supr_123 = this.enforestExpressionLoop(); + supr = this.enforestExpressionLoop(); } - let elements_125 = []; - let enf_126 = new Enforester_46(this.matchCurlies(), (0, _immutable.List)(), this.context); - while (enf_126.rest.size !== 0) { - if (enf_126.isPunctuator(enf_126.peek(), ";")) { - enf_126.advance(); + + let elements = []; + let enf = new Enforester(this.matchCurlies(), (0, _immutable.List)(), this.context); + while (enf.rest.size !== 0) { + if (enf.isPunctuator(enf.peek(), ';')) { + enf.advance(); continue; } + let isStatic = false; - var _enf_126$enforestMeth = enf_126.enforestMethodDefinition(); + var _enf$enforestMethodDe = enf.enforestMethodDefinition(); - let methodOrKey = _enf_126$enforestMeth.methodOrKey; - let kind = _enf_126$enforestMeth.kind; + let methodOrKey = _enf$enforestMethodDe.methodOrKey; + let kind = _enf$enforestMethodDe.kind; - if (kind === "identifier" && methodOrKey.value.val() === "static") { + if (kind === 'identifier' && methodOrKey.value.val() === 'static') { isStatic = true; - var _enf_126$enforestMeth2 = enf_126.enforestMethodDefinition(); + var _enf$enforestMethodDe2 = enf.enforestMethodDefinition(); - methodOrKey = _enf_126$enforestMeth2.methodOrKey; - kind = _enf_126$enforestMeth2.kind; + methodOrKey = _enf$enforestMethodDe2.methodOrKey; + kind = _enf$enforestMethodDe2.kind; } - if (kind === "method") { - elements_125.push(new _terms2.default("ClassElement", { isStatic: isStatic, method: methodOrKey })); + if (kind === 'method') { + elements.push(new _terms2.default('ClassElement', { isStatic: isStatic, method: methodOrKey })); } else { - throw this.createError(enf_126.peek(), "Only methods are allowed in classes"); + throw this.createError(enf.peek(), "Only methods are allowed in classes"); } } - return new _terms2.default(type_124, { name: name_122, super: supr_123, elements: (0, _immutable.List)(elements_125) }); + + return new _terms2.default(type, { + name: name, super: supr, + elements: (0, _immutable.List)(elements) + }); } + enforestBindingTarget() { var _ref2 = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; let allowPunctuator = _ref2.allowPunctuator; - let lookahead_127 = this.peek(); - if (this.isIdentifier(lookahead_127) || this.isKeyword(lookahead_127) || allowPunctuator && this.isPunctuator(lookahead_127)) { + let lookahead = this.peek(); + if (this.isIdentifier(lookahead) || this.isKeyword(lookahead) || allowPunctuator && this.isPunctuator(lookahead)) { return this.enforestBindingIdentifier({ allowPunctuator: allowPunctuator }); - } else if (this.isBrackets(lookahead_127)) { + } else if (this.isBrackets(lookahead)) { return this.enforestArrayBinding(); - } else if (this.isBraces(lookahead_127)) { + } else if (this.isBraces(lookahead)) { return this.enforestObjectBinding(); } - (0, _errors.assert)(false, "not implemented yet"); + (0, _errors.assert)(false, 'not implemented yet'); } + enforestObjectBinding() { - let enf_128 = new Enforester_46(this.matchCurlies(), (0, _immutable.List)(), this.context); - let properties_129 = []; - while (enf_128.rest.size !== 0) { - properties_129.push(enf_128.enforestBindingProperty()); - enf_128.consumeComma(); + let enf = new Enforester(this.matchCurlies(), (0, _immutable.List)(), this.context); + let properties = []; + while (enf.rest.size !== 0) { + properties.push(enf.enforestBindingProperty()); + enf.consumeComma(); } - return new _terms2.default("ObjectBinding", { properties: (0, _immutable.List)(properties_129) }); + + return new _terms2.default('ObjectBinding', { + properties: (0, _immutable.List)(properties) + }); } + enforestBindingProperty() { - let lookahead_130 = this.peek(); + let lookahead = this.peek(); var _enforestPropertyName = this.enforestPropertyName(); let name = _enforestPropertyName.name; let binding = _enforestPropertyName.binding; - if (this.isIdentifier(lookahead_130) || this.isKeyword(lookahead_130, "let") || this.isKeyword(lookahead_130, "yield")) { - if (!this.isPunctuator(this.peek(), ":")) { + if (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'let') || this.isKeyword(lookahead, 'yield')) { + if (!this.isPunctuator(this.peek(), ':')) { let defaultValue = null; if (this.isAssign(this.peek())) { this.advance(); let expr = this.enforestExpressionLoop(); defaultValue = expr; } - return new _terms2.default("BindingPropertyIdentifier", { binding: binding, init: defaultValue }); + return new _terms2.default('BindingPropertyIdentifier', { + binding: binding, init: defaultValue + }); } } - this.matchPunctuator(":"); + this.matchPunctuator(':'); binding = this.enforestBindingElement(); - return new _terms2.default("BindingPropertyProperty", { name: name, binding: binding }); + return new _terms2.default('BindingPropertyProperty', { + name: name, binding: binding + }); } + enforestArrayBinding() { - let bracket_131 = this.matchSquares(); - let enf_132 = new Enforester_46(bracket_131, (0, _immutable.List)(), this.context); - let elements_133 = [], - restElement_134 = null; - while (enf_132.rest.size !== 0) { + let bracket = this.matchSquares(); + let enf = new Enforester(bracket, (0, _immutable.List)(), this.context); + let elements = [], + restElement = null; + while (enf.rest.size !== 0) { let el; - if (enf_132.isPunctuator(enf_132.peek(), ",")) { - enf_132.consumeComma(); + if (enf.isPunctuator(enf.peek(), ',')) { + enf.consumeComma(); el = null; } else { - if (enf_132.isPunctuator(enf_132.peek(), "...")) { - enf_132.advance(); - restElement_134 = enf_132.enforestBindingTarget(); + if (enf.isPunctuator(enf.peek(), '...')) { + enf.advance(); + restElement = enf.enforestBindingTarget(); break; } else { - el = enf_132.enforestBindingElement(); + el = enf.enforestBindingElement(); } - enf_132.consumeComma(); + enf.consumeComma(); } - elements_133.push(el); + elements.push(el); } - return new _terms2.default("ArrayBinding", { elements: (0, _immutable.List)(elements_133), restElement: restElement_134 }); + return new _terms2.default('ArrayBinding', { + elements: (0, _immutable.List)(elements), + restElement: restElement + }); } + enforestBindingElement() { - let binding_135 = this.enforestBindingTarget(); + let binding = this.enforestBindingTarget(); + if (this.isAssign(this.peek())) { this.advance(); let init = this.enforestExpressionLoop(); - binding_135 = new _terms2.default("BindingWithDefault", { binding: binding_135, init: init }); + binding = new _terms2.default('BindingWithDefault', { binding: binding, init: init }); } - return binding_135; + return binding; } + enforestBindingIdentifier() { var _ref3 = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; let allowPunctuator = _ref3.allowPunctuator; - let name_136; + let name; if (allowPunctuator && this.isPunctuator(this.peek())) { - name_136 = this.enforestPunctuator(); + name = this.enforestPunctuator(); } else { - name_136 = this.enforestIdentifier(); + name = this.enforestIdentifier(); } - return new _terms2.default("BindingIdentifier", { name: name_136 }); + return new _terms2.default("BindingIdentifier", { name: name }); } + enforestPunctuator() { - let lookahead_137 = this.peek(); - if (this.isPunctuator(lookahead_137)) { + let lookahead = this.peek(); + if (this.isPunctuator(lookahead)) { return this.advance(); } - throw this.createError(lookahead_137, "expecting a punctuator"); + throw this.createError(lookahead, "expecting a punctuator"); } + enforestIdentifier() { - let lookahead_138 = this.peek(); - if (this.isIdentifier(lookahead_138) || this.isKeyword(lookahead_138)) { + let lookahead = this.peek(); + if (this.isIdentifier(lookahead) || this.isKeyword(lookahead)) { return this.advance(); } - throw this.createError(lookahead_138, "expecting an identifier"); + throw this.createError(lookahead, "expecting an identifier"); } + enforestReturnStatement() { - let kw_139 = this.advance(); - let lookahead_140 = this.peek(); - if (this.rest.size === 0 || lookahead_140 && !this.lineNumberEq(kw_139, lookahead_140)) { - return new _terms2.default("ReturnStatement", { expression: null }); + let kw = this.advance(); + let lookahead = this.peek(); + + // short circuit for the empty expression case + if (this.rest.size === 0 || lookahead && !this.lineNumberEq(kw, lookahead)) { + return new _terms2.default("ReturnStatement", { + expression: null + }); } - let term_141 = null; - if (!this.isPunctuator(lookahead_140, ";")) { - term_141 = this.enforestExpression(); - (0, _errors.expect)(term_141 != null, "Expecting an expression to follow return keyword", lookahead_140, this.rest); + + let term = null; + if (!this.isPunctuator(lookahead, ';')) { + term = this.enforestExpression(); + (0, _errors.expect)(term != null, "Expecting an expression to follow return keyword", lookahead, this.rest); } + this.consumeSemicolon(); - return new _terms2.default("ReturnStatement", { expression: term_141 }); + return new _terms2.default("ReturnStatement", { + expression: term + }); } + enforestVariableDeclaration() { - let kind_142; - let lookahead_143 = this.advance(); - let kindSyn_144 = lookahead_143; - let phase_145 = this.context.phase; - if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === _transforms.VariableDeclTransform) { - kind_142 = "var"; - } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === _transforms.LetDeclTransform) { - kind_142 = "let"; - } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === _transforms.ConstDeclTransform) { - kind_142 = "const"; - } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === _transforms.SyntaxDeclTransform) { - kind_142 = "syntax"; - } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === _transforms.SyntaxrecDeclTransform) { - kind_142 = "syntaxrec"; - } - let decls_146 = (0, _immutable.List)(); + let kind; + let lookahead = this.advance(); + let kindSyn = lookahead; + let phase = this.context.phase; + + if (kindSyn && this.context.env.get(kindSyn.resolve(phase)) === _transforms.VariableDeclTransform) { + kind = "var"; + } else if (kindSyn && this.context.env.get(kindSyn.resolve(phase)) === _transforms.LetDeclTransform) { + kind = "let"; + } else if (kindSyn && this.context.env.get(kindSyn.resolve(phase)) === _transforms.ConstDeclTransform) { + kind = "const"; + } else if (kindSyn && this.context.env.get(kindSyn.resolve(phase)) === _transforms.SyntaxDeclTransform) { + kind = "syntax"; + } else if (kindSyn && this.context.env.get(kindSyn.resolve(phase)) === _transforms.SyntaxrecDeclTransform) { + kind = "syntaxrec"; + } + + let decls = (0, _immutable.List)(); + while (true) { - let term = this.enforestVariableDeclarator({ isSyntax: kind_142 === "syntax" || kind_142 === "syntaxrec" }); - let lookahead_143 = this.peek(); - decls_146 = decls_146.concat(term); - if (this.isPunctuator(lookahead_143, ",")) { + let term = this.enforestVariableDeclarator({ isSyntax: kind === "syntax" || kind === 'syntaxrec' }); + let lookahead = this.peek(); + decls = decls.concat(term); + + if (this.isPunctuator(lookahead, ",")) { this.advance(); } else { break; } } - return new _terms2.default("VariableDeclaration", { kind: kind_142, declarators: decls_146 }); + + return new _terms2.default('VariableDeclaration', { + kind: kind, + declarators: decls + }); } + enforestVariableDeclarator(_ref4) { let isSyntax = _ref4.isSyntax; - let id_147 = this.enforestBindingTarget({ allowPunctuator: isSyntax }); - let lookahead_148 = this.peek(); - let init_149, rest_150; - if (this.isPunctuator(lookahead_148, "=")) { + let id = this.enforestBindingTarget({ allowPunctuator: isSyntax }); + let lookahead = this.peek(); + + let init; + if (this.isPunctuator(lookahead, '=')) { this.advance(); - let enf = new Enforester_46(this.rest, (0, _immutable.List)(), this.context); - init_149 = enf.enforest("expression"); + let enf = new Enforester(this.rest, (0, _immutable.List)(), this.context); + init = enf.enforest("expression"); this.rest = enf.rest; } else { - init_149 = null; + init = null; } - return new _terms2.default("VariableDeclarator", { binding: id_147, init: init_149 }); + return new _terms2.default("VariableDeclarator", { + binding: id, + init: init + }); } + enforestExpressionStatement() { - let start_151 = this.rest.get(0); - let expr_152 = this.enforestExpression(); - if (expr_152 === null) { - throw this.createError(start_151, "not a valid expression"); + let start = this.rest.get(0); + let expr = this.enforestExpression(); + if (expr === null) { + throw this.createError(start, "not a valid expression"); } this.consumeSemicolon(); - return new _terms2.default("ExpressionStatement", { expression: expr_152 }); + + return new _terms2.default("ExpressionStatement", { + expression: expr + }); } + enforestExpression() { - let left_153 = this.enforestExpressionLoop(); - let lookahead_154 = this.peek(); - if (this.isPunctuator(lookahead_154, ",")) { + let left = this.enforestExpressionLoop(); + let lookahead = this.peek(); + if (this.isPunctuator(lookahead, ',')) { while (this.rest.size !== 0) { - if (!this.isPunctuator(this.peek(), ",")) { + if (!this.isPunctuator(this.peek(), ',')) { break; } let operator = this.advance(); let right = this.enforestExpressionLoop(); - left_153 = new _terms2.default("BinaryExpression", { left: left_153, operator: operator, right: right }); + left = new _terms2.default('BinaryExpression', { left: left, operator: operator, right: right }); } } this.term = null; - return left_153; + return left; } + enforestExpressionLoop() { this.term = null; - this.opCtx = { prec: 0, combine: x_155 => x_155, stack: (0, _immutable.List)() }; + this.opCtx = { + prec: 0, + combine: x => x, + stack: (0, _immutable.List)() + }; + do { let term = this.enforestAssignmentExpression(); - if (term === EXPR_LOOP_NO_CHANGE_44 && this.opCtx.stack.size > 0) { + // no change means we've done as much enforesting as possible + // if nothing changed, maybe we just need to pop the expr stack + if (term === EXPR_LOOP_NO_CHANGE && this.opCtx.stack.size > 0) { this.term = this.opCtx.combine(this.term); var _opCtx$stack$last = this.opCtx.stack.last(); @@ -812,399 +1032,571 @@ class Enforester_46 { this.opCtx.prec = prec; this.opCtx.combine = combine; this.opCtx.stack = this.opCtx.stack.pop(); - } else if (term === EXPR_LOOP_NO_CHANGE_44) { + } else if (term === EXPR_LOOP_NO_CHANGE) { break; - } else if (term === EXPR_LOOP_OPERATOR_43 || term === EXPR_LOOP_EXPANSION_45) { + } else if (term === EXPR_LOOP_OPERATOR || term === EXPR_LOOP_EXPANSION) { + // operator means an opCtx was pushed on the stack this.term = null; } else { this.term = term; } - } while (true); + } while (true); // get a fixpoint return this.term; } + enforestAssignmentExpression() { - let lookahead_156 = this.peek(); - if (this.term === null && this.isCompiletimeTransform(lookahead_156)) { + let lookahead = this.peek(); + + if (this.term === null && this.isCompiletimeTransform(lookahead)) { this.expandMacro(); - lookahead_156 = this.peek(); + lookahead = this.peek(); } - if (this.term === null && this.isTerm(lookahead_156)) { + + if (this.term === null && this.isTerm(lookahead)) { + // TODO: check that this is actually an expression return this.advance(); } - if (this.term === null && this.isKeyword(lookahead_156, "yield")) { + + if (this.term === null && this.isKeyword(lookahead, 'yield')) { return this.enforestYieldExpression(); } - if (this.term === null && this.isKeyword(lookahead_156, "class")) { + + if (this.term === null && this.isKeyword(lookahead, 'class')) { return this.enforestClass({ isExpr: true }); } - if (this.term === null && (this.isIdentifier(lookahead_156) || this.isParens(lookahead_156)) && this.isPunctuator(this.peek(1), "=>") && this.lineNumberEq(lookahead_156, this.peek(1))) { + if (this.term === null && (this.isIdentifier(lookahead) || this.isParens(lookahead)) && this.isPunctuator(this.peek(1), '=>') && this.lineNumberEq(lookahead, this.peek(1))) { return this.enforestArrowExpression(); } - if (this.term === null && this.isSyntaxTemplate(lookahead_156)) { + + if (this.term === null && this.isSyntaxTemplate(lookahead)) { return this.enforestSyntaxTemplate(); } - if (this.term === null && this.isSyntaxQuoteTransform(lookahead_156)) { + // syntaxQuote ` ... ` + if (this.term === null && this.isSyntaxQuoteTransform(lookahead)) { return this.enforestSyntaxQuote(); } - if (this.term === null && this.isParens(lookahead_156)) { - return new _terms2.default("ParenthesizedExpression", { inner: this.advance().inner() }); + + // ($x:expr) + if (this.term === null && this.isParens(lookahead)) { + return new _terms2.default("ParenthesizedExpression", { + inner: this.advance().inner() + }); } - if (this.term === null && (this.isKeyword(lookahead_156, "this") || this.isIdentifier(lookahead_156) || this.isKeyword(lookahead_156, "let") || this.isKeyword(lookahead_156, "yield") || this.isNumericLiteral(lookahead_156) || this.isStringLiteral(lookahead_156) || this.isTemplate(lookahead_156) || this.isBooleanLiteral(lookahead_156) || this.isNullLiteral(lookahead_156) || this.isRegularExpression(lookahead_156) || this.isFnDeclTransform(lookahead_156) || this.isBraces(lookahead_156) || this.isBrackets(lookahead_156))) { + + if (this.term === null && (this.isKeyword(lookahead, "this") || this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'let') || this.isKeyword(lookahead, 'yield') || this.isNumericLiteral(lookahead) || this.isStringLiteral(lookahead) || this.isTemplate(lookahead) || this.isBooleanLiteral(lookahead) || this.isNullLiteral(lookahead) || this.isRegularExpression(lookahead) || this.isFnDeclTransform(lookahead) || this.isBraces(lookahead) || this.isBrackets(lookahead))) { return this.enforestPrimaryExpression(); } - if (this.term === null && this.isOperator(lookahead_156)) { + + // prefix unary + if (this.term === null && this.isOperator(lookahead)) { return this.enforestUnaryExpression(); } - if (this.term === null && this.isVarBindingTransform(lookahead_156)) { - let id = this.getFromCompiletimeEnvironment(lookahead_156).id; - if (id !== lookahead_156) { + + if (this.term === null && this.isVarBindingTransform(lookahead)) { + let id = this.getFromCompiletimeEnvironment(lookahead).id; + if (id !== lookahead) { this.advance(); this.rest = _immutable.List.of(id).concat(this.rest); - return EXPR_LOOP_EXPANSION_45; + return EXPR_LOOP_EXPANSION; } } - if (this.term === null && (this.isNewTransform(lookahead_156) || this.isKeyword(lookahead_156, "super")) || this.term && (this.isPunctuator(lookahead_156, ".") && (this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1))) || this.isBrackets(lookahead_156) || this.isParens(lookahead_156))) { + + if (this.term === null && (this.isNewTransform(lookahead) || this.isKeyword(lookahead, 'super')) || + // and then check the cases where the term part of p is something... + this.term && ( + // $x:expr . $prop:ident + this.isPunctuator(lookahead, '.') && (this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1))) || + // $x:expr [ $b:expr ] + this.isBrackets(lookahead) || + // $x:expr (...) + this.isParens(lookahead))) { return this.enforestLeftHandSideExpression({ allowCall: true }); } - if (this.term && this.isTemplate(lookahead_156)) { + + // $x:id `...` + if (this.term && this.isTemplate(lookahead)) { return this.enforestTemplateLiteral(); } - if (this.term && this.isUpdateOperator(lookahead_156)) { + + // postfix unary + if (this.term && this.isUpdateOperator(lookahead)) { return this.enforestUpdateExpression(); } - if (this.term && this.isOperator(lookahead_156)) { + + // $l:expr $op:binaryOperator $r:expr + if (this.term && this.isOperator(lookahead)) { return this.enforestBinaryExpression(); } - if (this.term && this.isAssign(lookahead_156)) { + + // $x:expr = $init:expr + if (this.term && this.isAssign(lookahead)) { let binding = this.transformDestructuring(this.term); let op = this.advance(); - let enf = new Enforester_46(this.rest, (0, _immutable.List)(), this.context); + + let enf = new Enforester(this.rest, (0, _immutable.List)(), this.context); let init = enf.enforest("expression"); this.rest = enf.rest; - if (op.val() === "=") { - return new _terms2.default("AssignmentExpression", { binding: binding, expression: init }); + + if (op.val() === '=') { + return new _terms2.default('AssignmentExpression', { + binding: binding, + expression: init + }); } else { - return new _terms2.default("CompoundAssignmentExpression", { binding: binding, operator: op.val(), expression: init }); + return new _terms2.default('CompoundAssignmentExpression', { + binding: binding, + operator: op.val(), + expression: init + }); } } - if (this.term && this.isPunctuator(lookahead_156, "?")) { + + if (this.term && this.isPunctuator(lookahead, '?')) { return this.enforestConditionalExpression(); } - return EXPR_LOOP_NO_CHANGE_44; + + return EXPR_LOOP_NO_CHANGE; } + enforestPrimaryExpression() { - let lookahead_157 = this.peek(); - if (this.term === null && this.isKeyword(lookahead_157, "this")) { + let lookahead = this.peek(); + // $x:ThisExpression + if (this.term === null && this.isKeyword(lookahead, "this")) { return this.enforestThisExpression(); } - if (this.term === null && (this.isIdentifier(lookahead_157) || this.isKeyword(lookahead_157, "let") || this.isKeyword(lookahead_157, "yield"))) { + // $x:ident + if (this.term === null && (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'let') || this.isKeyword(lookahead, 'yield'))) { return this.enforestIdentifierExpression(); } - if (this.term === null && this.isNumericLiteral(lookahead_157)) { + if (this.term === null && this.isNumericLiteral(lookahead)) { return this.enforestNumericLiteral(); } - if (this.term === null && this.isStringLiteral(lookahead_157)) { + if (this.term === null && this.isStringLiteral(lookahead)) { return this.enforestStringLiteral(); } - if (this.term === null && this.isTemplate(lookahead_157)) { + if (this.term === null && this.isTemplate(lookahead)) { return this.enforestTemplateLiteral(); } - if (this.term === null && this.isBooleanLiteral(lookahead_157)) { + if (this.term === null && this.isBooleanLiteral(lookahead)) { return this.enforestBooleanLiteral(); } - if (this.term === null && this.isNullLiteral(lookahead_157)) { + if (this.term === null && this.isNullLiteral(lookahead)) { return this.enforestNullLiteral(); } - if (this.term === null && this.isRegularExpression(lookahead_157)) { + if (this.term === null && this.isRegularExpression(lookahead)) { return this.enforestRegularExpressionLiteral(); } - if (this.term === null && this.isFnDeclTransform(lookahead_157)) { + // $x:FunctionExpression + if (this.term === null && this.isFnDeclTransform(lookahead)) { return this.enforestFunctionExpression(); } - if (this.term === null && this.isBraces(lookahead_157)) { + // { $p:prop (,) ... } + if (this.term === null && this.isBraces(lookahead)) { return this.enforestObjectExpression(); } - if (this.term === null && this.isBrackets(lookahead_157)) { + // [$x:expr (,) ...] + if (this.term === null && this.isBrackets(lookahead)) { return this.enforestArrayExpression(); } - (0, _errors.assert)(false, "Not a primary expression"); + (0, _errors.assert)(false, 'Not a primary expression'); } + enforestLeftHandSideExpression(_ref5) { let allowCall = _ref5.allowCall; - let lookahead_158 = this.peek(); - if (this.isKeyword(lookahead_158, "super")) { + let lookahead = this.peek(); + + if (this.isKeyword(lookahead, 'super')) { this.advance(); - this.term = new _terms2.default("Super", {}); - } else if (this.isNewTransform(lookahead_158)) { + this.term = new _terms2.default('Super', {}); + } else if (this.isNewTransform(lookahead)) { this.term = this.enforestNewExpression(); } + while (true) { - lookahead_158 = this.peek(); - if (this.isParens(lookahead_158)) { + lookahead = this.peek(); + if (this.isParens(lookahead)) { if (!allowCall) { - if (this.term && (0, _terms.isIdentifierExpression)(this.term)) { + // we're dealing with a new expression + if (this.term && ((0, _terms.isIdentifierExpression)(this.term) || (0, _terms.isStaticMemberExpression)(this.term) || (0, _terms.isComputedMemberExpression)(this.term))) { return this.term; } this.term = this.enforestExpressionLoop(); } else { this.term = this.enforestCallExpression(); } - } else if (this.isBrackets(lookahead_158)) { - this.term = allowCall ? this.enforestComputedMemberExpression() : this.enforestExpressionLoop(); - } else if (this.isPunctuator(lookahead_158, ".") && (this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1)))) { + } else if (this.isBrackets(lookahead)) { + this.term = this.term ? this.enforestComputedMemberExpression() : this.enforestPrimaryExpression(); + } else if (this.isPunctuator(lookahead, '.') && (this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1)))) { this.term = this.enforestStaticMemberExpression(); - } else if (this.isTemplate(lookahead_158)) { + } else if (this.isTemplate(lookahead)) { this.term = this.enforestTemplateLiteral(); - } else if (this.isBraces(lookahead_158)) { + } else if (this.isBraces(lookahead)) { this.term = this.enforestPrimaryExpression(); - } else if (this.isIdentifier(lookahead_158)) { - this.term = new _terms2.default("IdentifierExpression", { name: this.enforestIdentifier() }); + } else if (this.isIdentifier(lookahead)) { + this.term = new _terms2.default('IdentifierExpression', { name: this.enforestIdentifier() }); } else { break; } } return this.term; } + enforestBooleanLiteral() { - return new _terms2.default("LiteralBooleanExpression", { value: this.advance() }); + return new _terms2.default("LiteralBooleanExpression", { + value: this.advance() + }); } + enforestTemplateLiteral() { - return new _terms2.default("TemplateExpression", { tag: this.term, elements: this.enforestTemplateElements() }); + return new _terms2.default('TemplateExpression', { + tag: this.term, + elements: this.enforestTemplateElements() + }); } + enforestStringLiteral() { - return new _terms2.default("LiteralStringExpression", { value: this.advance() }); + return new _terms2.default("LiteralStringExpression", { + value: this.advance() + }); } + enforestNumericLiteral() { - let num_159 = this.advance(); - if (num_159.val() === 1 / 0) { - return new _terms2.default("LiteralInfinityExpression", {}); + let num = this.advance(); + if (num.val() === 1 / 0) { + return new _terms2.default('LiteralInfinityExpression', {}); } - return new _terms2.default("LiteralNumericExpression", { value: num_159 }); + return new _terms2.default("LiteralNumericExpression", { + value: num + }); } + enforestIdentifierExpression() { - return new _terms2.default("IdentifierExpression", { name: this.advance() }); + return new _terms2.default("IdentifierExpression", { + name: this.advance() + }); } + enforestRegularExpressionLiteral() { - let reStx_160 = this.advance(); - let lastSlash_161 = reStx_160.token.value.lastIndexOf("/"); - let pattern_162 = reStx_160.token.value.slice(1, lastSlash_161); - let flags_163 = reStx_160.token.value.slice(lastSlash_161 + 1); - return new _terms2.default("LiteralRegExpExpression", { pattern: pattern_162, flags: flags_163 }); + let reStx = this.advance(); + + let lastSlash = reStx.token.value.lastIndexOf("/"); + let pattern = reStx.token.value.slice(1, lastSlash); + let flags = reStx.token.value.slice(lastSlash + 1); + return new _terms2.default("LiteralRegExpExpression", { + pattern: pattern, flags: flags + }); } + enforestNullLiteral() { this.advance(); return new _terms2.default("LiteralNullExpression", {}); } + enforestThisExpression() { - return new _terms2.default("ThisExpression", { stx: this.advance() }); + return new _terms2.default("ThisExpression", { + stx: this.advance() + }); } + enforestArgumentList() { - let result_164 = []; + let result = []; while (this.rest.size > 0) { let arg; - if (this.isPunctuator(this.peek(), "...")) { + if (this.isPunctuator(this.peek(), '...')) { this.advance(); - arg = new _terms2.default("SpreadElement", { expression: this.enforestExpressionLoop() }); + arg = new _terms2.default('SpreadElement', { + expression: this.enforestExpressionLoop() + }); } else { arg = this.enforestExpressionLoop(); } if (this.rest.size > 0) { - this.matchPunctuator(","); + this.matchPunctuator(','); } - result_164.push(arg); + result.push(arg); } - return (0, _immutable.List)(result_164); + return (0, _immutable.List)(result); } + enforestNewExpression() { - this.matchKeyword("new"); - if (this.isPunctuator(this.peek(), ".") && this.isIdentifier(this.peek(1), "target")) { + this.matchKeyword('new'); + if (this.isPunctuator(this.peek(), '.') && this.isIdentifier(this.peek(1), 'target')) { this.advance(); this.advance(); - return new _terms2.default("NewTargetExpression", {}); + return new _terms2.default('NewTargetExpression', {}); } - let callee_165 = this.enforestLeftHandSideExpression({ allowCall: false }); - let args_166; + + let callee = this.enforestLeftHandSideExpression({ allowCall: false }); + let args; if (this.isParens(this.peek())) { - args_166 = this.matchParens(); + args = this.matchParens(); } else { - args_166 = (0, _immutable.List)(); + args = (0, _immutable.List)(); } - return new _terms2.default("NewExpression", { callee: callee_165, arguments: args_166 }); + return new _terms2.default('NewExpression', { + callee: callee, + arguments: args + }); } + enforestComputedMemberExpression() { - let enf_167 = new Enforester_46(this.matchSquares(), (0, _immutable.List)(), this.context); - return new _terms2.default("ComputedMemberExpression", { object: this.term, expression: enf_167.enforestExpression() }); - } - transformDestructuring(term_168) { - switch (term_168.type) { - case "IdentifierExpression": - return new _terms2.default("BindingIdentifier", { name: term_168.name }); - case "ParenthesizedExpression": - if (term_168.inner.size === 1 && this.isIdentifier(term_168.inner.get(0))) { - return new _terms2.default("BindingIdentifier", { name: term_168.inner.get(0) }); + let enf = new Enforester(this.matchSquares(), (0, _immutable.List)(), this.context); + return new _terms2.default('ComputedMemberExpression', { + object: this.term, + expression: enf.enforestExpression() + }); + } + + transformDestructuring(term) { + switch (term.type) { + case 'IdentifierExpression': + return new _terms2.default('BindingIdentifier', { name: term.name }); + + case 'ParenthesizedExpression': + if (term.inner.size === 1 && this.isIdentifier(term.inner.get(0))) { + return new _terms2.default('BindingIdentifier', { name: term.inner.get(0) }); } - case "DataProperty": - return new _terms2.default("BindingPropertyProperty", { name: term_168.name, binding: this.transformDestructuringWithDefault(term_168.expression) }); - case "ShorthandProperty": - return new _terms2.default("BindingPropertyIdentifier", { binding: new _terms2.default("BindingIdentifier", { name: term_168.name }), init: null }); - case "ObjectExpression": - return new _terms2.default("ObjectBinding", { properties: term_168.properties.map(t_169 => this.transformDestructuring(t_169)) }); - case "ArrayExpression": - let last = term_168.elements.last(); - if (last != null && last.type === "SpreadElement") { - return new _terms2.default("ArrayBinding", { elements: term_168.elements.slice(0, -1).map(t_170 => t_170 && this.transformDestructuringWithDefault(t_170)), restElement: this.transformDestructuringWithDefault(last.expression) }); - } else { - return new _terms2.default("ArrayBinding", { elements: term_168.elements.map(t_171 => t_171 && this.transformDestructuringWithDefault(t_171)), restElement: null }); + return term; + case 'DataProperty': + return new _terms2.default('BindingPropertyProperty', { + name: term.name, + binding: this.transformDestructuringWithDefault(term.expression) + }); + case 'ShorthandProperty': + return new _terms2.default('BindingPropertyIdentifier', { + binding: new _terms2.default('BindingIdentifier', { name: term.name }), + init: null + }); + case 'ObjectExpression': + return new _terms2.default('ObjectBinding', { + properties: term.properties.map(t => this.transformDestructuring(t)) + }); + case 'ArrayExpression': + { + let last = term.elements.last(); + if (last != null && last.type === 'SpreadElement') { + return new _terms2.default('ArrayBinding', { + elements: term.elements.slice(0, -1).map(t => t && this.transformDestructuringWithDefault(t)), + restElement: this.transformDestructuringWithDefault(last.expression) + }); + } else { + return new _terms2.default('ArrayBinding', { + elements: term.elements.map(t => t && this.transformDestructuringWithDefault(t)), + restElement: null + }); + } } - return new _terms2.default("ArrayBinding", { elements: term_168.elements.map(t_172 => t_172 && this.transformDestructuring(t_172)), restElement: null }); - case "StaticPropertyName": - return new _terms2.default("BindingIdentifier", { name: term_168.value }); - case "ComputedMemberExpression": - case "StaticMemberExpression": - case "ArrayBinding": - case "BindingIdentifier": - case "BindingPropertyIdentifier": - case "BindingPropertyProperty": - case "BindingWithDefault": - case "ObjectBinding": - return term_168; - } - (0, _errors.assert)(false, "not implemented yet for " + term_168.type); - } - transformDestructuringWithDefault(term_173) { - switch (term_173.type) { + case 'StaticPropertyName': + return new _terms2.default('BindingIdentifier', { + name: term.value + }); + case 'ComputedMemberExpression': + case 'StaticMemberExpression': + case 'ArrayBinding': + case 'BindingIdentifier': + case 'BindingPropertyIdentifier': + case 'BindingPropertyProperty': + case 'BindingWithDefault': + case 'ObjectBinding': + return term; + } + (0, _errors.assert)(false, 'not implemented yet for ' + term.type); + } + + transformDestructuringWithDefault(term) { + switch (term.type) { case "AssignmentExpression": - return new _terms2.default("BindingWithDefault", { binding: this.transformDestructuring(term_173.binding), init: term_173.expression }); + return new _terms2.default('BindingWithDefault', { + binding: this.transformDestructuring(term.binding), + init: term.expression + }); } - return this.transformDestructuring(term_173); + return this.transformDestructuring(term); } + enforestCallExpression() { - let paren_174 = this.advance(); - return new _terms2.default("CallExpression", { callee: this.term, arguments: paren_174.inner() }); + let paren = this.advance(); + return new _terms2.default("CallExpression", { + callee: this.term, + arguments: paren.inner() + }); } + enforestArrowExpression() { - let enf_175; + let enf; if (this.isIdentifier(this.peek())) { - enf_175 = new Enforester_46(_immutable.List.of(this.advance()), (0, _immutable.List)(), this.context); + enf = new Enforester(_immutable.List.of(this.advance()), (0, _immutable.List)(), this.context); } else { let p = this.matchParens(); - enf_175 = new Enforester_46(p, (0, _immutable.List)(), this.context); + enf = new Enforester(p, (0, _immutable.List)(), this.context); } - let params_176 = enf_175.enforestFormalParameters(); - this.matchPunctuator("=>"); - let body_177; + let params = enf.enforestFormalParameters(); + this.matchPunctuator('=>'); + + let body; if (this.isBraces(this.peek())) { - body_177 = this.matchCurlies(); + body = this.matchCurlies(); } else { - enf_175 = new Enforester_46(this.rest, (0, _immutable.List)(), this.context); - body_177 = enf_175.enforestExpressionLoop(); - this.rest = enf_175.rest; + enf = new Enforester(this.rest, (0, _immutable.List)(), this.context); + body = enf.enforestExpressionLoop(); + this.rest = enf.rest; } - return new _terms2.default("ArrowExpression", { params: params_176, body: body_177 }); + return new _terms2.default('ArrowExpression', { params: params, body: body }); } + enforestYieldExpression() { - let kwd_178 = this.matchKeyword("yield"); - let lookahead_179 = this.peek(); - if (this.rest.size === 0 || lookahead_179 && !this.lineNumberEq(kwd_178, lookahead_179)) { - return new _terms2.default("YieldExpression", { expression: null }); + let kwd = this.matchKeyword('yield'); + let lookahead = this.peek(); + + if (this.rest.size === 0 || lookahead && !this.lineNumberEq(kwd, lookahead)) { + return new _terms2.default('YieldExpression', { + expression: null + }); } else { let isGenerator = false; - if (this.isPunctuator(this.peek(), "*")) { + if (this.isPunctuator(this.peek(), '*')) { isGenerator = true; this.advance(); } let expr = this.enforestExpression(); - let type = isGenerator ? "YieldGeneratorExpression" : "YieldExpression"; - return new _terms2.default(type, { expression: expr }); + let type = isGenerator ? 'YieldGeneratorExpression' : 'YieldExpression'; + return new _terms2.default(type, { + expression: expr + }); } } + enforestSyntaxTemplate() { - return new _terms2.default("SyntaxTemplate", { template: this.advance() }); + return new _terms2.default('SyntaxTemplate', { + template: this.advance() + }); } + enforestSyntaxQuote() { - let name_180 = this.advance(); - return new _terms2.default("SyntaxQuote", { name: name_180, template: new _terms2.default("TemplateExpression", { tag: new _terms2.default("IdentifierExpression", { name: name_180 }), elements: this.enforestTemplateElements() }) }); + let name = this.advance(); + return new _terms2.default('SyntaxQuote', { + name: name, + template: new _terms2.default('TemplateExpression', { + tag: new _terms2.default('IdentifierExpression', { + name: name + }), + elements: this.enforestTemplateElements() + }) + }); } + enforestStaticMemberExpression() { - let object_181 = this.term; - let dot_182 = this.advance(); - let property_183 = this.advance(); - return new _terms2.default("StaticMemberExpression", { object: object_181, property: property_183 }); + let object = this.term; + this.advance(); + let property = this.advance(); + + return new _terms2.default("StaticMemberExpression", { + object: object, + property: property + }); } + enforestArrayExpression() { - let arr_184 = this.advance(); - let elements_185 = []; - let enf_186 = new Enforester_46(arr_184.inner(), (0, _immutable.List)(), this.context); - while (enf_186.rest.size > 0) { - let lookahead = enf_186.peek(); - if (enf_186.isPunctuator(lookahead, ",")) { - enf_186.advance(); - elements_185.push(null); - } else if (enf_186.isPunctuator(lookahead, "...")) { - enf_186.advance(); - let expression = enf_186.enforestExpressionLoop(); + let arr = this.advance(); + + let elements = []; + + let enf = new Enforester(arr.inner(), (0, _immutable.List)(), this.context); + + while (enf.rest.size > 0) { + let lookahead = enf.peek(); + if (enf.isPunctuator(lookahead, ",")) { + enf.advance(); + elements.push(null); + } else if (enf.isPunctuator(lookahead, '...')) { + enf.advance(); + let expression = enf.enforestExpressionLoop(); if (expression == null) { - throw enf_186.createError(lookahead, "expecting expression"); + throw enf.createError(lookahead, 'expecting expression'); } - elements_185.push(new _terms2.default("SpreadElement", { expression: expression })); + elements.push(new _terms2.default('SpreadElement', { expression: expression })); } else { - let term = enf_186.enforestExpressionLoop(); + let term = enf.enforestExpressionLoop(); if (term == null) { - throw enf_186.createError(lookahead, "expected expression"); + throw enf.createError(lookahead, "expected expression"); } - elements_185.push(term); - enf_186.consumeComma(); + elements.push(term); + enf.consumeComma(); } } - return new _terms2.default("ArrayExpression", { elements: (0, _immutable.List)(elements_185) }); + + return new _terms2.default("ArrayExpression", { + elements: (0, _immutable.List)(elements) + }); } + enforestObjectExpression() { - let obj_187 = this.advance(); - let properties_188 = (0, _immutable.List)(); - let enf_189 = new Enforester_46(obj_187.inner(), (0, _immutable.List)(), this.context); - let lastProp_190 = null; - while (enf_189.rest.size > 0) { - let prop = enf_189.enforestPropertyDefinition(); - enf_189.consumeComma(); - properties_188 = properties_188.concat(prop); - if (lastProp_190 === prop) { - throw enf_189.createError(prop, "invalid syntax in object"); + let obj = this.advance(); + + let properties = (0, _immutable.List)(); + + let enf = new Enforester(obj.inner(), (0, _immutable.List)(), this.context); + + let lastProp = null; + while (enf.rest.size > 0) { + let prop = enf.enforestPropertyDefinition(); + enf.consumeComma(); + properties = properties.concat(prop); + + if (lastProp === prop) { + throw enf.createError(prop, "invalid syntax in object"); } - lastProp_190 = prop; + lastProp = prop; } - return new _terms2.default("ObjectExpression", { properties: properties_188 }); + + return new _terms2.default("ObjectExpression", { + properties: properties + }); } + enforestPropertyDefinition() { var _enforestMethodDefini = this.enforestMethodDefinition(); let methodOrKey = _enforestMethodDefini.methodOrKey; let kind = _enforestMethodDefini.kind; + switch (kind) { - case "method": + case 'method': return methodOrKey; - case "identifier": + case 'identifier': if (this.isAssign(this.peek())) { this.advance(); let init = this.enforestExpressionLoop(); - return new _terms2.default("BindingPropertyIdentifier", { init: init, binding: this.transformDestructuring(methodOrKey) }); - } else if (!this.isPunctuator(this.peek(), ":")) { - return new _terms2.default("ShorthandProperty", { name: methodOrKey.value }); + return new _terms2.default('BindingPropertyIdentifier', { + init: init, binding: this.transformDestructuring(methodOrKey) + }); + } else if (!this.isPunctuator(this.peek(), ':')) { + return new _terms2.default('ShorthandProperty', { + name: methodOrKey.value + }); } } - this.matchPunctuator(":"); - let expr_191 = this.enforestExpressionLoop(); - return new _terms2.default("DataProperty", { name: methodOrKey, expression: expr_191 }); + + this.matchPunctuator(':'); + let expr = this.enforestExpressionLoop(); + + return new _terms2.default("DataProperty", { + name: methodOrKey, + expression: expr + }); } + enforestMethodDefinition() { - let lookahead_192 = this.peek(); - let isGenerator_193 = false; - if (this.isPunctuator(lookahead_192, "*")) { - isGenerator_193 = true; + let lookahead = this.peek(); + let isGenerator = false; + if (this.isPunctuator(lookahead, '*')) { + isGenerator = true; this.advance(); } - if (this.isIdentifier(lookahead_192, "get") && this.isPropertyName(this.peek(1))) { + + if (this.isIdentifier(lookahead, 'get') && this.isPropertyName(this.peek(1))) { this.advance(); var _enforestPropertyName2 = this.enforestPropertyName(); @@ -1213,18 +1605,24 @@ class Enforester_46 { this.matchParens(); let body = this.matchCurlies(); - return { methodOrKey: new _terms2.default("Getter", { name: name, body: body }), kind: "method" }; - } else if (this.isIdentifier(lookahead_192, "set") && this.isPropertyName(this.peek(1))) { + return { + methodOrKey: new _terms2.default('Getter', { name: name, body: body }), + kind: 'method' + }; + } else if (this.isIdentifier(lookahead, 'set') && this.isPropertyName(this.peek(1))) { this.advance(); var _enforestPropertyName3 = this.enforestPropertyName(); let name = _enforestPropertyName3.name; - let enf = new Enforester_46(this.matchParens(), (0, _immutable.List)(), this.context); + let enf = new Enforester(this.matchParens(), (0, _immutable.List)(), this.context); let param = enf.enforestBindingElement(); let body = this.matchCurlies(); - return { methodOrKey: new _terms2.default("Setter", { name: name, param: param, body: body }), kind: "method" }; + return { + methodOrKey: new _terms2.default('Setter', { name: name, param: param, body: body }), + kind: 'method' + }; } var _enforestPropertyName4 = this.enforestPropertyName(); @@ -1233,135 +1631,214 @@ class Enforester_46 { if (this.isParens(this.peek())) { let params = this.matchParens(); - let enf = new Enforester_46(params, (0, _immutable.List)(), this.context); + let enf = new Enforester(params, (0, _immutable.List)(), this.context); let formalParams = enf.enforestFormalParameters(); + let body = this.matchCurlies(); - return { methodOrKey: new _terms2.default("Method", { isGenerator: isGenerator_193, name: name, params: formalParams, body: body }), kind: "method" }; + return { + methodOrKey: new _terms2.default('Method', { + isGenerator: isGenerator, + name: name, params: formalParams, body: body + }), + kind: 'method' + }; } - return { methodOrKey: name, kind: this.isIdentifier(lookahead_192) || this.isKeyword(lookahead_192) ? "identifier" : "property" }; + return { + methodOrKey: name, + kind: this.isIdentifier(lookahead) || this.isKeyword(lookahead) ? 'identifier' : 'property' + }; } + enforestPropertyName() { - let lookahead_194 = this.peek(); - if (this.isStringLiteral(lookahead_194) || this.isNumericLiteral(lookahead_194)) { - return { name: new _terms2.default("StaticPropertyName", { value: this.advance() }), binding: null }; - } else if (this.isBrackets(lookahead_194)) { - let enf = new Enforester_46(this.matchSquares(), (0, _immutable.List)(), this.context); + let lookahead = this.peek(); + + if (this.isStringLiteral(lookahead) || this.isNumericLiteral(lookahead)) { + return { + name: new _terms2.default('StaticPropertyName', { + value: this.advance() + }), + binding: null + }; + } else if (this.isBrackets(lookahead)) { + let enf = new Enforester(this.matchSquares(), (0, _immutable.List)(), this.context); let expr = enf.enforestExpressionLoop(); - return { name: new _terms2.default("ComputedPropertyName", { expression: expr }), binding: null }; + return { + name: new _terms2.default('ComputedPropertyName', { + expression: expr + }), + binding: null + }; } - let name_195 = this.advance(); - return { name: new _terms2.default("StaticPropertyName", { value: name_195 }), binding: new _terms2.default("BindingIdentifier", { name: name_195 }) }; + let name = this.advance(); + return { + name: new _terms2.default('StaticPropertyName', { value: name }), + binding: new _terms2.default('BindingIdentifier', { name: name }) + }; } + enforestFunction(_ref6) { let isExpr = _ref6.isExpr; let inDefault = _ref6.inDefault; - let allowGenerator = _ref6.allowGenerator; - - let name_196 = null, - params_197, - body_198, - rest_199; - let isGenerator_200 = false; - let fnKeyword_201 = this.advance(); - let lookahead_202 = this.peek(); - let type_203 = isExpr ? "FunctionExpression" : "FunctionDeclaration"; - if (this.isPunctuator(lookahead_202, "*")) { - isGenerator_200 = true; + + let name = null, + params, + body; + let isGenerator = false; + // eat the function keyword + let fnKeyword = this.advance(); + let lookahead = this.peek(); + let type = isExpr ? 'FunctionExpression' : 'FunctionDeclaration'; + + if (this.isPunctuator(lookahead, "*")) { + isGenerator = true; this.advance(); - lookahead_202 = this.peek(); + lookahead = this.peek(); } - if (!this.isParens(lookahead_202)) { - name_196 = this.enforestBindingIdentifier(); + + if (!this.isParens(lookahead)) { + name = this.enforestBindingIdentifier(); } else if (inDefault) { - name_196 = new _terms2.default("BindingIdentifier", { name: _syntax2.default.fromIdentifier("*default*", fnKeyword_201) }); + name = new _terms2.default('BindingIdentifier', { + name: _syntax2.default.fromIdentifier('*default*', fnKeyword) + }); } - params_197 = this.matchParens(); - body_198 = this.matchCurlies(); - let enf_204 = new Enforester_46(params_197, (0, _immutable.List)(), this.context); - let formalParams_205 = enf_204.enforestFormalParameters(); - return new _terms2.default(type_203, { name: name_196, isGenerator: isGenerator_200, params: formalParams_205, body: body_198 }); + + params = this.matchParens(); + + body = this.matchCurlies(); + + let enf = new Enforester(params, (0, _immutable.List)(), this.context); + let formalParams = enf.enforestFormalParameters(); + + return new _terms2.default(type, { + name: name, + isGenerator: isGenerator, + params: formalParams, + body: body + }); } + enforestFunctionExpression() { - let name_206 = null, - params_207, - body_208, - rest_209; - let isGenerator_210 = false; + let name = null, + params, + body; + let isGenerator = false; + // eat the function keyword this.advance(); - let lookahead_211 = this.peek(); - if (this.isPunctuator(lookahead_211, "*")) { - isGenerator_210 = true; + let lookahead = this.peek(); + + if (this.isPunctuator(lookahead, "*")) { + isGenerator = true; this.advance(); - lookahead_211 = this.peek(); + lookahead = this.peek(); } - if (!this.isParens(lookahead_211)) { - name_206 = this.enforestBindingIdentifier(); + + if (!this.isParens(lookahead)) { + name = this.enforestBindingIdentifier(); } - params_207 = this.matchParens(); - body_208 = this.matchCurlies(); - let enf_212 = new Enforester_46(params_207, (0, _immutable.List)(), this.context); - let formalParams_213 = enf_212.enforestFormalParameters(); - return new _terms2.default("FunctionExpression", { name: name_206, isGenerator: isGenerator_210, params: formalParams_213, body: body_208 }); + + params = this.matchParens(); + body = this.matchCurlies(); + + let enf = new Enforester(params, (0, _immutable.List)(), this.context); + let formalParams = enf.enforestFormalParameters(); + + return new _terms2.default("FunctionExpression", { + name: name, + isGenerator: isGenerator, + params: formalParams, + body: body + }); } + enforestFunctionDeclaration() { - let name_214, params_215, body_216, rest_217; - let isGenerator_218 = false; + let name, params, body; + let isGenerator = false; + // eat the function keyword this.advance(); - let lookahead_219 = this.peek(); - if (this.isPunctuator(lookahead_219, "*")) { - isGenerator_218 = true; + let lookahead = this.peek(); + + if (this.isPunctuator(lookahead, "*")) { + isGenerator = true; this.advance(); } - name_214 = this.enforestBindingIdentifier(); - params_215 = this.matchParens(); - body_216 = this.matchCurlies(); - let enf_220 = new Enforester_46(params_215, (0, _immutable.List)(), this.context); - let formalParams_221 = enf_220.enforestFormalParameters(); - return new _terms2.default("FunctionDeclaration", { name: name_214, isGenerator: isGenerator_218, params: formalParams_221, body: body_216 }); + + name = this.enforestBindingIdentifier(); + + params = this.matchParens(); + body = this.matchCurlies(); + + let enf = new Enforester(params, (0, _immutable.List)(), this.context); + let formalParams = enf.enforestFormalParameters(); + + return new _terms2.default("FunctionDeclaration", { + name: name, + isGenerator: isGenerator, + params: formalParams, + body: body + }); } + enforestFormalParameters() { - let items_222 = []; - let rest_223 = null; + let items = []; + let rest = null; while (this.rest.size !== 0) { let lookahead = this.peek(); - if (this.isPunctuator(lookahead, "...")) { - this.matchPunctuator("..."); - rest_223 = this.enforestBindingIdentifier(); + if (this.isPunctuator(lookahead, '...')) { + this.matchPunctuator('...'); + rest = this.enforestBindingIdentifier(); break; } - items_222.push(this.enforestParam()); + items.push(this.enforestParam()); this.consumeComma(); } - return new _terms2.default("FormalParameters", { items: (0, _immutable.List)(items_222), rest: rest_223 }); + return new _terms2.default("FormalParameters", { + items: (0, _immutable.List)(items), rest: rest + }); } + enforestParam() { return this.enforestBindingElement(); } + enforestUpdateExpression() { - let operator_224 = this.matchUnaryOperator(); - return new _terms2.default("UpdateExpression", { isPrefix: false, operator: operator_224.val(), operand: this.transformDestructuring(this.term) }); + let operator = this.matchUnaryOperator(); + + return new _terms2.default('UpdateExpression', { + isPrefix: false, + operator: operator.val(), + operand: this.transformDestructuring(this.term) + }); } + enforestUnaryExpression() { - let operator_225 = this.matchUnaryOperator(); - this.opCtx.stack = this.opCtx.stack.push({ prec: this.opCtx.prec, combine: this.opCtx.combine }); + let operator = this.matchUnaryOperator(); + this.opCtx.stack = this.opCtx.stack.push({ + prec: this.opCtx.prec, + combine: this.opCtx.combine + }); + // TODO: all builtins are 14, custom operators will change this this.opCtx.prec = 14; - this.opCtx.combine = rightTerm_226 => { - let type_227, term_228, isPrefix_229; - if (operator_225.val() === "++" || operator_225.val() === "--") { - type_227 = "UpdateExpression"; - term_228 = this.transformDestructuring(rightTerm_226); - isPrefix_229 = true; + this.opCtx.combine = rightTerm => { + if (operator.val() === '++' || operator.val() === '--') { + return new _terms2.default('UpdateExpression', { + operator: operator.val(), + operand: this.transformDestructuring(rightTerm), + isPrefix: true + }); } else { - type_227 = "UnaryExpression"; - isPrefix_229 = undefined; - term_228 = rightTerm_226; + return new _terms2.default('UnaryExpression', { + operator: operator.val(), + operand: rightTerm + }); } - return new _terms2.default(type_227, { operator: operator_225.val(), operand: term_228, isPrefix: isPrefix_229 }); }; - return EXPR_LOOP_OPERATOR_43; + return EXPR_LOOP_OPERATOR; } + enforestConditionalExpression() { - let test_230 = this.opCtx.combine(this.term); + // first, pop the operator stack + let test = this.opCtx.combine(this.term); if (this.opCtx.stack.size > 0) { var _opCtx$stack$last2 = this.opCtx.stack.last(); @@ -1372,31 +1849,45 @@ class Enforester_46 { this.opCtx.prec = prec; this.opCtx.combine = combine; } - this.matchPunctuator("?"); - let enf_231 = new Enforester_46(this.rest, (0, _immutable.List)(), this.context); - let consequent_232 = enf_231.enforestExpressionLoop(); - enf_231.matchPunctuator(":"); - enf_231 = new Enforester_46(enf_231.rest, (0, _immutable.List)(), this.context); - let alternate_233 = enf_231.enforestExpressionLoop(); - this.rest = enf_231.rest; - return new _terms2.default("ConditionalExpression", { test: test_230, consequent: consequent_232, alternate: alternate_233 }); + + this.matchPunctuator('?'); + let enf = new Enforester(this.rest, (0, _immutable.List)(), this.context); + let consequent = enf.enforestExpressionLoop(); + enf.matchPunctuator(':'); + enf = new Enforester(enf.rest, (0, _immutable.List)(), this.context); + let alternate = enf.enforestExpressionLoop(); + this.rest = enf.rest; + return new _terms2.default('ConditionalExpression', { + test: test, consequent: consequent, alternate: alternate + }); } + enforestBinaryExpression() { - let leftTerm_234 = this.term; - let opStx_235 = this.peek(); - let op_236 = opStx_235.val(); - let opPrec_237 = (0, _operators.getOperatorPrec)(op_236); - let opAssoc_238 = (0, _operators.getOperatorAssoc)(op_236); - if ((0, _operators.operatorLt)(this.opCtx.prec, opPrec_237, opAssoc_238)) { - this.opCtx.stack = this.opCtx.stack.push({ prec: this.opCtx.prec, combine: this.opCtx.combine }); - this.opCtx.prec = opPrec_237; - this.opCtx.combine = rightTerm_239 => { - return new _terms2.default("BinaryExpression", { left: leftTerm_234, operator: opStx_235, right: rightTerm_239 }); + + let leftTerm = this.term; + let opStx = this.peek(); + let op = opStx.val(); + let opPrec = (0, _operators.getOperatorPrec)(op); + let opAssoc = (0, _operators.getOperatorAssoc)(op); + + if ((0, _operators.operatorLt)(this.opCtx.prec, opPrec, opAssoc)) { + this.opCtx.stack = this.opCtx.stack.push({ + prec: this.opCtx.prec, + combine: this.opCtx.combine + }); + this.opCtx.prec = opPrec; + this.opCtx.combine = rightTerm => { + return new _terms2.default("BinaryExpression", { + left: leftTerm, + operator: opStx, + right: rightTerm + }); }; this.advance(); - return EXPR_LOOP_OPERATOR_43; + return EXPR_LOOP_OPERATOR; } else { - let term = this.opCtx.combine(leftTerm_234); + let term = this.opCtx.combine(leftTerm); + // this.rest does not change var _opCtx$stack$last3 = this.opCtx.stack.last(); @@ -1409,324 +1900,395 @@ class Enforester_46 { return term; } } + enforestTemplateElements() { - let lookahead_240 = this.matchTemplate(); - let elements_241 = lookahead_240.token.items.map(it_242 => { - if (this.isDelimiter(it_242)) { - let enf = new Enforester_46(it_242.inner(), (0, _immutable.List)(), this.context); + let lookahead = this.matchTemplate(); + let elements = lookahead.token.items.map(it => { + if (this.isDelimiter(it)) { + let enf = new Enforester(it.inner(), (0, _immutable.List)(), this.context); return enf.enforest("expression"); } - return new _terms2.default("TemplateElement", { rawValue: it_242.slice.text }); + return new _terms2.default('TemplateElement', { + rawValue: it.slice.text + }); }); - return elements_241; + return elements; } + expandMacro() { - let lookahead_243 = this.peek(); - while (this.isCompiletimeTransform(lookahead_243)) { + let lookahead = this.peek(); + while (this.isCompiletimeTransform(lookahead)) { let name = this.advance(); + let syntaxTransform = this.getFromCompiletimeEnvironment(name); if (syntaxTransform == null || typeof syntaxTransform.value !== "function") { throw this.createError(name, "the macro name was not bound to a value that could be invoked"); } let useSiteScope = (0, _scope.freshScope)("u"); let introducedScope = (0, _scope.freshScope)("i"); + // TODO: needs to be a list of scopes I think this.context.useScope = useSiteScope; + let ctx = new _macroContext2.default(this, name, this.context, useSiteScope, introducedScope); + let result = (0, _loadSyntax.sanitizeReplacementValues)(syntaxTransform.value.call(null, ctx)); if (!_immutable.List.isList(result)) { throw this.createError(name, "macro must return a list but got: " + result); } - result = result.map(stx_244 => { - if (!(stx_244 && typeof stx_244.addScope === "function")) { - throw this.createError(name, "macro must return syntax objects or terms but got: " + stx_244); + result = result.map(stx => { + if (!(stx && typeof stx.addScope === 'function')) { + throw this.createError(name, 'macro must return syntax objects or terms but got: ' + stx); } - return stx_244.addScope(introducedScope, this.context.bindings, _syntax.ALL_PHASES, { flip: true }); + return stx.addScope(introducedScope, this.context.bindings, _syntax.ALL_PHASES, { flip: true }); }); + this.rest = result.concat(ctx._rest(this)); - lookahead_243 = this.peek(); + lookahead = this.peek(); } } + consumeSemicolon() { - let lookahead_245 = this.peek(); - if (lookahead_245 && this.isPunctuator(lookahead_245, ";")) { + let lookahead = this.peek(); + + if (lookahead && this.isPunctuator(lookahead, ";")) { this.advance(); } } + consumeComma() { - let lookahead_246 = this.peek(); - if (lookahead_246 && this.isPunctuator(lookahead_246, ",")) { + let lookahead = this.peek(); + + if (lookahead && this.isPunctuator(lookahead, ',')) { this.advance(); } } - safeCheck(obj_247, type_248) { - let val_249 = arguments.length <= 2 || arguments[2] === undefined ? null : arguments[2]; - return obj_247 && (typeof obj_247.match === "function" ? obj_247.match(type_248, val_249) : false); + safeCheck(obj, type) { + let val = arguments.length <= 2 || arguments[2] === undefined ? null : arguments[2]; + + return obj && (typeof obj.match === 'function' ? obj.match(type, val) : false); } - isTerm(term_250) { - return term_250 && term_250 instanceof _terms2.default; + + isTerm(term) { + return term && term instanceof _terms2.default; } - isEOF(obj_251) { - return this.safeCheck(obj_251, "eof"); + + isEOF(obj) { + return this.safeCheck(obj, 'eof'); } - isIdentifier(obj_252) { - let val_253 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - return this.safeCheck(obj_252, "identifier", val_253); + isIdentifier(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + + return this.safeCheck(obj, 'identifier', val); } - isPropertyName(obj_254) { - return this.isIdentifier(obj_254) || this.isKeyword(obj_254) || this.isNumericLiteral(obj_254) || this.isStringLiteral(obj_254) || this.isBrackets(obj_254); + + isPropertyName(obj) { + return this.isIdentifier(obj) || this.isKeyword(obj) || this.isNumericLiteral(obj) || this.isStringLiteral(obj) || this.isBrackets(obj); } - isNumericLiteral(obj_255) { - let val_256 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - return this.safeCheck(obj_255, "number", val_256); + isNumericLiteral(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + + return this.safeCheck(obj, 'number', val); } - isStringLiteral(obj_257) { - let val_258 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - return this.safeCheck(obj_257, "string", val_258); + isStringLiteral(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + + return this.safeCheck(obj, 'string', val); } - isTemplate(obj_259) { - let val_260 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - return this.safeCheck(obj_259, "template", val_260); + isTemplate(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + + return this.safeCheck(obj, 'template', val); } - isSyntaxTemplate(obj_261) { - return this.safeCheck(obj_261, "syntaxTemplate"); + + isSyntaxTemplate(obj) { + return this.safeCheck(obj, 'syntaxTemplate'); } - isBooleanLiteral(obj_262) { - let val_263 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - return this.safeCheck(obj_262, "boolean", val_263); + isBooleanLiteral(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + + return this.safeCheck(obj, 'boolean', val); } - isNullLiteral(obj_264) { - let val_265 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - return this.safeCheck(obj_264, "null", val_265); + isNullLiteral(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + + return this.safeCheck(obj, 'null', val); } - isRegularExpression(obj_266) { - let val_267 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - return this.safeCheck(obj_266, "regularExpression", val_267); + isRegularExpression(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + + return this.safeCheck(obj, 'regularExpression', val); } - isDelimiter(obj_268) { - return this.safeCheck(obj_268, "delimiter"); + + isDelimiter(obj) { + return this.safeCheck(obj, 'delimiter'); } - isParens(obj_269) { - return this.safeCheck(obj_269, "parens"); + + isParens(obj) { + return this.safeCheck(obj, 'parens'); } - isBraces(obj_270) { - return this.safeCheck(obj_270, "braces"); + + isBraces(obj) { + return this.safeCheck(obj, 'braces'); } - isBrackets(obj_271) { - return this.safeCheck(obj_271, "brackets"); + + isBrackets(obj) { + return this.safeCheck(obj, 'brackets'); } - isAssign(obj_272) { - let val_273 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - return this.safeCheck(obj_272, "assign", val_273); + isAssign(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + + return this.safeCheck(obj, 'assign', val); } - isKeyword(obj_274) { - let val_275 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - return this.safeCheck(obj_274, "keyword", val_275); + isKeyword(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + + return this.safeCheck(obj, 'keyword', val); } - isPunctuator(obj_276) { - let val_277 = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; - return this.safeCheck(obj_276, "punctuator", val_277); + isPunctuator(obj) { + let val = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + + return this.safeCheck(obj, 'punctuator', val); } - isOperator(obj_278) { - return (this.safeCheck(obj_278, "punctuator") || this.safeCheck(obj_278, "identifier") || this.safeCheck(obj_278, "keyword")) && (0, _operators.isOperator)(obj_278); + + isOperator(obj) { + return (this.safeCheck(obj, 'punctuator') || this.safeCheck(obj, 'identifier') || this.safeCheck(obj, 'keyword')) && (0, _operators.isOperator)(obj); } - isUpdateOperator(obj_279) { - return this.safeCheck(obj_279, "punctuator", "++") || this.safeCheck(obj_279, "punctuator", "--"); + + isUpdateOperator(obj) { + return this.safeCheck(obj, 'punctuator', '++') || this.safeCheck(obj, 'punctuator', '--'); } - safeResolve(obj_280, phase_281) { - return obj_280 && typeof obj_280.resolve === "function" ? Just_41(obj_280.resolve(phase_281)) : Nothing_42(); + + safeResolve(obj, phase) { + return obj && typeof obj.resolve === 'function' ? Just(obj.resolve(phase)) : Nothing(); } - isTransform(obj_282, trans_283) { - return this.safeResolve(obj_282, this.context.phase).map(name_284 => this.context.env.get(name_284) === trans_283 || this.context.store.get(name_284) === trans_283).getOrElse(false); + + isTransform(obj, trans) { + return this.safeResolve(obj, this.context.phase).map(name => this.context.env.get(name) === trans || this.context.store.get(name) === trans).getOrElse(false); } - isTransformInstance(obj_285, trans_286) { - return this.safeResolve(obj_285, this.context.phase).map(name_287 => this.context.env.get(name_287) instanceof trans_286 || this.context.store.get(name_287) instanceof trans_286).getOrElse(false); + + isTransformInstance(obj, trans) { + return this.safeResolve(obj, this.context.phase).map(name => this.context.env.get(name) instanceof trans || this.context.store.get(name) instanceof trans).getOrElse(false); } - isFnDeclTransform(obj_288) { - return this.isTransform(obj_288, _transforms.FunctionDeclTransform); + + isFnDeclTransform(obj) { + return this.isTransform(obj, _transforms.FunctionDeclTransform); } - isVarDeclTransform(obj_289) { - return this.isTransform(obj_289, _transforms.VariableDeclTransform); + + isVarDeclTransform(obj) { + return this.isTransform(obj, _transforms.VariableDeclTransform); } - isLetDeclTransform(obj_290) { - return this.isTransform(obj_290, _transforms.LetDeclTransform); + + isLetDeclTransform(obj) { + return this.isTransform(obj, _transforms.LetDeclTransform); } - isConstDeclTransform(obj_291) { - return this.isTransform(obj_291, _transforms.ConstDeclTransform); + + isConstDeclTransform(obj) { + return this.isTransform(obj, _transforms.ConstDeclTransform); } - isSyntaxDeclTransform(obj_292) { - return this.isTransform(obj_292, _transforms.SyntaxDeclTransform); + + isSyntaxDeclTransform(obj) { + return this.isTransform(obj, _transforms.SyntaxDeclTransform); } - isSyntaxrecDeclTransform(obj_293) { - return this.isTransform(obj_293, _transforms.SyntaxrecDeclTransform); + + isSyntaxrecDeclTransform(obj) { + return this.isTransform(obj, _transforms.SyntaxrecDeclTransform); } - isSyntaxQuoteTransform(obj_294) { - return this.isTransform(obj_294, _transforms.SyntaxQuoteTransform); + + isSyntaxQuoteTransform(obj) { + return this.isTransform(obj, _transforms.SyntaxQuoteTransform); } - isReturnStmtTransform(obj_295) { - return this.isTransform(obj_295, _transforms.ReturnStatementTransform); + + isReturnStmtTransform(obj) { + return this.isTransform(obj, _transforms.ReturnStatementTransform); } - isWhileTransform(obj_296) { - return this.isTransform(obj_296, _transforms.WhileTransform); + + isWhileTransform(obj) { + return this.isTransform(obj, _transforms.WhileTransform); } - isForTransform(obj_297) { - return this.isTransform(obj_297, _transforms.ForTransform); + + isForTransform(obj) { + return this.isTransform(obj, _transforms.ForTransform); } - isSwitchTransform(obj_298) { - return this.isTransform(obj_298, _transforms.SwitchTransform); + + isSwitchTransform(obj) { + return this.isTransform(obj, _transforms.SwitchTransform); } - isBreakTransform(obj_299) { - return this.isTransform(obj_299, _transforms.BreakTransform); + + isBreakTransform(obj) { + return this.isTransform(obj, _transforms.BreakTransform); } - isContinueTransform(obj_300) { - return this.isTransform(obj_300, _transforms.ContinueTransform); + + isContinueTransform(obj) { + return this.isTransform(obj, _transforms.ContinueTransform); } - isDoTransform(obj_301) { - return this.isTransform(obj_301, _transforms.DoTransform); + + isDoTransform(obj) { + return this.isTransform(obj, _transforms.DoTransform); } - isDebuggerTransform(obj_302) { - return this.isTransform(obj_302, _transforms.DebuggerTransform); + + isDebuggerTransform(obj) { + return this.isTransform(obj, _transforms.DebuggerTransform); } - isWithTransform(obj_303) { - return this.isTransform(obj_303, _transforms.WithTransform); + + isWithTransform(obj) { + return this.isTransform(obj, _transforms.WithTransform); } - isTryTransform(obj_304) { - return this.isTransform(obj_304, _transforms.TryTransform); + + isTryTransform(obj) { + return this.isTransform(obj, _transforms.TryTransform); } - isThrowTransform(obj_305) { - return this.isTransform(obj_305, _transforms.ThrowTransform); + + isThrowTransform(obj) { + return this.isTransform(obj, _transforms.ThrowTransform); } - isIfTransform(obj_306) { - return this.isTransform(obj_306, _transforms.IfTransform); + + isIfTransform(obj) { + return this.isTransform(obj, _transforms.IfTransform); } - isNewTransform(obj_307) { - return this.isTransform(obj_307, _transforms.NewTransform); + + isNewTransform(obj) { + return this.isTransform(obj, _transforms.NewTransform); } - isCompiletimeTransform(obj_308) { - return this.isTransformInstance(obj_308, _transforms.CompiletimeTransform); + + isCompiletimeTransform(obj) { + return this.isTransformInstance(obj, _transforms.CompiletimeTransform); } - isVarBindingTransform(obj_309) { - return this.isTransformInstance(obj_309, _transforms.VarBindingTransform); + + isVarBindingTransform(obj) { + return this.isTransformInstance(obj, _transforms.VarBindingTransform); } - getFromCompiletimeEnvironment(term_310) { - if (this.context.env.has(term_310.resolve(this.context.phase))) { - return this.context.env.get(term_310.resolve(this.context.phase)); + + getFromCompiletimeEnvironment(term) { + if (this.context.env.has(term.resolve(this.context.phase))) { + return this.context.env.get(term.resolve(this.context.phase)); } - return this.context.store.get(term_310.resolve(this.context.phase)); + return this.context.store.get(term.resolve(this.context.phase)); } - lineNumberEq(a_311, b_312) { - if (!(a_311 && b_312)) { + + lineNumberEq(a, b) { + if (!(a && b)) { return false; } - return a_311.lineNumber() === b_312.lineNumber(); + return a.lineNumber() === b.lineNumber(); } - matchIdentifier(val_313) { - let lookahead_314 = this.advance(); - if (this.isIdentifier(lookahead_314)) { - return lookahead_314; + + matchIdentifier(val) { + let lookahead = this.advance(); + if (this.isIdentifier(lookahead, val)) { + return lookahead; } - throw this.createError(lookahead_314, "expecting an identifier"); + throw this.createError(lookahead, "expecting an identifier"); } - matchKeyword(val_315) { - let lookahead_316 = this.advance(); - if (this.isKeyword(lookahead_316, val_315)) { - return lookahead_316; + + matchKeyword(val) { + let lookahead = this.advance(); + if (this.isKeyword(lookahead, val)) { + return lookahead; } - throw this.createError(lookahead_316, "expecting " + val_315); + throw this.createError(lookahead, 'expecting ' + val); } + matchLiteral() { - let lookahead_317 = this.advance(); - if (this.isNumericLiteral(lookahead_317) || this.isStringLiteral(lookahead_317) || this.isBooleanLiteral(lookahead_317) || this.isNullLiteral(lookahead_317) || this.isTemplate(lookahead_317) || this.isRegularExpression(lookahead_317)) { - return lookahead_317; + let lookahead = this.advance(); + if (this.isNumericLiteral(lookahead) || this.isStringLiteral(lookahead) || this.isBooleanLiteral(lookahead) || this.isNullLiteral(lookahead) || this.isTemplate(lookahead) || this.isRegularExpression(lookahead)) { + return lookahead; } - throw this.createError(lookahead_317, "expecting a literal"); + throw this.createError(lookahead, "expecting a literal"); } + matchStringLiteral() { - let lookahead_318 = this.advance(); - if (this.isStringLiteral(lookahead_318)) { - return lookahead_318; + let lookahead = this.advance(); + if (this.isStringLiteral(lookahead)) { + return lookahead; } - throw this.createError(lookahead_318, "expecting a string literal"); + throw this.createError(lookahead, 'expecting a string literal'); } + matchTemplate() { - let lookahead_319 = this.advance(); - if (this.isTemplate(lookahead_319)) { - return lookahead_319; + let lookahead = this.advance(); + if (this.isTemplate(lookahead)) { + return lookahead; } - throw this.createError(lookahead_319, "expecting a template literal"); + throw this.createError(lookahead, 'expecting a template literal'); } + matchParens() { - let lookahead_320 = this.advance(); - if (this.isParens(lookahead_320)) { - return lookahead_320.inner(); + let lookahead = this.advance(); + if (this.isParens(lookahead)) { + return lookahead.inner(); } - throw this.createError(lookahead_320, "expecting parens"); + throw this.createError(lookahead, "expecting parens"); } + matchCurlies() { - let lookahead_321 = this.advance(); - if (this.isBraces(lookahead_321)) { - return lookahead_321.inner(); + let lookahead = this.advance(); + if (this.isBraces(lookahead)) { + return lookahead.inner(); } - throw this.createError(lookahead_321, "expecting curly braces"); + throw this.createError(lookahead, "expecting curly braces"); } matchSquares() { - let lookahead_322 = this.advance(); - if (this.isBrackets(lookahead_322)) { - return lookahead_322.inner(); + let lookahead = this.advance(); + if (this.isBrackets(lookahead)) { + return lookahead.inner(); } - throw this.createError(lookahead_322, "expecting sqaure braces"); + throw this.createError(lookahead, "expecting sqaure braces"); } + matchUnaryOperator() { - let lookahead_323 = this.advance(); - if ((0, _operators.isUnaryOperator)(lookahead_323)) { - return lookahead_323; - } - throw this.createError(lookahead_323, "expecting a unary operator"); - } - matchPunctuator(val_324) { - let lookahead_325 = this.advance(); - if (this.isPunctuator(lookahead_325)) { - if (typeof val_324 !== "undefined") { - if (lookahead_325.val() === val_324) { - return lookahead_325; + let lookahead = this.advance(); + if ((0, _operators.isUnaryOperator)(lookahead)) { + return lookahead; + } + throw this.createError(lookahead, "expecting a unary operator"); + } + + matchPunctuator(val) { + let lookahead = this.advance(); + if (this.isPunctuator(lookahead)) { + if (typeof val !== 'undefined') { + if (lookahead.val() === val) { + return lookahead; } else { - throw this.createError(lookahead_325, "expecting a " + val_324 + " punctuator"); + throw this.createError(lookahead, "expecting a " + val + " punctuator"); } } - return lookahead_325; + return lookahead; } - throw this.createError(lookahead_325, "expecting a punctuator"); + throw this.createError(lookahead, "expecting a punctuator"); } - createError(stx_326, message_327) { - let ctx_328 = ""; - let offending_329 = stx_326; + + createError(stx, message) { + let ctx = ""; + let offending = stx; if (this.rest.size > 0) { - ctx_328 = this.rest.slice(0, 20).map(term_330 => { - if (this.isDelimiter(term_330)) { - return term_330.inner(); + ctx = this.rest.slice(0, 20).map(term => { + if (this.isDelimiter(term)) { + return term.inner(); } - return _immutable.List.of(term_330); - }).flatten().map(s_331 => { - if (s_331 === offending_329) { - return "__" + s_331.val() + "__"; + return _immutable.List.of(term); + }).flatten().map(s => { + if (s === offending) { + return "__" + s.val() + "__"; } - return s_331.val(); + return s.val(); }).join(" "); } else { - ctx_328 = offending_329.toString(); + ctx = offending.toString(); } - return new Error(message_327 + "\n" + ctx_328); + return new Error(message + "\n" + ctx); } } -exports.Enforester = Enforester_46; -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/enforester.js"],"names":[],"mappings":"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","file":"enforester.js","sourcesContent":["import Term, {isIdentifierExpression} from \"./terms\";\nimport {Maybe} from \"ramda-fantasy\";\nimport {FunctionDeclTransform, VariableDeclTransform, NewTransform, LetDeclTransform, ConstDeclTransform, SyntaxDeclTransform, SyntaxrecDeclTransform, SyntaxQuoteTransform, ReturnStatementTransform, WhileTransform, IfTransform, ForTransform, SwitchTransform, BreakTransform, ContinueTransform, DoTransform, DebuggerTransform, WithTransform, TryTransform, ThrowTransform, CompiletimeTransform, VarBindingTransform} from \"./transforms\";\nimport {List} from \"immutable\";\nimport {expect, assert} from \"./errors\";\nimport {isOperator, isUnaryOperator, getOperatorAssoc, getOperatorPrec, operatorLt} from \"./operators\";\nimport Syntax, {ALL_PHASES} from \"./syntax\";\nimport {freshScope} from \"./scope\";\nimport {sanitizeReplacementValues} from \"./load-syntax\";\nimport MacroContext from \"./macro-context\";\nconst Just_41 = Maybe.Just;\nconst Nothing_42 = Maybe.Nothing;\nconst EXPR_LOOP_OPERATOR_43 = {};\nconst EXPR_LOOP_NO_CHANGE_44 = {};\nconst EXPR_LOOP_EXPANSION_45 = {};\nclass Enforester_46 {\n  constructor(stxl_47, prev_48, context_49) {\n    this.done = false;\n    assert(List.isList(stxl_47), \"expecting a list of terms to enforest\");\n    assert(List.isList(prev_48), \"expecting a list of terms to enforest\");\n    assert(context_49, \"expecting a context to enforest\");\n    this.term = null;\n    this.rest = stxl_47;\n    this.prev = prev_48;\n    this.context = context_49;\n  }\n  peek(n_50 = 0) {\n    return this.rest.get(n_50);\n  }\n  advance() {\n    let ret_51 = this.rest.first();\n    this.rest = this.rest.rest();\n    return ret_51;\n  }\n  enforest(type_52 = \"Module\") {\n    this.term = null;\n    if (this.rest.size === 0) {\n      this.done = true;\n      return this.term;\n    }\n    if (this.isEOF(this.peek())) {\n      this.term = new Term(\"EOF\", {});\n      this.advance();\n      return this.term;\n    }\n    let result_53;\n    if (type_52 === \"expression\") {\n      result_53 = this.enforestExpressionLoop();\n    } else {\n      result_53 = this.enforestModule();\n    }\n    if (this.rest.size === 0) {\n      this.done = true;\n    }\n    return result_53;\n  }\n  enforestModule() {\n    return this.enforestBody();\n  }\n  enforestBody() {\n    return this.enforestModuleItem();\n  }\n  enforestModuleItem() {\n    let lookahead_54 = this.peek();\n    if (this.isKeyword(lookahead_54, \"import\")) {\n      this.advance();\n      return this.enforestImportDeclaration();\n    } else if (this.isKeyword(lookahead_54, \"export\")) {\n      this.advance();\n      return this.enforestExportDeclaration();\n    } else if (this.isIdentifier(lookahead_54, \"#\")) {\n      return this.enforestLanguagePragma();\n    }\n    return this.enforestStatement();\n  }\n  enforestLanguagePragma() {\n    this.matchIdentifier(\"#\");\n    this.matchIdentifier(\"lang\");\n    let path_55 = this.matchStringLiteral();\n    this.consumeSemicolon();\n    return new Term(\"Pragma\", {kind: \"lang\", items: List.of(path_55)});\n  }\n  enforestExportDeclaration() {\n    let lookahead_56 = this.peek();\n    if (this.isPunctuator(lookahead_56, \"*\")) {\n      this.advance();\n      let moduleSpecifier = this.enforestFromClause();\n      return new Term(\"ExportAllFrom\", {moduleSpecifier: moduleSpecifier});\n    } else if (this.isBraces(lookahead_56)) {\n      let namedExports = this.enforestExportClause();\n      let moduleSpecifier = null;\n      if (this.isIdentifier(this.peek(), \"from\")) {\n        moduleSpecifier = this.enforestFromClause();\n      }\n      return new Term(\"ExportFrom\", {namedExports: namedExports, moduleSpecifier: moduleSpecifier});\n    } else if (this.isKeyword(lookahead_56, \"class\")) {\n      return new Term(\"Export\", {declaration: this.enforestClass({isExpr: false})});\n    } else if (this.isFnDeclTransform(lookahead_56)) {\n      return new Term(\"Export\", {declaration: this.enforestFunction({isExpr: false, inDefault: false})});\n    } else if (this.isKeyword(lookahead_56, \"default\")) {\n      this.advance();\n      if (this.isFnDeclTransform(this.peek())) {\n        return new Term(\"ExportDefault\", {body: this.enforestFunction({isExpr: false, inDefault: true})});\n      } else if (this.isKeyword(this.peek(), \"class\")) {\n        return new Term(\"ExportDefault\", {body: this.enforestClass({isExpr: false, inDefault: true})});\n      } else {\n        let body = this.enforestExpressionLoop();\n        this.consumeSemicolon();\n        return new Term(\"ExportDefault\", {body: body});\n      }\n    } else if (this.isVarDeclTransform(lookahead_56) || this.isLetDeclTransform(lookahead_56) || this.isConstDeclTransform(lookahead_56) || this.isSyntaxrecDeclTransform(lookahead_56) || this.isSyntaxDeclTransform(lookahead_56)) {\n      return new Term(\"Export\", {declaration: this.enforestVariableDeclaration()});\n    }\n    throw this.createError(lookahead_56, \"unexpected syntax\");\n  }\n  enforestExportClause() {\n    let enf_57 = new Enforester_46(this.matchCurlies(), List(), this.context);\n    let result_58 = [];\n    while (enf_57.rest.size !== 0) {\n      result_58.push(enf_57.enforestExportSpecifier());\n      enf_57.consumeComma();\n    }\n    return List(result_58);\n  }\n  enforestExportSpecifier() {\n    let name_59 = this.enforestIdentifier();\n    if (this.isIdentifier(this.peek(), \"as\")) {\n      this.advance();\n      let exportedName = this.enforestIdentifier();\n      return new Term(\"ExportSpecifier\", {name: name_59, exportedName: exportedName});\n    }\n    return new Term(\"ExportSpecifier\", {name: null, exportedName: name_59});\n  }\n  enforestImportDeclaration() {\n    let lookahead_60 = this.peek();\n    let defaultBinding_61 = null;\n    let namedImports_62 = List();\n    let forSyntax_63 = false;\n    if (this.isStringLiteral(lookahead_60)) {\n      let moduleSpecifier = this.advance();\n      this.consumeSemicolon();\n      return new Term(\"Import\", {defaultBinding: defaultBinding_61, namedImports: namedImports_62, moduleSpecifier: moduleSpecifier});\n    }\n    if (this.isIdentifier(lookahead_60) || this.isKeyword(lookahead_60)) {\n      defaultBinding_61 = this.enforestBindingIdentifier();\n      if (!this.isPunctuator(this.peek(), \",\")) {\n        let moduleSpecifier = this.enforestFromClause();\n        if (this.isKeyword(this.peek(), \"for\") && this.isIdentifier(this.peek(1), \"syntax\")) {\n          this.advance();\n          this.advance();\n          forSyntax_63 = true;\n        }\n        return new Term(\"Import\", {defaultBinding: defaultBinding_61, moduleSpecifier: moduleSpecifier, namedImports: List(), forSyntax: forSyntax_63});\n      }\n    }\n    this.consumeComma();\n    lookahead_60 = this.peek();\n    if (this.isBraces(lookahead_60)) {\n      let imports = this.enforestNamedImports();\n      let fromClause = this.enforestFromClause();\n      if (this.isKeyword(this.peek(), \"for\") && this.isIdentifier(this.peek(1), \"syntax\")) {\n        this.advance();\n        this.advance();\n        forSyntax_63 = true;\n      }\n      return new Term(\"Import\", {defaultBinding: defaultBinding_61, forSyntax: forSyntax_63, namedImports: imports, moduleSpecifier: fromClause});\n    } else if (this.isPunctuator(lookahead_60, \"*\")) {\n      let namespaceBinding = this.enforestNamespaceBinding();\n      let moduleSpecifier = this.enforestFromClause();\n      if (this.isKeyword(this.peek(), \"for\") && this.isIdentifier(this.peek(1), \"syntax\")) {\n        this.advance();\n        this.advance();\n        forSyntax_63 = true;\n      }\n      return new Term(\"ImportNamespace\", {defaultBinding: defaultBinding_61, forSyntax: forSyntax_63, namespaceBinding: namespaceBinding, moduleSpecifier: moduleSpecifier});\n    }\n    throw this.createError(lookahead_60, \"unexpected syntax\");\n  }\n  enforestNamespaceBinding() {\n    this.matchPunctuator(\"*\");\n    this.matchIdentifier(\"as\");\n    return this.enforestBindingIdentifier();\n  }\n  enforestNamedImports() {\n    let enf_64 = new Enforester_46(this.matchCurlies(), List(), this.context);\n    let result_65 = [];\n    while (enf_64.rest.size !== 0) {\n      result_65.push(enf_64.enforestImportSpecifiers());\n      enf_64.consumeComma();\n    }\n    return List(result_65);\n  }\n  enforestImportSpecifiers() {\n    let lookahead_66 = this.peek();\n    let name_67;\n    if (this.isIdentifier(lookahead_66) || this.isKeyword(lookahead_66)) {\n      name_67 = this.advance();\n      if (!this.isIdentifier(this.peek(), \"as\")) {\n        return new Term(\"ImportSpecifier\", {name: null, binding: new Term(\"BindingIdentifier\", {name: name_67})});\n      } else {\n        this.matchIdentifier(\"as\");\n      }\n    } else {\n      throw this.createError(lookahead_66, \"unexpected token in import specifier\");\n    }\n    return new Term(\"ImportSpecifier\", {name: name_67, binding: this.enforestBindingIdentifier()});\n  }\n  enforestFromClause() {\n    this.matchIdentifier(\"from\");\n    let lookahead_68 = this.matchStringLiteral();\n    this.consumeSemicolon();\n    return lookahead_68;\n  }\n  enforestStatementListItem() {\n    let lookahead_69 = this.peek();\n    if (this.isFnDeclTransform(lookahead_69)) {\n      return this.enforestFunctionDeclaration({isExpr: false});\n    } else if (this.isKeyword(lookahead_69, \"class\")) {\n      return this.enforestClass({isExpr: false});\n    } else {\n      return this.enforestStatement();\n    }\n  }\n  enforestStatement() {\n    let lookahead_70 = this.peek();\n    if (this.term === null && this.isCompiletimeTransform(lookahead_70)) {\n      this.expandMacro();\n      lookahead_70 = this.peek();\n    }\n    if (this.term === null && this.isTerm(lookahead_70)) {\n      return this.advance();\n    }\n    if (this.term === null && this.isBraces(lookahead_70)) {\n      return this.enforestBlockStatement();\n    }\n    if (this.term === null && this.isWhileTransform(lookahead_70)) {\n      return this.enforestWhileStatement();\n    }\n    if (this.term === null && this.isIfTransform(lookahead_70)) {\n      return this.enforestIfStatement();\n    }\n    if (this.term === null && this.isForTransform(lookahead_70)) {\n      return this.enforestForStatement();\n    }\n    if (this.term === null && this.isSwitchTransform(lookahead_70)) {\n      return this.enforestSwitchStatement();\n    }\n    if (this.term === null && this.isBreakTransform(lookahead_70)) {\n      return this.enforestBreakStatement();\n    }\n    if (this.term === null && this.isContinueTransform(lookahead_70)) {\n      return this.enforestContinueStatement();\n    }\n    if (this.term === null && this.isDoTransform(lookahead_70)) {\n      return this.enforestDoStatement();\n    }\n    if (this.term === null && this.isDebuggerTransform(lookahead_70)) {\n      return this.enforestDebuggerStatement();\n    }\n    if (this.term === null && this.isWithTransform(lookahead_70)) {\n      return this.enforestWithStatement();\n    }\n    if (this.term === null && this.isTryTransform(lookahead_70)) {\n      return this.enforestTryStatement();\n    }\n    if (this.term === null && this.isThrowTransform(lookahead_70)) {\n      return this.enforestThrowStatement();\n    }\n    if (this.term === null && this.isKeyword(lookahead_70, \"class\")) {\n      return this.enforestClass({isExpr: false});\n    }\n    if (this.term === null && this.isFnDeclTransform(lookahead_70)) {\n      return this.enforestFunctionDeclaration();\n    }\n    if (this.term === null && this.isIdentifier(lookahead_70) && this.isPunctuator(this.peek(1), \":\")) {\n      return this.enforestLabeledStatement();\n    }\n    if (this.term === null && (this.isVarDeclTransform(lookahead_70) || this.isLetDeclTransform(lookahead_70) || this.isConstDeclTransform(lookahead_70) || this.isSyntaxrecDeclTransform(lookahead_70) || this.isSyntaxDeclTransform(lookahead_70))) {\n      let stmt = new Term(\"VariableDeclarationStatement\", {declaration: this.enforestVariableDeclaration()});\n      this.consumeSemicolon();\n      return stmt;\n    }\n    if (this.term === null && this.isReturnStmtTransform(lookahead_70)) {\n      return this.enforestReturnStatement();\n    }\n    if (this.term === null && this.isPunctuator(lookahead_70, \";\")) {\n      this.advance();\n      return new Term(\"EmptyStatement\", {});\n    }\n    return this.enforestExpressionStatement();\n  }\n  enforestLabeledStatement() {\n    let label_71 = this.matchIdentifier();\n    let punc_72 = this.matchPunctuator(\":\");\n    let stmt_73 = this.enforestStatement();\n    return new Term(\"LabeledStatement\", {label: label_71, body: stmt_73});\n  }\n  enforestBreakStatement() {\n    this.matchKeyword(\"break\");\n    let lookahead_74 = this.peek();\n    let label_75 = null;\n    if (this.rest.size === 0 || this.isPunctuator(lookahead_74, \";\")) {\n      this.consumeSemicolon();\n      return new Term(\"BreakStatement\", {label: label_75});\n    }\n    if (this.isIdentifier(lookahead_74) || this.isKeyword(lookahead_74, \"yield\") || this.isKeyword(lookahead_74, \"let\")) {\n      label_75 = this.enforestIdentifier();\n    }\n    this.consumeSemicolon();\n    return new Term(\"BreakStatement\", {label: label_75});\n  }\n  enforestTryStatement() {\n    this.matchKeyword(\"try\");\n    let body_76 = this.enforestBlock();\n    if (this.isKeyword(this.peek(), \"catch\")) {\n      let catchClause = this.enforestCatchClause();\n      if (this.isKeyword(this.peek(), \"finally\")) {\n        this.advance();\n        let finalizer = this.enforestBlock();\n        return new Term(\"TryFinallyStatement\", {body: body_76, catchClause: catchClause, finalizer: finalizer});\n      }\n      return new Term(\"TryCatchStatement\", {body: body_76, catchClause: catchClause});\n    }\n    if (this.isKeyword(this.peek(), \"finally\")) {\n      this.advance();\n      let finalizer = this.enforestBlock();\n      return new Term(\"TryFinallyStatement\", {body: body_76, catchClause: null, finalizer: finalizer});\n    }\n    throw this.createError(this.peek(), \"try with no catch or finally\");\n  }\n  enforestCatchClause() {\n    this.matchKeyword(\"catch\");\n    let bindingParens_77 = this.matchParens();\n    let enf_78 = new Enforester_46(bindingParens_77, List(), this.context);\n    let binding_79 = enf_78.enforestBindingTarget();\n    let body_80 = this.enforestBlock();\n    return new Term(\"CatchClause\", {binding: binding_79, body: body_80});\n  }\n  enforestThrowStatement() {\n    this.matchKeyword(\"throw\");\n    let expression_81 = this.enforestExpression();\n    this.consumeSemicolon();\n    return new Term(\"ThrowStatement\", {expression: expression_81});\n  }\n  enforestWithStatement() {\n    this.matchKeyword(\"with\");\n    let objParens_82 = this.matchParens();\n    let enf_83 = new Enforester_46(objParens_82, List(), this.context);\n    let object_84 = enf_83.enforestExpression();\n    let body_85 = this.enforestStatement();\n    return new Term(\"WithStatement\", {object: object_84, body: body_85});\n  }\n  enforestDebuggerStatement() {\n    this.matchKeyword(\"debugger\");\n    return new Term(\"DebuggerStatement\", {});\n  }\n  enforestDoStatement() {\n    this.matchKeyword(\"do\");\n    let body_86 = this.enforestStatement();\n    this.matchKeyword(\"while\");\n    let testBody_87 = this.matchParens();\n    let enf_88 = new Enforester_46(testBody_87, List(), this.context);\n    let test_89 = enf_88.enforestExpression();\n    this.consumeSemicolon();\n    return new Term(\"DoWhileStatement\", {body: body_86, test: test_89});\n  }\n  enforestContinueStatement() {\n    let kwd_90 = this.matchKeyword(\"continue\");\n    let lookahead_91 = this.peek();\n    let label_92 = null;\n    if (this.rest.size === 0 || this.isPunctuator(lookahead_91, \";\")) {\n      this.consumeSemicolon();\n      return new Term(\"ContinueStatement\", {label: label_92});\n    }\n    if (this.lineNumberEq(kwd_90, lookahead_91) && (this.isIdentifier(lookahead_91) || this.isKeyword(lookahead_91, \"yield\") || this.isKeyword(lookahead_91, \"let\"))) {\n      label_92 = this.enforestIdentifier();\n    }\n    this.consumeSemicolon();\n    return new Term(\"ContinueStatement\", {label: label_92});\n  }\n  enforestSwitchStatement() {\n    this.matchKeyword(\"switch\");\n    let cond_93 = this.matchParens();\n    let enf_94 = new Enforester_46(cond_93, List(), this.context);\n    let discriminant_95 = enf_94.enforestExpression();\n    let body_96 = this.matchCurlies();\n    if (body_96.size === 0) {\n      return new Term(\"SwitchStatement\", {discriminant: discriminant_95, cases: List()});\n    }\n    enf_94 = new Enforester_46(body_96, List(), this.context);\n    let cases_97 = enf_94.enforestSwitchCases();\n    let lookahead_98 = enf_94.peek();\n    if (enf_94.isKeyword(lookahead_98, \"default\")) {\n      let defaultCase = enf_94.enforestSwitchDefault();\n      let postDefaultCases = enf_94.enforestSwitchCases();\n      return new Term(\"SwitchStatementWithDefault\", {discriminant: discriminant_95, preDefaultCases: cases_97, defaultCase: defaultCase, postDefaultCases: postDefaultCases});\n    }\n    return new Term(\"SwitchStatement\", {discriminant: discriminant_95, cases: cases_97});\n  }\n  enforestSwitchCases() {\n    let cases_99 = [];\n    while (!(this.rest.size === 0 || this.isKeyword(this.peek(), \"default\"))) {\n      cases_99.push(this.enforestSwitchCase());\n    }\n    return List(cases_99);\n  }\n  enforestSwitchCase() {\n    this.matchKeyword(\"case\");\n    return new Term(\"SwitchCase\", {test: this.enforestExpression(), consequent: this.enforestSwitchCaseBody()});\n  }\n  enforestSwitchCaseBody() {\n    this.matchPunctuator(\":\");\n    return this.enforestStatementListInSwitchCaseBody();\n  }\n  enforestStatementListInSwitchCaseBody() {\n    let result_100 = [];\n    while (!(this.rest.size === 0 || this.isKeyword(this.peek(), \"default\") || this.isKeyword(this.peek(), \"case\"))) {\n      result_100.push(this.enforestStatementListItem());\n    }\n    return List(result_100);\n  }\n  enforestSwitchDefault() {\n    this.matchKeyword(\"default\");\n    return new Term(\"SwitchDefault\", {consequent: this.enforestSwitchCaseBody()});\n  }\n  enforestForStatement() {\n    this.matchKeyword(\"for\");\n    let cond_101 = this.matchParens();\n    let enf_102 = new Enforester_46(cond_101, List(), this.context);\n    let lookahead_103, test_104, init_105, right_106, type_107, left_108, update_109;\n    if (enf_102.isPunctuator(enf_102.peek(), \";\")) {\n      enf_102.advance();\n      if (!enf_102.isPunctuator(enf_102.peek(), \";\")) {\n        test_104 = enf_102.enforestExpression();\n      }\n      enf_102.matchPunctuator(\";\");\n      if (enf_102.rest.size !== 0) {\n        right_106 = enf_102.enforestExpression();\n      }\n      return new Term(\"ForStatement\", {init: null, test: test_104, update: right_106, body: this.enforestStatement()});\n    } else {\n      lookahead_103 = enf_102.peek();\n      if (enf_102.isVarDeclTransform(lookahead_103) || enf_102.isLetDeclTransform(lookahead_103) || enf_102.isConstDeclTransform(lookahead_103)) {\n        init_105 = enf_102.enforestVariableDeclaration();\n        lookahead_103 = enf_102.peek();\n        if (this.isKeyword(lookahead_103, \"in\") || this.isIdentifier(lookahead_103, \"of\")) {\n          if (this.isKeyword(lookahead_103, \"in\")) {\n            enf_102.advance();\n            right_106 = enf_102.enforestExpression();\n            type_107 = \"ForInStatement\";\n          } else if (this.isIdentifier(lookahead_103, \"of\")) {\n            enf_102.advance();\n            right_106 = enf_102.enforestExpression();\n            type_107 = \"ForOfStatement\";\n          }\n          return new Term(type_107, {left: init_105, right: right_106, body: this.enforestStatement()});\n        }\n        enf_102.matchPunctuator(\";\");\n        if (enf_102.isPunctuator(enf_102.peek(), \";\")) {\n          enf_102.advance();\n          test_104 = null;\n        } else {\n          test_104 = enf_102.enforestExpression();\n          enf_102.matchPunctuator(\";\");\n        }\n        update_109 = enf_102.enforestExpression();\n      } else {\n        if (this.isKeyword(enf_102.peek(1), \"in\") || this.isIdentifier(enf_102.peek(1), \"of\")) {\n          left_108 = enf_102.enforestBindingIdentifier();\n          let kind = enf_102.advance();\n          if (this.isKeyword(kind, \"in\")) {\n            type_107 = \"ForInStatement\";\n          } else {\n            type_107 = \"ForOfStatement\";\n          }\n          right_106 = enf_102.enforestExpression();\n          return new Term(type_107, {left: left_108, right: right_106, body: this.enforestStatement()});\n        }\n        init_105 = enf_102.enforestExpression();\n        enf_102.matchPunctuator(\";\");\n        if (enf_102.isPunctuator(enf_102.peek(), \";\")) {\n          enf_102.advance();\n          test_104 = null;\n        } else {\n          test_104 = enf_102.enforestExpression();\n          enf_102.matchPunctuator(\";\");\n        }\n        update_109 = enf_102.enforestExpression();\n      }\n      return new Term(\"ForStatement\", {init: init_105, test: test_104, update: update_109, body: this.enforestStatement()});\n    }\n  }\n  enforestIfStatement() {\n    this.matchKeyword(\"if\");\n    let cond_110 = this.matchParens();\n    let enf_111 = new Enforester_46(cond_110, List(), this.context);\n    let lookahead_112 = enf_111.peek();\n    let test_113 = enf_111.enforestExpression();\n    if (test_113 === null) {\n      throw enf_111.createError(lookahead_112, \"expecting an expression\");\n    }\n    let consequent_114 = this.enforestStatement();\n    let alternate_115 = null;\n    if (this.isKeyword(this.peek(), \"else\")) {\n      this.advance();\n      alternate_115 = this.enforestStatement();\n    }\n    return new Term(\"IfStatement\", {test: test_113, consequent: consequent_114, alternate: alternate_115});\n  }\n  enforestWhileStatement() {\n    this.matchKeyword(\"while\");\n    let cond_116 = this.matchParens();\n    let enf_117 = new Enforester_46(cond_116, List(), this.context);\n    let lookahead_118 = enf_117.peek();\n    let test_119 = enf_117.enforestExpression();\n    if (test_119 === null) {\n      throw enf_117.createError(lookahead_118, \"expecting an expression\");\n    }\n    let body_120 = this.enforestStatement();\n    return new Term(\"WhileStatement\", {test: test_119, body: body_120});\n  }\n  enforestBlockStatement() {\n    return new Term(\"BlockStatement\", {block: this.enforestBlock()});\n  }\n  enforestBlock() {\n    return new Term(\"Block\", {statements: this.matchCurlies()});\n  }\n  enforestClass({isExpr, inDefault}) {\n    let kw_121 = this.advance();\n    let name_122 = null, supr_123 = null;\n    let type_124 = isExpr ? \"ClassExpression\" : \"ClassDeclaration\";\n    if (this.isIdentifier(this.peek())) {\n      name_122 = this.enforestBindingIdentifier();\n    } else if (!isExpr) {\n      if (inDefault) {\n        name_122 = new Term(\"BindingIdentifier\", {name: Syntax.fromIdentifier(\"_default\", kw_121)});\n      } else {\n        throw this.createError(this.peek(), \"unexpected syntax\");\n      }\n    }\n    if (this.isKeyword(this.peek(), \"extends\")) {\n      this.advance();\n      supr_123 = this.enforestExpressionLoop();\n    }\n    let elements_125 = [];\n    let enf_126 = new Enforester_46(this.matchCurlies(), List(), this.context);\n    while (enf_126.rest.size !== 0) {\n      if (enf_126.isPunctuator(enf_126.peek(), \";\")) {\n        enf_126.advance();\n        continue;\n      }\n      let isStatic = false;\n      let {methodOrKey, kind} = enf_126.enforestMethodDefinition();\n      if (kind === \"identifier\" && methodOrKey.value.val() === \"static\") {\n        isStatic = true;\n        ({methodOrKey, kind} = enf_126.enforestMethodDefinition());\n      }\n      if (kind === \"method\") {\n        elements_125.push(new Term(\"ClassElement\", {isStatic: isStatic, method: methodOrKey}));\n      } else {\n        throw this.createError(enf_126.peek(), \"Only methods are allowed in classes\");\n      }\n    }\n    return new Term(type_124, {name: name_122, super: supr_123, elements: List(elements_125)});\n  }\n  enforestBindingTarget({allowPunctuator} = {}) {\n    let lookahead_127 = this.peek();\n    if (this.isIdentifier(lookahead_127) || this.isKeyword(lookahead_127) || allowPunctuator && this.isPunctuator(lookahead_127)) {\n      return this.enforestBindingIdentifier({allowPunctuator: allowPunctuator});\n    } else if (this.isBrackets(lookahead_127)) {\n      return this.enforestArrayBinding();\n    } else if (this.isBraces(lookahead_127)) {\n      return this.enforestObjectBinding();\n    }\n    assert(false, \"not implemented yet\");\n  }\n  enforestObjectBinding() {\n    let enf_128 = new Enforester_46(this.matchCurlies(), List(), this.context);\n    let properties_129 = [];\n    while (enf_128.rest.size !== 0) {\n      properties_129.push(enf_128.enforestBindingProperty());\n      enf_128.consumeComma();\n    }\n    return new Term(\"ObjectBinding\", {properties: List(properties_129)});\n  }\n  enforestBindingProperty() {\n    let lookahead_130 = this.peek();\n    let {name, binding} = this.enforestPropertyName();\n    if (this.isIdentifier(lookahead_130) || this.isKeyword(lookahead_130, \"let\") || this.isKeyword(lookahead_130, \"yield\")) {\n      if (!this.isPunctuator(this.peek(), \":\")) {\n        let defaultValue = null;\n        if (this.isAssign(this.peek())) {\n          this.advance();\n          let expr = this.enforestExpressionLoop();\n          defaultValue = expr;\n        }\n        return new Term(\"BindingPropertyIdentifier\", {binding: binding, init: defaultValue});\n      }\n    }\n    this.matchPunctuator(\":\");\n    binding = this.enforestBindingElement();\n    return new Term(\"BindingPropertyProperty\", {name: name, binding: binding});\n  }\n  enforestArrayBinding() {\n    let bracket_131 = this.matchSquares();\n    let enf_132 = new Enforester_46(bracket_131, List(), this.context);\n    let elements_133 = [], restElement_134 = null;\n    while (enf_132.rest.size !== 0) {\n      let el;\n      if (enf_132.isPunctuator(enf_132.peek(), \",\")) {\n        enf_132.consumeComma();\n        el = null;\n      } else {\n        if (enf_132.isPunctuator(enf_132.peek(), \"...\")) {\n          enf_132.advance();\n          restElement_134 = enf_132.enforestBindingTarget();\n          break;\n        } else {\n          el = enf_132.enforestBindingElement();\n        }\n        enf_132.consumeComma();\n      }\n      elements_133.push(el);\n    }\n    return new Term(\"ArrayBinding\", {elements: List(elements_133), restElement: restElement_134});\n  }\n  enforestBindingElement() {\n    let binding_135 = this.enforestBindingTarget();\n    if (this.isAssign(this.peek())) {\n      this.advance();\n      let init = this.enforestExpressionLoop();\n      binding_135 = new Term(\"BindingWithDefault\", {binding: binding_135, init: init});\n    }\n    return binding_135;\n  }\n  enforestBindingIdentifier({allowPunctuator} = {}) {\n    let name_136;\n    if (allowPunctuator && this.isPunctuator(this.peek())) {\n      name_136 = this.enforestPunctuator();\n    } else {\n      name_136 = this.enforestIdentifier();\n    }\n    return new Term(\"BindingIdentifier\", {name: name_136});\n  }\n  enforestPunctuator() {\n    let lookahead_137 = this.peek();\n    if (this.isPunctuator(lookahead_137)) {\n      return this.advance();\n    }\n    throw this.createError(lookahead_137, \"expecting a punctuator\");\n  }\n  enforestIdentifier() {\n    let lookahead_138 = this.peek();\n    if (this.isIdentifier(lookahead_138) || this.isKeyword(lookahead_138)) {\n      return this.advance();\n    }\n    throw this.createError(lookahead_138, \"expecting an identifier\");\n  }\n  enforestReturnStatement() {\n    let kw_139 = this.advance();\n    let lookahead_140 = this.peek();\n    if (this.rest.size === 0 || lookahead_140 && !this.lineNumberEq(kw_139, lookahead_140)) {\n      return new Term(\"ReturnStatement\", {expression: null});\n    }\n    let term_141 = null;\n    if (!this.isPunctuator(lookahead_140, \";\")) {\n      term_141 = this.enforestExpression();\n      expect(term_141 != null, \"Expecting an expression to follow return keyword\", lookahead_140, this.rest);\n    }\n    this.consumeSemicolon();\n    return new Term(\"ReturnStatement\", {expression: term_141});\n  }\n  enforestVariableDeclaration() {\n    let kind_142;\n    let lookahead_143 = this.advance();\n    let kindSyn_144 = lookahead_143;\n    let phase_145 = this.context.phase;\n    if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === VariableDeclTransform) {\n      kind_142 = \"var\";\n    } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === LetDeclTransform) {\n      kind_142 = \"let\";\n    } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === ConstDeclTransform) {\n      kind_142 = \"const\";\n    } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === SyntaxDeclTransform) {\n      kind_142 = \"syntax\";\n    } else if (kindSyn_144 && this.context.env.get(kindSyn_144.resolve(phase_145)) === SyntaxrecDeclTransform) {\n      kind_142 = \"syntaxrec\";\n    }\n    let decls_146 = List();\n    while (true) {\n      let term = this.enforestVariableDeclarator({isSyntax: kind_142 === \"syntax\" || kind_142 === \"syntaxrec\"});\n      let lookahead_143 = this.peek();\n      decls_146 = decls_146.concat(term);\n      if (this.isPunctuator(lookahead_143, \",\")) {\n        this.advance();\n      } else {\n        break;\n      }\n    }\n    return new Term(\"VariableDeclaration\", {kind: kind_142, declarators: decls_146});\n  }\n  enforestVariableDeclarator({isSyntax}) {\n    let id_147 = this.enforestBindingTarget({allowPunctuator: isSyntax});\n    let lookahead_148 = this.peek();\n    let init_149, rest_150;\n    if (this.isPunctuator(lookahead_148, \"=\")) {\n      this.advance();\n      let enf = new Enforester_46(this.rest, List(), this.context);\n      init_149 = enf.enforest(\"expression\");\n      this.rest = enf.rest;\n    } else {\n      init_149 = null;\n    }\n    return new Term(\"VariableDeclarator\", {binding: id_147, init: init_149});\n  }\n  enforestExpressionStatement() {\n    let start_151 = this.rest.get(0);\n    let expr_152 = this.enforestExpression();\n    if (expr_152 === null) {\n      throw this.createError(start_151, \"not a valid expression\");\n    }\n    this.consumeSemicolon();\n    return new Term(\"ExpressionStatement\", {expression: expr_152});\n  }\n  enforestExpression() {\n    let left_153 = this.enforestExpressionLoop();\n    let lookahead_154 = this.peek();\n    if (this.isPunctuator(lookahead_154, \",\")) {\n      while (this.rest.size !== 0) {\n        if (!this.isPunctuator(this.peek(), \",\")) {\n          break;\n        }\n        let operator = this.advance();\n        let right = this.enforestExpressionLoop();\n        left_153 = new Term(\"BinaryExpression\", {left: left_153, operator: operator, right: right});\n      }\n    }\n    this.term = null;\n    return left_153;\n  }\n  enforestExpressionLoop() {\n    this.term = null;\n    this.opCtx = {prec: 0, combine: x_155 => x_155, stack: List()};\n    do {\n      let term = this.enforestAssignmentExpression();\n      if (term === EXPR_LOOP_NO_CHANGE_44 && this.opCtx.stack.size > 0) {\n        this.term = this.opCtx.combine(this.term);\n        let {prec, combine} = this.opCtx.stack.last();\n        this.opCtx.prec = prec;\n        this.opCtx.combine = combine;\n        this.opCtx.stack = this.opCtx.stack.pop();\n      } else if (term === EXPR_LOOP_NO_CHANGE_44) {\n        break;\n      } else if (term === EXPR_LOOP_OPERATOR_43 || term === EXPR_LOOP_EXPANSION_45) {\n        this.term = null;\n      } else {\n        this.term = term;\n      }\n    } while (true);\n    return this.term;\n  }\n  enforestAssignmentExpression() {\n    let lookahead_156 = this.peek();\n    if (this.term === null && this.isCompiletimeTransform(lookahead_156)) {\n      this.expandMacro();\n      lookahead_156 = this.peek();\n    }\n    if (this.term === null && this.isTerm(lookahead_156)) {\n      return this.advance();\n    }\n    if (this.term === null && this.isKeyword(lookahead_156, \"yield\")) {\n      return this.enforestYieldExpression();\n    }\n    if (this.term === null && this.isKeyword(lookahead_156, \"class\")) {\n      return this.enforestClass({isExpr: true});\n    }\n    if (this.term === null && (this.isIdentifier(lookahead_156) || this.isParens(lookahead_156)) && this.isPunctuator(this.peek(1), \"=>\") && this.lineNumberEq(lookahead_156, this.peek(1))) {\n      return this.enforestArrowExpression();\n    }\n    if (this.term === null && this.isSyntaxTemplate(lookahead_156)) {\n      return this.enforestSyntaxTemplate();\n    }\n    if (this.term === null && this.isSyntaxQuoteTransform(lookahead_156)) {\n      return this.enforestSyntaxQuote();\n    }\n    if (this.term === null && this.isParens(lookahead_156)) {\n      return new Term(\"ParenthesizedExpression\", {inner: this.advance().inner()});\n    }\n    if (this.term === null && (this.isKeyword(lookahead_156, \"this\") || this.isIdentifier(lookahead_156) || this.isKeyword(lookahead_156, \"let\") || this.isKeyword(lookahead_156, \"yield\") || this.isNumericLiteral(lookahead_156) || this.isStringLiteral(lookahead_156) || this.isTemplate(lookahead_156) || this.isBooleanLiteral(lookahead_156) || this.isNullLiteral(lookahead_156) || this.isRegularExpression(lookahead_156) || this.isFnDeclTransform(lookahead_156) || this.isBraces(lookahead_156) || this.isBrackets(lookahead_156))) {\n      return this.enforestPrimaryExpression();\n    }\n    if (this.term === null && this.isOperator(lookahead_156)) {\n      return this.enforestUnaryExpression();\n    }\n    if (this.term === null && this.isVarBindingTransform(lookahead_156)) {\n      let id = this.getFromCompiletimeEnvironment(lookahead_156).id;\n      if (id !== lookahead_156) {\n        this.advance();\n        this.rest = List.of(id).concat(this.rest);\n        return EXPR_LOOP_EXPANSION_45;\n      }\n    }\n    if (this.term === null && (this.isNewTransform(lookahead_156) || this.isKeyword(lookahead_156, \"super\")) || this.term && (this.isPunctuator(lookahead_156, \".\") && (this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1))) || this.isBrackets(lookahead_156) || this.isParens(lookahead_156))) {\n      return this.enforestLeftHandSideExpression({allowCall: true});\n    }\n    if (this.term && this.isTemplate(lookahead_156)) {\n      return this.enforestTemplateLiteral();\n    }\n    if (this.term && this.isUpdateOperator(lookahead_156)) {\n      return this.enforestUpdateExpression();\n    }\n    if (this.term && this.isOperator(lookahead_156)) {\n      return this.enforestBinaryExpression();\n    }\n    if (this.term && this.isAssign(lookahead_156)) {\n      let binding = this.transformDestructuring(this.term);\n      let op = this.advance();\n      let enf = new Enforester_46(this.rest, List(), this.context);\n      let init = enf.enforest(\"expression\");\n      this.rest = enf.rest;\n      if (op.val() === \"=\") {\n        return new Term(\"AssignmentExpression\", {binding: binding, expression: init});\n      } else {\n        return new Term(\"CompoundAssignmentExpression\", {binding: binding, operator: op.val(), expression: init});\n      }\n    }\n    if (this.term && this.isPunctuator(lookahead_156, \"?\")) {\n      return this.enforestConditionalExpression();\n    }\n    return EXPR_LOOP_NO_CHANGE_44;\n  }\n  enforestPrimaryExpression() {\n    let lookahead_157 = this.peek();\n    if (this.term === null && this.isKeyword(lookahead_157, \"this\")) {\n      return this.enforestThisExpression();\n    }\n    if (this.term === null && (this.isIdentifier(lookahead_157) || this.isKeyword(lookahead_157, \"let\") || this.isKeyword(lookahead_157, \"yield\"))) {\n      return this.enforestIdentifierExpression();\n    }\n    if (this.term === null && this.isNumericLiteral(lookahead_157)) {\n      return this.enforestNumericLiteral();\n    }\n    if (this.term === null && this.isStringLiteral(lookahead_157)) {\n      return this.enforestStringLiteral();\n    }\n    if (this.term === null && this.isTemplate(lookahead_157)) {\n      return this.enforestTemplateLiteral();\n    }\n    if (this.term === null && this.isBooleanLiteral(lookahead_157)) {\n      return this.enforestBooleanLiteral();\n    }\n    if (this.term === null && this.isNullLiteral(lookahead_157)) {\n      return this.enforestNullLiteral();\n    }\n    if (this.term === null && this.isRegularExpression(lookahead_157)) {\n      return this.enforestRegularExpressionLiteral();\n    }\n    if (this.term === null && this.isFnDeclTransform(lookahead_157)) {\n      return this.enforestFunctionExpression();\n    }\n    if (this.term === null && this.isBraces(lookahead_157)) {\n      return this.enforestObjectExpression();\n    }\n    if (this.term === null && this.isBrackets(lookahead_157)) {\n      return this.enforestArrayExpression();\n    }\n    assert(false, \"Not a primary expression\");\n  }\n  enforestLeftHandSideExpression({allowCall}) {\n    let lookahead_158 = this.peek();\n    if (this.isKeyword(lookahead_158, \"super\")) {\n      this.advance();\n      this.term = new Term(\"Super\", {});\n    } else if (this.isNewTransform(lookahead_158)) {\n      this.term = this.enforestNewExpression();\n    }\n    while (true) {\n      lookahead_158 = this.peek();\n      if (this.isParens(lookahead_158)) {\n        if (!allowCall) {\n          if (this.term && isIdentifierExpression(this.term)) {\n            return this.term;\n          }\n          this.term = this.enforestExpressionLoop();\n        } else {\n          this.term = this.enforestCallExpression();\n        }\n      } else if (this.isBrackets(lookahead_158)) {\n        this.term = allowCall ? this.enforestComputedMemberExpression() : this.enforestExpressionLoop();\n      } else if (this.isPunctuator(lookahead_158, \".\") && (this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1)))) {\n        this.term = this.enforestStaticMemberExpression();\n      } else if (this.isTemplate(lookahead_158)) {\n        this.term = this.enforestTemplateLiteral();\n      } else if (this.isBraces(lookahead_158)) {\n        this.term = this.enforestPrimaryExpression();\n      } else if (this.isIdentifier(lookahead_158)) {\n        this.term = new Term(\"IdentifierExpression\", {name: this.enforestIdentifier()});\n      } else {\n        break;\n      }\n    }\n    return this.term;\n  }\n  enforestBooleanLiteral() {\n    return new Term(\"LiteralBooleanExpression\", {value: this.advance()});\n  }\n  enforestTemplateLiteral() {\n    return new Term(\"TemplateExpression\", {tag: this.term, elements: this.enforestTemplateElements()});\n  }\n  enforestStringLiteral() {\n    return new Term(\"LiteralStringExpression\", {value: this.advance()});\n  }\n  enforestNumericLiteral() {\n    let num_159 = this.advance();\n    if (num_159.val() === 1 / 0) {\n      return new Term(\"LiteralInfinityExpression\", {});\n    }\n    return new Term(\"LiteralNumericExpression\", {value: num_159});\n  }\n  enforestIdentifierExpression() {\n    return new Term(\"IdentifierExpression\", {name: this.advance()});\n  }\n  enforestRegularExpressionLiteral() {\n    let reStx_160 = this.advance();\n    let lastSlash_161 = reStx_160.token.value.lastIndexOf(\"/\");\n    let pattern_162 = reStx_160.token.value.slice(1, lastSlash_161);\n    let flags_163 = reStx_160.token.value.slice(lastSlash_161 + 1);\n    return new Term(\"LiteralRegExpExpression\", {pattern: pattern_162, flags: flags_163});\n  }\n  enforestNullLiteral() {\n    this.advance();\n    return new Term(\"LiteralNullExpression\", {});\n  }\n  enforestThisExpression() {\n    return new Term(\"ThisExpression\", {stx: this.advance()});\n  }\n  enforestArgumentList() {\n    let result_164 = [];\n    while (this.rest.size > 0) {\n      let arg;\n      if (this.isPunctuator(this.peek(), \"...\")) {\n        this.advance();\n        arg = new Term(\"SpreadElement\", {expression: this.enforestExpressionLoop()});\n      } else {\n        arg = this.enforestExpressionLoop();\n      }\n      if (this.rest.size > 0) {\n        this.matchPunctuator(\",\");\n      }\n      result_164.push(arg);\n    }\n    return List(result_164);\n  }\n  enforestNewExpression() {\n    this.matchKeyword(\"new\");\n    if (this.isPunctuator(this.peek(), \".\") && this.isIdentifier(this.peek(1), \"target\")) {\n      this.advance();\n      this.advance();\n      return new Term(\"NewTargetExpression\", {});\n    }\n    let callee_165 = this.enforestLeftHandSideExpression({allowCall: false});\n    let args_166;\n    if (this.isParens(this.peek())) {\n      args_166 = this.matchParens();\n    } else {\n      args_166 = List();\n    }\n    return new Term(\"NewExpression\", {callee: callee_165, arguments: args_166});\n  }\n  enforestComputedMemberExpression() {\n    let enf_167 = new Enforester_46(this.matchSquares(), List(), this.context);\n    return new Term(\"ComputedMemberExpression\", {object: this.term, expression: enf_167.enforestExpression()});\n  }\n  transformDestructuring(term_168) {\n    switch (term_168.type) {\n      case \"IdentifierExpression\":\n        return new Term(\"BindingIdentifier\", {name: term_168.name});\n      case \"ParenthesizedExpression\":\n        if (term_168.inner.size === 1 && this.isIdentifier(term_168.inner.get(0))) {\n          return new Term(\"BindingIdentifier\", {name: term_168.inner.get(0)});\n        }\n      case \"DataProperty\":\n        return new Term(\"BindingPropertyProperty\", {name: term_168.name, binding: this.transformDestructuringWithDefault(term_168.expression)});\n      case \"ShorthandProperty\":\n        return new Term(\"BindingPropertyIdentifier\", {binding: new Term(\"BindingIdentifier\", {name: term_168.name}), init: null});\n      case \"ObjectExpression\":\n        return new Term(\"ObjectBinding\", {properties: term_168.properties.map(t_169 => this.transformDestructuring(t_169))});\n      case \"ArrayExpression\":\n        let last = term_168.elements.last();\n        if (last != null && last.type === \"SpreadElement\") {\n          return new Term(\"ArrayBinding\", {elements: term_168.elements.slice(0, -1).map(t_170 => t_170 && this.transformDestructuringWithDefault(t_170)), restElement: this.transformDestructuringWithDefault(last.expression)});\n        } else {\n          return new Term(\"ArrayBinding\", {elements: term_168.elements.map(t_171 => t_171 && this.transformDestructuringWithDefault(t_171)), restElement: null});\n        }\n        return new Term(\"ArrayBinding\", {elements: term_168.elements.map(t_172 => t_172 && this.transformDestructuring(t_172)), restElement: null});\n      case \"StaticPropertyName\":\n        return new Term(\"BindingIdentifier\", {name: term_168.value});\n      case \"ComputedMemberExpression\":\n      case \"StaticMemberExpression\":\n      case \"ArrayBinding\":\n      case \"BindingIdentifier\":\n      case \"BindingPropertyIdentifier\":\n      case \"BindingPropertyProperty\":\n      case \"BindingWithDefault\":\n      case \"ObjectBinding\":\n        return term_168;\n    }\n    assert(false, \"not implemented yet for \" + term_168.type);\n  }\n  transformDestructuringWithDefault(term_173) {\n    switch (term_173.type) {\n      case \"AssignmentExpression\":\n        return new Term(\"BindingWithDefault\", {binding: this.transformDestructuring(term_173.binding), init: term_173.expression});\n    }\n    return this.transformDestructuring(term_173);\n  }\n  enforestCallExpression() {\n    let paren_174 = this.advance();\n    return new Term(\"CallExpression\", {callee: this.term, arguments: paren_174.inner()});\n  }\n  enforestArrowExpression() {\n    let enf_175;\n    if (this.isIdentifier(this.peek())) {\n      enf_175 = new Enforester_46(List.of(this.advance()), List(), this.context);\n    } else {\n      let p = this.matchParens();\n      enf_175 = new Enforester_46(p, List(), this.context);\n    }\n    let params_176 = enf_175.enforestFormalParameters();\n    this.matchPunctuator(\"=>\");\n    let body_177;\n    if (this.isBraces(this.peek())) {\n      body_177 = this.matchCurlies();\n    } else {\n      enf_175 = new Enforester_46(this.rest, List(), this.context);\n      body_177 = enf_175.enforestExpressionLoop();\n      this.rest = enf_175.rest;\n    }\n    return new Term(\"ArrowExpression\", {params: params_176, body: body_177});\n  }\n  enforestYieldExpression() {\n    let kwd_178 = this.matchKeyword(\"yield\");\n    let lookahead_179 = this.peek();\n    if (this.rest.size === 0 || lookahead_179 && !this.lineNumberEq(kwd_178, lookahead_179)) {\n      return new Term(\"YieldExpression\", {expression: null});\n    } else {\n      let isGenerator = false;\n      if (this.isPunctuator(this.peek(), \"*\")) {\n        isGenerator = true;\n        this.advance();\n      }\n      let expr = this.enforestExpression();\n      let type = isGenerator ? \"YieldGeneratorExpression\" : \"YieldExpression\";\n      return new Term(type, {expression: expr});\n    }\n  }\n  enforestSyntaxTemplate() {\n    return new Term(\"SyntaxTemplate\", {template: this.advance()});\n  }\n  enforestSyntaxQuote() {\n    let name_180 = this.advance();\n    return new Term(\"SyntaxQuote\", {name: name_180, template: new Term(\"TemplateExpression\", {tag: new Term(\"IdentifierExpression\", {name: name_180}), elements: this.enforestTemplateElements()})});\n  }\n  enforestStaticMemberExpression() {\n    let object_181 = this.term;\n    let dot_182 = this.advance();\n    let property_183 = this.advance();\n    return new Term(\"StaticMemberExpression\", {object: object_181, property: property_183});\n  }\n  enforestArrayExpression() {\n    let arr_184 = this.advance();\n    let elements_185 = [];\n    let enf_186 = new Enforester_46(arr_184.inner(), List(), this.context);\n    while (enf_186.rest.size > 0) {\n      let lookahead = enf_186.peek();\n      if (enf_186.isPunctuator(lookahead, \",\")) {\n        enf_186.advance();\n        elements_185.push(null);\n      } else if (enf_186.isPunctuator(lookahead, \"...\")) {\n        enf_186.advance();\n        let expression = enf_186.enforestExpressionLoop();\n        if (expression == null) {\n          throw enf_186.createError(lookahead, \"expecting expression\");\n        }\n        elements_185.push(new Term(\"SpreadElement\", {expression: expression}));\n      } else {\n        let term = enf_186.enforestExpressionLoop();\n        if (term == null) {\n          throw enf_186.createError(lookahead, \"expected expression\");\n        }\n        elements_185.push(term);\n        enf_186.consumeComma();\n      }\n    }\n    return new Term(\"ArrayExpression\", {elements: List(elements_185)});\n  }\n  enforestObjectExpression() {\n    let obj_187 = this.advance();\n    let properties_188 = List();\n    let enf_189 = new Enforester_46(obj_187.inner(), List(), this.context);\n    let lastProp_190 = null;\n    while (enf_189.rest.size > 0) {\n      let prop = enf_189.enforestPropertyDefinition();\n      enf_189.consumeComma();\n      properties_188 = properties_188.concat(prop);\n      if (lastProp_190 === prop) {\n        throw enf_189.createError(prop, \"invalid syntax in object\");\n      }\n      lastProp_190 = prop;\n    }\n    return new Term(\"ObjectExpression\", {properties: properties_188});\n  }\n  enforestPropertyDefinition() {\n    let {methodOrKey, kind} = this.enforestMethodDefinition();\n    switch (kind) {\n      case \"method\":\n        return methodOrKey;\n      case \"identifier\":\n        if (this.isAssign(this.peek())) {\n          this.advance();\n          let init = this.enforestExpressionLoop();\n          return new Term(\"BindingPropertyIdentifier\", {init: init, binding: this.transformDestructuring(methodOrKey)});\n        } else if (!this.isPunctuator(this.peek(), \":\")) {\n          return new Term(\"ShorthandProperty\", {name: methodOrKey.value});\n        }\n    }\n    this.matchPunctuator(\":\");\n    let expr_191 = this.enforestExpressionLoop();\n    return new Term(\"DataProperty\", {name: methodOrKey, expression: expr_191});\n  }\n  enforestMethodDefinition() {\n    let lookahead_192 = this.peek();\n    let isGenerator_193 = false;\n    if (this.isPunctuator(lookahead_192, \"*\")) {\n      isGenerator_193 = true;\n      this.advance();\n    }\n    if (this.isIdentifier(lookahead_192, \"get\") && this.isPropertyName(this.peek(1))) {\n      this.advance();\n      let {name} = this.enforestPropertyName();\n      this.matchParens();\n      let body = this.matchCurlies();\n      return {methodOrKey: new Term(\"Getter\", {name: name, body: body}), kind: \"method\"};\n    } else if (this.isIdentifier(lookahead_192, \"set\") && this.isPropertyName(this.peek(1))) {\n      this.advance();\n      let {name} = this.enforestPropertyName();\n      let enf = new Enforester_46(this.matchParens(), List(), this.context);\n      let param = enf.enforestBindingElement();\n      let body = this.matchCurlies();\n      return {methodOrKey: new Term(\"Setter\", {name: name, param: param, body: body}), kind: \"method\"};\n    }\n    let {name} = this.enforestPropertyName();\n    if (this.isParens(this.peek())) {\n      let params = this.matchParens();\n      let enf = new Enforester_46(params, List(), this.context);\n      let formalParams = enf.enforestFormalParameters();\n      let body = this.matchCurlies();\n      return {methodOrKey: new Term(\"Method\", {isGenerator: isGenerator_193, name: name, params: formalParams, body: body}), kind: \"method\"};\n    }\n    return {methodOrKey: name, kind: this.isIdentifier(lookahead_192) || this.isKeyword(lookahead_192) ? \"identifier\" : \"property\"};\n  }\n  enforestPropertyName() {\n    let lookahead_194 = this.peek();\n    if (this.isStringLiteral(lookahead_194) || this.isNumericLiteral(lookahead_194)) {\n      return {name: new Term(\"StaticPropertyName\", {value: this.advance()}), binding: null};\n    } else if (this.isBrackets(lookahead_194)) {\n      let enf = new Enforester_46(this.matchSquares(), List(), this.context);\n      let expr = enf.enforestExpressionLoop();\n      return {name: new Term(\"ComputedPropertyName\", {expression: expr}), binding: null};\n    }\n    let name_195 = this.advance();\n    return {name: new Term(\"StaticPropertyName\", {value: name_195}), binding: new Term(\"BindingIdentifier\", {name: name_195})};\n  }\n  enforestFunction({isExpr, inDefault, allowGenerator}) {\n    let name_196 = null, params_197, body_198, rest_199;\n    let isGenerator_200 = false;\n    let fnKeyword_201 = this.advance();\n    let lookahead_202 = this.peek();\n    let type_203 = isExpr ? \"FunctionExpression\" : \"FunctionDeclaration\";\n    if (this.isPunctuator(lookahead_202, \"*\")) {\n      isGenerator_200 = true;\n      this.advance();\n      lookahead_202 = this.peek();\n    }\n    if (!this.isParens(lookahead_202)) {\n      name_196 = this.enforestBindingIdentifier();\n    } else if (inDefault) {\n      name_196 = new Term(\"BindingIdentifier\", {name: Syntax.fromIdentifier(\"*default*\", fnKeyword_201)});\n    }\n    params_197 = this.matchParens();\n    body_198 = this.matchCurlies();\n    let enf_204 = new Enforester_46(params_197, List(), this.context);\n    let formalParams_205 = enf_204.enforestFormalParameters();\n    return new Term(type_203, {name: name_196, isGenerator: isGenerator_200, params: formalParams_205, body: body_198});\n  }\n  enforestFunctionExpression() {\n    let name_206 = null, params_207, body_208, rest_209;\n    let isGenerator_210 = false;\n    this.advance();\n    let lookahead_211 = this.peek();\n    if (this.isPunctuator(lookahead_211, \"*\")) {\n      isGenerator_210 = true;\n      this.advance();\n      lookahead_211 = this.peek();\n    }\n    if (!this.isParens(lookahead_211)) {\n      name_206 = this.enforestBindingIdentifier();\n    }\n    params_207 = this.matchParens();\n    body_208 = this.matchCurlies();\n    let enf_212 = new Enforester_46(params_207, List(), this.context);\n    let formalParams_213 = enf_212.enforestFormalParameters();\n    return new Term(\"FunctionExpression\", {name: name_206, isGenerator: isGenerator_210, params: formalParams_213, body: body_208});\n  }\n  enforestFunctionDeclaration() {\n    let name_214, params_215, body_216, rest_217;\n    let isGenerator_218 = false;\n    this.advance();\n    let lookahead_219 = this.peek();\n    if (this.isPunctuator(lookahead_219, \"*\")) {\n      isGenerator_218 = true;\n      this.advance();\n    }\n    name_214 = this.enforestBindingIdentifier();\n    params_215 = this.matchParens();\n    body_216 = this.matchCurlies();\n    let enf_220 = new Enforester_46(params_215, List(), this.context);\n    let formalParams_221 = enf_220.enforestFormalParameters();\n    return new Term(\"FunctionDeclaration\", {name: name_214, isGenerator: isGenerator_218, params: formalParams_221, body: body_216});\n  }\n  enforestFormalParameters() {\n    let items_222 = [];\n    let rest_223 = null;\n    while (this.rest.size !== 0) {\n      let lookahead = this.peek();\n      if (this.isPunctuator(lookahead, \"...\")) {\n        this.matchPunctuator(\"...\");\n        rest_223 = this.enforestBindingIdentifier();\n        break;\n      }\n      items_222.push(this.enforestParam());\n      this.consumeComma();\n    }\n    return new Term(\"FormalParameters\", {items: List(items_222), rest: rest_223});\n  }\n  enforestParam() {\n    return this.enforestBindingElement();\n  }\n  enforestUpdateExpression() {\n    let operator_224 = this.matchUnaryOperator();\n    return new Term(\"UpdateExpression\", {isPrefix: false, operator: operator_224.val(), operand: this.transformDestructuring(this.term)});\n  }\n  enforestUnaryExpression() {\n    let operator_225 = this.matchUnaryOperator();\n    this.opCtx.stack = this.opCtx.stack.push({prec: this.opCtx.prec, combine: this.opCtx.combine});\n    this.opCtx.prec = 14;\n    this.opCtx.combine = rightTerm_226 => {\n      let type_227, term_228, isPrefix_229;\n      if (operator_225.val() === \"++\" || operator_225.val() === \"--\") {\n        type_227 = \"UpdateExpression\";\n        term_228 = this.transformDestructuring(rightTerm_226);\n        isPrefix_229 = true;\n      } else {\n        type_227 = \"UnaryExpression\";\n        isPrefix_229 = undefined;\n        term_228 = rightTerm_226;\n      }\n      return new Term(type_227, {operator: operator_225.val(), operand: term_228, isPrefix: isPrefix_229});\n    };\n    return EXPR_LOOP_OPERATOR_43;\n  }\n  enforestConditionalExpression() {\n    let test_230 = this.opCtx.combine(this.term);\n    if (this.opCtx.stack.size > 0) {\n      let {prec, combine} = this.opCtx.stack.last();\n      this.opCtx.stack = this.opCtx.stack.pop();\n      this.opCtx.prec = prec;\n      this.opCtx.combine = combine;\n    }\n    this.matchPunctuator(\"?\");\n    let enf_231 = new Enforester_46(this.rest, List(), this.context);\n    let consequent_232 = enf_231.enforestExpressionLoop();\n    enf_231.matchPunctuator(\":\");\n    enf_231 = new Enforester_46(enf_231.rest, List(), this.context);\n    let alternate_233 = enf_231.enforestExpressionLoop();\n    this.rest = enf_231.rest;\n    return new Term(\"ConditionalExpression\", {test: test_230, consequent: consequent_232, alternate: alternate_233});\n  }\n  enforestBinaryExpression() {\n    let leftTerm_234 = this.term;\n    let opStx_235 = this.peek();\n    let op_236 = opStx_235.val();\n    let opPrec_237 = getOperatorPrec(op_236);\n    let opAssoc_238 = getOperatorAssoc(op_236);\n    if (operatorLt(this.opCtx.prec, opPrec_237, opAssoc_238)) {\n      this.opCtx.stack = this.opCtx.stack.push({prec: this.opCtx.prec, combine: this.opCtx.combine});\n      this.opCtx.prec = opPrec_237;\n      this.opCtx.combine = rightTerm_239 => {\n        return new Term(\"BinaryExpression\", {left: leftTerm_234, operator: opStx_235, right: rightTerm_239});\n      };\n      this.advance();\n      return EXPR_LOOP_OPERATOR_43;\n    } else {\n      let term = this.opCtx.combine(leftTerm_234);\n      let {prec, combine} = this.opCtx.stack.last();\n      this.opCtx.stack = this.opCtx.stack.pop();\n      this.opCtx.prec = prec;\n      this.opCtx.combine = combine;\n      return term;\n    }\n  }\n  enforestTemplateElements() {\n    let lookahead_240 = this.matchTemplate();\n    let elements_241 = lookahead_240.token.items.map(it_242 => {\n      if (this.isDelimiter(it_242)) {\n        let enf = new Enforester_46(it_242.inner(), List(), this.context);\n        return enf.enforest(\"expression\");\n      }\n      return new Term(\"TemplateElement\", {rawValue: it_242.slice.text});\n    });\n    return elements_241;\n  }\n  expandMacro() {\n    let lookahead_243 = this.peek();\n    while (this.isCompiletimeTransform(lookahead_243)) {\n      let name = this.advance();\n      let syntaxTransform = this.getFromCompiletimeEnvironment(name);\n      if (syntaxTransform == null || typeof syntaxTransform.value !== \"function\") {\n        throw this.createError(name, \"the macro name was not bound to a value that could be invoked\");\n      }\n      let useSiteScope = freshScope(\"u\");\n      let introducedScope = freshScope(\"i\");\n      this.context.useScope = useSiteScope;\n      let ctx = new MacroContext(this, name, this.context, useSiteScope, introducedScope);\n      let result = sanitizeReplacementValues(syntaxTransform.value.call(null, ctx));\n      if (!List.isList(result)) {\n        throw this.createError(name, \"macro must return a list but got: \" + result);\n      }\n      result = result.map(stx_244 => {\n        if (!(stx_244 && typeof stx_244.addScope === \"function\")) {\n          throw this.createError(name, \"macro must return syntax objects or terms but got: \" + stx_244);\n        }\n        return stx_244.addScope(introducedScope, this.context.bindings, ALL_PHASES, {flip: true});\n      });\n      this.rest = result.concat(ctx._rest(this));\n      lookahead_243 = this.peek();\n    }\n  }\n  consumeSemicolon() {\n    let lookahead_245 = this.peek();\n    if (lookahead_245 && this.isPunctuator(lookahead_245, \";\")) {\n      this.advance();\n    }\n  }\n  consumeComma() {\n    let lookahead_246 = this.peek();\n    if (lookahead_246 && this.isPunctuator(lookahead_246, \",\")) {\n      this.advance();\n    }\n  }\n  safeCheck(obj_247, type_248, val_249 = null) {\n    return obj_247 && (typeof obj_247.match === \"function\" ? obj_247.match(type_248, val_249) : false);\n  }\n  isTerm(term_250) {\n    return term_250 && term_250 instanceof Term;\n  }\n  isEOF(obj_251) {\n    return this.safeCheck(obj_251, \"eof\");\n  }\n  isIdentifier(obj_252, val_253 = null) {\n    return this.safeCheck(obj_252, \"identifier\", val_253);\n  }\n  isPropertyName(obj_254) {\n    return this.isIdentifier(obj_254) || this.isKeyword(obj_254) || this.isNumericLiteral(obj_254) || this.isStringLiteral(obj_254) || this.isBrackets(obj_254);\n  }\n  isNumericLiteral(obj_255, val_256 = null) {\n    return this.safeCheck(obj_255, \"number\", val_256);\n  }\n  isStringLiteral(obj_257, val_258 = null) {\n    return this.safeCheck(obj_257, \"string\", val_258);\n  }\n  isTemplate(obj_259, val_260 = null) {\n    return this.safeCheck(obj_259, \"template\", val_260);\n  }\n  isSyntaxTemplate(obj_261) {\n    return this.safeCheck(obj_261, \"syntaxTemplate\");\n  }\n  isBooleanLiteral(obj_262, val_263 = null) {\n    return this.safeCheck(obj_262, \"boolean\", val_263);\n  }\n  isNullLiteral(obj_264, val_265 = null) {\n    return this.safeCheck(obj_264, \"null\", val_265);\n  }\n  isRegularExpression(obj_266, val_267 = null) {\n    return this.safeCheck(obj_266, \"regularExpression\", val_267);\n  }\n  isDelimiter(obj_268) {\n    return this.safeCheck(obj_268, \"delimiter\");\n  }\n  isParens(obj_269) {\n    return this.safeCheck(obj_269, \"parens\");\n  }\n  isBraces(obj_270) {\n    return this.safeCheck(obj_270, \"braces\");\n  }\n  isBrackets(obj_271) {\n    return this.safeCheck(obj_271, \"brackets\");\n  }\n  isAssign(obj_272, val_273 = null) {\n    return this.safeCheck(obj_272, \"assign\", val_273);\n  }\n  isKeyword(obj_274, val_275 = null) {\n    return this.safeCheck(obj_274, \"keyword\", val_275);\n  }\n  isPunctuator(obj_276, val_277 = null) {\n    return this.safeCheck(obj_276, \"punctuator\", val_277);\n  }\n  isOperator(obj_278) {\n    return (this.safeCheck(obj_278, \"punctuator\") || this.safeCheck(obj_278, \"identifier\") || this.safeCheck(obj_278, \"keyword\")) && isOperator(obj_278);\n  }\n  isUpdateOperator(obj_279) {\n    return this.safeCheck(obj_279, \"punctuator\", \"++\") || this.safeCheck(obj_279, \"punctuator\", \"--\");\n  }\n  safeResolve(obj_280, phase_281) {\n    return obj_280 && typeof obj_280.resolve === \"function\" ? Just_41(obj_280.resolve(phase_281)) : Nothing_42();\n  }\n  isTransform(obj_282, trans_283) {\n    return this.safeResolve(obj_282, this.context.phase).map(name_284 => this.context.env.get(name_284) === trans_283 || this.context.store.get(name_284) === trans_283).getOrElse(false);\n  }\n  isTransformInstance(obj_285, trans_286) {\n    return this.safeResolve(obj_285, this.context.phase).map(name_287 => this.context.env.get(name_287) instanceof trans_286 || this.context.store.get(name_287) instanceof trans_286).getOrElse(false);\n  }\n  isFnDeclTransform(obj_288) {\n    return this.isTransform(obj_288, FunctionDeclTransform);\n  }\n  isVarDeclTransform(obj_289) {\n    return this.isTransform(obj_289, VariableDeclTransform);\n  }\n  isLetDeclTransform(obj_290) {\n    return this.isTransform(obj_290, LetDeclTransform);\n  }\n  isConstDeclTransform(obj_291) {\n    return this.isTransform(obj_291, ConstDeclTransform);\n  }\n  isSyntaxDeclTransform(obj_292) {\n    return this.isTransform(obj_292, SyntaxDeclTransform);\n  }\n  isSyntaxrecDeclTransform(obj_293) {\n    return this.isTransform(obj_293, SyntaxrecDeclTransform);\n  }\n  isSyntaxQuoteTransform(obj_294) {\n    return this.isTransform(obj_294, SyntaxQuoteTransform);\n  }\n  isReturnStmtTransform(obj_295) {\n    return this.isTransform(obj_295, ReturnStatementTransform);\n  }\n  isWhileTransform(obj_296) {\n    return this.isTransform(obj_296, WhileTransform);\n  }\n  isForTransform(obj_297) {\n    return this.isTransform(obj_297, ForTransform);\n  }\n  isSwitchTransform(obj_298) {\n    return this.isTransform(obj_298, SwitchTransform);\n  }\n  isBreakTransform(obj_299) {\n    return this.isTransform(obj_299, BreakTransform);\n  }\n  isContinueTransform(obj_300) {\n    return this.isTransform(obj_300, ContinueTransform);\n  }\n  isDoTransform(obj_301) {\n    return this.isTransform(obj_301, DoTransform);\n  }\n  isDebuggerTransform(obj_302) {\n    return this.isTransform(obj_302, DebuggerTransform);\n  }\n  isWithTransform(obj_303) {\n    return this.isTransform(obj_303, WithTransform);\n  }\n  isTryTransform(obj_304) {\n    return this.isTransform(obj_304, TryTransform);\n  }\n  isThrowTransform(obj_305) {\n    return this.isTransform(obj_305, ThrowTransform);\n  }\n  isIfTransform(obj_306) {\n    return this.isTransform(obj_306, IfTransform);\n  }\n  isNewTransform(obj_307) {\n    return this.isTransform(obj_307, NewTransform);\n  }\n  isCompiletimeTransform(obj_308) {\n    return this.isTransformInstance(obj_308, CompiletimeTransform);\n  }\n  isVarBindingTransform(obj_309) {\n    return this.isTransformInstance(obj_309, VarBindingTransform);\n  }\n  getFromCompiletimeEnvironment(term_310) {\n    if (this.context.env.has(term_310.resolve(this.context.phase))) {\n      return this.context.env.get(term_310.resolve(this.context.phase));\n    }\n    return this.context.store.get(term_310.resolve(this.context.phase));\n  }\n  lineNumberEq(a_311, b_312) {\n    if (!(a_311 && b_312)) {\n      return false;\n    }\n    return a_311.lineNumber() === b_312.lineNumber();\n  }\n  matchIdentifier(val_313) {\n    let lookahead_314 = this.advance();\n    if (this.isIdentifier(lookahead_314)) {\n      return lookahead_314;\n    }\n    throw this.createError(lookahead_314, \"expecting an identifier\");\n  }\n  matchKeyword(val_315) {\n    let lookahead_316 = this.advance();\n    if (this.isKeyword(lookahead_316, val_315)) {\n      return lookahead_316;\n    }\n    throw this.createError(lookahead_316, \"expecting \" + val_315);\n  }\n  matchLiteral() {\n    let lookahead_317 = this.advance();\n    if (this.isNumericLiteral(lookahead_317) || this.isStringLiteral(lookahead_317) || this.isBooleanLiteral(lookahead_317) || this.isNullLiteral(lookahead_317) || this.isTemplate(lookahead_317) || this.isRegularExpression(lookahead_317)) {\n      return lookahead_317;\n    }\n    throw this.createError(lookahead_317, \"expecting a literal\");\n  }\n  matchStringLiteral() {\n    let lookahead_318 = this.advance();\n    if (this.isStringLiteral(lookahead_318)) {\n      return lookahead_318;\n    }\n    throw this.createError(lookahead_318, \"expecting a string literal\");\n  }\n  matchTemplate() {\n    let lookahead_319 = this.advance();\n    if (this.isTemplate(lookahead_319)) {\n      return lookahead_319;\n    }\n    throw this.createError(lookahead_319, \"expecting a template literal\");\n  }\n  matchParens() {\n    let lookahead_320 = this.advance();\n    if (this.isParens(lookahead_320)) {\n      return lookahead_320.inner();\n    }\n    throw this.createError(lookahead_320, \"expecting parens\");\n  }\n  matchCurlies() {\n    let lookahead_321 = this.advance();\n    if (this.isBraces(lookahead_321)) {\n      return lookahead_321.inner();\n    }\n    throw this.createError(lookahead_321, \"expecting curly braces\");\n  }\n  matchSquares() {\n    let lookahead_322 = this.advance();\n    if (this.isBrackets(lookahead_322)) {\n      return lookahead_322.inner();\n    }\n    throw this.createError(lookahead_322, \"expecting sqaure braces\");\n  }\n  matchUnaryOperator() {\n    let lookahead_323 = this.advance();\n    if (isUnaryOperator(lookahead_323)) {\n      return lookahead_323;\n    }\n    throw this.createError(lookahead_323, \"expecting a unary operator\");\n  }\n  matchPunctuator(val_324) {\n    let lookahead_325 = this.advance();\n    if (this.isPunctuator(lookahead_325)) {\n      if (typeof val_324 !== \"undefined\") {\n        if (lookahead_325.val() === val_324) {\n          return lookahead_325;\n        } else {\n          throw this.createError(lookahead_325, \"expecting a \" + val_324 + \" punctuator\");\n        }\n      }\n      return lookahead_325;\n    }\n    throw this.createError(lookahead_325, \"expecting a punctuator\");\n  }\n  createError(stx_326, message_327) {\n    let ctx_328 = \"\";\n    let offending_329 = stx_326;\n    if (this.rest.size > 0) {\n      ctx_328 = this.rest.slice(0, 20).map(term_330 => {\n        if (this.isDelimiter(term_330)) {\n          return term_330.inner();\n        }\n        return List.of(term_330);\n      }).flatten().map(s_331 => {\n        if (s_331 === offending_329) {\n          return \"__\" + s_331.val() + \"__\";\n        }\n        return s_331.val();\n      }).join(\" \");\n    } else {\n      ctx_328 = offending_329.toString();\n    }\n    return new Error(message_327 + \"\\n\" + ctx_328);\n  }\n}\nexport {Enforester_46 as Enforester}"]} \ No newline at end of file +exports.Enforester = Enforester; +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/enforester.js"],"names":[],"mappings":";;;;;;;AAAA;;;;AACA;;AAIA;;AAwBA;;AACA;;AACA;;AAOA;;;;AAEA;;AACA;;AAEA;;;;;;AAzCA,MAAM,OAAO,oBAAM,IAAnB;AACA,MAAM,UAAU,oBAAM,OAAtB;;AA0CA,MAAM,qBAAqB,EAA3B;AACA,MAAM,sBAAsB,EAA5B;AACA,MAAM,sBAAsB,EAA5B;;AAEO,MAAM,UAAN,CAAiB;AACtB,cAAY,IAAZ,EAAkB,IAAlB,EAAwB,OAAxB,EAAiC;AAC/B,SAAK,IAAL,GAAY,KAAZ;AACA,wBAAO,gBAAK,MAAL,CAAY,IAAZ,CAAP,EAA0B,uCAA1B;AACA,wBAAO,gBAAK,MAAL,CAAY,IAAZ,CAAP,EAA0B,uCAA1B;AACA,wBAAO,OAAP,EAAgB,iCAAhB;AACA,SAAK,IAAL,GAAY,IAAZ;;AAEA,SAAK,IAAL,GAAY,IAAZ;AACA,SAAK,IAAL,GAAY,IAAZ;;AAEA,SAAK,OAAL,GAAe,OAAf;AACD;;AAED,SAAY;AAAA,QAAP,CAAO,yDAAH,CAAG;;AACV,WAAO,KAAK,IAAL,CAAU,GAAV,CAAc,CAAd,CAAP;AACD;;AAED,YAAU;AACR,QAAI,MAAM,KAAK,IAAL,CAAU,KAAV,EAAV;AACA,SAAK,IAAL,GAAY,KAAK,IAAL,CAAU,IAAV,EAAZ;AACA,WAAO,GAAP;AACD;;AAED;;;;;;AAMA,aAA0B;AAAA,QAAjB,IAAiB,yDAAV,QAAU;;AACxB;AACA,SAAK,IAAL,GAAY,IAAZ;;AAEA,QAAI,KAAK,IAAL,CAAU,IAAV,KAAmB,CAAvB,EAA0B;AACxB,WAAK,IAAL,GAAY,IAAZ;AACA,aAAO,KAAK,IAAZ;AACD;;AAED,QAAI,KAAK,KAAL,CAAW,KAAK,IAAL,EAAX,CAAJ,EAA6B;AAC3B,WAAK,IAAL,GAAY,oBAAS,KAAT,EAAgB,EAAhB,CAAZ;AACA,WAAK,OAAL;AACA,aAAO,KAAK,IAAZ;AACD;;AAED,QAAI,MAAJ;AACA,QAAI,SAAS,YAAb,EAA2B;AACzB,eAAS,KAAK,sBAAL,EAAT;AACD,KAFD,MAEO;AACL,eAAS,KAAK,cAAL,EAAT;AACD;;AAED,QAAI,KAAK,IAAL,CAAU,IAAV,KAAmB,CAAvB,EAA0B;AACxB,WAAK,IAAL,GAAY,IAAZ;AACD;AACD,WAAO,MAAP;AACD;;AAED,mBAAiB;AACf,WAAO,KAAK,YAAL,EAAP;AACD;;AAED,iBAAe;AACb,WAAO,KAAK,kBAAL,EAAP;AACD;;AAED,uBAAqB;AACnB,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA,QAAI,KAAK,SAAL,CAAe,SAAf,EAA0B,QAA1B,CAAJ,EAAyC;AACvC,WAAK,OAAL;AACA,aAAO,KAAK,yBAAL,EAAP;AACD,KAHD,MAGO,IAAI,KAAK,SAAL,CAAe,SAAf,EAA0B,QAA1B,CAAJ,EAAyC;AAC9C,WAAK,OAAL;AACA,aAAO,KAAK,yBAAL,EAAP;AACD,KAHM,MAGA,IAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAJ,EAAuC;AAC5C,aAAO,KAAK,sBAAL,EAAP;AACD;AACD,WAAO,KAAK,iBAAL,EAAP;AACD;;AAED,2BAAyB;AACvB,SAAK,eAAL,CAAqB,GAArB;AACA,SAAK,eAAL,CAAqB,MAArB;AACA,QAAI,OAAO,KAAK,kBAAL,EAAX;AACA,SAAK,gBAAL;AACA,WAAO,oBAAS,QAAT,EAAmB;AACxB,YAAM,MADkB;AAExB,aAAO,gBAAK,EAAL,CAAQ,IAAR;AAFiB,KAAnB,CAAP;AAID;;AAED,8BAA4B;AAC1B,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA,QAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,WAAK,OAAL;AACA,UAAI,kBAAkB,KAAK,kBAAL,EAAtB;AACA,aAAO,oBAAS,eAAT,EAA0B,EAAE,gCAAF,EAA1B,CAAP;AACD,KAJD,MAIO,IAAI,KAAK,QAAL,CAAc,SAAd,CAAJ,EAA8B;AACnC,UAAI,eAAe,KAAK,oBAAL,EAAnB;AACA,UAAI,kBAAkB,IAAtB;AACA,UAAI,KAAK,YAAL,CAAkB,KAAK,IAAL,EAAlB,EAA+B,MAA/B,CAAJ,EAA4C;AAC1C,0BAAkB,KAAK,kBAAL,EAAlB;AACD;AACD,aAAO,oBAAS,YAAT,EAAuB,EAAE,0BAAF,EAAgB,gCAAhB,EAAvB,CAAP;AACD,KAPM,MAOA,IAAI,KAAK,SAAL,CAAe,SAAf,EAA0B,OAA1B,CAAJ,EAAwC;AAC7C,aAAO,oBAAS,QAAT,EAAmB;AACxB,qBAAa,KAAK,aAAL,CAAmB,EAAE,QAAQ,KAAV,EAAnB;AADW,OAAnB,CAAP;AAGD,KAJM,MAIA,IAAI,KAAK,iBAAL,CAAuB,SAAvB,CAAJ,EAAuC;AAC5C,aAAO,oBAAS,QAAT,EAAmB;AACxB,qBAAa,KAAK,gBAAL,CAAsB,EAAC,QAAQ,KAAT,EAAgB,WAAW,KAA3B,EAAtB;AADW,OAAnB,CAAP;AAGD,KAJM,MAIA,IAAI,KAAK,SAAL,CAAe,SAAf,EAA0B,SAA1B,CAAJ,EAA0C;AAC/C,WAAK,OAAL;AACA,UAAI,KAAK,iBAAL,CAAuB,KAAK,IAAL,EAAvB,CAAJ,EAAyC;AACvC,eAAO,oBAAS,eAAT,EAA0B;AAC/B,gBAAM,KAAK,gBAAL,CAAsB,EAAC,QAAQ,KAAT,EAAgB,WAAW,IAA3B,EAAtB;AADyB,SAA1B,CAAP;AAGD,OAJD,MAIO,IAAI,KAAK,SAAL,CAAe,KAAK,IAAL,EAAf,EAA4B,OAA5B,CAAJ,EAA0C;AAC/C,eAAO,oBAAS,eAAT,EAA0B;AAC/B,gBAAM,KAAK,aAAL,CAAmB,EAAC,QAAQ,KAAT,EAAgB,WAAW,IAA3B,EAAnB;AADyB,SAA1B,CAAP;AAGD,OAJM,MAIA;AACL,YAAI,OAAO,KAAK,sBAAL,EAAX;AACA,aAAK,gBAAL;AACA,eAAO,oBAAS,eAAT,EAA0B,EAAE,UAAF,EAA1B,CAAP;AACD;AACF,KAfM,MAeA,IAAI,KAAK,kBAAL,CAAwB,SAAxB,KACP,KAAK,kBAAL,CAAwB,SAAxB,CADO,IAEP,KAAK,oBAAL,CAA0B,SAA1B,CAFO,IAGP,KAAK,wBAAL,CAA8B,SAA9B,CAHO,IAIP,KAAK,qBAAL,CAA2B,SAA3B,CAJG,EAIoC;AACzC,aAAO,oBAAS,QAAT,EAAmB;AACxB,qBAAa,KAAK,2BAAL;AADW,OAAnB,CAAP;AAGD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,mBAA5B,CAAN;AACD;;AAED,yBAAuB;AACrB,QAAI,MAAM,IAAI,UAAJ,CAAe,KAAK,YAAL,EAAf,EAAoC,sBAApC,EAA4C,KAAK,OAAjD,CAAV;AACA,QAAI,SAAS,EAAb;AACA,WAAO,IAAI,IAAJ,CAAS,IAAT,KAAkB,CAAzB,EAA4B;AAC1B,aAAO,IAAP,CAAY,IAAI,uBAAJ,EAAZ;AACA,UAAI,YAAJ;AACD;AACD,WAAO,qBAAK,MAAL,CAAP;AACD;;AAED,4BAA0B;AACxB,QAAI,OAAO,KAAK,kBAAL,EAAX;AACA,QAAI,KAAK,YAAL,CAAkB,KAAK,IAAL,EAAlB,EAA+B,IAA/B,CAAJ,EAA0C;AACxC,WAAK,OAAL;AACA,UAAI,eAAe,KAAK,kBAAL,EAAnB;AACA,aAAO,oBAAS,iBAAT,EAA4B,EAAE,UAAF,EAAQ,0BAAR,EAA5B,CAAP;AACD;AACD,WAAO,oBAAS,iBAAT,EAA4B;AACjC,YAAM,IAD2B;AAEjC,oBAAc;AAFmB,KAA5B,CAAP;AAID;;AAED,8BAA4B;AAC1B,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA,QAAI,iBAAiB,IAArB;AACA,QAAI,eAAe,sBAAnB;AACA,QAAI,YAAY,KAAhB;;AAEA,QAAI,KAAK,eAAL,CAAqB,SAArB,CAAJ,EAAqC;AACnC,UAAI,kBAAkB,KAAK,OAAL,EAAtB;AACA,WAAK,gBAAL;AACA,aAAO,oBAAS,QAAT,EAAmB;AACxB,sCADwB;AAExB,kCAFwB;AAGxB,wCAHwB;AAIxB;AAJwB,OAAnB,CAAP;AAMD;;AAED,QAAI,KAAK,YAAL,CAAkB,SAAlB,KAAgC,KAAK,SAAL,CAAe,SAAf,CAApC,EAA+D;AAC7D,uBAAiB,KAAK,yBAAL,EAAjB;AACA,UAAI,CAAC,KAAK,YAAL,CAAkB,KAAK,IAAL,EAAlB,EAA+B,GAA/B,CAAL,EAA0C;AACxC,YAAI,kBAAkB,KAAK,kBAAL,EAAtB;AACA,YAAI,KAAK,SAAL,CAAe,KAAK,IAAL,EAAf,EAA4B,KAA5B,KAAsC,KAAK,YAAL,CAAkB,KAAK,IAAL,CAAU,CAAV,CAAlB,EAAgC,QAAhC,CAA1C,EAAqF;AACnF,eAAK,OAAL;AACA,eAAK,OAAL;AACA,sBAAY,IAAZ;AACD;;AAED,eAAO,oBAAS,QAAT,EAAmB;AACxB,wCADwB,EACR,gCADQ;AAExB,wBAAc,sBAFU;AAGxB;AAHwB,SAAnB,CAAP;AAKD;AACF;AACD,SAAK,YAAL;AACA,gBAAY,KAAK,IAAL,EAAZ;AACA,QAAI,KAAK,QAAL,CAAc,SAAd,CAAJ,EAA8B;AAC5B,UAAI,UAAU,KAAK,oBAAL,EAAd;AACA,UAAI,aAAa,KAAK,kBAAL,EAAjB;AACA,UAAI,KAAK,SAAL,CAAe,KAAK,IAAL,EAAf,EAA4B,KAA5B,KAAsC,KAAK,YAAL,CAAkB,KAAK,IAAL,CAAU,CAAV,CAAlB,EAAgC,QAAhC,CAA1C,EAAqF;AACnF,aAAK,OAAL;AACA,aAAK,OAAL;AACA,oBAAY,IAAZ;AACD;;AAED,aAAO,oBAAS,QAAT,EAAmB;AACxB,sCADwB;AAExB,4BAFwB;AAGxB,sBAAc,OAHU;AAIxB,yBAAiB;;AAJO,OAAnB,CAAP;AAOD,KAhBD,MAgBO,IAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAJ,EAAuC;AAC5C,UAAI,mBAAmB,KAAK,wBAAL,EAAvB;AACA,UAAI,kBAAkB,KAAK,kBAAL,EAAtB;AACA,UAAI,KAAK,SAAL,CAAe,KAAK,IAAL,EAAf,EAA4B,KAA5B,KAAsC,KAAK,YAAL,CAAkB,KAAK,IAAL,CAAU,CAAV,CAAlB,EAAgC,QAAhC,CAA1C,EAAqF;AACnF,aAAK,OAAL;AACA,aAAK,OAAL;AACA,oBAAY,IAAZ;AACD;AACD,aAAO,oBAAS,iBAAT,EAA4B;AACjC,sCADiC,EACjB,oBADiB,EACN,kCADM,EACY;AADZ,OAA5B,CAAP;AAGD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,mBAA5B,CAAN;AACD;;AAED,6BAA2B;AACzB,SAAK,eAAL,CAAqB,GAArB;AACA,SAAK,eAAL,CAAqB,IAArB;AACA,WAAO,KAAK,yBAAL,EAAP;AACD;;AAED,yBAAuB;AACrB,QAAI,MAAM,IAAI,UAAJ,CAAe,KAAK,YAAL,EAAf,EAAoC,sBAApC,EAA4C,KAAK,OAAjD,CAAV;AACA,QAAI,SAAS,EAAb;AACA,WAAO,IAAI,IAAJ,CAAS,IAAT,KAAkB,CAAzB,EAA4B;AAC1B,aAAO,IAAP,CAAY,IAAI,wBAAJ,EAAZ;AACA,UAAI,YAAJ;AACD;AACD,WAAO,qBAAK,MAAL,CAAP;AACD;;AAED,6BAA2B;AACzB,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA,QAAI,IAAJ;AACA,QAAI,KAAK,YAAL,CAAkB,SAAlB,KAAgC,KAAK,SAAL,CAAe,SAAf,CAApC,EAA+D;AAC7D,aAAO,KAAK,OAAL,EAAP;AACA,UAAI,CAAC,KAAK,YAAL,CAAkB,KAAK,IAAL,EAAlB,EAA+B,IAA/B,CAAL,EAA2C;AACzC,eAAO,oBAAS,iBAAT,EAA4B;AACjC,gBAAM,IAD2B;AAEjC,mBAAS,oBAAS,mBAAT,EAA8B;AACrC,kBAAM;AAD+B,WAA9B;AAFwB,SAA5B,CAAP;AAMD,OAPD,MAOO;AACL,aAAK,eAAL,CAAqB,IAArB;AACD;AACF,KAZD,MAYO;AACL,YAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,sCAA5B,CAAN;AACD;AACD,WAAO,oBAAS,iBAAT,EAA4B;AACjC,gBADiC,EAC3B,SAAS,KAAK,yBAAL;AADkB,KAA5B,CAAP;AAGD;;AAED,uBAAqB;AACnB,SAAK,eAAL,CAAqB,MAArB;AACA,QAAI,YAAY,KAAK,kBAAL,EAAhB;AACA,SAAK,gBAAL;AACA,WAAO,SAAP;AACD;;AAED,8BAA4B;AAC1B,QAAI,YAAY,KAAK,IAAL,EAAhB;;AAEA,QAAI,KAAK,iBAAL,CAAuB,SAAvB,CAAJ,EAAuC;AACrC,aAAO,KAAK,2BAAL,CAAiC,EAAE,QAAQ,KAAV,EAAjC,CAAP;AACD,KAFD,MAEO,IAAI,KAAK,SAAL,CAAe,SAAf,EAA0B,OAA1B,CAAJ,EAAwC;AAC7C,aAAO,KAAK,aAAL,CAAmB,EAAE,QAAQ,KAAV,EAAnB,CAAP;AACD,KAFM,MAEA;AACL,aAAO,KAAK,iBAAL,EAAP;AACD;AACF;;AAED,sBAAoB;AAClB,QAAI,YAAY,KAAK,IAAL,EAAhB;;AAEA,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,sBAAL,CAA4B,SAA5B,CAA1B,EAAkE;AAChE,WAAK,WAAL;AACA,kBAAY,KAAK,IAAL,EAAZ;AACD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,MAAL,CAAY,SAAZ,CAA1B,EAAkD;AAChD;AACA,aAAO,KAAK,OAAL,EAAP;AACD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,QAAL,CAAc,SAAd,CAA1B,EAAoD;AAClD,aAAO,KAAK,sBAAL,EAAP;AACD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,gBAAL,CAAsB,SAAtB,CAA1B,EAA4D;AAC1D,aAAO,KAAK,sBAAL,EAAP;AACD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,aAAL,CAAmB,SAAnB,CAA1B,EAAyD;AACvD,aAAO,KAAK,mBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,cAAL,CAAoB,SAApB,CAA1B,EAA0D;AACxD,aAAO,KAAK,oBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,iBAAL,CAAuB,SAAvB,CAA1B,EAA6D;AAC3D,aAAO,KAAK,uBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,gBAAL,CAAsB,SAAtB,CAA1B,EAA4D;AAC1D,aAAO,KAAK,sBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,mBAAL,CAAyB,SAAzB,CAA1B,EAA+D;AAC7D,aAAO,KAAK,yBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,aAAL,CAAmB,SAAnB,CAA1B,EAAyD;AACvD,aAAO,KAAK,mBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,mBAAL,CAAyB,SAAzB,CAA1B,EAA+D;AAC7D,aAAO,KAAK,yBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,eAAL,CAAqB,SAArB,CAA1B,EAA2D;AACzD,aAAO,KAAK,qBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,cAAL,CAAoB,SAApB,CAA1B,EAA0D;AACxD,aAAO,KAAK,oBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,gBAAL,CAAsB,SAAtB,CAA1B,EAA4D;AAC1D,aAAO,KAAK,sBAAL,EAAP;AACD;;AAED;AACA,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,SAAL,CAAe,SAAf,EAA0B,OAA1B,CAA1B,EAA8D;AAC5D,aAAO,KAAK,aAAL,CAAmB,EAAC,QAAQ,KAAT,EAAnB,CAAP;AACD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,iBAAL,CAAuB,SAAvB,CAA1B,EAA6D;AAC3D,aAAO,KAAK,2BAAL,EAAP;AACD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,YAAL,CAAkB,SAAlB,CAAtB,IACA,KAAK,YAAL,CAAkB,KAAK,IAAL,CAAU,CAAV,CAAlB,EAAgC,GAAhC,CADJ,EAC0C;AACxC,aAAO,KAAK,wBAAL,EAAP;AACD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,KACC,KAAK,kBAAL,CAAwB,SAAxB,KACA,KAAK,kBAAL,CAAwB,SAAxB,CADA,IAEA,KAAK,oBAAL,CAA0B,SAA1B,CAFA,IAGA,KAAK,wBAAL,CAA8B,SAA9B,CAHA,IAIA,KAAK,qBAAL,CAA2B,SAA3B,CALD,CAAJ,EAK6C;AAC3C,UAAI,OAAO,oBAAS,8BAAT,EAAyC;AAClD,qBAAa,KAAK,2BAAL;AADqC,OAAzC,CAAX;AAGA,WAAK,gBAAL;AACA,aAAO,IAAP;AACD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,qBAAL,CAA2B,SAA3B,CAA1B,EAAiE;AAC/D,aAAO,KAAK,uBAAL,EAAP;AACD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAA1B,EAA6D;AAC3D,WAAK,OAAL;AACA,aAAO,oBAAS,gBAAT,EAA2B,EAA3B,CAAP;AACD;;AAGD,WAAO,KAAK,2BAAL,EAAP;AACD;;AAED,6BAA2B;AACzB,QAAI,QAAQ,KAAK,eAAL,EAAZ;AACA,SAAK,eAAL,CAAqB,GAArB;AACA,QAAI,OAAO,KAAK,iBAAL,EAAX;;AAEA,WAAO,oBAAS,kBAAT,EAA6B;AAClC,aAAO,KAD2B;AAElC,YAAM;AAF4B,KAA7B,CAAP;AAID;;AAED,2BAAyB;AACvB,SAAK,YAAL,CAAkB,OAAlB;AACA,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA,QAAI,QAAQ,IAAZ;AACA,QAAI,KAAK,IAAL,CAAU,IAAV,KAAmB,CAAnB,IAAwB,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAA5B,EAA+D;AAC7D,WAAK,gBAAL;AACA,aAAO,oBAAS,gBAAT,EAA2B,EAAE,YAAF,EAA3B,CAAP;AACD;AACD,QAAI,KAAK,YAAL,CAAkB,SAAlB,KAAgC,KAAK,SAAL,CAAe,SAAf,EAA0B,OAA1B,CAAhC,IAAsE,KAAK,SAAL,CAAe,SAAf,EAA0B,KAA1B,CAA1E,EAA4G;AAC1G,cAAQ,KAAK,kBAAL,EAAR;AACD;AACD,SAAK,gBAAL;;AAEA,WAAO,oBAAS,gBAAT,EAA2B,EAAE,YAAF,EAA3B,CAAP;AACD;;AAED,yBAAuB;AACrB,SAAK,YAAL,CAAkB,KAAlB;AACA,QAAI,OAAO,KAAK,aAAL,EAAX;AACA,QAAI,KAAK,SAAL,CAAe,KAAK,IAAL,EAAf,EAA4B,OAA5B,CAAJ,EAA0C;AACxC,UAAI,cAAc,KAAK,mBAAL,EAAlB;AACA,UAAI,KAAK,SAAL,CAAe,KAAK,IAAL,EAAf,EAA4B,SAA5B,CAAJ,EAA4C;AAC1C,aAAK,OAAL;AACA,YAAI,YAAY,KAAK,aAAL,EAAhB;AACA,eAAO,oBAAS,qBAAT,EAAgC;AACrC,oBADqC,EAC/B,wBAD+B,EAClB;AADkB,SAAhC,CAAP;AAGD;AACD,aAAO,oBAAS,mBAAT,EAA8B,EAAE,UAAF,EAAQ,wBAAR,EAA9B,CAAP;AACD;AACD,QAAI,KAAK,SAAL,CAAe,KAAK,IAAL,EAAf,EAA4B,SAA5B,CAAJ,EAA4C;AAC1C,WAAK,OAAL;AACA,UAAI,YAAY,KAAK,aAAL,EAAhB;AACA,aAAO,oBAAS,qBAAT,EAAgC,EAAE,UAAF,EAAQ,aAAa,IAArB,EAA2B,oBAA3B,EAAhC,CAAP;AACD;AACD,UAAM,KAAK,WAAL,CAAiB,KAAK,IAAL,EAAjB,EAA8B,8BAA9B,CAAN;AACD;;AAED,wBAAsB;AACpB,SAAK,YAAL,CAAkB,OAAlB;AACA,QAAI,gBAAgB,KAAK,WAAL,EAApB;AACA,QAAI,MAAM,IAAI,UAAJ,CAAe,aAAf,EAA8B,sBAA9B,EAAsC,KAAK,OAA3C,CAAV;AACA,QAAI,UAAU,IAAI,qBAAJ,EAAd;AACA,QAAI,OAAO,KAAK,aAAL,EAAX;AACA,WAAO,oBAAS,aAAT,EAAwB,EAAE,gBAAF,EAAW,UAAX,EAAxB,CAAP;AACD;;AAED,2BAAyB;AACvB,SAAK,YAAL,CAAkB,OAAlB;AACA,QAAI,aAAa,KAAK,kBAAL,EAAjB;AACA,SAAK,gBAAL;AACA,WAAO,oBAAS,gBAAT,EAA2B,EAAE,sBAAF,EAA3B,CAAP;AACD;;AAED,0BAAwB;AACtB,SAAK,YAAL,CAAkB,MAAlB;AACA,QAAI,YAAY,KAAK,WAAL,EAAhB;AACA,QAAI,MAAM,IAAI,UAAJ,CAAe,SAAf,EAA0B,sBAA1B,EAAkC,KAAK,OAAvC,CAAV;AACA,QAAI,SAAS,IAAI,kBAAJ,EAAb;AACA,QAAI,OAAO,KAAK,iBAAL,EAAX;AACA,WAAO,oBAAS,eAAT,EAA0B,EAAE,cAAF,EAAU,UAAV,EAA1B,CAAP;AACD;;AAED,8BAA4B;AAC1B,SAAK,YAAL,CAAkB,UAAlB;;AAEA,WAAO,oBAAS,mBAAT,EAA8B,EAA9B,CAAP;AACD;;AAED,wBAAsB;AACpB,SAAK,YAAL,CAAkB,IAAlB;AACA,QAAI,OAAO,KAAK,iBAAL,EAAX;AACA,SAAK,YAAL,CAAkB,OAAlB;AACA,QAAI,WAAW,KAAK,WAAL,EAAf;AACA,QAAI,MAAM,IAAI,UAAJ,CAAe,QAAf,EAAyB,sBAAzB,EAAiC,KAAK,OAAtC,CAAV;AACA,QAAI,OAAO,IAAI,kBAAJ,EAAX;AACA,SAAK,gBAAL;AACA,WAAO,oBAAS,kBAAT,EAA6B,EAAE,UAAF,EAAQ,UAAR,EAA7B,CAAP;AACD;;AAED,8BAA4B;AAC1B,QAAI,MAAM,KAAK,YAAL,CAAkB,UAAlB,CAAV;AACA,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA,QAAI,QAAQ,IAAZ;AACA,QAAI,KAAK,IAAL,CAAU,IAAV,KAAmB,CAAnB,IAAwB,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAA5B,EAA+D;AAC7D,WAAK,gBAAL;AACA,aAAO,oBAAS,mBAAT,EAA8B,EAAE,YAAF,EAA9B,CAAP;AACD;AACD,QAAI,KAAK,YAAL,CAAkB,GAAlB,EAAuB,SAAvB,MACC,KAAK,YAAL,CAAkB,SAAlB,KACA,KAAK,SAAL,CAAe,SAAf,EAA0B,OAA1B,CADA,IAEA,KAAK,SAAL,CAAe,SAAf,EAA0B,KAA1B,CAHD,CAAJ,EAGwC;AACtC,cAAQ,KAAK,kBAAL,EAAR;AACD;AACD,SAAK,gBAAL;;AAEA,WAAO,oBAAS,mBAAT,EAA8B,EAAE,YAAF,EAA9B,CAAP;AACD;;AAED,4BAA0B;AACxB,SAAK,YAAL,CAAkB,QAAlB;AACA,QAAI,OAAO,KAAK,WAAL,EAAX;AACA,QAAI,MAAM,IAAI,UAAJ,CAAe,IAAf,EAAqB,sBAArB,EAA6B,KAAK,OAAlC,CAAV;AACA,QAAI,eAAe,IAAI,kBAAJ,EAAnB;AACA,QAAI,OAAO,KAAK,YAAL,EAAX;;AAEA,QAAI,KAAK,IAAL,KAAc,CAAlB,EAAqB;AACnB,aAAO,oBAAS,iBAAT,EAA4B;AACjC,sBAAc,YADmB;AAEjC,eAAO;AAF0B,OAA5B,CAAP;AAID;AACD,UAAM,IAAI,UAAJ,CAAe,IAAf,EAAqB,sBAArB,EAA6B,KAAK,OAAlC,CAAN;AACA,QAAI,QAAQ,IAAI,mBAAJ,EAAZ;AACA,QAAI,YAAY,IAAI,IAAJ,EAAhB;AACA,QAAI,IAAI,SAAJ,CAAc,SAAd,EAAyB,SAAzB,CAAJ,EAAyC;AACvC,UAAI,cAAc,IAAI,qBAAJ,EAAlB;AACA,UAAI,mBAAmB,IAAI,mBAAJ,EAAvB;AACA,aAAO,oBAAS,4BAAT,EAAuC;AAC5C,kCAD4C;AAE5C,yBAAiB,KAF2B;AAG5C,gCAH4C;AAI5C;AAJ4C,OAAvC,CAAP;AAMD;AACD,WAAO,oBAAS,iBAAT,EAA4B,EAAG,0BAAH,EAAiB,YAAjB,EAA5B,CAAP;AACD;;AAED,wBAAsB;AACpB,QAAI,QAAQ,EAAZ;AACA,WAAO,EAAE,KAAK,IAAL,CAAU,IAAV,KAAmB,CAAnB,IAAwB,KAAK,SAAL,CAAe,KAAK,IAAL,EAAf,EAA4B,SAA5B,CAA1B,CAAP,EAA0E;AACxE,YAAM,IAAN,CAAW,KAAK,kBAAL,EAAX;AACD;AACD,WAAO,qBAAK,KAAL,CAAP;AACD;;AAED,uBAAqB;AACnB,SAAK,YAAL,CAAkB,MAAlB;AACA,WAAO,oBAAS,YAAT,EAAuB;AAC5B,YAAM,KAAK,kBAAL,EADsB;AAE5B,kBAAY,KAAK,sBAAL;AAFgB,KAAvB,CAAP;AAID;;AAED,2BAAyB;AACvB,SAAK,eAAL,CAAqB,GAArB;AACA,WAAO,KAAK,qCAAL,EAAP;AACD;;AAED,0CAAwC;AACtC,QAAI,SAAS,EAAb;AACA,WAAM,EAAE,KAAK,IAAL,CAAU,IAAV,KAAmB,CAAnB,IAAwB,KAAK,SAAL,CAAe,KAAK,IAAL,EAAf,EAA4B,SAA5B,CAAxB,IAAkE,KAAK,SAAL,CAAe,KAAK,IAAL,EAAf,EAA4B,MAA5B,CAApE,CAAN,EAAgH;AAC9G,aAAO,IAAP,CAAY,KAAK,yBAAL,EAAZ;AACD;AACD,WAAO,qBAAK,MAAL,CAAP;AACD;;AAED,0BAAwB;AACtB,SAAK,YAAL,CAAkB,SAAlB;AACA,WAAO,oBAAS,eAAT,EAA0B;AAC/B,kBAAY,KAAK,sBAAL;AADmB,KAA1B,CAAP;AAGD;;AAED,yBAAuB;AACrB,SAAK,YAAL,CAAkB,KAAlB;AACA,QAAI,OAAO,KAAK,WAAL,EAAX;AACA,QAAI,MAAM,IAAI,UAAJ,CAAe,IAAf,EAAqB,sBAArB,EAA6B,KAAK,OAAlC,CAAV;AACA,QAAI,SAAJ,EAAe,IAAf,EAAqB,IAArB,EAA2B,KAA3B,EAAkC,IAAlC,EAAwC,IAAxC,EAA8C,MAA9C;;AAEA;AACA,QAAI,IAAI,YAAJ,CAAiB,IAAI,IAAJ,EAAjB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,UAAI,OAAJ;AACA,UAAI,CAAC,IAAI,YAAJ,CAAiB,IAAI,IAAJ,EAAjB,EAA6B,GAA7B,CAAL,EAAwC;AACtC,eAAO,IAAI,kBAAJ,EAAP;AACD;AACD,UAAI,eAAJ,CAAoB,GAApB;AACA,UAAI,IAAI,IAAJ,CAAS,IAAT,KAAkB,CAAtB,EAAyB;AACvB,gBAAQ,IAAI,kBAAJ,EAAR;AACD;AACD,aAAO,oBAAS,cAAT,EAAyB;AAC9B,cAAM,IADwB;AAE9B,cAAM,IAFwB;AAG9B,gBAAQ,KAHsB;AAI9B,cAAM,KAAK,iBAAL;AAJwB,OAAzB,CAAP;AAMF;AACC,KAhBD,MAgBO;AACL;AACA,kBAAY,IAAI,IAAJ,EAAZ;AACA,UAAI,IAAI,kBAAJ,CAAuB,SAAvB,KACA,IAAI,kBAAJ,CAAuB,SAAvB,CADA,IAEA,IAAI,oBAAJ,CAAyB,SAAzB,CAFJ,EAEyC;AACvC,eAAO,IAAI,2BAAJ,EAAP;AACA,oBAAY,IAAI,IAAJ,EAAZ;AACA,YAAI,KAAK,SAAL,CAAe,SAAf,EAA0B,IAA1B,KAAmC,KAAK,YAAL,CAAkB,SAAlB,EAA6B,IAA7B,CAAvC,EAA2E;AACzE,cAAI,KAAK,SAAL,CAAe,SAAf,EAA0B,IAA1B,CAAJ,EAAqC;AACnC,gBAAI,OAAJ;AACA,oBAAQ,IAAI,kBAAJ,EAAR;AACA,mBAAO,gBAAP;AACD,WAJD,MAIO,IAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,IAA7B,CAAJ,EAAwC;AAC7C,gBAAI,OAAJ;AACA,oBAAQ,IAAI,kBAAJ,EAAR;AACA,mBAAO,gBAAP;AACD;AACD,iBAAO,oBAAS,IAAT,EAAe;AACpB,kBAAM,IADc,EACR,YADQ,EACD,MAAM,KAAK,iBAAL;AADL,WAAf,CAAP;AAGD;AACD,YAAI,eAAJ,CAAoB,GAApB;AACA,YAAI,IAAI,YAAJ,CAAiB,IAAI,IAAJ,EAAjB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,cAAI,OAAJ;AACA,iBAAO,IAAP;AACD,SAHD,MAGO;AACL,iBAAO,IAAI,kBAAJ,EAAP;AACA,cAAI,eAAJ,CAAoB,GAApB;AACD;AACD,iBAAS,IAAI,kBAAJ,EAAT;AACD,OA5BD,MA4BO;AACL,YAAI,KAAK,SAAL,CAAe,IAAI,IAAJ,CAAS,CAAT,CAAf,EAA4B,IAA5B,KAAqC,KAAK,YAAL,CAAkB,IAAI,IAAJ,CAAS,CAAT,CAAlB,EAA+B,IAA/B,CAAzC,EAA+E;AAC7E,iBAAO,IAAI,yBAAJ,EAAP;AACA,cAAI,OAAO,IAAI,OAAJ,EAAX;AACA,cAAI,KAAK,SAAL,CAAe,IAAf,EAAqB,IAArB,CAAJ,EAAgC;AAC9B,mBAAO,gBAAP;AACD,WAFD,MAEO;AACL,mBAAO,gBAAP;AACD;AACD,kBAAQ,IAAI,kBAAJ,EAAR;AACA,iBAAO,oBAAS,IAAT,EAAe;AACpB,kBAAM,IADc,EACR,YADQ,EACD,MAAM,KAAK,iBAAL;AADL,WAAf,CAAP;AAGD;AACD,eAAO,IAAI,kBAAJ,EAAP;AACA,YAAI,eAAJ,CAAoB,GAApB;AACA,YAAI,IAAI,YAAJ,CAAiB,IAAI,IAAJ,EAAjB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,cAAI,OAAJ;AACA,iBAAO,IAAP;AACD,SAHD,MAGO;AACL,iBAAO,IAAI,kBAAJ,EAAP;AACA,cAAI,eAAJ,CAAoB,GAApB;AACD;AACD,iBAAS,IAAI,kBAAJ,EAAT;AACD;AACD,aAAO,oBAAS,cAAT,EAAyB,EAAE,UAAF,EAAQ,UAAR,EAAc,cAAd,EAAsB,MAAM,KAAK,iBAAL,EAA5B,EAAzB,CAAP;AACD;AACF;;AAED,wBAAsB;AACpB,SAAK,YAAL,CAAkB,IAAlB;AACA,QAAI,OAAO,KAAK,WAAL,EAAX;AACA,QAAI,MAAM,IAAI,UAAJ,CAAe,IAAf,EAAqB,sBAArB,EAA6B,KAAK,OAAlC,CAAV;AACA,QAAI,YAAY,IAAI,IAAJ,EAAhB;AACA,QAAI,OAAO,IAAI,kBAAJ,EAAX;AACA,QAAI,SAAS,IAAb,EAAmB;AACjB,YAAM,IAAI,WAAJ,CAAgB,SAAhB,EAA2B,yBAA3B,CAAN;AACD;AACD,QAAI,aAAa,KAAK,iBAAL,EAAjB;AACA,QAAI,YAAY,IAAhB;AACA,QAAI,KAAK,SAAL,CAAe,KAAK,IAAL,EAAf,EAA4B,MAA5B,CAAJ,EAAyC;AACvC,WAAK,OAAL;AACA,kBAAY,KAAK,iBAAL,EAAZ;AACD;AACD,WAAO,oBAAS,aAAT,EAAwB,EAAE,UAAF,EAAQ,sBAAR,EAAoB,oBAApB,EAAxB,CAAP;AACD;;AAED,2BAAyB;AACvB,SAAK,YAAL,CAAkB,OAAlB;AACA,QAAI,OAAO,KAAK,WAAL,EAAX;AACA,QAAI,MAAM,IAAI,UAAJ,CAAe,IAAf,EAAqB,sBAArB,EAA6B,KAAK,OAAlC,CAAV;AACA,QAAI,YAAY,IAAI,IAAJ,EAAhB;AACA,QAAI,OAAO,IAAI,kBAAJ,EAAX;AACA,QAAI,SAAS,IAAb,EAAmB;AACjB,YAAM,IAAI,WAAJ,CAAgB,SAAhB,EAA2B,yBAA3B,CAAN;AACD;AACD,QAAI,OAAO,KAAK,iBAAL,EAAX;;AAEA,WAAO,oBAAS,gBAAT,EAA2B,EAAE,UAAF,EAAQ,UAAR,EAA3B,CAAP;AACD;;AAED,2BAAyB;AACvB,WAAO,oBAAS,gBAAT,EAA2B;AAChC,aAAO,KAAK,aAAL;AADyB,KAA3B,CAAP;AAGD;;AAED,kBAAgB;AACd,WAAO,oBAAS,OAAT,EAAkB;AACvB,kBAAY,KAAK,YAAL;AADW,KAAlB,CAAP;AAGD;;AAED,sBAAqC;AAAA,QAArB,MAAqB,QAArB,MAAqB;AAAA,QAAb,SAAa,QAAb,SAAa;;AACnC,QAAI,KAAK,KAAK,OAAL,EAAT;AACA,QAAI,OAAO,IAAX;AAAA,QAAiB,OAAO,IAAxB;AACA,QAAI,OAAO,SAAS,iBAAT,GAA6B,kBAAxC;;AAEA,QAAI,KAAK,YAAL,CAAkB,KAAK,IAAL,EAAlB,CAAJ,EAAoC;AAClC,aAAO,KAAK,yBAAL,EAAP;AACD,KAFD,MAEO,IAAI,CAAC,MAAL,EAAa;AAClB,UAAI,SAAJ,EAAe;AACb,eAAO,oBAAS,mBAAT,EAA8B;AACnC,gBAAM,iBAAO,cAAP,CAAsB,UAAtB,EAAkC,EAAlC;AAD6B,SAA9B,CAAP;AAGD,OAJD,MAIO;AACL,cAAM,KAAK,WAAL,CAAiB,KAAK,IAAL,EAAjB,EAA8B,mBAA9B,CAAN;AACD;AACF;;AAED,QAAI,KAAK,SAAL,CAAe,KAAK,IAAL,EAAf,EAA4B,SAA5B,CAAJ,EAA4C;AAC1C,WAAK,OAAL;AACA,aAAO,KAAK,sBAAL,EAAP;AACD;;AAED,QAAI,WAAW,EAAf;AACA,QAAI,MAAM,IAAI,UAAJ,CAAe,KAAK,YAAL,EAAf,EAAoC,sBAApC,EAA4C,KAAK,OAAjD,CAAV;AACA,WAAO,IAAI,IAAJ,CAAS,IAAT,KAAkB,CAAzB,EAA4B;AAC1B,UAAI,IAAI,YAAJ,CAAiB,IAAI,IAAJ,EAAjB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,YAAI,OAAJ;AACA;AACD;;AAED,UAAI,WAAW,KAAf;;AAN0B,kCAOA,IAAI,wBAAJ,EAPA;;AAAA,UAOrB,WAPqB,yBAOrB,WAPqB;AAAA,UAOR,IAPQ,yBAOR,IAPQ;;AAQ1B,UAAI,SAAS,YAAT,IAAyB,YAAY,KAAZ,CAAkB,GAAlB,OAA4B,QAAzD,EAAmE;AACjE,mBAAW,IAAX;;AADiE,qCAE1C,IAAI,wBAAJ,EAF0C;;AAE/D,mBAF+D,0BAE/D,WAF+D;AAElD,YAFkD,0BAElD,IAFkD;AAGlE;AACD,UAAI,SAAS,QAAb,EAAuB;AACrB,iBAAS,IAAT,CAAc,oBAAS,cAAT,EAAyB,EAAC,kBAAD,EAAW,QAAQ,WAAnB,EAAzB,CAAd;AACD,OAFD,MAEO;AACL,cAAM,KAAK,WAAL,CAAiB,IAAI,IAAJ,EAAjB,EAA6B,qCAA7B,CAAN;AACD;AACF;;AAED,WAAO,oBAAS,IAAT,EAAe;AACpB,gBADoB,EACd,OAAO,IADO;AAEpB,gBAAU,qBAAK,QAAL;AAFU,KAAf,CAAP;AAID;;AAED,0BAAgD;AAAA,sEAAJ,EAAI;;AAAA,QAAxB,eAAwB,SAAxB,eAAwB;;AAC9C,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA,QAAI,KAAK,YAAL,CAAkB,SAAlB,KAAgC,KAAK,SAAL,CAAe,SAAf,CAAhC,IAA8D,mBAAmB,KAAK,YAAL,CAAkB,SAAlB,CAArF,EAAoH;AAClH,aAAO,KAAK,yBAAL,CAA+B,EAAE,gCAAF,EAA/B,CAAP;AACD,KAFD,MAEO,IAAI,KAAK,UAAL,CAAgB,SAAhB,CAAJ,EAAgC;AACrC,aAAO,KAAK,oBAAL,EAAP;AACD,KAFM,MAEA,IAAI,KAAK,QAAL,CAAc,SAAd,CAAJ,EAA8B;AACnC,aAAO,KAAK,qBAAL,EAAP;AACD;AACD,wBAAO,KAAP,EAAc,qBAAd;AACD;;AAED,0BAAwB;AACtB,QAAI,MAAM,IAAI,UAAJ,CAAe,KAAK,YAAL,EAAf,EAAoC,sBAApC,EAA4C,KAAK,OAAjD,CAAV;AACA,QAAI,aAAa,EAAjB;AACA,WAAO,IAAI,IAAJ,CAAS,IAAT,KAAkB,CAAzB,EAA4B;AAC1B,iBAAW,IAAX,CAAgB,IAAI,uBAAJ,EAAhB;AACA,UAAI,YAAJ;AACD;;AAED,WAAO,oBAAS,eAAT,EAA0B;AAC/B,kBAAY,qBAAK,UAAL;AADmB,KAA1B,CAAP;AAGD;;AAED,4BAA0B;AACxB,QAAI,YAAY,KAAK,IAAL,EAAhB;;AADwB,gCAEF,KAAK,oBAAL,EAFE;;AAAA,QAEnB,IAFmB,yBAEnB,IAFmB;AAAA,QAEb,OAFa,yBAEb,OAFa;;AAGxB,QAAI,KAAK,YAAL,CAAkB,SAAlB,KAAgC,KAAK,SAAL,CAAe,SAAf,EAA0B,KAA1B,CAAhC,IAAoE,KAAK,SAAL,CAAe,SAAf,EAA0B,OAA1B,CAAxE,EAA4G;AAC1G,UAAI,CAAC,KAAK,YAAL,CAAkB,KAAK,IAAL,EAAlB,EAA+B,GAA/B,CAAL,EAA0C;AACxC,YAAI,eAAe,IAAnB;AACA,YAAI,KAAK,QAAL,CAAc,KAAK,IAAL,EAAd,CAAJ,EAAgC;AAC9B,eAAK,OAAL;AACA,cAAI,OAAO,KAAK,sBAAL,EAAX;AACA,yBAAe,IAAf;AACD;AACD,eAAO,oBAAS,2BAAT,EAAsC;AAC3C,0BAD2C,EAClC,MAAM;AAD4B,SAAtC,CAAP;AAGD;AACF;AACD,SAAK,eAAL,CAAqB,GAArB;AACA,cAAU,KAAK,sBAAL,EAAV;AACA,WAAO,oBAAS,yBAAT,EAAoC;AACzC,gBADyC,EACnC;AADmC,KAApC,CAAP;AAGD;;AAED,yBAAuB;AACrB,QAAI,UAAU,KAAK,YAAL,EAAd;AACA,QAAI,MAAM,IAAI,UAAJ,CAAe,OAAf,EAAwB,sBAAxB,EAAgC,KAAK,OAArC,CAAV;AACA,QAAI,WAAW,EAAf;AAAA,QAAmB,cAAc,IAAjC;AACA,WAAO,IAAI,IAAJ,CAAS,IAAT,KAAkB,CAAzB,EAA4B;AAC1B,UAAI,EAAJ;AACA,UAAI,IAAI,YAAJ,CAAiB,IAAI,IAAJ,EAAjB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,YAAI,YAAJ;AACA,aAAK,IAAL;AACD,OAHD,MAGO;AACL,YAAI,IAAI,YAAJ,CAAiB,IAAI,IAAJ,EAAjB,EAA6B,KAA7B,CAAJ,EAAyC;AACvC,cAAI,OAAJ;AACA,wBAAc,IAAI,qBAAJ,EAAd;AACA;AACD,SAJD,MAIO;AACL,eAAK,IAAI,sBAAJ,EAAL;AACD;AACD,YAAI,YAAJ;AACD;AACD,eAAS,IAAT,CAAc,EAAd;AACD;AACD,WAAO,oBAAS,cAAT,EAAyB;AAC9B,gBAAU,qBAAK,QAAL,CADoB;AAE9B;AAF8B,KAAzB,CAAP;AAID;;AAED,2BAAyB;AACvB,QAAI,UAAU,KAAK,qBAAL,EAAd;;AAEA,QAAI,KAAK,QAAL,CAAc,KAAK,IAAL,EAAd,CAAJ,EAAgC;AAC9B,WAAK,OAAL;AACA,UAAI,OAAO,KAAK,sBAAL,EAAX;AACA,gBAAU,oBAAS,oBAAT,EAA+B,EAAE,gBAAF,EAAW,UAAX,EAA/B,CAAV;AACD;AACD,WAAO,OAAP;AACD;;AAED,8BAAoD;AAAA,sEAAJ,EAAI;;AAAA,QAAxB,eAAwB,SAAxB,eAAwB;;AAClD,QAAI,IAAJ;AACA,QAAI,mBAAmB,KAAK,YAAL,CAAkB,KAAK,IAAL,EAAlB,CAAvB,EAAuD;AACrD,aAAO,KAAK,kBAAL,EAAP;AACD,KAFD,MAEO;AACL,aAAO,KAAK,kBAAL,EAAP;AACD;AACD,WAAO,oBAAS,mBAAT,EAA8B,EAAE,UAAF,EAA9B,CAAP;AACD;;AAED,uBAAqB;AACnB,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA,QAAI,KAAK,YAAL,CAAkB,SAAlB,CAAJ,EAAkC;AAChC,aAAO,KAAK,OAAL,EAAP;AACD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,wBAA5B,CAAN;AACD;;AAED,uBAAqB;AACnB,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA,QAAI,KAAK,YAAL,CAAkB,SAAlB,KAAgC,KAAK,SAAL,CAAe,SAAf,CAApC,EAA+D;AAC7D,aAAO,KAAK,OAAL,EAAP;AACD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,yBAA5B,CAAN;AACD;;AAGD,4BAA0B;AACxB,QAAI,KAAK,KAAK,OAAL,EAAT;AACA,QAAI,YAAY,KAAK,IAAL,EAAhB;;AAEA;AACA,QAAI,KAAK,IAAL,CAAU,IAAV,KAAmB,CAAnB,IACC,aAAa,CAAC,KAAK,YAAL,CAAkB,EAAlB,EAAsB,SAAtB,CADnB,EACsD;AACpD,aAAO,oBAAS,iBAAT,EAA4B;AACjC,oBAAY;AADqB,OAA5B,CAAP;AAGD;;AAED,QAAI,OAAO,IAAX;AACA,QAAI,CAAC,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAL,EAAwC;AACtC,aAAO,KAAK,kBAAL,EAAP;AACA,0BAAO,QAAQ,IAAf,EAAqB,kDAArB,EAAyE,SAAzE,EAAoF,KAAK,IAAzF;AACD;;AAED,SAAK,gBAAL;AACA,WAAO,oBAAS,iBAAT,EAA4B;AACjC,kBAAY;AADqB,KAA5B,CAAP;AAGD;;AAED,gCAA8B;AAC5B,QAAI,IAAJ;AACA,QAAI,YAAY,KAAK,OAAL,EAAhB;AACA,QAAI,UAAU,SAAd;AACA,QAAI,QAAQ,KAAK,OAAL,CAAa,KAAzB;;AAEA,QAAI,WACA,KAAK,OAAL,CAAa,GAAb,CAAiB,GAAjB,CAAqB,QAAQ,OAAR,CAAgB,KAAhB,CAArB,uCADJ,EAC4E;AAC1E,aAAO,KAAP;AACD,KAHD,MAGO,IAAI,WACA,KAAK,OAAL,CAAa,GAAb,CAAiB,GAAjB,CAAqB,QAAQ,OAAR,CAAgB,KAAhB,CAArB,kCADJ,EACuE;AAC5E,aAAO,KAAP;AACD,KAHM,MAGA,IAAI,WACA,KAAK,OAAL,CAAa,GAAb,CAAiB,GAAjB,CAAqB,QAAQ,OAAR,CAAgB,KAAhB,CAArB,oCADJ,EACyE;AAC9E,aAAO,OAAP;AACD,KAHM,MAGA,IAAI,WACA,KAAK,OAAL,CAAa,GAAb,CAAiB,GAAjB,CAAqB,QAAQ,OAAR,CAAgB,KAAhB,CAArB,qCADJ,EAC0E;AAC/E,aAAO,QAAP;AACD,KAHM,MAGA,IAAI,WACA,KAAK,OAAL,CAAa,GAAb,CAAiB,GAAjB,CAAqB,QAAQ,OAAR,CAAgB,KAAhB,CAArB,wCADJ,EAC6E;AAClF,aAAO,WAAP;AACD;;AAED,QAAI,QAAQ,sBAAZ;;AAEA,WAAO,IAAP,EAAa;AACX,UAAI,OAAO,KAAK,0BAAL,CAAgC,EAAE,UAAU,SAAS,QAAT,IAAqB,SAAS,WAA1C,EAAhC,CAAX;AACA,UAAI,YAAY,KAAK,IAAL,EAAhB;AACA,cAAQ,MAAM,MAAN,CAAa,IAAb,CAAR;;AAEA,UAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,aAAK,OAAL;AACD,OAFD,MAEO;AACL;AACD;AACF;;AAED,WAAO,oBAAS,qBAAT,EAAgC;AACrC,YAAM,IAD+B;AAErC,mBAAa;AAFwB,KAAhC,CAAP;AAID;;AAED,oCAAyC;AAAA,QAAZ,QAAY,SAAZ,QAAY;;AACvC,QAAI,KAAK,KAAK,qBAAL,CAA2B,EAAE,iBAAiB,QAAnB,EAA3B,CAAT;AACA,QAAI,YAAY,KAAK,IAAL,EAAhB;;AAEA,QAAI,IAAJ;AACA,QAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,WAAK,OAAL;AACA,UAAI,MAAM,IAAI,UAAJ,CAAe,KAAK,IAApB,EAA0B,sBAA1B,EAAkC,KAAK,OAAvC,CAAV;AACA,aAAO,IAAI,QAAJ,CAAa,YAAb,CAAP;AACA,WAAK,IAAL,GAAY,IAAI,IAAhB;AACD,KALD,MAKO;AACL,aAAO,IAAP;AACD;AACD,WAAO,oBAAS,oBAAT,EAA+B;AACpC,eAAS,EAD2B;AAEpC,YAAM;AAF8B,KAA/B,CAAP;AAID;;AAED,gCAA8B;AAC5B,QAAI,QAAQ,KAAK,IAAL,CAAU,GAAV,CAAc,CAAd,CAAZ;AACA,QAAI,OAAO,KAAK,kBAAL,EAAX;AACA,QAAI,SAAS,IAAb,EAAmB;AACjB,YAAM,KAAK,WAAL,CAAiB,KAAjB,EAAwB,wBAAxB,CAAN;AACD;AACD,SAAK,gBAAL;;AAEA,WAAO,oBAAS,qBAAT,EAAgC;AACrC,kBAAY;AADyB,KAAhC,CAAP;AAGD;;AAED,uBAAqB;AACnB,QAAI,OAAO,KAAK,sBAAL,EAAX;AACA,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA,QAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,aAAO,KAAK,IAAL,CAAU,IAAV,KAAmB,CAA1B,EAA6B;AAC3B,YAAI,CAAC,KAAK,YAAL,CAAkB,KAAK,IAAL,EAAlB,EAA+B,GAA/B,CAAL,EAA0C;AACxC;AACD;AACD,YAAI,WAAW,KAAK,OAAL,EAAf;AACA,YAAI,QAAQ,KAAK,sBAAL,EAAZ;AACA,eAAO,oBAAS,kBAAT,EAA6B,EAAC,UAAD,EAAO,kBAAP,EAAiB,YAAjB,EAA7B,CAAP;AACD;AACF;AACD,SAAK,IAAL,GAAY,IAAZ;AACA,WAAO,IAAP;AACD;;AAED,2BAAyB;AACvB,SAAK,IAAL,GAAY,IAAZ;AACA,SAAK,KAAL,GAAa;AACX,YAAM,CADK;AAEX,eAAU,CAAD,IAAO,CAFL;AAGX,aAAO;AAHI,KAAb;;AAMA,OAAG;AACD,UAAI,OAAO,KAAK,4BAAL,EAAX;AACA;AACA;AACA,UAAI,SAAS,mBAAT,IAAgC,KAAK,KAAL,CAAW,KAAX,CAAiB,IAAjB,GAAwB,CAA5D,EAA+D;AAC7D,aAAK,IAAL,GAAY,KAAK,KAAL,CAAW,OAAX,CAAmB,KAAK,IAAxB,CAAZ;;AAD6D,gCAEvC,KAAK,KAAL,CAAW,KAAX,CAAiB,IAAjB,EAFuC;;AAAA,YAExD,IAFwD,qBAExD,IAFwD;AAAA,YAElD,OAFkD,qBAElD,OAFkD;;AAG7D,aAAK,KAAL,CAAW,IAAX,GAAkB,IAAlB;AACA,aAAK,KAAL,CAAW,OAAX,GAAqB,OAArB;AACA,aAAK,KAAL,CAAW,KAAX,GAAmB,KAAK,KAAL,CAAW,KAAX,CAAiB,GAAjB,EAAnB;AACD,OAND,MAMO,IAAI,SAAS,mBAAb,EAAkC;AACvC;AACD,OAFM,MAEA,IAAI,SAAS,kBAAT,IAA+B,SAAS,mBAA5C,EAAiE;AACtE;AACA,aAAK,IAAL,GAAY,IAAZ;AACD,OAHM,MAGA;AACL,aAAK,IAAL,GAAY,IAAZ;AACD;AACF,KAlBD,QAkBS,IAlBT,EAkBiB;AACjB,WAAO,KAAK,IAAZ;AACD;;AAED,iCAA+B;AAC7B,QAAI,YAAY,KAAK,IAAL,EAAhB;;AAEA,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,sBAAL,CAA4B,SAA5B,CAA1B,EAAkE;AAChE,WAAK,WAAL;AACA,kBAAY,KAAK,IAAL,EAAZ;AACD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,MAAL,CAAY,SAAZ,CAA1B,EAAkD;AAChD;AACA,aAAO,KAAK,OAAL,EAAP;AACD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,SAAL,CAAe,SAAf,EAA0B,OAA1B,CAA1B,EAA8D;AAC5D,aAAO,KAAK,uBAAL,EAAP;AACD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,SAAL,CAAe,SAAf,EAA0B,OAA1B,CAA1B,EAA8D;AAC5D,aAAO,KAAK,aAAL,CAAmB,EAAC,QAAQ,IAAT,EAAnB,CAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,KACD,KAAK,YAAL,CAAkB,SAAlB,KAAgC,KAAK,QAAL,CAAc,SAAd,CAD/B,KAED,KAAK,YAAL,CAAkB,KAAK,IAAL,CAAU,CAAV,CAAlB,EAAgC,IAAhC,CAFC,IAGD,KAAK,YAAL,CAAkB,SAAlB,EAA6B,KAAK,IAAL,CAAU,CAAV,CAA7B,CAHH,EAG+C;AAC7C,aAAO,KAAK,uBAAL,EAAP;AACD;;AAID,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,gBAAL,CAAsB,SAAtB,CAA1B,EAA4D;AAC1D,aAAO,KAAK,sBAAL,EAAP;AACD;AACD;AACA,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,sBAAL,CAA4B,SAA5B,CAA1B,EAAkE;AAChE,aAAO,KAAK,mBAAL,EAAP;AACD;;AAED;AACA,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,QAAL,CAAc,SAAd,CAA1B,EAAoD;AAClD,aAAO,oBAAS,yBAAT,EAAoC;AACzC,eAAO,KAAK,OAAL,GAAe,KAAf;AADkC,OAApC,CAAP;AAGD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,KACF,KAAK,SAAL,CAAe,SAAf,EAA0B,MAA1B,KACA,KAAK,YAAL,CAAkB,SAAlB,CADA,IAEA,KAAK,SAAL,CAAe,SAAf,EAA0B,KAA1B,CAFA,IAGA,KAAK,SAAL,CAAe,SAAf,EAA0B,OAA1B,CAHA,IAIA,KAAK,gBAAL,CAAsB,SAAtB,CAJA,IAKA,KAAK,eAAL,CAAqB,SAArB,CALA,IAMA,KAAK,UAAL,CAAgB,SAAhB,CANA,IAOA,KAAK,gBAAL,CAAsB,SAAtB,CAPA,IAQA,KAAK,aAAL,CAAmB,SAAnB,CARA,IASA,KAAK,mBAAL,CAAyB,SAAzB,CATA,IAUA,KAAK,iBAAL,CAAuB,SAAvB,CAVA,IAWA,KAAK,QAAL,CAAc,SAAd,CAXA,IAYA,KAAK,UAAL,CAAgB,SAAhB,CAbE,CAAJ,EAa+B;AAC7B,aAAO,KAAK,yBAAL,EAAP;AACD;;AAED;AACA,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,UAAL,CAAgB,SAAhB,CAA1B,EAAsD;AACpD,aAAO,KAAK,uBAAL,EAAP;AACD;;AAED,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,qBAAL,CAA2B,SAA3B,CAA1B,EAAiE;AAC/D,UAAI,KAAK,KAAK,6BAAL,CAAmC,SAAnC,EAA8C,EAAvD;AACA,UAAI,OAAO,SAAX,EAAsB;AACpB,aAAK,OAAL;AACA,aAAK,IAAL,GAAY,gBAAK,EAAL,CAAQ,EAAR,EAAY,MAAZ,CAAmB,KAAK,IAAxB,CAAZ;AACA,eAAO,mBAAP;AACD;AACF;;AAED,QAAK,KAAK,IAAL,KAAc,IAAd,KACH,KAAK,cAAL,CAAoB,SAApB,KACE,KAAK,SAAL,CAAe,SAAf,EAA0B,OAA1B,CAFC,CAAD;AAGA;AACC,SAAK,IAAL;AACC;AACC,SAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,MACC,KAAK,YAAL,CAAkB,KAAK,IAAL,CAAU,CAAV,CAAlB,KAAmC,KAAK,SAAL,CAAe,KAAK,IAAL,CAAU,CAAV,CAAf,CADpC,CAAD;AAEE;AACA,SAAK,UAAL,CAAgB,SAAhB,CAHF;AAIE;AACA,SAAK,QAAL,CAAc,SAAd,CAPH,CAJL,EAYQ;AACN,aAAO,KAAK,8BAAL,CAAoC,EAAE,WAAW,IAAb,EAApC,CAAP;AACD;;AAED;AACA,QAAG,KAAK,IAAL,IAAa,KAAK,UAAL,CAAgB,SAAhB,CAAhB,EAA4C;AAC1C,aAAO,KAAK,uBAAL,EAAP;AACD;;AAED;AACA,QAAI,KAAK,IAAL,IAAa,KAAK,gBAAL,CAAsB,SAAtB,CAAjB,EAAmD;AACjD,aAAO,KAAK,wBAAL,EAAP;AACD;;AAED;AACA,QAAI,KAAK,IAAL,IAAa,KAAK,UAAL,CAAgB,SAAhB,CAAjB,EAA6C;AAC3C,aAAO,KAAK,wBAAL,EAAP;AACD;;AAED;AACA,QAAI,KAAK,IAAL,IAAa,KAAK,QAAL,CAAc,SAAd,CAAjB,EAA2C;AACzC,UAAI,UAAU,KAAK,sBAAL,CAA4B,KAAK,IAAjC,CAAd;AACA,UAAI,KAAK,KAAK,OAAL,EAAT;;AAEA,UAAI,MAAM,IAAI,UAAJ,CAAe,KAAK,IAApB,EAA0B,sBAA1B,EAAkC,KAAK,OAAvC,CAAV;AACA,UAAI,OAAO,IAAI,QAAJ,CAAa,YAAb,CAAX;AACA,WAAK,IAAL,GAAY,IAAI,IAAhB;;AAEA,UAAI,GAAG,GAAH,OAAa,GAAjB,EAAsB;AACpB,eAAO,oBAAS,sBAAT,EAAiC;AACtC,0BADsC;AAEtC,sBAAY;AAF0B,SAAjC,CAAP;AAID,OALD,MAKO;AACL,eAAO,oBAAS,8BAAT,EAAyC;AAC9C,0BAD8C;AAE9C,oBAAU,GAAG,GAAH,EAFoC;AAG9C,sBAAY;AAHkC,SAAzC,CAAP;AAKD;AACF;;AAED,QAAI,KAAK,IAAL,IAAa,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAjB,EAAoD;AAClD,aAAO,KAAK,6BAAL,EAAP;AACD;;AAED,WAAO,mBAAP;AACD;;AAED,8BAA4B;AAC1B,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA;AACA,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,SAAL,CAAe,SAAf,EAA0B,MAA1B,CAA1B,EAA6D;AAC3D,aAAO,KAAK,sBAAL,EAAP;AACD;AACD;AACA,QAAI,KAAK,IAAL,KAAc,IAAd,KAAuB,KAAK,YAAL,CAAkB,SAAlB,KAAgC,KAAK,SAAL,CAAe,SAAf,EAA0B,KAA1B,CAAhC,IAAoE,KAAK,SAAL,CAAe,SAAf,EAA0B,OAA1B,CAA3F,CAAJ,EAAoI;AAClI,aAAO,KAAK,4BAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,gBAAL,CAAsB,SAAtB,CAA1B,EAA4D;AAC1D,aAAO,KAAK,sBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,eAAL,CAAqB,SAArB,CAA1B,EAA2D;AACzD,aAAO,KAAK,qBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,UAAL,CAAgB,SAAhB,CAA1B,EAAsD;AACpD,aAAO,KAAK,uBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,gBAAL,CAAsB,SAAtB,CAA1B,EAA4D;AAC1D,aAAO,KAAK,sBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,aAAL,CAAmB,SAAnB,CAA1B,EAAyD;AACvD,aAAO,KAAK,mBAAL,EAAP;AACD;AACD,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,mBAAL,CAAyB,SAAzB,CAA1B,EAA+D;AAC7D,aAAO,KAAK,gCAAL,EAAP;AACD;AACD;AACA,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,iBAAL,CAAuB,SAAvB,CAA1B,EAA6D;AAC3D,aAAO,KAAK,0BAAL,EAAP;AACD;AACD;AACA,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,QAAL,CAAc,SAAd,CAA1B,EAAoD;AAClD,aAAO,KAAK,wBAAL,EAAP;AACD;AACD;AACA,QAAI,KAAK,IAAL,KAAc,IAAd,IAAsB,KAAK,UAAL,CAAgB,SAAhB,CAA1B,EAAsD;AACpD,aAAO,KAAK,uBAAL,EAAP;AACD;AACD,wBAAO,KAAP,EAAc,0BAAd;AACD;;AAED,wCAA8C;AAAA,QAAb,SAAa,SAAb,SAAa;;AAC5C,QAAI,YAAY,KAAK,IAAL,EAAhB;;AAEA,QAAI,KAAK,SAAL,CAAe,SAAf,EAA0B,OAA1B,CAAJ,EAAwC;AACtC,WAAK,OAAL;AACA,WAAK,IAAL,GAAY,oBAAS,OAAT,EAAkB,EAAlB,CAAZ;AACD,KAHD,MAGO,IAAI,KAAK,cAAL,CAAoB,SAApB,CAAJ,EAAoC;AACzC,WAAK,IAAL,GAAY,KAAK,qBAAL,EAAZ;AACD;;AAED,WAAO,IAAP,EAAa;AACX,kBAAY,KAAK,IAAL,EAAZ;AACA,UAAI,KAAK,QAAL,CAAc,SAAd,CAAJ,EAA8B;AAC5B,YAAI,CAAC,SAAL,EAAgB;AACd;AACA,cAAI,KAAK,IAAL,KACC,mCAAuB,KAAK,IAA5B,KACA,qCAAyB,KAAK,IAA9B,CADA,IAEA,uCAA2B,KAAK,IAAhC,CAHD,CAAJ,EAG6C;AAC3C,mBAAO,KAAK,IAAZ;AACD;AACD,eAAK,IAAL,GAAY,KAAK,sBAAL,EAAZ;AACD,SATD,MASO;AACL,eAAK,IAAL,GAAY,KAAK,sBAAL,EAAZ;AACD;AACF,OAbD,MAaO,IAAI,KAAK,UAAL,CAAgB,SAAhB,CAAJ,EAAgC;AACrC,aAAK,IAAL,GAAY,KAAK,IAAL,GAAY,KAAK,gCAAL,EAAZ,GAAsD,KAAK,yBAAL,EAAlE;AACD,OAFM,MAEA,IAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,MACT,KAAK,YAAL,CAAkB,KAAK,IAAL,CAAU,CAAV,CAAlB,KAAmC,KAAK,SAAL,CAAe,KAAK,IAAL,CAAU,CAAV,CAAf,CAD1B,CAAJ,EAC6D;AAClE,aAAK,IAAL,GAAY,KAAK,8BAAL,EAAZ;AACD,OAHM,MAGA,IAAI,KAAK,UAAL,CAAgB,SAAhB,CAAJ,EAAgC;AACrC,aAAK,IAAL,GAAY,KAAK,uBAAL,EAAZ;AACD,OAFM,MAEA,IAAI,KAAK,QAAL,CAAc,SAAd,CAAJ,EAA8B;AACnC,aAAK,IAAL,GAAY,KAAK,yBAAL,EAAZ;AACD,OAFM,MAEA,IAAI,KAAK,YAAL,CAAkB,SAAlB,CAAJ,EAAkC;AACvC,aAAK,IAAL,GAAY,oBAAS,sBAAT,EAAiC,EAAE,MAAM,KAAK,kBAAL,EAAR,EAAjC,CAAZ;AACD,OAFM,MAEA;AACL;AACD;AACF;AACD,WAAO,KAAK,IAAZ;AACD;;AAED,2BAAyB;AACvB,WAAO,oBAAS,0BAAT,EAAqC;AAC1C,aAAO,KAAK,OAAL;AADmC,KAArC,CAAP;AAGD;;AAED,4BAA0B;AACxB,WAAO,oBAAS,oBAAT,EAA+B;AACpC,WAAK,KAAK,IAD0B;AAEpC,gBAAU,KAAK,wBAAL;AAF0B,KAA/B,CAAP;AAID;;AAED,0BAAwB;AACtB,WAAO,oBAAS,yBAAT,EAAoC;AACzC,aAAO,KAAK,OAAL;AADkC,KAApC,CAAP;AAGD;;AAED,2BAAyB;AACvB,QAAI,MAAM,KAAK,OAAL,EAAV;AACA,QAAI,IAAI,GAAJ,OAAc,IAAI,CAAtB,EAAyB;AACvB,aAAO,oBAAS,2BAAT,EAAsC,EAAtC,CAAP;AACD;AACD,WAAO,oBAAS,0BAAT,EAAqC;AAC1C,aAAO;AADmC,KAArC,CAAP;AAGD;;AAED,iCAA+B;AAC7B,WAAO,oBAAS,sBAAT,EAAiC;AACtC,YAAM,KAAK,OAAL;AADgC,KAAjC,CAAP;AAGD;;AAED,qCAAmC;AACjC,QAAI,QAAQ,KAAK,OAAL,EAAZ;;AAEA,QAAI,YAAY,MAAM,KAAN,CAAY,KAAZ,CAAkB,WAAlB,CAA8B,GAA9B,CAAhB;AACA,QAAI,UAAU,MAAM,KAAN,CAAY,KAAZ,CAAkB,KAAlB,CAAwB,CAAxB,EAA2B,SAA3B,CAAd;AACA,QAAI,QAAQ,MAAM,KAAN,CAAY,KAAZ,CAAkB,KAAlB,CAAwB,YAAY,CAApC,CAAZ;AACA,WAAO,oBAAS,yBAAT,EAAoC;AACzC,sBADyC,EAChC;AADgC,KAApC,CAAP;AAGD;;AAED,wBAAsB;AACpB,SAAK,OAAL;AACA,WAAO,oBAAS,uBAAT,EAAkC,EAAlC,CAAP;AACD;;AAED,2BAAyB;AACvB,WAAO,oBAAS,gBAAT,EAA2B;AAChC,WAAK,KAAK,OAAL;AAD2B,KAA3B,CAAP;AAGD;;AAED,yBAAuB;AACrB,QAAI,SAAS,EAAb;AACA,WAAO,KAAK,IAAL,CAAU,IAAV,GAAiB,CAAxB,EAA2B;AACzB,UAAI,GAAJ;AACA,UAAI,KAAK,YAAL,CAAkB,KAAK,IAAL,EAAlB,EAA+B,KAA/B,CAAJ,EAA2C;AACzC,aAAK,OAAL;AACA,cAAM,oBAAS,eAAT,EAA0B;AAC9B,sBAAY,KAAK,sBAAL;AADkB,SAA1B,CAAN;AAGD,OALD,MAKO;AACL,cAAM,KAAK,sBAAL,EAAN;AACD;AACD,UAAI,KAAK,IAAL,CAAU,IAAV,GAAiB,CAArB,EAAwB;AACtB,aAAK,eAAL,CAAqB,GAArB;AACD;AACD,aAAO,IAAP,CAAY,GAAZ;AACD;AACD,WAAO,qBAAK,MAAL,CAAP;AACD;;AAED,0BAAwB;AACtB,SAAK,YAAL,CAAkB,KAAlB;AACA,QAAI,KAAK,YAAL,CAAkB,KAAK,IAAL,EAAlB,EAA+B,GAA/B,KAAuC,KAAK,YAAL,CAAkB,KAAK,IAAL,CAAU,CAAV,CAAlB,EAAgC,QAAhC,CAA3C,EAAsF;AACpF,WAAK,OAAL;AACA,WAAK,OAAL;AACA,aAAO,oBAAS,qBAAT,EAAgC,EAAhC,CAAP;AACD;;AAED,QAAI,SAAS,KAAK,8BAAL,CAAoC,EAAE,WAAW,KAAb,EAApC,CAAb;AACA,QAAI,IAAJ;AACA,QAAI,KAAK,QAAL,CAAc,KAAK,IAAL,EAAd,CAAJ,EAAgC;AAC9B,aAAO,KAAK,WAAL,EAAP;AACD,KAFD,MAEO;AACL,aAAO,sBAAP;AACD;AACD,WAAO,oBAAS,eAAT,EAA0B;AAC/B,oBAD+B;AAE/B,iBAAW;AAFoB,KAA1B,CAAP;AAID;;AAED,qCAAmC;AACjC,QAAI,MAAM,IAAI,UAAJ,CAAe,KAAK,YAAL,EAAf,EAAoC,sBAApC,EAA4C,KAAK,OAAjD,CAAV;AACA,WAAO,oBAAS,0BAAT,EAAqC;AAC1C,cAAQ,KAAK,IAD6B;AAE1C,kBAAY,IAAI,kBAAJ;AAF8B,KAArC,CAAP;AAID;;AAED,yBAAuB,IAAvB,EAA6B;AAC3B,YAAQ,KAAK,IAAb;AACE,WAAK,sBAAL;AACE,eAAO,oBAAS,mBAAT,EAA8B,EAAC,MAAM,KAAK,IAAZ,EAA9B,CAAP;;AAEF,WAAK,yBAAL;AACE,YAAI,KAAK,KAAL,CAAW,IAAX,KAAoB,CAApB,IAAyB,KAAK,YAAL,CAAkB,KAAK,KAAL,CAAW,GAAX,CAAe,CAAf,CAAlB,CAA7B,EAAmE;AACjE,iBAAO,oBAAS,mBAAT,EAA8B,EAAE,MAAM,KAAK,KAAL,CAAW,GAAX,CAAe,CAAf,CAAR,EAA9B,CAAP;AACD;AACD,eAAO,IAAP;AACF,WAAK,cAAL;AACE,eAAO,oBAAS,yBAAT,EAAoC;AACzC,gBAAM,KAAK,IAD8B;AAEzC,mBAAS,KAAK,iCAAL,CAAuC,KAAK,UAA5C;AAFgC,SAApC,CAAP;AAIF,WAAK,mBAAL;AACE,eAAO,oBAAS,2BAAT,EAAsC;AAC3C,mBAAS,oBAAS,mBAAT,EAA8B,EAAE,MAAM,KAAK,IAAb,EAA9B,CADkC;AAE3C,gBAAM;AAFqC,SAAtC,CAAP;AAIF,WAAK,kBAAL;AACE,eAAO,oBAAS,eAAT,EAA0B;AAC/B,sBAAY,KAAK,UAAL,CAAgB,GAAhB,CAAoB,KAAK,KAAK,sBAAL,CAA4B,CAA5B,CAAzB;AADmB,SAA1B,CAAP;AAGF,WAAK,iBAAL;AAAwB;AACtB,cAAI,OAAO,KAAK,QAAL,CAAc,IAAd,EAAX;AACA,cAAI,QAAQ,IAAR,IAAgB,KAAK,IAAL,KAAc,eAAlC,EAAmD;AACjD,mBAAO,oBAAS,cAAT,EAAyB;AAC9B,wBAAU,KAAK,QAAL,CAAc,KAAd,CAAoB,CAApB,EAAuB,CAAC,CAAxB,EAA2B,GAA3B,CAA+B,KAAK,KAAK,KAAK,iCAAL,CAAuC,CAAvC,CAAzC,CADoB;AAE9B,2BAAa,KAAK,iCAAL,CAAuC,KAAK,UAA5C;AAFiB,aAAzB,CAAP;AAID,WALD,MAKO;AACL,mBAAO,oBAAS,cAAT,EAAyB;AAC9B,wBAAU,KAAK,QAAL,CAAc,GAAd,CAAkB,KAAK,KAAK,KAAK,iCAAL,CAAuC,CAAvC,CAA5B,CADoB;AAE9B,2BAAa;AAFiB,aAAzB,CAAP;AAID;AACF;AACD,WAAK,oBAAL;AACE,eAAO,oBAAS,mBAAT,EAA8B;AACnC,gBAAM,KAAK;AADwB,SAA9B,CAAP;AAGF,WAAK,0BAAL;AACA,WAAK,wBAAL;AACA,WAAK,cAAL;AACA,WAAK,mBAAL;AACA,WAAK,2BAAL;AACA,WAAK,yBAAL;AACA,WAAK,oBAAL;AACA,WAAK,eAAL;AACE,eAAO,IAAP;AAjDJ;AAmDA,wBAAO,KAAP,EAAc,6BAA6B,KAAK,IAAhD;AACD;;AAED,oCAAkC,IAAlC,EAAwC;AACtC,YAAQ,KAAK,IAAb;AACE,WAAK,sBAAL;AACE,eAAO,oBAAS,oBAAT,EAA+B;AACpC,mBAAS,KAAK,sBAAL,CAA4B,KAAK,OAAjC,CAD2B;AAEpC,gBAAM,KAAK;AAFyB,SAA/B,CAAP;AAFJ;AAOA,WAAO,KAAK,sBAAL,CAA4B,IAA5B,CAAP;AACD;;AAED,2BAAyB;AACvB,QAAI,QAAQ,KAAK,OAAL,EAAZ;AACA,WAAO,oBAAS,gBAAT,EAA2B;AAChC,cAAQ,KAAK,IADmB;AAEhC,iBAAW,MAAM,KAAN;AAFqB,KAA3B,CAAP;AAID;;AAED,4BAA0B;AACxB,QAAI,GAAJ;AACA,QAAI,KAAK,YAAL,CAAkB,KAAK,IAAL,EAAlB,CAAJ,EAAoC;AAClC,YAAM,IAAI,UAAJ,CAAe,gBAAK,EAAL,CAAQ,KAAK,OAAL,EAAR,CAAf,EAAwC,sBAAxC,EAAgD,KAAK,OAArD,CAAN;AACD,KAFD,MAEO;AACL,UAAI,IAAI,KAAK,WAAL,EAAR;AACA,YAAM,IAAI,UAAJ,CAAe,CAAf,EAAkB,sBAAlB,EAA0B,KAAK,OAA/B,CAAN;AACD;AACD,QAAI,SAAS,IAAI,wBAAJ,EAAb;AACA,SAAK,eAAL,CAAqB,IAArB;;AAEA,QAAI,IAAJ;AACA,QAAI,KAAK,QAAL,CAAc,KAAK,IAAL,EAAd,CAAJ,EAAgC;AAC9B,aAAO,KAAK,YAAL,EAAP;AACD,KAFD,MAEO;AACL,YAAM,IAAI,UAAJ,CAAe,KAAK,IAApB,EAA0B,sBAA1B,EAAkC,KAAK,OAAvC,CAAN;AACA,aAAO,IAAI,sBAAJ,EAAP;AACA,WAAK,IAAL,GAAY,IAAI,IAAhB;AACD;AACD,WAAO,oBAAS,iBAAT,EAA4B,EAAE,cAAF,EAAU,UAAV,EAA5B,CAAP;AACD;;AAGD,4BAA0B;AACxB,QAAI,MAAM,KAAK,YAAL,CAAkB,OAAlB,CAAV;AACA,QAAI,YAAY,KAAK,IAAL,EAAhB;;AAEA,QAAI,KAAK,IAAL,CAAU,IAAV,KAAmB,CAAnB,IAAyB,aAAa,CAAC,KAAK,YAAL,CAAkB,GAAlB,EAAuB,SAAvB,CAA3C,EAA+E;AAC7E,aAAO,oBAAS,iBAAT,EAA4B;AACjC,oBAAY;AADqB,OAA5B,CAAP;AAGD,KAJD,MAIO;AACL,UAAI,cAAc,KAAlB;AACA,UAAI,KAAK,YAAL,CAAkB,KAAK,IAAL,EAAlB,EAA+B,GAA/B,CAAJ,EAAyC;AACrC,sBAAc,IAAd;AACA,aAAK,OAAL;AACH;AACD,UAAI,OAAO,KAAK,kBAAL,EAAX;AACA,UAAI,OAAO,cAAc,0BAAd,GAA2C,iBAAtD;AACA,aAAO,oBAAS,IAAT,EAAe;AACpB,oBAAY;AADQ,OAAf,CAAP;AAGD;AACF;;AAED,2BAAyB;AACvB,WAAO,oBAAS,gBAAT,EAA2B;AAChC,gBAAU,KAAK,OAAL;AADsB,KAA3B,CAAP;AAGD;;AAED,wBAAsB;AACpB,QAAI,OAAO,KAAK,OAAL,EAAX;AACA,WAAO,oBAAS,aAAT,EAAwB;AAC7B,YAAM,IADuB;AAE7B,gBAAU,oBAAS,oBAAT,EAA+B;AACvC,aAAK,oBAAS,sBAAT,EAAiC;AACpC,gBAAM;AAD8B,SAAjC,CADkC;AAIvC,kBAAU,KAAK,wBAAL;AAJ6B,OAA/B;AAFmB,KAAxB,CAAP;AASD;;AAED,mCAAiC;AAC/B,QAAI,SAAS,KAAK,IAAlB;AACA,SAAK,OAAL;AACA,QAAI,WAAW,KAAK,OAAL,EAAf;;AAEA,WAAO,oBAAS,wBAAT,EAAmC;AACxC,cAAQ,MADgC;AAExC,gBAAU;AAF8B,KAAnC,CAAP;AAID;;AAED,4BAA0B;AACxB,QAAI,MAAM,KAAK,OAAL,EAAV;;AAEA,QAAI,WAAW,EAAf;;AAEA,QAAI,MAAM,IAAI,UAAJ,CAAe,IAAI,KAAJ,EAAf,EAA4B,sBAA5B,EAAoC,KAAK,OAAzC,CAAV;;AAEA,WAAO,IAAI,IAAJ,CAAS,IAAT,GAAgB,CAAvB,EAA0B;AACxB,UAAI,YAAY,IAAI,IAAJ,EAAhB;AACA,UAAI,IAAI,YAAJ,CAAiB,SAAjB,EAA4B,GAA5B,CAAJ,EAAsC;AACpC,YAAI,OAAJ;AACA,iBAAS,IAAT,CAAc,IAAd;AACD,OAHD,MAGO,IAAI,IAAI,YAAJ,CAAiB,SAAjB,EAA4B,KAA5B,CAAJ,EAAwC;AAC7C,YAAI,OAAJ;AACA,YAAI,aAAa,IAAI,sBAAJ,EAAjB;AACA,YAAI,cAAc,IAAlB,EAAwB;AACtB,gBAAM,IAAI,WAAJ,CAAgB,SAAhB,EAA2B,sBAA3B,CAAN;AACD;AACD,iBAAS,IAAT,CAAc,oBAAS,eAAT,EAA0B,EAAE,sBAAF,EAA1B,CAAd;AACD,OAPM,MAOA;AACL,YAAI,OAAO,IAAI,sBAAJ,EAAX;AACA,YAAI,QAAQ,IAAZ,EAAkB;AAChB,gBAAM,IAAI,WAAJ,CAAgB,SAAhB,EAA2B,qBAA3B,CAAN;AACD;AACD,iBAAS,IAAT,CAAc,IAAd;AACA,YAAI,YAAJ;AACD;AACF;;AAED,WAAO,oBAAS,iBAAT,EAA4B;AACjC,gBAAU,qBAAK,QAAL;AADuB,KAA5B,CAAP;AAGD;;AAED,6BAA2B;AACzB,QAAI,MAAM,KAAK,OAAL,EAAV;;AAEA,QAAI,aAAa,sBAAjB;;AAEA,QAAI,MAAM,IAAI,UAAJ,CAAe,IAAI,KAAJ,EAAf,EAA4B,sBAA5B,EAAoC,KAAK,OAAzC,CAAV;;AAEA,QAAI,WAAW,IAAf;AACA,WAAO,IAAI,IAAJ,CAAS,IAAT,GAAgB,CAAvB,EAA0B;AACxB,UAAI,OAAO,IAAI,0BAAJ,EAAX;AACA,UAAI,YAAJ;AACA,mBAAa,WAAW,MAAX,CAAkB,IAAlB,CAAb;;AAEA,UAAI,aAAa,IAAjB,EAAuB;AACrB,cAAM,IAAI,WAAJ,CAAgB,IAAhB,EAAsB,0BAAtB,CAAN;AACD;AACD,iBAAW,IAAX;AACD;;AAED,WAAO,oBAAS,kBAAT,EAA6B;AAClC,kBAAY;AADsB,KAA7B,CAAP;AAGD;;AAED,+BAA6B;AAAA,gCAED,KAAK,wBAAL,EAFC;;AAAA,QAEtB,WAFsB,yBAEtB,WAFsB;AAAA,QAET,IAFS,yBAET,IAFS;;;AAI3B,YAAQ,IAAR;AACE,WAAK,QAAL;AACE,eAAO,WAAP;AACF,WAAK,YAAL;AACE,YAAI,KAAK,QAAL,CAAc,KAAK,IAAL,EAAd,CAAJ,EAAgC;AAC9B,eAAK,OAAL;AACA,cAAI,OAAO,KAAK,sBAAL,EAAX;AACA,iBAAO,oBAAS,2BAAT,EAAsC;AAC3C,sBAD2C,EACrC,SAAS,KAAK,sBAAL,CAA4B,WAA5B;AAD4B,WAAtC,CAAP;AAGD,SAND,MAMO,IAAI,CAAC,KAAK,YAAL,CAAkB,KAAK,IAAL,EAAlB,EAA+B,GAA/B,CAAL,EAA0C;AAC/C,iBAAO,oBAAS,mBAAT,EAA8B;AACnC,kBAAM,YAAY;AADiB,WAA9B,CAAP;AAGD;AAdL;;AAiBA,SAAK,eAAL,CAAqB,GAArB;AACA,QAAI,OAAO,KAAK,sBAAL,EAAX;;AAEA,WAAO,oBAAS,cAAT,EAAyB;AAC9B,YAAM,WADwB;AAE9B,kBAAY;AAFkB,KAAzB,CAAP;AAID;;AAED,6BAA2B;AACzB,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA,QAAI,cAAc,KAAlB;AACA,QAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,oBAAc,IAAd;AACA,WAAK,OAAL;AACD;;AAED,QAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,KAA7B,KAAuC,KAAK,cAAL,CAAoB,KAAK,IAAL,CAAU,CAAV,CAApB,CAA3C,EAA8E;AAC5E,WAAK,OAAL;;AAD4E,mCAE/D,KAAK,oBAAL,EAF+D;;AAAA,UAEvE,IAFuE,0BAEvE,IAFuE;;AAG5E,WAAK,WAAL;AACA,UAAI,OAAO,KAAK,YAAL,EAAX;AACA,aAAO;AACL,qBAAa,oBAAS,QAAT,EAAmB,EAAE,UAAF,EAAQ,UAAR,EAAnB,CADR;AAEL,cAAM;AAFD,OAAP;AAID,KATD,MASO,IAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,KAA7B,KAAuC,KAAK,cAAL,CAAoB,KAAK,IAAL,CAAU,CAAV,CAApB,CAA3C,EAA8E;AACnF,WAAK,OAAL;;AADmF,mCAEtE,KAAK,oBAAL,EAFsE;;AAAA,UAE9E,IAF8E,0BAE9E,IAF8E;;AAGnF,UAAI,MAAM,IAAI,UAAJ,CAAe,KAAK,WAAL,EAAf,EAAmC,sBAAnC,EAA2C,KAAK,OAAhD,CAAV;AACA,UAAI,QAAQ,IAAI,sBAAJ,EAAZ;AACA,UAAI,OAAO,KAAK,YAAL,EAAX;AACA,aAAO;AACL,qBAAa,oBAAS,QAAT,EAAmB,EAAE,UAAF,EAAQ,YAAR,EAAe,UAAf,EAAnB,CADR;AAEL,cAAM;AAFD,OAAP;AAID;;AA3BwB,iCA4BZ,KAAK,oBAAL,EA5BY;;AAAA,QA4BpB,IA5BoB,0BA4BpB,IA5BoB;;AA6BzB,QAAI,KAAK,QAAL,CAAc,KAAK,IAAL,EAAd,CAAJ,EAAgC;AAC9B,UAAI,SAAS,KAAK,WAAL,EAAb;AACA,UAAI,MAAM,IAAI,UAAJ,CAAe,MAAf,EAAuB,sBAAvB,EAA+B,KAAK,OAApC,CAAV;AACA,UAAI,eAAe,IAAI,wBAAJ,EAAnB;;AAEA,UAAI,OAAO,KAAK,YAAL,EAAX;AACA,aAAO;AACL,qBAAa,oBAAS,QAAT,EAAmB;AAC9B,kCAD8B;AAE9B,oBAF8B,EAExB,QAAQ,YAFgB,EAEF;AAFE,SAAnB,CADR;AAKL,cAAM;AALD,OAAP;AAOD;AACD,WAAO;AACL,mBAAa,IADR;AAEL,YAAM,KAAK,YAAL,CAAkB,SAAlB,KAAgC,KAAK,SAAL,CAAe,SAAf,CAAhC,GAA4D,YAA5D,GAA2E;AAF5E,KAAP;AAID;;AAED,yBAAuB;AACrB,QAAI,YAAY,KAAK,IAAL,EAAhB;;AAEA,QAAI,KAAK,eAAL,CAAqB,SAArB,KAAmC,KAAK,gBAAL,CAAsB,SAAtB,CAAvC,EAAyE;AACvE,aAAO;AACL,cAAM,oBAAS,oBAAT,EAA+B;AACnC,iBAAO,KAAK,OAAL;AAD4B,SAA/B,CADD;AAIL,iBAAS;AAJJ,OAAP;AAMD,KAPD,MAOO,IAAI,KAAK,UAAL,CAAgB,SAAhB,CAAJ,EAAgC;AACrC,UAAI,MAAM,IAAI,UAAJ,CAAe,KAAK,YAAL,EAAf,EAAoC,sBAApC,EAA4C,KAAK,OAAjD,CAAV;AACA,UAAI,OAAO,IAAI,sBAAJ,EAAX;AACA,aAAO;AACL,cAAM,oBAAS,sBAAT,EAAiC;AACrC,sBAAY;AADyB,SAAjC,CADD;AAIL,iBAAS;AAJJ,OAAP;AAMD;AACD,QAAI,OAAO,KAAK,OAAL,EAAX;AACA,WAAO;AACL,YAAM,oBAAS,oBAAT,EAA+B,EAAE,OAAO,IAAT,EAA/B,CADD;AAEL,eAAS,oBAAS,mBAAT,EAA8B,EAAE,UAAF,EAA9B;AAFJ,KAAP;AAID;;AAED,0BAAsC;AAAA,QAApB,MAAoB,SAApB,MAAoB;AAAA,QAAZ,SAAY,SAAZ,SAAY;;AACpC,QAAI,OAAO,IAAX;AAAA,QAAiB,MAAjB;AAAA,QAAyB,IAAzB;AACA,QAAI,cAAc,KAAlB;AACA;AACA,QAAI,YAAY,KAAK,OAAL,EAAhB;AACA,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA,QAAI,OAAO,SAAS,oBAAT,GAAgC,qBAA3C;;AAEA,QAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,oBAAc,IAAd;AACA,WAAK,OAAL;AACA,kBAAY,KAAK,IAAL,EAAZ;AACD;;AAED,QAAI,CAAC,KAAK,QAAL,CAAc,SAAd,CAAL,EAA+B;AAC7B,aAAO,KAAK,yBAAL,EAAP;AACD,KAFD,MAEO,IAAI,SAAJ,EAAe;AACpB,aAAO,oBAAS,mBAAT,EAA8B;AACnC,cAAM,iBAAO,cAAP,CAAsB,WAAtB,EAAmC,SAAnC;AAD6B,OAA9B,CAAP;AAGD;;AAGD,aAAS,KAAK,WAAL,EAAT;;AAGA,WAAO,KAAK,YAAL,EAAP;;AAEA,QAAI,MAAM,IAAI,UAAJ,CAAe,MAAf,EAAuB,sBAAvB,EAA+B,KAAK,OAApC,CAAV;AACA,QAAI,eAAe,IAAI,wBAAJ,EAAnB;;AAEA,WAAO,oBAAS,IAAT,EAAe;AACpB,YAAM,IADc;AAEpB,mBAAa,WAFO;AAGpB,cAAQ,YAHY;AAIpB,YAAM;AAJc,KAAf,CAAP;AAMD;;AAED,+BAA6B;AAC3B,QAAI,OAAO,IAAX;AAAA,QAAiB,MAAjB;AAAA,QAAyB,IAAzB;AACA,QAAI,cAAc,KAAlB;AACA;AACA,SAAK,OAAL;AACA,QAAI,YAAY,KAAK,IAAL,EAAhB;;AAEA,QAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,oBAAc,IAAd;AACA,WAAK,OAAL;AACA,kBAAY,KAAK,IAAL,EAAZ;AACD;;AAED,QAAI,CAAC,KAAK,QAAL,CAAc,SAAd,CAAL,EAA+B;AAC7B,aAAO,KAAK,yBAAL,EAAP;AACD;;AAED,aAAS,KAAK,WAAL,EAAT;AACA,WAAO,KAAK,YAAL,EAAP;;AAEA,QAAI,MAAM,IAAI,UAAJ,CAAe,MAAf,EAAuB,sBAAvB,EAA+B,KAAK,OAApC,CAAV;AACA,QAAI,eAAe,IAAI,wBAAJ,EAAnB;;AAEA,WAAO,oBAAS,oBAAT,EAA+B;AACpC,YAAM,IAD8B;AAEpC,mBAAa,WAFuB;AAGpC,cAAQ,YAH4B;AAIpC,YAAM;AAJ8B,KAA/B,CAAP;AAMD;;AAED,gCAA8B;AAC5B,QAAI,IAAJ,EAAU,MAAV,EAAkB,IAAlB;AACA,QAAI,cAAc,KAAlB;AACA;AACA,SAAK,OAAL;AACA,QAAI,YAAY,KAAK,IAAL,EAAhB;;AAEA,QAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,oBAAc,IAAd;AACA,WAAK,OAAL;AACD;;AAED,WAAO,KAAK,yBAAL,EAAP;;AAEA,aAAS,KAAK,WAAL,EAAT;AACA,WAAO,KAAK,YAAL,EAAP;;AAEA,QAAI,MAAM,IAAI,UAAJ,CAAe,MAAf,EAAuB,sBAAvB,EAA+B,KAAK,OAApC,CAAV;AACA,QAAI,eAAe,IAAI,wBAAJ,EAAnB;;AAEA,WAAO,oBAAS,qBAAT,EAAgC;AACrC,YAAM,IAD+B;AAErC,mBAAa,WAFwB;AAGrC,cAAQ,YAH6B;AAIrC,YAAM;AAJ+B,KAAhC,CAAP;AAMD;;AAED,6BAA2B;AACzB,QAAI,QAAQ,EAAZ;AACA,QAAI,OAAO,IAAX;AACA,WAAO,KAAK,IAAL,CAAU,IAAV,KAAmB,CAA1B,EAA6B;AAC3B,UAAI,YAAY,KAAK,IAAL,EAAhB;AACA,UAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,KAA7B,CAAJ,EAAyC;AACvC,aAAK,eAAL,CAAqB,KAArB;AACA,eAAO,KAAK,yBAAL,EAAP;AACA;AACD;AACD,YAAM,IAAN,CAAW,KAAK,aAAL,EAAX;AACA,WAAK,YAAL;AACD;AACD,WAAO,oBAAS,kBAAT,EAA6B;AAClC,aAAO,qBAAK,KAAL,CAD2B,EACd;AADc,KAA7B,CAAP;AAGD;;AAED,kBAAgB;AACd,WAAO,KAAK,sBAAL,EAAP;AACD;;AAED,6BAA2B;AACzB,QAAI,WAAW,KAAK,kBAAL,EAAf;;AAEA,WAAO,oBAAS,kBAAT,EAA6B;AAClC,gBAAU,KADwB;AAElC,gBAAU,SAAS,GAAT,EAFwB;AAGlC,eAAS,KAAK,sBAAL,CAA4B,KAAK,IAAjC;AAHyB,KAA7B,CAAP;AAKD;;AAED,4BAA0B;AACxB,QAAI,WAAW,KAAK,kBAAL,EAAf;AACA,SAAK,KAAL,CAAW,KAAX,GAAmB,KAAK,KAAL,CAAW,KAAX,CAAiB,IAAjB,CAAsB;AACvC,YAAM,KAAK,KAAL,CAAW,IADsB;AAEvC,eAAS,KAAK,KAAL,CAAW;AAFmB,KAAtB,CAAnB;AAIA;AACA,SAAK,KAAL,CAAW,IAAX,GAAkB,EAAlB;AACA,SAAK,KAAL,CAAW,OAAX,GAAqB,aAAa;AAChC,UAAI,SAAS,GAAT,OAAmB,IAAnB,IAA2B,SAAS,GAAT,OAAmB,IAAlD,EAAwD;AACtD,eAAO,oBAAS,kBAAT,EAA6B;AAClC,oBAAU,SAAS,GAAT,EADwB;AAElC,mBAAS,KAAK,sBAAL,CAA4B,SAA5B,CAFyB;AAGlC,oBAAU;AAHwB,SAA7B,CAAP;AAKD,OAND,MAMO;AACL,eAAO,oBAAS,iBAAT,EAA4B;AACjC,oBAAU,SAAS,GAAT,EADuB;AAEjC,mBAAS;AAFwB,SAA5B,CAAP;AAID;AACF,KAbD;AAcA,WAAO,kBAAP;AACD;;AAED,kCAAgC;AAC9B;AACA,QAAI,OAAO,KAAK,KAAL,CAAW,OAAX,CAAmB,KAAK,IAAxB,CAAX;AACA,QAAI,KAAK,KAAL,CAAW,KAAX,CAAiB,IAAjB,GAAwB,CAA5B,EAA+B;AAAA,+BACL,KAAK,KAAL,CAAW,KAAX,CAAiB,IAAjB,EADK;;AAAA,UACvB,IADuB,sBACvB,IADuB;AAAA,UACjB,OADiB,sBACjB,OADiB;;AAE7B,WAAK,KAAL,CAAW,KAAX,GAAmB,KAAK,KAAL,CAAW,KAAX,CAAiB,GAAjB,EAAnB;AACA,WAAK,KAAL,CAAW,IAAX,GAAkB,IAAlB;AACA,WAAK,KAAL,CAAW,OAAX,GAAqB,OAArB;AACD;;AAED,SAAK,eAAL,CAAqB,GAArB;AACA,QAAI,MAAM,IAAI,UAAJ,CAAe,KAAK,IAApB,EAA0B,sBAA1B,EAAkC,KAAK,OAAvC,CAAV;AACA,QAAI,aAAa,IAAI,sBAAJ,EAAjB;AACA,QAAI,eAAJ,CAAoB,GAApB;AACA,UAAM,IAAI,UAAJ,CAAe,IAAI,IAAnB,EAAyB,sBAAzB,EAAiC,KAAK,OAAtC,CAAN;AACA,QAAI,YAAY,IAAI,sBAAJ,EAAhB;AACA,SAAK,IAAL,GAAY,IAAI,IAAhB;AACA,WAAO,oBAAS,uBAAT,EAAkC;AACvC,gBADuC,EACjC,sBADiC,EACrB;AADqB,KAAlC,CAAP;AAGD;;AAED,6BAA2B;;AAEzB,QAAI,WAAW,KAAK,IAApB;AACA,QAAI,QAAQ,KAAK,IAAL,EAAZ;AACA,QAAI,KAAK,MAAM,GAAN,EAAT;AACA,QAAI,SAAS,gCAAgB,EAAhB,CAAb;AACA,QAAI,UAAU,iCAAiB,EAAjB,CAAd;;AAEA,QAAI,2BAAW,KAAK,KAAL,CAAW,IAAtB,EAA4B,MAA5B,EAAoC,OAApC,CAAJ,EAAkD;AAChD,WAAK,KAAL,CAAW,KAAX,GAAmB,KAAK,KAAL,CAAW,KAAX,CAAiB,IAAjB,CAAsB;AACvC,cAAM,KAAK,KAAL,CAAW,IADsB;AAEvC,iBAAS,KAAK,KAAL,CAAW;AAFmB,OAAtB,CAAnB;AAIA,WAAK,KAAL,CAAW,IAAX,GAAkB,MAAlB;AACA,WAAK,KAAL,CAAW,OAAX,GAAsB,SAAD,IAAe;AAClC,eAAO,oBAAS,kBAAT,EAA6B;AAClC,gBAAM,QAD4B;AAElC,oBAAU,KAFwB;AAGlC,iBAAO;AAH2B,SAA7B,CAAP;AAKD,OAND;AAOA,WAAK,OAAL;AACA,aAAO,kBAAP;AACD,KAfD,MAeO;AACL,UAAI,OAAO,KAAK,KAAL,CAAW,OAAX,CAAmB,QAAnB,CAAX;AACA;;AAFK,+BAGmB,KAAK,KAAL,CAAW,KAAX,CAAiB,IAAjB,EAHnB;;AAAA,UAGC,IAHD,sBAGC,IAHD;AAAA,UAGO,OAHP,sBAGO,OAHP;;AAIL,WAAK,KAAL,CAAW,KAAX,GAAmB,KAAK,KAAL,CAAW,KAAX,CAAiB,GAAjB,EAAnB;AACA,WAAK,KAAL,CAAW,IAAX,GAAkB,IAAlB;AACA,WAAK,KAAL,CAAW,OAAX,GAAqB,OAArB;AACA,aAAO,IAAP;AACD;AACF;;AAED,6BAA2B;AACzB,QAAI,YAAY,KAAK,aAAL,EAAhB;AACA,QAAI,WAAW,UAAU,KAAV,CAAgB,KAAhB,CAAsB,GAAtB,CAA0B,MAAM;AAC7C,UAAI,KAAK,WAAL,CAAiB,EAAjB,CAAJ,EAA0B;AACxB,YAAI,MAAM,IAAI,UAAJ,CAAe,GAAG,KAAH,EAAf,EAA2B,sBAA3B,EAAmC,KAAK,OAAxC,CAAV;AACA,eAAO,IAAI,QAAJ,CAAa,YAAb,CAAP;AACD;AACD,aAAO,oBAAS,iBAAT,EAA4B;AACjC,kBAAU,GAAG,KAAH,CAAS;AADc,OAA5B,CAAP;AAGD,KARc,CAAf;AASA,WAAO,QAAP;AACD;;AAED,gBAAc;AACZ,QAAI,YAAY,KAAK,IAAL,EAAhB;AACA,WAAO,KAAK,sBAAL,CAA4B,SAA5B,CAAP,EAA+C;AAC7C,UAAI,OAAO,KAAK,OAAL,EAAX;;AAEA,UAAI,kBAAkB,KAAK,6BAAL,CAAmC,IAAnC,CAAtB;AACA,UAAI,mBAAmB,IAAnB,IAA2B,OAAO,gBAAgB,KAAvB,KAAiC,UAAhE,EAA4E;AAC1E,cAAM,KAAK,WAAL,CAAiB,IAAjB,EACJ,+DADI,CAAN;AAED;AACD,UAAI,eAAe,uBAAW,GAAX,CAAnB;AACA,UAAI,kBAAkB,uBAAW,GAAX,CAAtB;AACA;AACA,WAAK,OAAL,CAAa,QAAb,GAAwB,YAAxB;;AAEA,UAAI,MAAM,2BAAiB,IAAjB,EAAuB,IAAvB,EAA6B,KAAK,OAAlC,EAA2C,YAA3C,EAAyD,eAAzD,CAAV;;AAEA,UAAI,SAAS,2CAA0B,gBAAgB,KAAhB,CAAsB,IAAtB,CAA2B,IAA3B,EAAiC,GAAjC,CAA1B,CAAb;AACA,UAAI,CAAC,gBAAK,MAAL,CAAY,MAAZ,CAAL,EAA0B;AACxB,cAAM,KAAK,WAAL,CAAiB,IAAjB,EAAuB,uCAAuC,MAA9D,CAAN;AACD;AACD,eAAS,OAAO,GAAP,CAAW,OAAO;AACzB,YAAI,EAAE,OAAO,OAAO,IAAI,QAAX,KAAwB,UAAjC,CAAJ,EAAkD;AAChD,gBAAM,KAAK,WAAL,CAAiB,IAAjB,EAAuB,wDAAwD,GAA/E,CAAN;AACD;AACD,eAAO,IAAI,QAAJ,CAAa,eAAb,EAA8B,KAAK,OAAL,CAAa,QAA3C,sBAAiE,EAAE,MAAM,IAAR,EAAjE,CAAP;AACD,OALQ,CAAT;;AAOA,WAAK,IAAL,GAAY,OAAO,MAAP,CAAc,IAAI,KAAJ,CAAU,IAAV,CAAd,CAAZ;AACA,kBAAY,KAAK,IAAL,EAAZ;AACD;AACF;;AAED,qBAAmB;AACjB,QAAI,YAAY,KAAK,IAAL,EAAhB;;AAEA,QAAI,aAAa,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAjB,EAAoD;AAClD,WAAK,OAAL;AACD;AACF;;AAED,iBAAe;AACb,QAAI,YAAY,KAAK,IAAL,EAAhB;;AAEA,QAAI,aAAa,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAjB,EAAoD;AAClD,WAAK,OAAL;AACD;AACF;;AAED,YAAU,GAAV,EAAe,IAAf,EAAiC;AAAA,QAAZ,GAAY,yDAAN,IAAM;;AAC/B,WAAO,QAAQ,OAAO,IAAI,KAAX,KAAqB,UAArB,GAAkC,IAAI,KAAJ,CAAU,IAAV,EAAgB,GAAhB,CAAlC,GAAyD,KAAjE,CAAP;AACD;;AAED,SAAO,IAAP,EAAa;AACX,WAAO,QAAS,+BAAhB;AACD;;AAED,QAAM,GAAN,EAAW;AACT,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,KAApB,CAAP;AACD;;AAED,eAAa,GAAb,EAA8B;AAAA,QAAZ,GAAY,yDAAN,IAAM;;AAC5B,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,YAApB,EAAkC,GAAlC,CAAP;AACD;;AAED,iBAAe,GAAf,EAAoB;AAClB,WAAO,KAAK,YAAL,CAAkB,GAAlB,KAA0B,KAAK,SAAL,CAAe,GAAf,CAA1B,IACA,KAAK,gBAAL,CAAsB,GAAtB,CADA,IAC8B,KAAK,eAAL,CAAqB,GAArB,CAD9B,IAC2D,KAAK,UAAL,CAAgB,GAAhB,CADlE;AAED;;AAED,mBAAiB,GAAjB,EAAkC;AAAA,QAAZ,GAAY,yDAAN,IAAM;;AAChC,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,QAApB,EAA8B,GAA9B,CAAP;AACD;;AAED,kBAAgB,GAAhB,EAAiC;AAAA,QAAZ,GAAY,yDAAN,IAAM;;AAC/B,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,QAApB,EAA8B,GAA9B,CAAP;AACD;;AAED,aAAW,GAAX,EAA4B;AAAA,QAAZ,GAAY,yDAAN,IAAM;;AAC1B,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,UAApB,EAAgC,GAAhC,CAAP;AACD;;AAED,mBAAiB,GAAjB,EAAsB;AACpB,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,gBAApB,CAAP;AACD;;AAED,mBAAiB,GAAjB,EAAkC;AAAA,QAAZ,GAAY,yDAAN,IAAM;;AAChC,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,SAApB,EAA+B,GAA/B,CAAP;AACD;;AAED,gBAAc,GAAd,EAA+B;AAAA,QAAZ,GAAY,yDAAN,IAAM;;AAC7B,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,MAApB,EAA4B,GAA5B,CAAP;AACD;;AAED,sBAAoB,GAApB,EAAqC;AAAA,QAAZ,GAAY,yDAAN,IAAM;;AACnC,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,mBAApB,EAAyC,GAAzC,CAAP;AACD;;AAED,cAAY,GAAZ,EAAiB;AACf,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,WAApB,CAAP;AACD;;AAED,WAAS,GAAT,EAAc;AACZ,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,QAApB,CAAP;AACD;;AAED,WAAS,GAAT,EAAc;AACZ,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,QAApB,CAAP;AACD;;AAED,aAAW,GAAX,EAAgB;AACd,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,UAApB,CAAP;AACD;;AAED,WAAS,GAAT,EAA0B;AAAA,QAAZ,GAAY,yDAAN,IAAM;;AACxB,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,QAApB,EAA8B,GAA9B,CAAP;AACD;;AAGD,YAAU,GAAV,EAA2B;AAAA,QAAZ,GAAY,yDAAN,IAAM;;AACzB,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,SAApB,EAA+B,GAA/B,CAAP;AACD;;AAED,eAAa,GAAb,EAA8B;AAAA,QAAZ,GAAY,yDAAN,IAAM;;AAC5B,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,YAApB,EAAkC,GAAlC,CAAP;AACD;;AAED,aAAW,GAAX,EAAgB;AACd,WAAO,CAAC,KAAK,SAAL,CAAe,GAAf,EAAoB,YAApB,KACA,KAAK,SAAL,CAAe,GAAf,EAAoB,YAApB,CADA,IAEA,KAAK,SAAL,CAAe,GAAf,EAAoB,SAApB,CAFD,KAEoC,2BAAW,GAAX,CAF3C;AAGD;;AAED,mBAAiB,GAAjB,EAAsB;AACpB,WAAO,KAAK,SAAL,CAAe,GAAf,EAAoB,YAApB,EAAkC,IAAlC,KACA,KAAK,SAAL,CAAe,GAAf,EAAoB,YAApB,EAAkC,IAAlC,CADP;AAED;;AAED,cAAY,GAAZ,EAAiB,KAAjB,EAAwB;AACtB,WAAQ,OAAO,OAAO,IAAI,OAAX,KAAuB,UAA/B,GAA6C,KAAK,IAAI,OAAJ,CAAY,KAAZ,CAAL,CAA7C,GAAwE,SAA/E;AACD;;AAED,cAAY,GAAZ,EAAiB,KAAjB,EAAwB;AACtB,WAAO,KAAK,WAAL,CAAiB,GAAjB,EAAsB,KAAK,OAAL,CAAa,KAAnC,EACK,GADL,CACS,QAAQ,KAAK,OAAL,CAAa,GAAb,CAAiB,GAAjB,CAAqB,IAArB,MAA+B,KAA/B,IACA,KAAK,OAAL,CAAa,KAAb,CAAmB,GAAnB,CAAuB,IAAvB,MAAiC,KAFlD,EAGK,SAHL,CAGe,KAHf,CAAP;AAID;;AAED,sBAAoB,GAApB,EAAyB,KAAzB,EAAgC;AAC9B,WAAO,KAAK,WAAL,CAAiB,GAAjB,EAAsB,KAAK,OAAL,CAAa,KAAnC,EACK,GADL,CACS,QAAQ,KAAK,OAAL,CAAa,GAAb,CAAiB,GAAjB,CAAqB,IAArB,aAAsC,KAAtC,IACA,KAAK,OAAL,CAAa,KAAb,CAAmB,GAAnB,CAAuB,IAAvB,aAAwC,KAFzD,EAGK,SAHL,CAGe,KAHf,CAAP;AAID;;AAED,oBAAkB,GAAlB,EAAuB;AACrB,WAAO,KAAK,WAAL,CAAiB,GAAjB,oCAAP;AACD;;AAED,qBAAmB,GAAnB,EAAwB;AACtB,WAAO,KAAK,WAAL,CAAiB,GAAjB,oCAAP;AACD;;AAED,qBAAmB,GAAnB,EAAwB;AACtB,WAAO,KAAK,WAAL,CAAiB,GAAjB,+BAAP;AACD;;AAED,uBAAqB,GAArB,EAA0B;AACxB,WAAO,KAAK,WAAL,CAAiB,GAAjB,iCAAP;AACD;;AAED,wBAAsB,GAAtB,EAA2B;AACzB,WAAO,KAAK,WAAL,CAAiB,GAAjB,kCAAP;AACD;;AAED,2BAAyB,GAAzB,EAA8B;AAC5B,WAAO,KAAK,WAAL,CAAiB,GAAjB,qCAAP;AACD;;AAED,yBAAuB,GAAvB,EAA4B;AAC1B,WAAO,KAAK,WAAL,CAAiB,GAAjB,mCAAP;AACD;;AAED,wBAAsB,GAAtB,EAA2B;AACzB,WAAO,KAAK,WAAL,CAAiB,GAAjB,uCAAP;AACD;;AAED,mBAAiB,GAAjB,EAAsB;AACpB,WAAO,KAAK,WAAL,CAAiB,GAAjB,6BAAP;AACD;;AAED,iBAAe,GAAf,EAAoB;AAClB,WAAO,KAAK,WAAL,CAAiB,GAAjB,2BAAP;AACD;;AAED,oBAAkB,GAAlB,EAAuB;AACrB,WAAO,KAAK,WAAL,CAAiB,GAAjB,8BAAP;AACD;;AAED,mBAAiB,GAAjB,EAAsB;AACpB,WAAO,KAAK,WAAL,CAAiB,GAAjB,6BAAP;AACD;;AAED,sBAAoB,GAApB,EAAyB;AACvB,WAAO,KAAK,WAAL,CAAiB,GAAjB,gCAAP;AACD;;AAED,gBAAc,GAAd,EAAmB;AACjB,WAAO,KAAK,WAAL,CAAiB,GAAjB,0BAAP;AACD;;AAED,sBAAoB,GAApB,EAAyB;AACvB,WAAO,KAAK,WAAL,CAAiB,GAAjB,gCAAP;AACD;;AAED,kBAAgB,GAAhB,EAAqB;AACnB,WAAO,KAAK,WAAL,CAAiB,GAAjB,4BAAP;AACD;;AAED,iBAAe,GAAf,EAAoB;AAClB,WAAO,KAAK,WAAL,CAAiB,GAAjB,2BAAP;AACD;;AAED,mBAAiB,GAAjB,EAAsB;AACpB,WAAO,KAAK,WAAL,CAAiB,GAAjB,6BAAP;AACD;;AAED,gBAAc,GAAd,EAAmB;AACjB,WAAO,KAAK,WAAL,CAAiB,GAAjB,0BAAP;AACD;;AAED,iBAAe,GAAf,EAAoB;AAClB,WAAO,KAAK,WAAL,CAAiB,GAAjB,2BAAP;AACD;;AAED,yBAAuB,GAAvB,EAA4B;AAC1B,WAAO,KAAK,mBAAL,CAAyB,GAAzB,mCAAP;AACD;;AAED,wBAAsB,GAAtB,EAA2B;AACzB,WAAO,KAAK,mBAAL,CAAyB,GAAzB,kCAAP;AACD;;AAED,gCAA8B,IAA9B,EAAoC;AAClC,QAAI,KAAK,OAAL,CAAa,GAAb,CAAiB,GAAjB,CAAqB,KAAK,OAAL,CAAa,KAAK,OAAL,CAAa,KAA1B,CAArB,CAAJ,EAA4D;AAC1D,aAAO,KAAK,OAAL,CAAa,GAAb,CAAiB,GAAjB,CAAqB,KAAK,OAAL,CAAa,KAAK,OAAL,CAAa,KAA1B,CAArB,CAAP;AACD;AACD,WAAO,KAAK,OAAL,CAAa,KAAb,CAAmB,GAAnB,CAAuB,KAAK,OAAL,CAAa,KAAK,OAAL,CAAa,KAA1B,CAAvB,CAAP;AACD;;AAED,eAAa,CAAb,EAAgB,CAAhB,EAAmB;AACjB,QAAI,EAAE,KAAK,CAAP,CAAJ,EAAe;AACb,aAAO,KAAP;AACD;AACD,WAAO,EAAE,UAAF,OAAmB,EAAE,UAAF,EAA1B;AACD;;AAED,kBAAgB,GAAhB,EAAqB;AACnB,QAAI,YAAY,KAAK,OAAL,EAAhB;AACA,QAAI,KAAK,YAAL,CAAkB,SAAlB,EAA6B,GAA7B,CAAJ,EAAuC;AACrC,aAAO,SAAP;AACD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,yBAA5B,CAAN;AACD;;AAED,eAAa,GAAb,EAAkB;AAChB,QAAI,YAAY,KAAK,OAAL,EAAhB;AACA,QAAI,KAAK,SAAL,CAAe,SAAf,EAA0B,GAA1B,CAAJ,EAAoC;AAClC,aAAO,SAAP;AACD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,eAAe,GAA3C,CAAN;AACD;;AAED,iBAAe;AACb,QAAI,YAAY,KAAK,OAAL,EAAhB;AACA,QAAI,KAAK,gBAAL,CAAsB,SAAtB,KACA,KAAK,eAAL,CAAqB,SAArB,CADA,IAEA,KAAK,gBAAL,CAAsB,SAAtB,CAFA,IAGA,KAAK,aAAL,CAAmB,SAAnB,CAHA,IAIA,KAAK,UAAL,CAAgB,SAAhB,CAJA,IAKA,KAAK,mBAAL,CAAyB,SAAzB,CALJ,EAKyC;AACvC,aAAO,SAAP;AACD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,qBAA5B,CAAN;AACD;;AAED,uBAAqB;AACnB,QAAI,YAAY,KAAK,OAAL,EAAhB;AACA,QAAI,KAAK,eAAL,CAAqB,SAArB,CAAJ,EAAqC;AACnC,aAAO,SAAP;AACD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,4BAA5B,CAAN;AACD;;AAED,kBAAgB;AACd,QAAI,YAAY,KAAK,OAAL,EAAhB;AACA,QAAI,KAAK,UAAL,CAAgB,SAAhB,CAAJ,EAAgC;AAC9B,aAAO,SAAP;AACD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,8BAA5B,CAAN;AACD;;AAED,gBAAc;AACZ,QAAI,YAAY,KAAK,OAAL,EAAhB;AACA,QAAI,KAAK,QAAL,CAAc,SAAd,CAAJ,EAA8B;AAC5B,aAAO,UAAU,KAAV,EAAP;AACD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,kBAA5B,CAAN;AACD;;AAED,iBAAe;AACb,QAAI,YAAY,KAAK,OAAL,EAAhB;AACA,QAAI,KAAK,QAAL,CAAc,SAAd,CAAJ,EAA8B;AAC5B,aAAO,UAAU,KAAV,EAAP;AACD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,wBAA5B,CAAN;AACD;AACD,iBAAe;AACb,QAAI,YAAY,KAAK,OAAL,EAAhB;AACA,QAAI,KAAK,UAAL,CAAgB,SAAhB,CAAJ,EAAgC;AAC9B,aAAO,UAAU,KAAV,EAAP;AACD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,yBAA5B,CAAN;AACD;;AAED,uBAAqB;AACnB,QAAI,YAAY,KAAK,OAAL,EAAhB;AACA,QAAI,gCAAgB,SAAhB,CAAJ,EAAgC;AAC9B,aAAO,SAAP;AACD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,4BAA5B,CAAN;AACD;;AAED,kBAAgB,GAAhB,EAAqB;AACnB,QAAI,YAAY,KAAK,OAAL,EAAhB;AACA,QAAI,KAAK,YAAL,CAAkB,SAAlB,CAAJ,EAAkC;AAChC,UAAI,OAAO,GAAP,KAAe,WAAnB,EAAgC;AAC9B,YAAI,UAAU,GAAV,OAAoB,GAAxB,EAA6B;AAC3B,iBAAO,SAAP;AACD,SAFD,MAEO;AACL,gBAAM,KAAK,WAAL,CAAiB,SAAjB,EACJ,iBAAiB,GAAjB,GAAuB,aADnB,CAAN;AAED;AACF;AACD,aAAO,SAAP;AACD;AACD,UAAM,KAAK,WAAL,CAAiB,SAAjB,EAA4B,wBAA5B,CAAN;AACD;;AAED,cAAY,GAAZ,EAAiB,OAAjB,EAA0B;AACxB,QAAI,MAAM,EAAV;AACA,QAAI,YAAY,GAAhB;AACA,QAAI,KAAK,IAAL,CAAU,IAAV,GAAiB,CAArB,EAAwB;AACtB,YAAM,KAAK,IAAL,CAAU,KAAV,CAAgB,CAAhB,EAAmB,EAAnB,EAAuB,GAAvB,CAA2B,QAAQ;AACvC,YAAI,KAAK,WAAL,CAAiB,IAAjB,CAAJ,EAA4B;AAC1B,iBAAO,KAAK,KAAL,EAAP;AACD;AACD,eAAO,gBAAK,EAAL,CAAQ,IAAR,CAAP;AACD,OALK,EAKH,OALG,GAKO,GALP,CAKW,KAAK;AACpB,YAAI,MAAM,SAAV,EAAqB;AACnB,iBAAO,OAAO,EAAE,GAAF,EAAP,GAAiB,IAAxB;AACD;AACD,eAAO,EAAE,GAAF,EAAP;AACD,OAVK,EAUH,IAVG,CAUE,GAVF,CAAN;AAWD,KAZD,MAYO;AACL,YAAM,UAAU,QAAV,EAAN;AACD;AACD,WAAO,IAAI,KAAJ,CAAU,UAAU,IAAV,GAAiB,GAA3B,CAAP;AAED;AAjrEqB;QAAX,U,GAAA,U","file":"enforester.js","sourcesContent":["import Term, { isIdentifierExpression, isStaticMemberExpression, isComputedMemberExpression } from \"./terms\";\nimport { Maybe } from \"ramda-fantasy\";\nconst Just = Maybe.Just;\nconst Nothing = Maybe.Nothing;\n\nimport {\n  FunctionDeclTransform,\n  VariableDeclTransform,\n  NewTransform,\n  LetDeclTransform,\n  ConstDeclTransform,\n  SyntaxDeclTransform,\n  SyntaxrecDeclTransform,\n  SyntaxQuoteTransform,\n  ReturnStatementTransform,\n  WhileTransform,\n  IfTransform,\n  ForTransform,\n  SwitchTransform,\n  BreakTransform,\n  ContinueTransform,\n  DoTransform,\n  DebuggerTransform,\n  WithTransform,\n  TryTransform,\n  ThrowTransform,\n  CompiletimeTransform,\n  VarBindingTransform\n} from \"./transforms\";\nimport { List } from \"immutable\";\nimport { expect, assert } from \"./errors\";\nimport {\n  isOperator,\n  isUnaryOperator,\n  getOperatorAssoc,\n  getOperatorPrec,\n  operatorLt\n} from \"./operators\";\nimport Syntax, { ALL_PHASES } from \"./syntax\";\n\nimport { freshScope } from \"./scope\";\nimport { sanitizeReplacementValues } from './load-syntax';\n\nimport MacroContext from \"./macro-context\";\n\nconst EXPR_LOOP_OPERATOR = {};\nconst EXPR_LOOP_NO_CHANGE = {};\nconst EXPR_LOOP_EXPANSION = {};\n\nexport class Enforester {\n  constructor(stxl, prev, context) {\n    this.done = false;\n    assert(List.isList(stxl), \"expecting a list of terms to enforest\");\n    assert(List.isList(prev), \"expecting a list of terms to enforest\");\n    assert(context, \"expecting a context to enforest\");\n    this.term = null;\n\n    this.rest = stxl;\n    this.prev = prev;\n\n    this.context = context;\n  }\n\n  peek(n = 0) {\n    return this.rest.get(n);\n  }\n\n  advance() {\n    let ret = this.rest.first();\n    this.rest = this.rest.rest();\n    return ret;\n  }\n\n  /*\n   enforest works over:\n   prev - a list of the previously enforest Terms\n   term - the current term being enforested (initially null)\n   rest - remaining Terms to enforest\n   */\n  enforest(type = \"Module\") {\n    // initialize the term\n    this.term = null;\n\n    if (this.rest.size === 0) {\n      this.done = true;\n      return this.term;\n    }\n\n    if (this.isEOF(this.peek())) {\n      this.term = new Term(\"EOF\", {});\n      this.advance();\n      return this.term;\n    }\n\n    let result;\n    if (type === \"expression\") {\n      result = this.enforestExpressionLoop();\n    } else {\n      result = this.enforestModule();\n    }\n\n    if (this.rest.size === 0) {\n      this.done = true;\n    }\n    return result;\n  }\n\n  enforestModule() {\n    return this.enforestBody();\n  }\n\n  enforestBody() {\n    return this.enforestModuleItem();\n  }\n\n  enforestModuleItem() {\n    let lookahead = this.peek();\n    if (this.isKeyword(lookahead, 'import')) {\n      this.advance();\n      return this.enforestImportDeclaration();\n    } else if (this.isKeyword(lookahead, 'export')) {\n      this.advance();\n      return this.enforestExportDeclaration();\n    } else if (this.isIdentifier(lookahead, '#')) {\n      return this.enforestLanguagePragma();\n    }\n    return this.enforestStatement();\n  }\n\n  enforestLanguagePragma() {\n    this.matchIdentifier('#');\n    this.matchIdentifier('lang');\n    let path = this.matchStringLiteral();\n    this.consumeSemicolon();\n    return new Term('Pragma', {\n      kind: 'lang',\n      items: List.of(path)\n    });\n  }\n\n  enforestExportDeclaration() {\n    let lookahead = this.peek();\n    if (this.isPunctuator(lookahead, '*')) {\n      this.advance();\n      let moduleSpecifier = this.enforestFromClause();\n      return new Term('ExportAllFrom', { moduleSpecifier });\n    } else if (this.isBraces(lookahead)) {\n      let namedExports = this.enforestExportClause();\n      let moduleSpecifier = null;\n      if (this.isIdentifier(this.peek(), 'from')) {\n        moduleSpecifier = this.enforestFromClause();\n      }\n      return new Term('ExportFrom', { namedExports, moduleSpecifier });\n    } else if (this.isKeyword(lookahead, 'class')) {\n      return new Term('Export', {\n        declaration: this.enforestClass({ isExpr: false })\n      });\n    } else if (this.isFnDeclTransform(lookahead)) {\n      return new Term('Export', {\n        declaration: this.enforestFunction({isExpr: false, inDefault: false})\n      });\n    } else if (this.isKeyword(lookahead, 'default')) {\n      this.advance();\n      if (this.isFnDeclTransform(this.peek())) {\n        return new Term('ExportDefault', {\n          body: this.enforestFunction({isExpr: false, inDefault: true})\n        });\n      } else if (this.isKeyword(this.peek(), 'class')) {\n        return new Term('ExportDefault', {\n          body: this.enforestClass({isExpr: false, inDefault: true})\n        });\n      } else {\n        let body = this.enforestExpressionLoop();\n        this.consumeSemicolon();\n        return new Term('ExportDefault', { body });\n      }\n    } else if (this.isVarDeclTransform(lookahead) ||\n        this.isLetDeclTransform(lookahead) ||\n        this.isConstDeclTransform(lookahead) ||\n        this.isSyntaxrecDeclTransform(lookahead) ||\n        this.isSyntaxDeclTransform(lookahead)) {\n      return new Term('Export', {\n        declaration: this.enforestVariableDeclaration()\n      });\n    }\n    throw this.createError(lookahead, 'unexpected syntax');\n  }\n\n  enforestExportClause() {\n    let enf = new Enforester(this.matchCurlies(), List(), this.context);\n    let result = [];\n    while (enf.rest.size !== 0) {\n      result.push(enf.enforestExportSpecifier());\n      enf.consumeComma();\n    }\n    return List(result);\n  }\n\n  enforestExportSpecifier() {\n    let name = this.enforestIdentifier();\n    if (this.isIdentifier(this.peek(), 'as')) {\n      this.advance();\n      let exportedName = this.enforestIdentifier();\n      return new Term('ExportSpecifier', { name, exportedName });\n    }\n    return new Term('ExportSpecifier', {\n      name: null,\n      exportedName: name\n    });\n  }\n\n  enforestImportDeclaration() {\n    let lookahead = this.peek();\n    let defaultBinding = null;\n    let namedImports = List();\n    let forSyntax = false;\n\n    if (this.isStringLiteral(lookahead)) {\n      let moduleSpecifier = this.advance();\n      this.consumeSemicolon();\n      return new Term('Import', {\n        defaultBinding,\n        namedImports,\n        moduleSpecifier,\n        forSyntax\n      });\n    }\n\n    if (this.isIdentifier(lookahead) || this.isKeyword(lookahead)) {\n      defaultBinding = this.enforestBindingIdentifier();\n      if (!this.isPunctuator(this.peek(), ',')) {\n        let moduleSpecifier = this.enforestFromClause();\n        if (this.isKeyword(this.peek(), 'for') && this.isIdentifier(this.peek(1), 'syntax')) {\n          this.advance();\n          this.advance();\n          forSyntax = true;\n        }\n\n        return new Term('Import', {\n          defaultBinding, moduleSpecifier,\n          namedImports: List(),\n          forSyntax\n        });\n      }\n    }\n    this.consumeComma();\n    lookahead = this.peek();\n    if (this.isBraces(lookahead)) {\n      let imports = this.enforestNamedImports();\n      let fromClause = this.enforestFromClause();\n      if (this.isKeyword(this.peek(), 'for') && this.isIdentifier(this.peek(1), 'syntax')) {\n        this.advance();\n        this.advance();\n        forSyntax = true;\n      }\n\n      return new Term(\"Import\", {\n        defaultBinding,\n        forSyntax,\n        namedImports: imports,\n        moduleSpecifier: fromClause\n\n      });\n    } else if (this.isPunctuator(lookahead, '*')) {\n      let namespaceBinding = this.enforestNamespaceBinding();\n      let moduleSpecifier = this.enforestFromClause();\n      if (this.isKeyword(this.peek(), 'for') && this.isIdentifier(this.peek(1), 'syntax')) {\n        this.advance();\n        this.advance();\n        forSyntax = true;\n      }\n      return new Term('ImportNamespace', {\n        defaultBinding, forSyntax, namespaceBinding, moduleSpecifier\n      });\n    }\n    throw this.createError(lookahead, 'unexpected syntax');\n  }\n\n  enforestNamespaceBinding() {\n    this.matchPunctuator('*');\n    this.matchIdentifier('as');\n    return this.enforestBindingIdentifier();\n  }\n\n  enforestNamedImports() {\n    let enf = new Enforester(this.matchCurlies(), List(), this.context);\n    let result = [];\n    while (enf.rest.size !== 0) {\n      result.push(enf.enforestImportSpecifiers());\n      enf.consumeComma();\n    }\n    return List(result);\n  }\n\n  enforestImportSpecifiers() {\n    let lookahead = this.peek();\n    let name;\n    if (this.isIdentifier(lookahead) || this.isKeyword(lookahead)) {\n      name = this.advance();\n      if (!this.isIdentifier(this.peek(), 'as')) {\n        return new Term('ImportSpecifier', {\n          name: null,\n          binding: new Term('BindingIdentifier', {\n            name: name\n          })\n        });\n      } else {\n        this.matchIdentifier('as');\n      }\n    } else {\n      throw this.createError(lookahead, 'unexpected token in import specifier');\n    }\n    return new Term('ImportSpecifier', {\n      name, binding: this.enforestBindingIdentifier()\n    });\n  }\n\n  enforestFromClause() {\n    this.matchIdentifier('from');\n    let lookahead = this.matchStringLiteral();\n    this.consumeSemicolon();\n    return lookahead;\n  }\n\n  enforestStatementListItem() {\n    let lookahead = this.peek();\n\n    if (this.isFnDeclTransform(lookahead)) {\n      return this.enforestFunctionDeclaration({ isExpr: false });\n    } else if (this.isKeyword(lookahead, 'class')) {\n      return this.enforestClass({ isExpr: false });\n    } else {\n      return this.enforestStatement();\n    }\n  }\n\n  enforestStatement() {\n    let lookahead = this.peek();\n\n    if (this.term === null && this.isCompiletimeTransform(lookahead)) {\n      this.expandMacro();\n      lookahead = this.peek();\n    }\n\n    if (this.term === null && this.isTerm(lookahead)) {\n      // TODO: check that this is actually an statement\n      return this.advance();\n    }\n\n    if (this.term === null && this.isBraces(lookahead)) {\n      return this.enforestBlockStatement();\n    }\n\n    if (this.term === null && this.isWhileTransform(lookahead)) {\n      return this.enforestWhileStatement();\n    }\n\n    if (this.term === null && this.isIfTransform(lookahead)) {\n      return this.enforestIfStatement();\n    }\n    if (this.term === null && this.isForTransform(lookahead)) {\n      return this.enforestForStatement();\n    }\n    if (this.term === null && this.isSwitchTransform(lookahead)) {\n      return this.enforestSwitchStatement();\n    }\n    if (this.term === null && this.isBreakTransform(lookahead)) {\n      return this.enforestBreakStatement();\n    }\n    if (this.term === null && this.isContinueTransform(lookahead)) {\n      return this.enforestContinueStatement();\n    }\n    if (this.term === null && this.isDoTransform(lookahead)) {\n      return this.enforestDoStatement();\n    }\n    if (this.term === null && this.isDebuggerTransform(lookahead)) {\n      return this.enforestDebuggerStatement();\n    }\n    if (this.term === null && this.isWithTransform(lookahead)) {\n      return this.enforestWithStatement();\n    }\n    if (this.term === null && this.isTryTransform(lookahead)) {\n      return this.enforestTryStatement();\n    }\n    if (this.term === null && this.isThrowTransform(lookahead)) {\n      return this.enforestThrowStatement();\n    }\n\n    // TODO: put somewhere else\n    if (this.term === null && this.isKeyword(lookahead, \"class\")) {\n      return this.enforestClass({isExpr: false});\n    }\n\n    if (this.term === null && this.isFnDeclTransform(lookahead)) {\n      return this.enforestFunctionDeclaration();\n    }\n\n    if (this.term === null && this.isIdentifier(lookahead) &&\n        this.isPunctuator(this.peek(1), ':')) {\n      return this.enforestLabeledStatement();\n    }\n\n    if (this.term === null &&\n        (this.isVarDeclTransform(lookahead) ||\n         this.isLetDeclTransform(lookahead) ||\n         this.isConstDeclTransform(lookahead) ||\n         this.isSyntaxrecDeclTransform(lookahead) ||\n         this.isSyntaxDeclTransform(lookahead))) {\n      let stmt = new Term('VariableDeclarationStatement', {\n        declaration: this.enforestVariableDeclaration()\n      });\n      this.consumeSemicolon();\n      return stmt;\n    }\n\n    if (this.term === null && this.isReturnStmtTransform(lookahead)) {\n      return this.enforestReturnStatement();\n    }\n\n    if (this.term === null && this.isPunctuator(lookahead, \";\")) {\n      this.advance();\n      return new Term(\"EmptyStatement\", {});\n    }\n\n\n    return this.enforestExpressionStatement();\n  }\n\n  enforestLabeledStatement() {\n    let label = this.matchIdentifier();\n    this.matchPunctuator(':');\n    let stmt = this.enforestStatement();\n\n    return new Term('LabeledStatement', {\n      label: label,\n      body: stmt\n    });\n  }\n\n  enforestBreakStatement() {\n    this.matchKeyword('break');\n    let lookahead = this.peek();\n    let label = null;\n    if (this.rest.size === 0 || this.isPunctuator(lookahead, ';')) {\n      this.consumeSemicolon();\n      return new Term('BreakStatement', { label });\n    }\n    if (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'yield') || this.isKeyword(lookahead, 'let')) {\n      label = this.enforestIdentifier();\n    }\n    this.consumeSemicolon();\n\n    return new Term('BreakStatement', { label });\n  }\n\n  enforestTryStatement() {\n    this.matchKeyword('try');\n    let body = this.enforestBlock();\n    if (this.isKeyword(this.peek(), 'catch')) {\n      let catchClause = this.enforestCatchClause();\n      if (this.isKeyword(this.peek(), 'finally')) {\n        this.advance();\n        let finalizer = this.enforestBlock();\n        return new Term('TryFinallyStatement', {\n          body, catchClause, finalizer\n        });\n      }\n      return new Term('TryCatchStatement', { body, catchClause });\n    }\n    if (this.isKeyword(this.peek(), 'finally')) {\n      this.advance();\n      let finalizer = this.enforestBlock();\n      return new Term('TryFinallyStatement', { body, catchClause: null, finalizer });\n    }\n    throw this.createError(this.peek(), 'try with no catch or finally');\n  }\n\n  enforestCatchClause() {\n    this.matchKeyword('catch');\n    let bindingParens = this.matchParens();\n    let enf = new Enforester(bindingParens, List(), this.context);\n    let binding = enf.enforestBindingTarget();\n    let body = this.enforestBlock();\n    return new Term('CatchClause', { binding, body });\n  }\n\n  enforestThrowStatement() {\n    this.matchKeyword('throw');\n    let expression = this.enforestExpression();\n    this.consumeSemicolon();\n    return new Term('ThrowStatement', { expression });\n  }\n\n  enforestWithStatement() {\n    this.matchKeyword('with');\n    let objParens = this.matchParens();\n    let enf = new Enforester(objParens, List(), this.context);\n    let object = enf.enforestExpression();\n    let body = this.enforestStatement();\n    return new Term('WithStatement', { object, body });\n  }\n\n  enforestDebuggerStatement() {\n    this.matchKeyword('debugger');\n\n    return new Term('DebuggerStatement', {});\n  }\n\n  enforestDoStatement() {\n    this.matchKeyword('do');\n    let body = this.enforestStatement();\n    this.matchKeyword('while');\n    let testBody = this.matchParens();\n    let enf = new Enforester(testBody, List(), this.context);\n    let test = enf.enforestExpression();\n    this.consumeSemicolon();\n    return new Term('DoWhileStatement', { body, test });\n  }\n\n  enforestContinueStatement() {\n    let kwd = this.matchKeyword('continue');\n    let lookahead = this.peek();\n    let label = null;\n    if (this.rest.size === 0 || this.isPunctuator(lookahead, ';')) {\n      this.consumeSemicolon();\n      return new Term('ContinueStatement', { label });\n    }\n    if (this.lineNumberEq(kwd, lookahead) &&\n        (this.isIdentifier(lookahead) ||\n         this.isKeyword(lookahead, 'yield') ||\n         this.isKeyword(lookahead, 'let'))) {\n      label = this.enforestIdentifier();\n    }\n    this.consumeSemicolon();\n\n    return new Term('ContinueStatement', { label });\n  }\n\n  enforestSwitchStatement() {\n    this.matchKeyword('switch');\n    let cond = this.matchParens();\n    let enf = new Enforester(cond, List(), this.context);\n    let discriminant = enf.enforestExpression();\n    let body = this.matchCurlies();\n\n    if (body.size === 0) {\n      return new Term('SwitchStatement', {\n        discriminant: discriminant,\n        cases: List()\n      });\n    }\n    enf = new Enforester(body, List(), this.context);\n    let cases = enf.enforestSwitchCases();\n    let lookahead = enf.peek();\n    if (enf.isKeyword(lookahead, 'default')) {\n      let defaultCase = enf.enforestSwitchDefault();\n      let postDefaultCases = enf.enforestSwitchCases();\n      return new Term('SwitchStatementWithDefault', {\n        discriminant,\n        preDefaultCases: cases,\n        defaultCase,\n        postDefaultCases\n      });\n    }\n    return new Term('SwitchStatement', {  discriminant, cases });\n  }\n\n  enforestSwitchCases() {\n    let cases = [];\n    while (!(this.rest.size === 0 || this.isKeyword(this.peek(), 'default'))) {\n      cases.push(this.enforestSwitchCase());\n    }\n    return List(cases);\n  }\n\n  enforestSwitchCase() {\n    this.matchKeyword('case');\n    return new Term('SwitchCase', {\n      test: this.enforestExpression(),\n      consequent: this.enforestSwitchCaseBody()\n    });\n  }\n\n  enforestSwitchCaseBody() {\n    this.matchPunctuator(':');\n    return this.enforestStatementListInSwitchCaseBody();\n  }\n\n  enforestStatementListInSwitchCaseBody() {\n    let result = [];\n    while(!(this.rest.size === 0 || this.isKeyword(this.peek(), 'default') || this.isKeyword(this.peek(), 'case'))) {\n      result.push(this.enforestStatementListItem());\n    }\n    return List(result);\n  }\n\n  enforestSwitchDefault() {\n    this.matchKeyword('default');\n    return new Term('SwitchDefault', {\n      consequent: this.enforestSwitchCaseBody()\n    });\n  }\n\n  enforestForStatement() {\n    this.matchKeyword('for');\n    let cond = this.matchParens();\n    let enf = new Enforester(cond, List(), this.context);\n    let lookahead, test, init, right, type, left, update;\n\n    // case where init is null\n    if (enf.isPunctuator(enf.peek(), ';')) {\n      enf.advance();\n      if (!enf.isPunctuator(enf.peek(), ';')) {\n        test = enf.enforestExpression();\n      }\n      enf.matchPunctuator(';');\n      if (enf.rest.size !== 0) {\n        right = enf.enforestExpression();\n      }\n      return new Term('ForStatement', {\n        init: null,\n        test: test,\n        update: right,\n        body: this.enforestStatement()\n      });\n    // case where init is not null\n    } else {\n      // testing\n      lookahead = enf.peek();\n      if (enf.isVarDeclTransform(lookahead) ||\n          enf.isLetDeclTransform(lookahead) ||\n          enf.isConstDeclTransform(lookahead)) {\n        init = enf.enforestVariableDeclaration();\n        lookahead = enf.peek();\n        if (this.isKeyword(lookahead, 'in') || this.isIdentifier(lookahead, 'of')) {\n          if (this.isKeyword(lookahead, 'in')) {\n            enf.advance();\n            right = enf.enforestExpression();\n            type = 'ForInStatement';\n          } else if (this.isIdentifier(lookahead, 'of')) {\n            enf.advance();\n            right = enf.enforestExpression();\n            type = 'ForOfStatement';\n          }\n          return new Term(type, {\n            left: init, right, body: this.enforestStatement()\n          });\n        }\n        enf.matchPunctuator(';');\n        if (enf.isPunctuator(enf.peek(), ';')) {\n          enf.advance();\n          test = null;\n        } else {\n          test = enf.enforestExpression();\n          enf.matchPunctuator(';');\n        }\n        update = enf.enforestExpression();\n      } else {\n        if (this.isKeyword(enf.peek(1), 'in') || this.isIdentifier(enf.peek(1), 'of')) {\n          left = enf.enforestBindingIdentifier();\n          let kind = enf.advance();\n          if (this.isKeyword(kind, 'in')) {\n            type = 'ForInStatement';\n          } else {\n            type = 'ForOfStatement';\n          }\n          right = enf.enforestExpression();\n          return new Term(type, {\n            left: left, right, body: this.enforestStatement()\n          });\n        }\n        init = enf.enforestExpression();\n        enf.matchPunctuator(';');\n        if (enf.isPunctuator(enf.peek(), ';')) {\n          enf.advance();\n          test = null;\n        } else {\n          test = enf.enforestExpression();\n          enf.matchPunctuator(';');\n        }\n        update = enf.enforestExpression();\n      }\n      return new Term('ForStatement', { init, test, update, body: this.enforestStatement() });\n    }\n  }\n\n  enforestIfStatement() {\n    this.matchKeyword('if');\n    let cond = this.matchParens();\n    let enf = new Enforester(cond, List(), this.context);\n    let lookahead = enf.peek();\n    let test = enf.enforestExpression();\n    if (test === null) {\n      throw enf.createError(lookahead, 'expecting an expression');\n    }\n    let consequent = this.enforestStatement();\n    let alternate = null;\n    if (this.isKeyword(this.peek(), 'else')) {\n      this.advance();\n      alternate = this.enforestStatement();\n    }\n    return new Term('IfStatement', { test, consequent, alternate });\n  }\n\n  enforestWhileStatement() {\n    this.matchKeyword('while');\n    let cond = this.matchParens();\n    let enf = new Enforester(cond, List(), this.context);\n    let lookahead = enf.peek();\n    let test = enf.enforestExpression();\n    if (test === null) {\n      throw enf.createError(lookahead, 'expecting an expression');\n    }\n    let body = this.enforestStatement();\n\n    return new Term('WhileStatement', { test, body });\n  }\n\n  enforestBlockStatement() {\n    return new Term('BlockStatement', {\n      block: this.enforestBlock()\n    });\n  }\n\n  enforestBlock() {\n    return new Term('Block', {\n      statements: this.matchCurlies()\n    });\n  }\n\n  enforestClass({ isExpr, inDefault }) {\n    let kw = this.advance();\n    let name = null, supr = null;\n    let type = isExpr ? 'ClassExpression' : 'ClassDeclaration';\n\n    if (this.isIdentifier(this.peek())) {\n      name = this.enforestBindingIdentifier();\n    } else if (!isExpr) {\n      if (inDefault) {\n        name = new Term('BindingIdentifier', {\n          name: Syntax.fromIdentifier('_default', kw)\n        });\n      } else {\n        throw this.createError(this.peek(), 'unexpected syntax');\n      }\n    }\n\n    if (this.isKeyword(this.peek(), 'extends')) {\n      this.advance();\n      supr = this.enforestExpressionLoop();\n    }\n\n    let elements = [];\n    let enf = new Enforester(this.matchCurlies(), List(), this.context);\n    while (enf.rest.size !== 0) {\n      if (enf.isPunctuator(enf.peek(), ';')) {\n        enf.advance();\n        continue;\n      }\n\n      let isStatic = false;\n      let {methodOrKey, kind} = enf.enforestMethodDefinition();\n      if (kind === 'identifier' && methodOrKey.value.val() === 'static') {\n        isStatic = true;\n        ({methodOrKey, kind} = enf.enforestMethodDefinition());\n      }\n      if (kind === 'method') {\n        elements.push(new Term('ClassElement', {isStatic, method: methodOrKey}));\n      } else {\n        throw this.createError(enf.peek(), \"Only methods are allowed in classes\");\n      }\n    }\n\n    return new Term(type, {\n      name, super: supr,\n      elements: List(elements)\n    });\n  }\n\n  enforestBindingTarget({ allowPunctuator } = {}) {\n    let lookahead = this.peek();\n    if (this.isIdentifier(lookahead) || this.isKeyword(lookahead) || (allowPunctuator && this.isPunctuator(lookahead))) {\n      return this.enforestBindingIdentifier({ allowPunctuator });\n    } else if (this.isBrackets(lookahead)) {\n      return this.enforestArrayBinding();\n    } else if (this.isBraces(lookahead)) {\n      return this.enforestObjectBinding();\n    }\n    assert(false, 'not implemented yet');\n  }\n\n  enforestObjectBinding() {\n    let enf = new Enforester(this.matchCurlies(), List(), this.context);\n    let properties = [];\n    while (enf.rest.size !== 0) {\n      properties.push(enf.enforestBindingProperty());\n      enf.consumeComma();\n    }\n\n    return new Term('ObjectBinding', {\n      properties: List(properties)\n    });\n  }\n\n  enforestBindingProperty() {\n    let lookahead = this.peek();\n    let {name, binding} = this.enforestPropertyName();\n    if (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'let') || this.isKeyword(lookahead, 'yield')) {\n      if (!this.isPunctuator(this.peek(), ':')) {\n        let defaultValue = null;\n        if (this.isAssign(this.peek())) {\n          this.advance();\n          let expr = this.enforestExpressionLoop();\n          defaultValue = expr;\n        }\n        return new Term('BindingPropertyIdentifier', {\n          binding, init: defaultValue\n        });\n      }\n    }\n    this.matchPunctuator(':');\n    binding = this.enforestBindingElement();\n    return new Term('BindingPropertyProperty', {\n      name, binding\n    });\n  }\n\n  enforestArrayBinding() {\n    let bracket = this.matchSquares();\n    let enf = new Enforester(bracket, List(), this.context);\n    let elements = [], restElement = null;\n    while (enf.rest.size !== 0) {\n      let el;\n      if (enf.isPunctuator(enf.peek(), ',')) {\n        enf.consumeComma();\n        el = null;\n      } else {\n        if (enf.isPunctuator(enf.peek(), '...')) {\n          enf.advance();\n          restElement = enf.enforestBindingTarget();\n          break;\n        } else {\n          el = enf.enforestBindingElement();\n        }\n        enf.consumeComma();\n      }\n      elements.push(el);\n    }\n    return new Term('ArrayBinding', {\n      elements: List(elements),\n      restElement\n    });\n  }\n\n  enforestBindingElement() {\n    let binding = this.enforestBindingTarget();\n\n    if (this.isAssign(this.peek())) {\n      this.advance();\n      let init = this.enforestExpressionLoop();\n      binding = new Term('BindingWithDefault', { binding, init });\n    }\n    return binding;\n  }\n\n  enforestBindingIdentifier({ allowPunctuator } = {}) {\n    let name;\n    if (allowPunctuator && this.isPunctuator(this.peek())) {\n      name = this.enforestPunctuator();\n    } else {\n      name = this.enforestIdentifier();\n    }\n    return new Term(\"BindingIdentifier\", { name });\n  }\n\n  enforestPunctuator() {\n    let lookahead = this.peek();\n    if (this.isPunctuator(lookahead)) {\n      return this.advance();\n    }\n    throw this.createError(lookahead, \"expecting a punctuator\");\n  }\n\n  enforestIdentifier() {\n    let lookahead = this.peek();\n    if (this.isIdentifier(lookahead) || this.isKeyword(lookahead)) {\n      return this.advance();\n    }\n    throw this.createError(lookahead, \"expecting an identifier\");\n  }\n\n\n  enforestReturnStatement() {\n    let kw = this.advance();\n    let lookahead = this.peek();\n\n    // short circuit for the empty expression case\n    if (this.rest.size === 0 ||\n        (lookahead && !this.lineNumberEq(kw, lookahead))) {\n      return new Term(\"ReturnStatement\", {\n        expression: null\n      });\n    }\n\n    let term = null;\n    if (!this.isPunctuator(lookahead, ';')) {\n      term = this.enforestExpression();\n      expect(term != null, \"Expecting an expression to follow return keyword\", lookahead, this.rest);\n    }\n\n    this.consumeSemicolon();\n    return new Term(\"ReturnStatement\", {\n      expression: term\n    });\n  }\n\n  enforestVariableDeclaration() {\n    let kind;\n    let lookahead = this.advance();\n    let kindSyn = lookahead;\n    let phase = this.context.phase;\n\n    if (kindSyn &&\n        this.context.env.get(kindSyn.resolve(phase)) === VariableDeclTransform) {\n      kind = \"var\";\n    } else if (kindSyn &&\n               this.context.env.get(kindSyn.resolve(phase)) === LetDeclTransform) {\n      kind = \"let\";\n    } else if (kindSyn &&\n               this.context.env.get(kindSyn.resolve(phase)) === ConstDeclTransform) {\n      kind = \"const\";\n    } else if (kindSyn &&\n               this.context.env.get(kindSyn.resolve(phase)) === SyntaxDeclTransform) {\n      kind = \"syntax\";\n    } else if (kindSyn &&\n               this.context.env.get(kindSyn.resolve(phase)) === SyntaxrecDeclTransform) {\n      kind = \"syntaxrec\";\n    }\n\n    let decls = List();\n\n    while (true) {\n      let term = this.enforestVariableDeclarator({ isSyntax: kind === \"syntax\" || kind === 'syntaxrec' });\n      let lookahead = this.peek();\n      decls = decls.concat(term);\n\n      if (this.isPunctuator(lookahead, \",\")) {\n        this.advance();\n      } else {\n        break;\n      }\n    }\n\n    return new Term('VariableDeclaration', {\n      kind: kind,\n      declarators: decls\n    });\n  }\n\n  enforestVariableDeclarator({ isSyntax }) {\n    let id = this.enforestBindingTarget({ allowPunctuator: isSyntax });\n    let lookahead = this.peek();\n\n    let init;\n    if (this.isPunctuator(lookahead, '=')) {\n      this.advance();\n      let enf = new Enforester(this.rest, List(), this.context);\n      init = enf.enforest(\"expression\");\n      this.rest = enf.rest;\n    } else {\n      init = null;\n    }\n    return new Term(\"VariableDeclarator\", {\n      binding: id,\n      init: init\n    });\n  }\n\n  enforestExpressionStatement() {\n    let start = this.rest.get(0);\n    let expr = this.enforestExpression();\n    if (expr === null) {\n      throw this.createError(start, \"not a valid expression\");\n    }\n    this.consumeSemicolon();\n\n    return new Term(\"ExpressionStatement\", {\n      expression: expr\n    });\n  }\n\n  enforestExpression() {\n    let left = this.enforestExpressionLoop();\n    let lookahead = this.peek();\n    if (this.isPunctuator(lookahead, ',')) {\n      while (this.rest.size !== 0) {\n        if (!this.isPunctuator(this.peek(), ',')) {\n          break;\n        }\n        let operator = this.advance();\n        let right = this.enforestExpressionLoop();\n        left = new Term('BinaryExpression', {left, operator, right});\n      }\n    }\n    this.term = null;\n    return left;\n  }\n\n  enforestExpressionLoop() {\n    this.term = null;\n    this.opCtx = {\n      prec: 0,\n      combine: (x) => x,\n      stack: List()\n    };\n\n    do {\n      let term = this.enforestAssignmentExpression();\n      // no change means we've done as much enforesting as possible\n      // if nothing changed, maybe we just need to pop the expr stack\n      if (term === EXPR_LOOP_NO_CHANGE && this.opCtx.stack.size > 0) {\n        this.term = this.opCtx.combine(this.term);\n        let {prec, combine} = this.opCtx.stack.last();\n        this.opCtx.prec = prec;\n        this.opCtx.combine = combine;\n        this.opCtx.stack = this.opCtx.stack.pop();\n      } else if (term === EXPR_LOOP_NO_CHANGE) {\n        break;\n      } else if (term === EXPR_LOOP_OPERATOR || term === EXPR_LOOP_EXPANSION) {\n        // operator means an opCtx was pushed on the stack\n        this.term = null;\n      } else {\n        this.term = term;\n      }\n    } while (true);  // get a fixpoint\n    return this.term;\n  }\n\n  enforestAssignmentExpression() {\n    let lookahead = this.peek();\n\n    if (this.term === null && this.isCompiletimeTransform(lookahead)) {\n      this.expandMacro();\n      lookahead = this.peek();\n    }\n\n    if (this.term === null && this.isTerm(lookahead)) {\n      // TODO: check that this is actually an expression\n      return this.advance();\n    }\n\n    if (this.term === null && this.isKeyword(lookahead, 'yield')) {\n      return this.enforestYieldExpression();\n    }\n\n    if (this.term === null && this.isKeyword(lookahead, 'class')) {\n      return this.enforestClass({isExpr: true});\n    }\n    if (this.term === null &&\n      (this.isIdentifier(lookahead) || this.isParens(lookahead)) &&\n       this.isPunctuator(this.peek(1), '=>') &&\n       this.lineNumberEq(lookahead, this.peek(1))) {\n      return this.enforestArrowExpression();\n    }\n\n\n\n    if (this.term === null && this.isSyntaxTemplate(lookahead)) {\n      return this.enforestSyntaxTemplate();\n    }\n    // syntaxQuote ` ... `\n    if (this.term === null && this.isSyntaxQuoteTransform(lookahead)) {\n      return this.enforestSyntaxQuote();\n    }\n\n    // ($x:expr)\n    if (this.term === null && this.isParens(lookahead)) {\n      return new Term(\"ParenthesizedExpression\", {\n        inner: this.advance().inner()\n      });\n    }\n\n    if (this.term === null && (\n      this.isKeyword(lookahead, \"this\") ||\n      this.isIdentifier(lookahead) ||\n      this.isKeyword(lookahead, 'let') ||\n      this.isKeyword(lookahead, 'yield') ||\n      this.isNumericLiteral(lookahead) ||\n      this.isStringLiteral(lookahead) ||\n      this.isTemplate(lookahead) ||\n      this.isBooleanLiteral(lookahead) ||\n      this.isNullLiteral(lookahead) ||\n      this.isRegularExpression(lookahead) ||\n      this.isFnDeclTransform(lookahead) ||\n      this.isBraces(lookahead) ||\n      this.isBrackets(lookahead))) {\n      return this.enforestPrimaryExpression();\n    }\n\n    // prefix unary\n    if (this.term === null && this.isOperator(lookahead)) {\n      return this.enforestUnaryExpression();\n    }\n\n    if (this.term === null && this.isVarBindingTransform(lookahead)) {\n      let id = this.getFromCompiletimeEnvironment(lookahead).id;\n      if (id !== lookahead) {\n        this.advance();\n        this.rest = List.of(id).concat(this.rest);\n        return EXPR_LOOP_EXPANSION;\n      }\n    }\n\n    if ((this.term === null && (\n      this.isNewTransform(lookahead) ||\n        this.isKeyword(lookahead, 'super'))) ||\n        // and then check the cases where the term part of p is something...\n        (this.term && (\n          // $x:expr . $prop:ident\n          (this.isPunctuator(lookahead, '.') && (\n            this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1)))) ||\n            // $x:expr [ $b:expr ]\n            this.isBrackets(lookahead) ||\n            // $x:expr (...)\n            this.isParens(lookahead)\n        ))) {\n      return this.enforestLeftHandSideExpression({ allowCall: true });\n    }\n\n    // $x:id `...`\n    if(this.term && this.isTemplate(lookahead)) {\n      return this.enforestTemplateLiteral();\n    }\n\n    // postfix unary\n    if (this.term && this.isUpdateOperator(lookahead)) {\n      return this.enforestUpdateExpression();\n    }\n\n    // $l:expr $op:binaryOperator $r:expr\n    if (this.term && this.isOperator(lookahead)) {\n      return this.enforestBinaryExpression();\n    }\n\n    // $x:expr = $init:expr\n    if (this.term && this.isAssign(lookahead)) {\n      let binding = this.transformDestructuring(this.term);\n      let op = this.advance();\n\n      let enf = new Enforester(this.rest, List(), this.context);\n      let init = enf.enforest(\"expression\");\n      this.rest = enf.rest;\n\n      if (op.val() === '=') {\n        return new Term('AssignmentExpression', {\n          binding,\n          expression: init\n        });\n      } else {\n        return new Term('CompoundAssignmentExpression', {\n          binding,\n          operator: op.val(),\n          expression: init\n        });\n      }\n    }\n\n    if (this.term && this.isPunctuator(lookahead, '?')) {\n      return this.enforestConditionalExpression();\n    }\n\n    return EXPR_LOOP_NO_CHANGE;\n  }\n\n  enforestPrimaryExpression() {\n    let lookahead = this.peek();\n    // $x:ThisExpression\n    if (this.term === null && this.isKeyword(lookahead, \"this\")) {\n      return this.enforestThisExpression();\n    }\n    // $x:ident\n    if (this.term === null && (this.isIdentifier(lookahead) || this.isKeyword(lookahead, 'let') || this.isKeyword(lookahead, 'yield'))) {\n      return this.enforestIdentifierExpression();\n    }\n    if (this.term === null && this.isNumericLiteral(lookahead)) {\n      return this.enforestNumericLiteral();\n    }\n    if (this.term === null && this.isStringLiteral(lookahead)) {\n      return this.enforestStringLiteral();\n    }\n    if (this.term === null && this.isTemplate(lookahead)) {\n      return this.enforestTemplateLiteral();\n    }\n    if (this.term === null && this.isBooleanLiteral(lookahead)) {\n      return this.enforestBooleanLiteral();\n    }\n    if (this.term === null && this.isNullLiteral(lookahead)) {\n      return this.enforestNullLiteral();\n    }\n    if (this.term === null && this.isRegularExpression(lookahead)) {\n      return this.enforestRegularExpressionLiteral();\n    }\n    // $x:FunctionExpression\n    if (this.term === null && this.isFnDeclTransform(lookahead)) {\n      return this.enforestFunctionExpression();\n    }\n    // { $p:prop (,) ... }\n    if (this.term === null && this.isBraces(lookahead)) {\n      return this.enforestObjectExpression();\n    }\n    // [$x:expr (,) ...]\n    if (this.term === null && this.isBrackets(lookahead)) {\n      return this.enforestArrayExpression();\n    }\n    assert(false, 'Not a primary expression');\n  }\n\n  enforestLeftHandSideExpression({ allowCall }) {\n    let lookahead = this.peek();\n\n    if (this.isKeyword(lookahead, 'super')) {\n      this.advance();\n      this.term = new Term('Super', {});\n    } else if (this.isNewTransform(lookahead)) {\n      this.term = this.enforestNewExpression();\n    }\n\n    while (true) {\n      lookahead = this.peek();\n      if (this.isParens(lookahead)) {\n        if (!allowCall) {\n          // we're dealing with a new expression\n          if (this.term &&\n              (isIdentifierExpression(this.term) ||\n               isStaticMemberExpression(this.term) ||\n               isComputedMemberExpression(this.term))) {\n            return this.term;\n          }\n          this.term = this.enforestExpressionLoop();\n        } else {\n          this.term = this.enforestCallExpression();\n        }\n      } else if (this.isBrackets(lookahead)) {\n        this.term = this.term ? this.enforestComputedMemberExpression() : this.enforestPrimaryExpression();\n      } else if (this.isPunctuator(lookahead, '.') && (\n        this.isIdentifier(this.peek(1)) || this.isKeyword(this.peek(1)))) {\n        this.term = this.enforestStaticMemberExpression();\n      } else if (this.isTemplate(lookahead)) {\n        this.term = this.enforestTemplateLiteral();\n      } else if (this.isBraces(lookahead)) {\n        this.term = this.enforestPrimaryExpression();\n      } else if (this.isIdentifier(lookahead)) {\n        this.term = new Term('IdentifierExpression', { name: this.enforestIdentifier() });\n      } else {\n        break;\n      }\n    }\n    return this.term;\n  }\n\n  enforestBooleanLiteral() {\n    return new Term(\"LiteralBooleanExpression\", {\n      value: this.advance()\n    });\n  }\n\n  enforestTemplateLiteral() {\n    return new Term('TemplateExpression', {\n      tag: this.term,\n      elements: this.enforestTemplateElements()\n    });\n  }\n\n  enforestStringLiteral() {\n    return new Term(\"LiteralStringExpression\", {\n      value: this.advance()\n    });\n  }\n\n  enforestNumericLiteral() {\n    let num = this.advance();\n    if (num.val() === 1 / 0) {\n      return new Term('LiteralInfinityExpression', {});\n    }\n    return new Term(\"LiteralNumericExpression\", {\n      value: num\n    });\n  }\n\n  enforestIdentifierExpression() {\n    return new Term(\"IdentifierExpression\", {\n      name: this.advance()\n    });\n  }\n\n  enforestRegularExpressionLiteral() {\n    let reStx = this.advance();\n\n    let lastSlash = reStx.token.value.lastIndexOf(\"/\");\n    let pattern = reStx.token.value.slice(1, lastSlash);\n    let flags = reStx.token.value.slice(lastSlash + 1);\n    return new Term(\"LiteralRegExpExpression\", {\n      pattern, flags\n    });\n  }\n\n  enforestNullLiteral() {\n    this.advance();\n    return new Term(\"LiteralNullExpression\", {});\n  }\n\n  enforestThisExpression() {\n    return new Term(\"ThisExpression\", {\n      stx: this.advance()\n    });\n  }\n\n  enforestArgumentList() {\n    let result = [];\n    while (this.rest.size > 0) {\n      let arg;\n      if (this.isPunctuator(this.peek(), '...')) {\n        this.advance();\n        arg = new Term('SpreadElement', {\n          expression: this.enforestExpressionLoop()\n        });\n      } else {\n        arg = this.enforestExpressionLoop();\n      }\n      if (this.rest.size > 0) {\n        this.matchPunctuator(',');\n      }\n      result.push(arg);\n    }\n    return List(result);\n  }\n\n  enforestNewExpression() {\n    this.matchKeyword('new');\n    if (this.isPunctuator(this.peek(), '.') && this.isIdentifier(this.peek(1), 'target')) {\n      this.advance();\n      this.advance();\n      return new Term('NewTargetExpression', {});\n    }\n\n    let callee = this.enforestLeftHandSideExpression({ allowCall: false });\n    let args;\n    if (this.isParens(this.peek())) {\n      args = this.matchParens();\n    } else {\n      args = List();\n    }\n    return new Term('NewExpression', {\n      callee,\n      arguments: args\n    });\n  }\n\n  enforestComputedMemberExpression() {\n    let enf = new Enforester(this.matchSquares(), List(), this.context);\n    return new Term('ComputedMemberExpression', {\n      object: this.term,\n      expression: enf.enforestExpression()\n    });\n  }\n\n  transformDestructuring(term) {\n    switch (term.type) {\n      case 'IdentifierExpression':\n        return new Term('BindingIdentifier', {name: term.name});\n\n      case 'ParenthesizedExpression':\n        if (term.inner.size === 1 && this.isIdentifier(term.inner.get(0))) {\n          return new Term('BindingIdentifier', { name: term.inner.get(0)});\n        }\n        return term;\n      case 'DataProperty':\n        return new Term('BindingPropertyProperty', {\n          name: term.name,\n          binding: this.transformDestructuringWithDefault(term.expression)\n        });\n      case 'ShorthandProperty':\n        return new Term('BindingPropertyIdentifier', {\n          binding: new Term('BindingIdentifier', { name: term.name }),\n          init: null\n        });\n      case 'ObjectExpression':\n        return new Term('ObjectBinding', {\n          properties: term.properties.map(t => this.transformDestructuring(t))\n        });\n      case 'ArrayExpression': {\n        let last = term.elements.last();\n        if (last != null && last.type === 'SpreadElement') {\n          return new Term('ArrayBinding', {\n            elements: term.elements.slice(0, -1).map(t => t && this.transformDestructuringWithDefault(t)),\n            restElement: this.transformDestructuringWithDefault(last.expression)\n          });\n        } else {\n          return new Term('ArrayBinding', {\n            elements: term.elements.map(t => t && this.transformDestructuringWithDefault(t)),\n            restElement: null\n          });\n        }\n      }\n      case 'StaticPropertyName':\n        return new Term('BindingIdentifier', {\n          name: term.value\n        });\n      case 'ComputedMemberExpression':\n      case 'StaticMemberExpression':\n      case 'ArrayBinding':\n      case 'BindingIdentifier':\n      case 'BindingPropertyIdentifier':\n      case 'BindingPropertyProperty':\n      case 'BindingWithDefault':\n      case 'ObjectBinding':\n        return term;\n    }\n    assert(false, 'not implemented yet for ' + term.type);\n  }\n\n  transformDestructuringWithDefault(term) {\n    switch (term.type) {\n      case \"AssignmentExpression\":\n        return new Term('BindingWithDefault', {\n          binding: this.transformDestructuring(term.binding),\n          init: term.expression,\n        });\n    }\n    return this.transformDestructuring(term);\n  }\n\n  enforestCallExpression() {\n    let paren = this.advance();\n    return new Term(\"CallExpression\", {\n      callee: this.term,\n      arguments: paren.inner()\n    });\n  }\n\n  enforestArrowExpression() {\n    let enf;\n    if (this.isIdentifier(this.peek())) {\n      enf = new Enforester(List.of(this.advance()), List(), this.context);\n    } else {\n      let p = this.matchParens();\n      enf = new Enforester(p, List(), this.context);\n    }\n    let params = enf.enforestFormalParameters();\n    this.matchPunctuator('=>');\n\n    let body;\n    if (this.isBraces(this.peek())) {\n      body = this.matchCurlies();\n    } else {\n      enf = new Enforester(this.rest, List(), this.context);\n      body = enf.enforestExpressionLoop();\n      this.rest = enf.rest;\n    }\n    return new Term('ArrowExpression', { params, body });\n  }\n\n\n  enforestYieldExpression() {\n    let kwd = this.matchKeyword('yield');\n    let lookahead = this.peek();\n\n    if (this.rest.size === 0 || (lookahead && !this.lineNumberEq(kwd, lookahead))) {\n      return new Term('YieldExpression', {\n        expression: null\n      });\n    } else {\n      let isGenerator = false;\n      if (this.isPunctuator(this.peek(), '*')) {\n          isGenerator = true;\n          this.advance();\n      }\n      let expr = this.enforestExpression();\n      let type = isGenerator ? 'YieldGeneratorExpression' : 'YieldExpression';\n      return new Term(type, {\n        expression: expr\n      });\n    }\n  }\n\n  enforestSyntaxTemplate() {\n    return new Term('SyntaxTemplate', {\n      template: this.advance()\n    });\n  }\n\n  enforestSyntaxQuote() {\n    let name = this.advance();\n    return new Term('SyntaxQuote', {\n      name: name,\n      template: new Term('TemplateExpression', {\n        tag: new Term('IdentifierExpression', {\n          name: name\n        }),\n        elements: this.enforestTemplateElements()\n      })\n    });\n  }\n\n  enforestStaticMemberExpression() {\n    let object = this.term;\n    this.advance();\n    let property = this.advance();\n\n    return new Term(\"StaticMemberExpression\", {\n      object: object,\n      property: property\n    });\n  }\n\n  enforestArrayExpression() {\n    let arr = this.advance();\n\n    let elements = [];\n\n    let enf = new Enforester(arr.inner(), List(), this.context);\n\n    while (enf.rest.size > 0) {\n      let lookahead = enf.peek();\n      if (enf.isPunctuator(lookahead, \",\")) {\n        enf.advance();\n        elements.push(null);\n      } else if (enf.isPunctuator(lookahead, '...')) {\n        enf.advance();\n        let expression = enf.enforestExpressionLoop();\n        if (expression == null) {\n          throw enf.createError(lookahead, 'expecting expression');\n        }\n        elements.push(new Term('SpreadElement', { expression }));\n      } else {\n        let term = enf.enforestExpressionLoop();\n        if (term == null) {\n          throw enf.createError(lookahead, \"expected expression\");\n        }\n        elements.push(term);\n        enf.consumeComma();\n      }\n    }\n\n    return new Term(\"ArrayExpression\", {\n      elements: List(elements)\n    });\n  }\n\n  enforestObjectExpression() {\n    let obj = this.advance();\n\n    let properties = List();\n\n    let enf = new Enforester(obj.inner(), List(), this.context);\n\n    let lastProp = null;\n    while (enf.rest.size > 0) {\n      let prop = enf.enforestPropertyDefinition();\n      enf.consumeComma();\n      properties = properties.concat(prop);\n\n      if (lastProp === prop) {\n        throw enf.createError(prop, \"invalid syntax in object\");\n      }\n      lastProp = prop;\n    }\n\n    return new Term(\"ObjectExpression\", {\n      properties: properties\n    });\n  }\n\n  enforestPropertyDefinition() {\n\n    let {methodOrKey, kind} = this.enforestMethodDefinition();\n\n    switch (kind) {\n      case 'method':\n        return methodOrKey;\n      case 'identifier':\n        if (this.isAssign(this.peek())) {\n          this.advance();\n          let init = this.enforestExpressionLoop();\n          return new Term('BindingPropertyIdentifier', {\n            init, binding: this.transformDestructuring(methodOrKey)\n          });\n        } else if (!this.isPunctuator(this.peek(), ':')) {\n          return new Term('ShorthandProperty', {\n            name: methodOrKey.value\n          });\n        }\n    }\n\n    this.matchPunctuator(':');\n    let expr = this.enforestExpressionLoop();\n\n    return new Term(\"DataProperty\", {\n      name: methodOrKey,\n      expression: expr\n    });\n  }\n\n  enforestMethodDefinition() {\n    let lookahead = this.peek();\n    let isGenerator = false;\n    if (this.isPunctuator(lookahead, '*')) {\n      isGenerator = true;\n      this.advance();\n    }\n\n    if (this.isIdentifier(lookahead, 'get') && this.isPropertyName(this.peek(1))) {\n      this.advance();\n      let {name} = this.enforestPropertyName();\n      this.matchParens();\n      let body = this.matchCurlies();\n      return {\n        methodOrKey: new Term('Getter', { name, body }),\n        kind: 'method'\n      };\n    } else if (this.isIdentifier(lookahead, 'set') && this.isPropertyName(this.peek(1))) {\n      this.advance();\n      let {name} = this.enforestPropertyName();\n      let enf = new Enforester(this.matchParens(), List(), this.context);\n      let param = enf.enforestBindingElement();\n      let body = this.matchCurlies();\n      return {\n        methodOrKey: new Term('Setter', { name, param, body }),\n        kind: 'method'\n      };\n    }\n    let {name} = this.enforestPropertyName();\n    if (this.isParens(this.peek())) {\n      let params = this.matchParens();\n      let enf = new Enforester(params, List(), this.context);\n      let formalParams = enf.enforestFormalParameters();\n\n      let body = this.matchCurlies();\n      return {\n        methodOrKey: new Term('Method', {\n          isGenerator,\n          name, params: formalParams, body\n        }),\n        kind: 'method'\n      };\n    }\n    return {\n      methodOrKey: name,\n      kind: this.isIdentifier(lookahead) || this.isKeyword(lookahead) ? 'identifier' : 'property'\n    };\n  }\n\n  enforestPropertyName() {\n    let lookahead = this.peek();\n\n    if (this.isStringLiteral(lookahead) || this.isNumericLiteral(lookahead)) {\n      return {\n        name: new Term('StaticPropertyName', {\n          value: this.advance()\n        }),\n        binding: null\n      };\n    } else if (this.isBrackets(lookahead)) {\n      let enf = new Enforester(this.matchSquares(), List(), this.context);\n      let expr = enf.enforestExpressionLoop();\n      return {\n        name: new Term('ComputedPropertyName', {\n          expression: expr\n        }),\n        binding: null\n      };\n    }\n    let name = this.advance();\n    return {\n      name: new Term('StaticPropertyName', { value: name }),\n      binding: new Term('BindingIdentifier', { name })\n    };\n  }\n\n  enforestFunction({isExpr, inDefault}) {\n    let name = null, params, body;\n    let isGenerator = false;\n    // eat the function keyword\n    let fnKeyword = this.advance();\n    let lookahead = this.peek();\n    let type = isExpr ? 'FunctionExpression' : 'FunctionDeclaration';\n\n    if (this.isPunctuator(lookahead, \"*\")) {\n      isGenerator = true;\n      this.advance();\n      lookahead = this.peek();\n    }\n\n    if (!this.isParens(lookahead)) {\n      name = this.enforestBindingIdentifier();\n    } else if (inDefault) {\n      name = new Term('BindingIdentifier', {\n        name: Syntax.fromIdentifier('*default*', fnKeyword)\n      });\n    }\n\n\n    params = this.matchParens();\n\n\n    body = this.matchCurlies();\n\n    let enf = new Enforester(params, List(), this.context);\n    let formalParams = enf.enforestFormalParameters();\n\n    return new Term(type, {\n      name: name,\n      isGenerator: isGenerator,\n      params: formalParams,\n      body: body\n    });\n  }\n\n  enforestFunctionExpression() {\n    let name = null, params, body;\n    let isGenerator = false;\n    // eat the function keyword\n    this.advance();\n    let lookahead = this.peek();\n\n    if (this.isPunctuator(lookahead, \"*\")) {\n      isGenerator = true;\n      this.advance();\n      lookahead = this.peek();\n    }\n\n    if (!this.isParens(lookahead)) {\n      name = this.enforestBindingIdentifier();\n    }\n\n    params = this.matchParens();\n    body = this.matchCurlies();\n\n    let enf = new Enforester(params, List(), this.context);\n    let formalParams = enf.enforestFormalParameters();\n\n    return new Term(\"FunctionExpression\", {\n      name: name,\n      isGenerator: isGenerator,\n      params: formalParams,\n      body: body\n    });\n  }\n\n  enforestFunctionDeclaration() {\n    let name, params, body;\n    let isGenerator = false;\n    // eat the function keyword\n    this.advance();\n    let lookahead = this.peek();\n\n    if (this.isPunctuator(lookahead, \"*\")) {\n      isGenerator = true;\n      this.advance();\n    }\n\n    name = this.enforestBindingIdentifier();\n\n    params = this.matchParens();\n    body = this.matchCurlies();\n\n    let enf = new Enforester(params, List(), this.context);\n    let formalParams = enf.enforestFormalParameters();\n\n    return new Term(\"FunctionDeclaration\", {\n      name: name,\n      isGenerator: isGenerator,\n      params: formalParams,\n      body: body\n    });\n  }\n\n  enforestFormalParameters() {\n    let items = [];\n    let rest = null;\n    while (this.rest.size !== 0) {\n      let lookahead = this.peek();\n      if (this.isPunctuator(lookahead, '...')) {\n        this.matchPunctuator('...');\n        rest = this.enforestBindingIdentifier();\n        break;\n      }\n      items.push(this.enforestParam());\n      this.consumeComma();\n    }\n    return new Term(\"FormalParameters\", {\n      items: List(items), rest\n    });\n  }\n\n  enforestParam() {\n    return this.enforestBindingElement();\n  }\n\n  enforestUpdateExpression() {\n    let operator = this.matchUnaryOperator();\n\n    return new Term('UpdateExpression', {\n      isPrefix: false,\n      operator: operator.val(),\n      operand: this.transformDestructuring(this.term)\n    });\n  }\n\n  enforestUnaryExpression() {\n    let operator = this.matchUnaryOperator();\n    this.opCtx.stack = this.opCtx.stack.push({\n      prec: this.opCtx.prec,\n      combine: this.opCtx.combine\n    });\n    // TODO: all builtins are 14, custom operators will change this\n    this.opCtx.prec = 14;\n    this.opCtx.combine = rightTerm => {\n      if (operator.val() === '++' || operator.val() === '--') {\n        return new Term('UpdateExpression', {\n          operator: operator.val(),\n          operand: this.transformDestructuring(rightTerm),\n          isPrefix: true\n        });\n      } else {\n        return new Term('UnaryExpression', {\n          operator: operator.val(),\n          operand: rightTerm\n        });\n      }\n    };\n    return EXPR_LOOP_OPERATOR;\n  }\n\n  enforestConditionalExpression() {\n    // first, pop the operator stack\n    let test = this.opCtx.combine(this.term);\n    if (this.opCtx.stack.size > 0) {\n      let { prec, combine } = this.opCtx.stack.last();\n      this.opCtx.stack = this.opCtx.stack.pop();\n      this.opCtx.prec = prec;\n      this.opCtx.combine = combine;\n    }\n\n    this.matchPunctuator('?');\n    let enf = new Enforester(this.rest, List(), this.context);\n    let consequent = enf.enforestExpressionLoop();\n    enf.matchPunctuator(':');\n    enf = new Enforester(enf.rest, List(), this.context);\n    let alternate = enf.enforestExpressionLoop();\n    this.rest = enf.rest;\n    return new Term('ConditionalExpression', {\n      test, consequent, alternate\n    });\n  }\n\n  enforestBinaryExpression() {\n\n    let leftTerm = this.term;\n    let opStx = this.peek();\n    let op = opStx.val();\n    let opPrec = getOperatorPrec(op);\n    let opAssoc = getOperatorAssoc(op);\n\n    if (operatorLt(this.opCtx.prec, opPrec, opAssoc)) {\n      this.opCtx.stack = this.opCtx.stack.push({\n        prec: this.opCtx.prec,\n        combine: this.opCtx.combine\n      });\n      this.opCtx.prec = opPrec;\n      this.opCtx.combine = (rightTerm) => {\n        return new Term(\"BinaryExpression\", {\n          left: leftTerm,\n          operator: opStx,\n          right: rightTerm\n        });\n      };\n      this.advance();\n      return EXPR_LOOP_OPERATOR;\n    } else {\n      let term = this.opCtx.combine(leftTerm);\n      // this.rest does not change\n      let { prec, combine } = this.opCtx.stack.last();\n      this.opCtx.stack = this.opCtx.stack.pop();\n      this.opCtx.prec = prec;\n      this.opCtx.combine = combine;\n      return term;\n    }\n  }\n\n  enforestTemplateElements() {\n    let lookahead = this.matchTemplate();\n    let elements = lookahead.token.items.map(it => {\n      if (this.isDelimiter(it)) {\n        let enf = new Enforester(it.inner(), List(), this.context);\n        return enf.enforest(\"expression\");\n      }\n      return new Term('TemplateElement', {\n        rawValue: it.slice.text\n      });\n    });\n    return elements;\n  }\n\n  expandMacro() {\n    let lookahead = this.peek();\n    while (this.isCompiletimeTransform(lookahead)) {\n      let name = this.advance();\n\n      let syntaxTransform = this.getFromCompiletimeEnvironment(name);\n      if (syntaxTransform == null || typeof syntaxTransform.value !== \"function\") {\n        throw this.createError(name,\n          \"the macro name was not bound to a value that could be invoked\");\n      }\n      let useSiteScope = freshScope(\"u\");\n      let introducedScope = freshScope(\"i\");\n      // TODO: needs to be a list of scopes I think\n      this.context.useScope = useSiteScope;\n\n      let ctx = new MacroContext(this, name, this.context, useSiteScope, introducedScope);\n\n      let result = sanitizeReplacementValues(syntaxTransform.value.call(null, ctx));\n      if (!List.isList(result)) {\n        throw this.createError(name, \"macro must return a list but got: \" + result);\n      }\n      result = result.map(stx => {\n        if (!(stx && typeof stx.addScope === 'function')) {\n          throw this.createError(name, 'macro must return syntax objects or terms but got: ' + stx);\n        }\n        return stx.addScope(introducedScope, this.context.bindings, ALL_PHASES, { flip: true });\n      });\n\n      this.rest = result.concat(ctx._rest(this));\n      lookahead = this.peek();\n    }\n  }\n\n  consumeSemicolon() {\n    let lookahead = this.peek();\n\n    if (lookahead && this.isPunctuator(lookahead, \";\")) {\n      this.advance();\n    }\n  }\n\n  consumeComma() {\n    let lookahead = this.peek();\n\n    if (lookahead && this.isPunctuator(lookahead, ',')) {\n      this.advance();\n    }\n  }\n\n  safeCheck(obj, type, val = null) {\n    return obj && (typeof obj.match === 'function' ? obj.match(type, val) : false);\n  }\n\n  isTerm(term) {\n    return term && (term instanceof Term);\n  }\n\n  isEOF(obj) {\n    return this.safeCheck(obj, 'eof');\n  }\n\n  isIdentifier(obj, val = null) {\n    return this.safeCheck(obj, 'identifier', val);\n  }\n\n  isPropertyName(obj) {\n    return this.isIdentifier(obj) || this.isKeyword(obj) ||\n           this.isNumericLiteral(obj) || this.isStringLiteral(obj) || this.isBrackets(obj);\n  }\n\n  isNumericLiteral(obj, val = null) {\n    return this.safeCheck(obj, 'number', val);\n  }\n\n  isStringLiteral(obj, val = null) {\n    return this.safeCheck(obj, 'string', val);\n  }\n\n  isTemplate(obj, val = null) {\n    return this.safeCheck(obj, 'template', val);\n  }\n\n  isSyntaxTemplate(obj) {\n    return this.safeCheck(obj, 'syntaxTemplate');\n  }\n\n  isBooleanLiteral(obj, val = null) {\n    return this.safeCheck(obj, 'boolean', val);\n  }\n\n  isNullLiteral(obj, val = null) {\n    return this.safeCheck(obj, 'null', val);\n  }\n\n  isRegularExpression(obj, val = null) {\n    return this.safeCheck(obj, 'regularExpression', val);\n  }\n\n  isDelimiter(obj) {\n    return this.safeCheck(obj, 'delimiter');\n  }\n\n  isParens(obj) {\n    return this.safeCheck(obj, 'parens');\n  }\n\n  isBraces(obj) {\n    return this.safeCheck(obj, 'braces');\n  }\n\n  isBrackets(obj) {\n    return this.safeCheck(obj, 'brackets');\n  }\n\n  isAssign(obj, val = null) {\n    return this.safeCheck(obj, 'assign', val);\n  }\n\n\n  isKeyword(obj, val = null) {\n    return this.safeCheck(obj, 'keyword', val);\n  }\n\n  isPunctuator(obj, val = null) {\n    return this.safeCheck(obj, 'punctuator', val);\n  }\n\n  isOperator(obj) {\n    return (this.safeCheck(obj, 'punctuator') ||\n            this.safeCheck(obj, 'identifier') ||\n            this.safeCheck(obj, 'keyword')) && isOperator(obj);\n  }\n\n  isUpdateOperator(obj) {\n    return this.safeCheck(obj, 'punctuator', '++') ||\n           this.safeCheck(obj, 'punctuator', '--');\n  }\n\n  safeResolve(obj, phase) {\n    return (obj && typeof obj.resolve === 'function') ? Just(obj.resolve(phase)) : Nothing();\n  }\n\n  isTransform(obj, trans) {\n    return this.safeResolve(obj, this.context.phase)\n               .map(name => this.context.env.get(name) === trans ||\n                            this.context.store.get(name) === trans)\n               .getOrElse(false);\n  }\n\n  isTransformInstance(obj, trans) {\n    return this.safeResolve(obj, this.context.phase)\n               .map(name => this.context.env.get(name) instanceof trans ||\n                            this.context.store.get(name) instanceof trans)\n               .getOrElse(false);\n  }\n\n  isFnDeclTransform(obj) {\n    return this.isTransform(obj, FunctionDeclTransform);\n  }\n\n  isVarDeclTransform(obj) {\n    return this.isTransform(obj, VariableDeclTransform);\n  }\n\n  isLetDeclTransform(obj) {\n    return this.isTransform(obj, LetDeclTransform);\n  }\n\n  isConstDeclTransform(obj) {\n    return this.isTransform(obj, ConstDeclTransform);\n  }\n\n  isSyntaxDeclTransform(obj) {\n    return this.isTransform(obj, SyntaxDeclTransform);\n  }\n\n  isSyntaxrecDeclTransform(obj) {\n    return this.isTransform(obj, SyntaxrecDeclTransform);\n  }\n\n  isSyntaxQuoteTransform(obj) {\n    return this.isTransform(obj, SyntaxQuoteTransform);\n  }\n\n  isReturnStmtTransform(obj) {\n    return this.isTransform(obj, ReturnStatementTransform);\n  }\n\n  isWhileTransform(obj) {\n    return this.isTransform(obj, WhileTransform);\n  }\n\n  isForTransform(obj) {\n    return this.isTransform(obj, ForTransform);\n  }\n\n  isSwitchTransform(obj) {\n    return this.isTransform(obj, SwitchTransform);\n  }\n\n  isBreakTransform(obj) {\n    return this.isTransform(obj, BreakTransform);\n  }\n\n  isContinueTransform(obj) {\n    return this.isTransform(obj, ContinueTransform);\n  }\n\n  isDoTransform(obj) {\n    return this.isTransform(obj, DoTransform);\n  }\n\n  isDebuggerTransform(obj) {\n    return this.isTransform(obj, DebuggerTransform);\n  }\n\n  isWithTransform(obj) {\n    return this.isTransform(obj, WithTransform);\n  }\n\n  isTryTransform(obj) {\n    return this.isTransform(obj, TryTransform);\n  }\n\n  isThrowTransform(obj) {\n    return this.isTransform(obj, ThrowTransform);\n  }\n\n  isIfTransform(obj) {\n    return this.isTransform(obj, IfTransform);\n  }\n\n  isNewTransform(obj) {\n    return this.isTransform(obj, NewTransform);\n  }\n\n  isCompiletimeTransform(obj) {\n    return this.isTransformInstance(obj, CompiletimeTransform);\n  }\n\n  isVarBindingTransform(obj) {\n    return this.isTransformInstance(obj, VarBindingTransform);\n  }\n\n  getFromCompiletimeEnvironment(term) {\n    if (this.context.env.has(term.resolve(this.context.phase))) {\n      return this.context.env.get(term.resolve(this.context.phase));\n    }\n    return this.context.store.get(term.resolve(this.context.phase));\n  }\n\n  lineNumberEq(a, b) {\n    if (!(a && b)) {\n      return false;\n    }\n    return a.lineNumber() === b.lineNumber();\n  }\n\n  matchIdentifier(val) {\n    let lookahead = this.advance();\n    if (this.isIdentifier(lookahead, val)) {\n      return lookahead;\n    }\n    throw this.createError(lookahead, \"expecting an identifier\");\n  }\n\n  matchKeyword(val) {\n    let lookahead = this.advance();\n    if (this.isKeyword(lookahead, val)) {\n      return lookahead;\n    }\n    throw this.createError(lookahead, 'expecting ' + val);\n  }\n\n  matchLiteral() {\n    let lookahead = this.advance();\n    if (this.isNumericLiteral(lookahead) ||\n        this.isStringLiteral(lookahead) ||\n        this.isBooleanLiteral(lookahead) ||\n        this.isNullLiteral(lookahead) ||\n        this.isTemplate(lookahead) ||\n        this.isRegularExpression(lookahead)) {\n      return lookahead;\n    }\n    throw this.createError(lookahead, \"expecting a literal\");\n  }\n\n  matchStringLiteral() {\n    let lookahead = this.advance();\n    if (this.isStringLiteral(lookahead)) {\n      return lookahead;\n    }\n    throw this.createError(lookahead, 'expecting a string literal');\n  }\n\n  matchTemplate() {\n    let lookahead = this.advance();\n    if (this.isTemplate(lookahead)) {\n      return lookahead;\n    }\n    throw this.createError(lookahead, 'expecting a template literal');\n  }\n\n  matchParens() {\n    let lookahead = this.advance();\n    if (this.isParens(lookahead)) {\n      return lookahead.inner();\n    }\n    throw this.createError(lookahead, \"expecting parens\");\n  }\n\n  matchCurlies() {\n    let lookahead = this.advance();\n    if (this.isBraces(lookahead)) {\n      return lookahead.inner();\n    }\n    throw this.createError(lookahead, \"expecting curly braces\");\n  }\n  matchSquares() {\n    let lookahead = this.advance();\n    if (this.isBrackets(lookahead)) {\n      return lookahead.inner();\n    }\n    throw this.createError(lookahead, \"expecting sqaure braces\");\n  }\n\n  matchUnaryOperator() {\n    let lookahead = this.advance();\n    if (isUnaryOperator(lookahead)) {\n      return lookahead;\n    }\n    throw this.createError(lookahead, \"expecting a unary operator\");\n  }\n\n  matchPunctuator(val) {\n    let lookahead = this.advance();\n    if (this.isPunctuator(lookahead)) {\n      if (typeof val !== 'undefined') {\n        if (lookahead.val() === val) {\n          return lookahead;\n        } else {\n          throw this.createError(lookahead,\n            \"expecting a \" + val + \" punctuator\");\n        }\n      }\n      return lookahead;\n    }\n    throw this.createError(lookahead, \"expecting a punctuator\");\n  }\n\n  createError(stx, message) {\n    let ctx = \"\";\n    let offending = stx;\n    if (this.rest.size > 0) {\n      ctx = this.rest.slice(0, 20).map(term => {\n        if (this.isDelimiter(term)) {\n          return term.inner();\n        }\n        return List.of(term);\n      }).flatten().map(s => {\n        if (s === offending) {\n          return \"__\" + s.val() + \"__\";\n        }\n        return s.val();\n      }).join(\" \");\n    } else {\n      ctx = offending.toString();\n    }\n    return new Error(message + \"\\n\" + ctx);\n\n  }\n}\n"]} \ No newline at end of file diff --git a/dist/env.js b/dist/env.js index a2721a29..50b5cc7d 100644 --- a/dist/env.js +++ b/dist/env.js @@ -30,15 +30,18 @@ class Env { this.map.set("throw", _transforms.ThrowTransform); this.map.set("new", _transforms.NewTransform); } - has(key_332) { - return this.map.has(key_332); + + has(key) { + return this.map.has(key); } - get(key_333) { - return this.map.get(key_333); + + get(key) { + return this.map.get(key); } - set(key_334, val_335) { - return this.map.set(key_334, val_335); + + set(key, val) { + return this.map.set(key, val); } } exports.default = Env; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2Vudi5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7QUFDZSxNQUFNLEdBQU4sQ0FBVTtBQUN2QixnQkFBYztBQUNaLFNBQUssR0FBTCxHQUFXLElBQUksR0FBSixFQUFYO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLFVBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsS0FBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxLQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLE9BQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsYUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxXQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLFFBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsUUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxPQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLElBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsS0FBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxRQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLE9BQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsVUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxJQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLFVBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsTUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxLQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLE9BQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsS0FBYjtBQUNEO0FBQ0QsTUFBSSxPQUFKLEVBQWE7QUFDWCxXQUFPLEtBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxPQUFiLENBQVA7QUFDRDtBQUNELE1BQUksT0FBSixFQUFhO0FBQ1gsV0FBTyxLQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsT0FBYixDQUFQO0FBQ0Q7QUFDRCxNQUFJLE9BQUosRUFBYSxPQUFiLEVBQXNCO0FBQ3BCLFdBQU8sS0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLE9BQWIsRUFBc0IsT0FBdEIsQ0FBUDtBQUNEO0FBaENzQjtrQkFBSixHIiwiZmlsZSI6ImVudi5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RnVuY3Rpb25EZWNsVHJhbnNmb3JtLCBWYXJpYWJsZURlY2xUcmFuc2Zvcm0sIExldERlY2xUcmFuc2Zvcm0sIENvbnN0RGVjbFRyYW5zZm9ybSwgU3ludGF4RGVjbFRyYW5zZm9ybSwgU3ludGF4cmVjRGVjbFRyYW5zZm9ybSwgU3ludGF4UXVvdGVUcmFuc2Zvcm0sIFJldHVyblN0YXRlbWVudFRyYW5zZm9ybSwgSWZUcmFuc2Zvcm0sIEZvclRyYW5zZm9ybSwgU3dpdGNoVHJhbnNmb3JtLCBCcmVha1RyYW5zZm9ybSwgQ29udGludWVUcmFuc2Zvcm0sIERvVHJhbnNmb3JtLCBEZWJ1Z2dlclRyYW5zZm9ybSwgV2l0aFRyYW5zZm9ybSwgVHJ5VHJhbnNmb3JtLCBUaHJvd1RyYW5zZm9ybSwgTmV3VHJhbnNmb3JtLCBXaGlsZVRyYW5zZm9ybX0gZnJvbSBcIi4vdHJhbnNmb3Jtc1wiO1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgRW52IHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5tYXAgPSBuZXcgTWFwO1xuICAgIHRoaXMubWFwLnNldChcImZ1bmN0aW9uXCIsIEZ1bmN0aW9uRGVjbFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwidmFyXCIsIFZhcmlhYmxlRGVjbFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwibGV0XCIsIExldERlY2xUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcImNvbnN0XCIsIENvbnN0RGVjbFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwic3ludGF4UXVvdGVcIiwgU3ludGF4UXVvdGVUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcInN5bnRheHJlY1wiLCBTeW50YXhyZWNEZWNsVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJzeW50YXhcIiwgU3ludGF4RGVjbFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwicmV0dXJuXCIsIFJldHVyblN0YXRlbWVudFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwid2hpbGVcIiwgV2hpbGVUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcImlmXCIsIElmVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJmb3JcIiwgRm9yVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJzd2l0Y2hcIiwgU3dpdGNoVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJicmVha1wiLCBCcmVha1RyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwiY29udGludWVcIiwgQ29udGludWVUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcImRvXCIsIERvVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJkZWJ1Z2dlclwiLCBEZWJ1Z2dlclRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwid2l0aFwiLCBXaXRoVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJ0cnlcIiwgVHJ5VHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJ0aHJvd1wiLCBUaHJvd1RyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwibmV3XCIsIE5ld1RyYW5zZm9ybSk7XG4gIH1cbiAgaGFzKGtleV8zMzIpIHtcbiAgICByZXR1cm4gdGhpcy5tYXAuaGFzKGtleV8zMzIpO1xuICB9XG4gIGdldChrZXlfMzMzKSB7XG4gICAgcmV0dXJuIHRoaXMubWFwLmdldChrZXlfMzMzKTtcbiAgfVxuICBzZXQoa2V5XzMzNCwgdmFsXzMzNSkge1xuICAgIHJldHVybiB0aGlzLm1hcC5zZXQoa2V5XzMzNCwgdmFsXzMzNSk7XG4gIH1cbn1cbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lbnYuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7O0FBdUJlLE1BQU0sR0FBTixDQUFVO0FBQ3ZCLGdCQUFjO0FBQ1osU0FBSyxHQUFMLEdBQVcsSUFBSSxHQUFKLEVBQVg7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsVUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxLQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLEtBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsT0FBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxhQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLFdBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsUUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxRQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLE9BQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsSUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxLQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLFFBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsT0FBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxVQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLElBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsVUFBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxNQUFiO0FBQ0EsU0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLEtBQWI7QUFDQSxTQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsT0FBYjtBQUNBLFNBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxLQUFiO0FBQ0Q7O0FBRUQsTUFBSSxHQUFKLEVBQVM7QUFDUCxXQUFPLEtBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxHQUFiLENBQVA7QUFDRDs7QUFFRCxNQUFJLEdBQUosRUFBUztBQUNQLFdBQU8sS0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLEdBQWIsQ0FBUDtBQUNEOztBQUVELE1BQUksR0FBSixFQUFTLEdBQVQsRUFBYztBQUNaLFdBQU8sS0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLEdBQWIsRUFBa0IsR0FBbEIsQ0FBUDtBQUNEO0FBbkNzQjtrQkFBSixHIiwiZmlsZSI6ImVudi5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEZ1bmN0aW9uRGVjbFRyYW5zZm9ybSxcbiAgVmFyaWFibGVEZWNsVHJhbnNmb3JtLFxuICBMZXREZWNsVHJhbnNmb3JtLFxuICBDb25zdERlY2xUcmFuc2Zvcm0sXG4gIFN5bnRheERlY2xUcmFuc2Zvcm0sXG4gIFN5bnRheHJlY0RlY2xUcmFuc2Zvcm0sXG4gIFN5bnRheFF1b3RlVHJhbnNmb3JtLFxuICBSZXR1cm5TdGF0ZW1lbnRUcmFuc2Zvcm0sXG4gIElmVHJhbnNmb3JtLFxuICBGb3JUcmFuc2Zvcm0sXG4gIFN3aXRjaFRyYW5zZm9ybSxcbiAgQnJlYWtUcmFuc2Zvcm0sXG4gIENvbnRpbnVlVHJhbnNmb3JtLFxuICBEb1RyYW5zZm9ybSxcbiAgRGVidWdnZXJUcmFuc2Zvcm0sXG4gIFdpdGhUcmFuc2Zvcm0sXG4gIFRyeVRyYW5zZm9ybSxcbiAgVGhyb3dUcmFuc2Zvcm0sXG4gIE5ld1RyYW5zZm9ybSxcbiAgV2hpbGVUcmFuc2Zvcm1cbn0gZnJvbSBcIi4vdHJhbnNmb3Jtc1wiO1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBFbnYge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLm1hcCA9IG5ldyBNYXAoKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJmdW5jdGlvblwiLCBGdW5jdGlvbkRlY2xUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcInZhclwiLCBWYXJpYWJsZURlY2xUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcImxldFwiLCBMZXREZWNsVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJjb25zdFwiLCBDb25zdERlY2xUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcInN5bnRheFF1b3RlXCIsIFN5bnRheFF1b3RlVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJzeW50YXhyZWNcIiwgU3ludGF4cmVjRGVjbFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwic3ludGF4XCIsIFN5bnRheERlY2xUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcInJldHVyblwiLCBSZXR1cm5TdGF0ZW1lbnRUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcIndoaWxlXCIsIFdoaWxlVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJpZlwiLCBJZlRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwiZm9yXCIsIEZvclRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwic3dpdGNoXCIsIFN3aXRjaFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwiYnJlYWtcIiwgQnJlYWtUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcImNvbnRpbnVlXCIsIENvbnRpbnVlVHJhbnNmb3JtKTtcbiAgICB0aGlzLm1hcC5zZXQoXCJkb1wiLCBEb1RyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwiZGVidWdnZXJcIiwgRGVidWdnZXJUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcIndpdGhcIiwgV2l0aFRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwidHJ5XCIsIFRyeVRyYW5zZm9ybSk7XG4gICAgdGhpcy5tYXAuc2V0KFwidGhyb3dcIiwgVGhyb3dUcmFuc2Zvcm0pO1xuICAgIHRoaXMubWFwLnNldChcIm5ld1wiLCBOZXdUcmFuc2Zvcm0pO1xuICB9XG5cbiAgaGFzKGtleSkge1xuICAgIHJldHVybiB0aGlzLm1hcC5oYXMoa2V5KTtcbiAgfVxuXG4gIGdldChrZXkpIHtcbiAgICByZXR1cm4gdGhpcy5tYXAuZ2V0KGtleSk7XG4gIH1cblxuICBzZXQoa2V5LCB2YWwpIHtcbiAgICByZXR1cm4gdGhpcy5tYXAuc2V0KGtleSwgdmFsKTtcbiAgfVxufVxuIl19 \ No newline at end of file diff --git a/dist/errors.js b/dist/errors.js index 6d9664b4..9f5ffe92 100644 --- a/dist/errors.js +++ b/dist/errors.js @@ -3,26 +3,27 @@ Object.defineProperty(exports, "__esModule", { value: true }); -function expect_336(cond_338, message_339, offendingSyntax_340, rest_341) { - if (!cond_338) { +exports.expect = expect; +exports.assert = assert; +function expect(cond, message, offendingSyntax, rest) { + if (!cond) { let ctx = ""; - if (rest_341) { - let ctx = rest_341.slice(0, 20).map(s_342 => { - let val_343 = s_342.isDelimiter() ? "( ... )" : s_342.val(); - if (s_342 === offendingSyntax_340) { - return "__" + val_343 + "__"; + if (rest) { + ctx = rest.slice(0, 20).map(s => { + let val = s.isDelimiter() ? "( ... )" : s.val(); + if (s === offendingSyntax) { + return "__" + val + "__"; } - return val_343; + return val; }).join(" "); } - throw new Error("[error]: " + message_339 + "\n" + ctx); + throw new Error("[error]: " + message + "\n" + ctx); } } -function assert_337(cond_344, message_345) { - if (!cond_344) { - throw new Error("[assertion error]: " + message_345); + +function assert(cond, message) { + if (!cond) { + throw new Error("[assertion error]: " + message); } } -exports.expect = expect_336; -exports.assert = assert_337; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2Vycm9ycy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLFNBQVMsVUFBVCxDQUFvQixRQUFwQixFQUE4QixXQUE5QixFQUEyQyxtQkFBM0MsRUFBZ0UsUUFBaEUsRUFBMEU7QUFDeEUsTUFBSSxDQUFDLFFBQUwsRUFBZTtBQUNiLFFBQUksTUFBTSxFQUFWO0FBQ0EsUUFBSSxRQUFKLEVBQWM7QUFDWixVQUFJLE1BQU0sU0FBUyxLQUFULENBQWUsQ0FBZixFQUFrQixFQUFsQixFQUFzQixHQUF0QixDQUEwQixTQUFTO0FBQzNDLFlBQUksVUFBVSxNQUFNLFdBQU4sS0FBc0IsU0FBdEIsR0FBa0MsTUFBTSxHQUFOLEVBQWhEO0FBQ0EsWUFBSSxVQUFVLG1CQUFkLEVBQW1DO0FBQ2pDLGlCQUFPLE9BQU8sT0FBUCxHQUFpQixJQUF4QjtBQUNEO0FBQ0QsZUFBTyxPQUFQO0FBQ0QsT0FOUyxFQU1QLElBTk8sQ0FNRixHQU5FLENBQVY7QUFPRDtBQUNELFVBQU0sSUFBSSxLQUFKLENBQVUsY0FBYyxXQUFkLEdBQTRCLElBQTVCLEdBQW1DLEdBQTdDLENBQU47QUFDRDtBQUNGO0FBQ0QsU0FBUyxVQUFULENBQW9CLFFBQXBCLEVBQThCLFdBQTlCLEVBQTJDO0FBQ3pDLE1BQUksQ0FBQyxRQUFMLEVBQWU7QUFDYixVQUFNLElBQUksS0FBSixDQUFVLHdCQUF3QixXQUFsQyxDQUFOO0FBQ0Q7QUFDRjtRQUNxQixNLEdBQWQsVTtRQUNjLE0sR0FBZCxVIiwiZmlsZSI6ImVycm9ycy5qcyIsInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIGV4cGVjdF8zMzYoY29uZF8zMzgsIG1lc3NhZ2VfMzM5LCBvZmZlbmRpbmdTeW50YXhfMzQwLCByZXN0XzM0MSkge1xuICBpZiAoIWNvbmRfMzM4KSB7XG4gICAgbGV0IGN0eCA9IFwiXCI7XG4gICAgaWYgKHJlc3RfMzQxKSB7XG4gICAgICBsZXQgY3R4ID0gcmVzdF8zNDEuc2xpY2UoMCwgMjApLm1hcChzXzM0MiA9PiB7XG4gICAgICAgIGxldCB2YWxfMzQzID0gc18zNDIuaXNEZWxpbWl0ZXIoKSA/IFwiKCAuLi4gKVwiIDogc18zNDIudmFsKCk7XG4gICAgICAgIGlmIChzXzM0MiA9PT0gb2ZmZW5kaW5nU3ludGF4XzM0MCkge1xuICAgICAgICAgIHJldHVybiBcIl9fXCIgKyB2YWxfMzQzICsgXCJfX1wiO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB2YWxfMzQzO1xuICAgICAgfSkuam9pbihcIiBcIik7XG4gICAgfVxuICAgIHRocm93IG5ldyBFcnJvcihcIltlcnJvcl06IFwiICsgbWVzc2FnZV8zMzkgKyBcIlxcblwiICsgY3R4KTtcbiAgfVxufVxuZnVuY3Rpb24gYXNzZXJ0XzMzNyhjb25kXzM0NCwgbWVzc2FnZV8zNDUpIHtcbiAgaWYgKCFjb25kXzM0NCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIlthc3NlcnRpb24gZXJyb3JdOiBcIiArIG1lc3NhZ2VfMzQ1KTtcbiAgfVxufVxuZXhwb3J0IHtleHBlY3RfMzM2IGFzIGV4cGVjdH07XG5leHBvcnQge2Fzc2VydF8zMzcgYXMgYXNzZXJ0fSJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9lcnJvcnMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7UUFBZ0IsTSxHQUFBLE07UUFnQkEsTSxHQUFBLE07QUFoQlQsU0FBUyxNQUFULENBQWdCLElBQWhCLEVBQXNCLE9BQXRCLEVBQStCLGVBQS9CLEVBQWdELElBQWhELEVBQXNEO0FBQzNELE1BQUksQ0FBQyxJQUFMLEVBQVc7QUFDVCxRQUFJLE1BQU0sRUFBVjtBQUNBLFFBQUksSUFBSixFQUFVO0FBQ1IsWUFBTSxLQUFLLEtBQUwsQ0FBVyxDQUFYLEVBQWMsRUFBZCxFQUFrQixHQUFsQixDQUFzQixLQUFLO0FBQy9CLFlBQUksTUFBTSxFQUFFLFdBQUYsS0FBa0IsU0FBbEIsR0FBOEIsRUFBRSxHQUFGLEVBQXhDO0FBQ0EsWUFBSSxNQUFNLGVBQVYsRUFBMkI7QUFDekIsaUJBQU8sT0FBTyxHQUFQLEdBQWEsSUFBcEI7QUFDRDtBQUNELGVBQU8sR0FBUDtBQUNELE9BTkssRUFNSCxJQU5HLENBTUUsR0FORixDQUFOO0FBT0Q7QUFDRCxVQUFNLElBQUksS0FBSixDQUFVLGNBQWMsT0FBZCxHQUF3QixJQUF4QixHQUErQixHQUF6QyxDQUFOO0FBQ0Q7QUFDRjs7QUFFTSxTQUFTLE1BQVQsQ0FBZ0IsSUFBaEIsRUFBc0IsT0FBdEIsRUFBK0I7QUFDcEMsTUFBSSxDQUFDLElBQUwsRUFBVztBQUNULFVBQU0sSUFBSSxLQUFKLENBQVUsd0JBQXdCLE9BQWxDLENBQU47QUFDRDtBQUNGIiwiZmlsZSI6ImVycm9ycy5qcyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBmdW5jdGlvbiBleHBlY3QoY29uZCwgbWVzc2FnZSwgb2ZmZW5kaW5nU3ludGF4LCByZXN0KSB7XG4gIGlmICghY29uZCkge1xuICAgIGxldCBjdHggPSBcIlwiO1xuICAgIGlmIChyZXN0KSB7XG4gICAgICBjdHggPSByZXN0LnNsaWNlKDAsIDIwKS5tYXAocyA9PiB7XG4gICAgICAgIGxldCB2YWwgPSBzLmlzRGVsaW1pdGVyKCkgPyBcIiggLi4uIClcIiA6IHMudmFsKCk7XG4gICAgICAgIGlmIChzID09PSBvZmZlbmRpbmdTeW50YXgpIHtcbiAgICAgICAgICByZXR1cm4gXCJfX1wiICsgdmFsICsgXCJfX1wiO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB2YWw7XG4gICAgICB9KS5qb2luKFwiIFwiKTtcbiAgICB9XG4gICAgdGhyb3cgbmV3IEVycm9yKFwiW2Vycm9yXTogXCIgKyBtZXNzYWdlICsgXCJcXG5cIiArIGN0eCk7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGFzc2VydChjb25kLCBtZXNzYWdlKSB7XG4gIGlmICghY29uZCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIlthc3NlcnRpb24gZXJyb3JdOiBcIiArIG1lc3NhZ2UpO1xuICB9XG59XG4iXX0= \ No newline at end of file diff --git a/dist/hygiene-utils.js b/dist/hygiene-utils.js index ccc288ea..008d9e4a 100644 --- a/dist/hygiene-utils.js +++ b/dist/hygiene-utils.js @@ -1,65 +1,91 @@ -"use strict"; +'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); -exports.collectBindings = exports.CollectBindingSyntax = undefined; +exports.CollectBindingSyntax = undefined; +exports.collectBindings = collectBindings; -var _symbol = require("./symbol"); +var _immutable = require('immutable'); -var _transforms = require("./transforms"); - -var _errors = require("./errors"); - -var _terms = require("./terms"); - -var _terms2 = _interopRequireDefault(_terms); - -var _immutable = require("immutable"); - -var _astDispatcher = require("./ast-dispatcher"); +var _astDispatcher = require('./ast-dispatcher'); var _astDispatcher2 = _interopRequireDefault(_astDispatcher); -var _ramda = require("ramda"); - -var _ = _interopRequireWildcard(_ramda); - -function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } -class CollectBindingSyntax_346 extends _astDispatcher2.default { +class CollectBindingSyntax extends _astDispatcher2.default { constructor() { - super("collect", true); + super('collect', true); this.names = (0, _immutable.List)(); } - collect(term_348) { - return this.dispatch(term_348); + + // registerSyntax(stx) { + // let newBinding = gensym(stx.val()); + // this.context.bindings.add(stx, { + // binding: newBinding, + // phase: this.context.phase, + // // skip dup because js allows variable redeclarations + // // (technically only for `var` but we can let later stages of the pipeline + // // handle incorrect redeclarations of `const` and `let`) + // skipDup: true + // }); + // return stx; + // } + + collect(term) { + return this.dispatch(term); } - collectBindingIdentifier(term_349) { - return this.names.concat(term_349.name); + + collectBindingIdentifier(term) { + return this.names.concat(term.name); } - collectBindingPropertyIdentifier(term_350) { - return this.collect(term_350.binding); + + collectBindingPropertyIdentifier(term) { + return this.collect(term.binding); } - collectBindingPropertyProperty(term_351) { - return this.collect(term_351.binding); + + collectBindingPropertyProperty(term) { + return this.collect(term.binding); } - collectArrayBinding(term_352) { - let restElement_353 = null; - if (term_352.restElement != null) { - restElement_353 = this.collect(term_352.restElement); + + collectArrayBinding(term) { + let restElement = null; + if (term.restElement != null) { + restElement = this.collect(term.restElement); } - return this.names.concat(restElement_353).concat(term_352.elements.filter(el_354 => el_354 != null).flatMap(el_355 => this.collect(el_355))); + return this.names.concat(restElement).concat(term.elements.filter(el => el != null).flatMap(el => this.collect(el))); } - collectObjectBinding(term_356) { + + collectObjectBinding() { + // return term.properties.flatMap(prop => this.collect(prop)); return (0, _immutable.List)(); } + + // registerVariableDeclaration(term) { + // let declarators = term.declarators.map(decl => { + // return decl.extend({ + // binding: this.register(decl.binding) + // }); + // }); + // return term.extend({ declarators }); + // } + // + // registerFunctionDeclaration(term) { + // return term.extend({ + // name: this.register(term.name) + // }); + // } + // + // registerExport(term) { + // return term.extend({ + // declaration: this.register(term.declaration) + // }); + // } } -function collectBindings_347(term_357) { - return new CollectBindingSyntax_346().collect(term_357); + +exports.CollectBindingSyntax = CollectBindingSyntax; +function collectBindings(term) { + return new CollectBindingSyntax().collect(term); } -exports.CollectBindingSyntax = CollectBindingSyntax_346; -exports.collectBindings = collectBindings_347; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2h5Z2llbmUtdXRpbHMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOzs7O0FBQ0E7O0FBQ0E7Ozs7QUFDQTs7SUFBYSxDOzs7Ozs7QUFDYixNQUFNLHdCQUFOLGlDQUFxRDtBQUNuRCxnQkFBYztBQUNaLFVBQU0sU0FBTixFQUFpQixJQUFqQjtBQUNBLFNBQUssS0FBTCxHQUFhLHNCQUFiO0FBQ0Q7QUFDRCxVQUFRLFFBQVIsRUFBa0I7QUFDaEIsV0FBTyxLQUFLLFFBQUwsQ0FBYyxRQUFkLENBQVA7QUFDRDtBQUNELDJCQUF5QixRQUF6QixFQUFtQztBQUNqQyxXQUFPLEtBQUssS0FBTCxDQUFXLE1BQVgsQ0FBa0IsU0FBUyxJQUEzQixDQUFQO0FBQ0Q7QUFDRCxtQ0FBaUMsUUFBakMsRUFBMkM7QUFDekMsV0FBTyxLQUFLLE9BQUwsQ0FBYSxTQUFTLE9BQXRCLENBQVA7QUFDRDtBQUNELGlDQUErQixRQUEvQixFQUF5QztBQUN2QyxXQUFPLEtBQUssT0FBTCxDQUFhLFNBQVMsT0FBdEIsQ0FBUDtBQUNEO0FBQ0Qsc0JBQW9CLFFBQXBCLEVBQThCO0FBQzVCLFFBQUksa0JBQWtCLElBQXRCO0FBQ0EsUUFBSSxTQUFTLFdBQVQsSUFBd0IsSUFBNUIsRUFBa0M7QUFDaEMsd0JBQWtCLEtBQUssT0FBTCxDQUFhLFNBQVMsV0FBdEIsQ0FBbEI7QUFDRDtBQUNELFdBQU8sS0FBSyxLQUFMLENBQVcsTUFBWCxDQUFrQixlQUFsQixFQUFtQyxNQUFuQyxDQUEwQyxTQUFTLFFBQVQsQ0FBa0IsTUFBbEIsQ0FBeUIsVUFBVSxVQUFVLElBQTdDLEVBQW1ELE9BQW5ELENBQTJELFVBQVUsS0FBSyxPQUFMLENBQWEsTUFBYixDQUFyRSxDQUExQyxDQUFQO0FBQ0Q7QUFDRCx1QkFBcUIsUUFBckIsRUFBK0I7QUFDN0IsV0FBTyxzQkFBUDtBQUNEO0FBMUJrRDtBQTRCckQsU0FBUyxtQkFBVCxDQUE2QixRQUE3QixFQUF1QztBQUNyQyxTQUFRLElBQUksd0JBQUosRUFBRCxDQUErQixPQUEvQixDQUF1QyxRQUF2QyxDQUFQO0FBQ0Q7UUFDbUMsb0IsR0FBNUIsd0I7UUFDdUIsZSxHQUF2QixtQiIsImZpbGUiOiJoeWdpZW5lLXV0aWxzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtnZW5zeW19IGZyb20gXCIuL3N5bWJvbFwiO1xuaW1wb3J0IHtWYXJCaW5kaW5nVHJhbnNmb3JtLCBDb21waWxldGltZVRyYW5zZm9ybX0gZnJvbSBcIi4vdHJhbnNmb3Jtc1wiO1xuaW1wb3J0IHtleHBlY3QsIGFzc2VydH0gZnJvbSBcIi4vZXJyb3JzXCI7XG5pbXBvcnQgVGVybSwge2lzRU9GLCBpc0JpbmRpbmdJZGVudGlmaWVyLCBpc0JpbmRpbmdQcm9wZXJ0eVByb3BlcnR5LCBpc0JpbmRpbmdQcm9wZXJ0eUlkZW50aWZpZXIsIGlzT2JqZWN0QmluZGluZywgaXNBcnJheUJpbmRpbmcsIGlzRnVuY3Rpb25EZWNsYXJhdGlvbiwgaXNGdW5jdGlvbkV4cHJlc3Npb24sIGlzRnVuY3Rpb25UZXJtLCBpc0Z1bmN0aW9uV2l0aE5hbWUsIGlzU3ludGF4RGVjbGFyYXRpb24sIGlzU3ludGF4cmVjRGVjbGFyYXRpb24sIGlzVmFyaWFibGVEZWNsYXJhdGlvbiwgaXNWYXJpYWJsZURlY2xhcmF0aW9uU3RhdGVtZW50LCBpc0ltcG9ydCwgaXNFeHBvcnQsIGlzUHJhZ21hLCBpc0V4cG9ydFN5bnRheH0gZnJvbSBcIi4vdGVybXNcIjtcbmltcG9ydCB7TGlzdH0gZnJvbSBcImltbXV0YWJsZVwiO1xuaW1wb3J0IEFTVERpc3BhdGNoZXIgZnJvbSBcIi4vYXN0LWRpc3BhdGNoZXJcIjtcbmltcG9ydCAgKiBhcyBfIGZyb20gXCJyYW1kYVwiO1xuY2xhc3MgQ29sbGVjdEJpbmRpbmdTeW50YXhfMzQ2IGV4dGVuZHMgQVNURGlzcGF0Y2hlciB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKFwiY29sbGVjdFwiLCB0cnVlKTtcbiAgICB0aGlzLm5hbWVzID0gTGlzdCgpO1xuICB9XG4gIGNvbGxlY3QodGVybV8zNDgpIHtcbiAgICByZXR1cm4gdGhpcy5kaXNwYXRjaCh0ZXJtXzM0OCk7XG4gIH1cbiAgY29sbGVjdEJpbmRpbmdJZGVudGlmaWVyKHRlcm1fMzQ5KSB7XG4gICAgcmV0dXJuIHRoaXMubmFtZXMuY29uY2F0KHRlcm1fMzQ5Lm5hbWUpO1xuICB9XG4gIGNvbGxlY3RCaW5kaW5nUHJvcGVydHlJZGVudGlmaWVyKHRlcm1fMzUwKSB7XG4gICAgcmV0dXJuIHRoaXMuY29sbGVjdCh0ZXJtXzM1MC5iaW5kaW5nKTtcbiAgfVxuICBjb2xsZWN0QmluZGluZ1Byb3BlcnR5UHJvcGVydHkodGVybV8zNTEpIHtcbiAgICByZXR1cm4gdGhpcy5jb2xsZWN0KHRlcm1fMzUxLmJpbmRpbmcpO1xuICB9XG4gIGNvbGxlY3RBcnJheUJpbmRpbmcodGVybV8zNTIpIHtcbiAgICBsZXQgcmVzdEVsZW1lbnRfMzUzID0gbnVsbDtcbiAgICBpZiAodGVybV8zNTIucmVzdEVsZW1lbnQgIT0gbnVsbCkge1xuICAgICAgcmVzdEVsZW1lbnRfMzUzID0gdGhpcy5jb2xsZWN0KHRlcm1fMzUyLnJlc3RFbGVtZW50KTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMubmFtZXMuY29uY2F0KHJlc3RFbGVtZW50XzM1MykuY29uY2F0KHRlcm1fMzUyLmVsZW1lbnRzLmZpbHRlcihlbF8zNTQgPT4gZWxfMzU0ICE9IG51bGwpLmZsYXRNYXAoZWxfMzU1ID0+IHRoaXMuY29sbGVjdChlbF8zNTUpKSk7XG4gIH1cbiAgY29sbGVjdE9iamVjdEJpbmRpbmcodGVybV8zNTYpIHtcbiAgICByZXR1cm4gTGlzdCgpO1xuICB9XG59XG5mdW5jdGlvbiBjb2xsZWN0QmluZGluZ3NfMzQ3KHRlcm1fMzU3KSB7XG4gIHJldHVybiAobmV3IENvbGxlY3RCaW5kaW5nU3ludGF4XzM0NikuY29sbGVjdCh0ZXJtXzM1Nyk7XG59XG5leHBvcnQge0NvbGxlY3RCaW5kaW5nU3ludGF4XzM0NiBhcyBDb2xsZWN0QmluZGluZ1N5bnRheH07XG5leHBvcnQge2NvbGxlY3RCaW5kaW5nc18zNDcgYXMgY29sbGVjdEJpbmRpbmdzfSJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9oeWdpZW5lLXV0aWxzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztRQTZFZ0IsZSxHQUFBLGU7O0FBN0VoQjs7QUFFQTs7Ozs7O0FBRU8sTUFBTSxvQkFBTixpQ0FBaUQ7QUFDdEQsZ0JBQWM7QUFDWixVQUFNLFNBQU4sRUFBaUIsSUFBakI7QUFDQSxTQUFLLEtBQUwsR0FBYSxzQkFBYjtBQUNEOztBQUVEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFRLElBQVIsRUFBYztBQUNaLFdBQU8sS0FBSyxRQUFMLENBQWMsSUFBZCxDQUFQO0FBQ0Q7O0FBRUQsMkJBQXlCLElBQXpCLEVBQStCO0FBQzdCLFdBQU8sS0FBSyxLQUFMLENBQVcsTUFBWCxDQUFrQixLQUFLLElBQXZCLENBQVA7QUFDRDs7QUFFRCxtQ0FBaUMsSUFBakMsRUFBdUM7QUFDckMsV0FBTyxLQUFLLE9BQUwsQ0FBYSxLQUFLLE9BQWxCLENBQVA7QUFDRDs7QUFFRCxpQ0FBZ0MsSUFBaEMsRUFBc0M7QUFDcEMsV0FBTyxLQUFLLE9BQUwsQ0FBYSxLQUFLLE9BQWxCLENBQVA7QUFDRDs7QUFFRCxzQkFBcUIsSUFBckIsRUFBMkI7QUFDekIsUUFBSSxjQUFjLElBQWxCO0FBQ0EsUUFBSSxLQUFLLFdBQUwsSUFBb0IsSUFBeEIsRUFBOEI7QUFDNUIsb0JBQWMsS0FBSyxPQUFMLENBQWEsS0FBSyxXQUFsQixDQUFkO0FBQ0Q7QUFDRCxXQUFPLEtBQUssS0FBTCxDQUFXLE1BQVgsQ0FBa0IsV0FBbEIsRUFBK0IsTUFBL0IsQ0FDTCxLQUFLLFFBQUwsQ0FBYyxNQUFkLENBQXFCLE1BQU0sTUFBTSxJQUFqQyxFQUNjLE9BRGQsQ0FDc0IsTUFBTSxLQUFLLE9BQUwsQ0FBYSxFQUFiLENBRDVCLENBREssQ0FBUDtBQUlEOztBQUVELHlCQUF3QjtBQUN0QjtBQUNBLFdBQU8sc0JBQVA7QUFDRDs7QUFFRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBdEVzRDs7UUFBM0Msb0IsR0FBQSxvQjtBQXlFTixTQUFTLGVBQVQsQ0FBeUIsSUFBekIsRUFBK0I7QUFDcEMsU0FBTyxJQUFJLG9CQUFKLEdBQTJCLE9BQTNCLENBQW1DLElBQW5DLENBQVA7QUFDRCIsImZpbGUiOiJoeWdpZW5lLXV0aWxzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTGlzdCB9IGZyb20gJ2ltbXV0YWJsZSc7XG5cbmltcG9ydCBBU1REaXNwYXRjaGVyIGZyb20gJy4vYXN0LWRpc3BhdGNoZXInO1xuXG5leHBvcnQgY2xhc3MgQ29sbGVjdEJpbmRpbmdTeW50YXggZXh0ZW5kcyBBU1REaXNwYXRjaGVyIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoJ2NvbGxlY3QnLCB0cnVlKTtcbiAgICB0aGlzLm5hbWVzID0gTGlzdCgpO1xuICB9XG5cbiAgLy8gcmVnaXN0ZXJTeW50YXgoc3R4KSB7XG4gIC8vICAgbGV0IG5ld0JpbmRpbmcgPSBnZW5zeW0oc3R4LnZhbCgpKTtcbiAgLy8gICB0aGlzLmNvbnRleHQuYmluZGluZ3MuYWRkKHN0eCwge1xuICAvLyAgICAgYmluZGluZzogbmV3QmluZGluZyxcbiAgLy8gICAgIHBoYXNlOiB0aGlzLmNvbnRleHQucGhhc2UsXG4gIC8vICAgICAvLyBza2lwIGR1cCBiZWNhdXNlIGpzIGFsbG93cyB2YXJpYWJsZSByZWRlY2xhcmF0aW9uc1xuICAvLyAgICAgLy8gKHRlY2huaWNhbGx5IG9ubHkgZm9yIGB2YXJgIGJ1dCB3ZSBjYW4gbGV0IGxhdGVyIHN0YWdlcyBvZiB0aGUgcGlwZWxpbmVcbiAgLy8gICAgIC8vIGhhbmRsZSBpbmNvcnJlY3QgcmVkZWNsYXJhdGlvbnMgb2YgYGNvbnN0YCBhbmQgYGxldGApXG4gIC8vICAgICBza2lwRHVwOiB0cnVlXG4gIC8vICAgfSk7XG4gIC8vICAgcmV0dXJuIHN0eDtcbiAgLy8gfVxuXG4gIGNvbGxlY3QodGVybSkge1xuICAgIHJldHVybiB0aGlzLmRpc3BhdGNoKHRlcm0pO1xuICB9XG5cbiAgY29sbGVjdEJpbmRpbmdJZGVudGlmaWVyKHRlcm0pIHtcbiAgICByZXR1cm4gdGhpcy5uYW1lcy5jb25jYXQodGVybS5uYW1lKTtcbiAgfVxuXG4gIGNvbGxlY3RCaW5kaW5nUHJvcGVydHlJZGVudGlmaWVyKHRlcm0pIHtcbiAgICByZXR1cm4gdGhpcy5jb2xsZWN0KHRlcm0uYmluZGluZyk7XG4gIH1cblxuICBjb2xsZWN0QmluZGluZ1Byb3BlcnR5UHJvcGVydHkgKHRlcm0pIHtcbiAgICByZXR1cm4gdGhpcy5jb2xsZWN0KHRlcm0uYmluZGluZyk7XG4gIH1cblxuICBjb2xsZWN0QXJyYXlCaW5kaW5nICh0ZXJtKSB7XG4gICAgbGV0IHJlc3RFbGVtZW50ID0gbnVsbDtcbiAgICBpZiAodGVybS5yZXN0RWxlbWVudCAhPSBudWxsKSB7XG4gICAgICByZXN0RWxlbWVudCA9IHRoaXMuY29sbGVjdCh0ZXJtLnJlc3RFbGVtZW50KTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMubmFtZXMuY29uY2F0KHJlc3RFbGVtZW50KS5jb25jYXQoXG4gICAgICB0ZXJtLmVsZW1lbnRzLmZpbHRlcihlbCA9PiBlbCAhPSBudWxsKVxuICAgICAgICAgICAgICAgICAgIC5mbGF0TWFwKGVsID0+IHRoaXMuY29sbGVjdChlbCkpXG4gICAgKTtcbiAgfVxuXG4gIGNvbGxlY3RPYmplY3RCaW5kaW5nICgpIHtcbiAgICAvLyByZXR1cm4gdGVybS5wcm9wZXJ0aWVzLmZsYXRNYXAocHJvcCA9PiB0aGlzLmNvbGxlY3QocHJvcCkpO1xuICAgIHJldHVybiBMaXN0KCk7XG4gIH1cblxuICAvLyByZWdpc3RlclZhcmlhYmxlRGVjbGFyYXRpb24odGVybSkge1xuICAvLyAgIGxldCBkZWNsYXJhdG9ycyA9IHRlcm0uZGVjbGFyYXRvcnMubWFwKGRlY2wgPT4ge1xuICAvLyAgICAgcmV0dXJuIGRlY2wuZXh0ZW5kKHtcbiAgLy8gICAgICAgYmluZGluZzogdGhpcy5yZWdpc3RlcihkZWNsLmJpbmRpbmcpXG4gIC8vICAgICB9KTtcbiAgLy8gICB9KTtcbiAgLy8gICByZXR1cm4gdGVybS5leHRlbmQoeyBkZWNsYXJhdG9ycyB9KTtcbiAgLy8gfVxuICAvL1xuICAvLyByZWdpc3RlckZ1bmN0aW9uRGVjbGFyYXRpb24odGVybSkge1xuICAvLyAgIHJldHVybiB0ZXJtLmV4dGVuZCh7XG4gIC8vICAgICBuYW1lOiB0aGlzLnJlZ2lzdGVyKHRlcm0ubmFtZSlcbiAgLy8gICB9KTtcbiAgLy8gfVxuICAvL1xuICAvLyByZWdpc3RlckV4cG9ydCh0ZXJtKSB7XG4gIC8vICAgcmV0dXJuIHRlcm0uZXh0ZW5kKHtcbiAgLy8gICAgIGRlY2xhcmF0aW9uOiB0aGlzLnJlZ2lzdGVyKHRlcm0uZGVjbGFyYXRpb24pXG4gIC8vICAgfSk7XG4gIC8vIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNvbGxlY3RCaW5kaW5ncyh0ZXJtKSB7XG4gIHJldHVybiBuZXcgQ29sbGVjdEJpbmRpbmdTeW50YXgoKS5jb2xsZWN0KHRlcm0pO1xufVxuIl19 \ No newline at end of file diff --git a/dist/list-collector.js b/dist/list-collector.js index c2d53b92..e4367ead 100644 --- a/dist/list-collector.js +++ b/dist/list-collector.js @@ -1,26 +1,26 @@ -"use strict"; +'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); -var _immutable = require("immutable"); +var _immutable = require('immutable'); -let EMPTY_358; +let EMPTY; class ListCollector { - constructor(x_359) { - this.value = x_359; + constructor(x) { + this.value = x; } static empty() { - return EMPTY_358; + return EMPTY; } - concat(a_360) { - return new ListCollector(this.value.concat(a_360.value)); + concat(a) { + return new ListCollector(this.value.concat(a.value)); } extract() { return this.value; } } exports.default = ListCollector; -EMPTY_358 = new ListCollector((0, _immutable.List)()); -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L2xpc3QtY29sbGVjdG9yLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOztBQUNBLElBQUksU0FBSjtBQUNlLE1BQU0sYUFBTixDQUFvQjtBQUNqQyxjQUFZLEtBQVosRUFBbUI7QUFDakIsU0FBSyxLQUFMLEdBQWEsS0FBYjtBQUNEO0FBQ0QsU0FBTyxLQUFQLEdBQWU7QUFDYixXQUFPLFNBQVA7QUFDRDtBQUNELFNBQU8sS0FBUCxFQUFjO0FBQ1osV0FBTyxJQUFJLGFBQUosQ0FBa0IsS0FBSyxLQUFMLENBQVcsTUFBWCxDQUFrQixNQUFNLEtBQXhCLENBQWxCLENBQVA7QUFDRDtBQUNELFlBQVU7QUFDUixXQUFPLEtBQUssS0FBWjtBQUNEO0FBWmdDO2tCQUFkLGE7QUFjckIsWUFBWSxJQUFJLGFBQUosQ0FBa0Isc0JBQWxCLENBQVoiLCJmaWxlIjoibGlzdC1jb2xsZWN0b3IuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0xpc3R9IGZyb20gXCJpbW11dGFibGVcIjtcbmxldCBFTVBUWV8zNTg7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBMaXN0Q29sbGVjdG9yIHtcbiAgY29uc3RydWN0b3IoeF8zNTkpIHtcbiAgICB0aGlzLnZhbHVlID0geF8zNTk7XG4gIH1cbiAgc3RhdGljIGVtcHR5KCkge1xuICAgIHJldHVybiBFTVBUWV8zNTg7XG4gIH1cbiAgY29uY2F0KGFfMzYwKSB7XG4gICAgcmV0dXJuIG5ldyBMaXN0Q29sbGVjdG9yKHRoaXMudmFsdWUuY29uY2F0KGFfMzYwLnZhbHVlKSk7XG4gIH1cbiAgZXh0cmFjdCgpIHtcbiAgICByZXR1cm4gdGhpcy52YWx1ZTtcbiAgfVxufVxuRU1QVFlfMzU4ID0gbmV3IExpc3RDb2xsZWN0b3IoTGlzdCgpKTtcbiJdfQ== \ No newline at end of file +EMPTY = new ListCollector((0, _immutable.List)()); +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saXN0LWNvbGxlY3Rvci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7QUFFQSxJQUFJLEtBQUo7QUFDZSxNQUFNLGFBQU4sQ0FBb0I7QUFDakMsY0FBWSxDQUFaLEVBQWU7QUFBRSxTQUFLLEtBQUwsR0FBYSxDQUFiO0FBQWlCO0FBQ2xDLFNBQU8sS0FBUCxHQUFlO0FBQUUsV0FBTyxLQUFQO0FBQWU7QUFDaEMsU0FBTyxDQUFQLEVBQVU7QUFBRSxXQUFPLElBQUksYUFBSixDQUFrQixLQUFLLEtBQUwsQ0FBVyxNQUFYLENBQWtCLEVBQUUsS0FBcEIsQ0FBbEIsQ0FBUDtBQUF1RDtBQUNuRSxZQUFVO0FBQUUsV0FBTyxLQUFLLEtBQVo7QUFBb0I7QUFKQztrQkFBZCxhO0FBTXJCLFFBQVEsSUFBSSxhQUFKLENBQWtCLHNCQUFsQixDQUFSIiwiZmlsZSI6Imxpc3QtY29sbGVjdG9yLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTGlzdCB9IGZyb20gJ2ltbXV0YWJsZSc7XG5cbmxldCBFTVBUWTtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIExpc3RDb2xsZWN0b3Ige1xuICBjb25zdHJ1Y3Rvcih4KSB7IHRoaXMudmFsdWUgPSB4OyB9XG4gIHN0YXRpYyBlbXB0eSgpIHsgcmV0dXJuIEVNUFRZOyB9XG4gIGNvbmNhdChhKSB7IHJldHVybiBuZXcgTGlzdENvbGxlY3Rvcih0aGlzLnZhbHVlLmNvbmNhdChhLnZhbHVlKSk7IH1cbiAgZXh0cmFjdCgpIHsgcmV0dXJuIHRoaXMudmFsdWU7IH1cbn1cbkVNUFRZID0gbmV3IExpc3RDb2xsZWN0b3IoTGlzdCgpKTtcbiJdfQ== \ No newline at end of file diff --git a/dist/load-syntax.js b/dist/load-syntax.js index 0d6698e9..aa96afa3 100644 --- a/dist/load-syntax.js +++ b/dist/load-syntax.js @@ -1,123 +1,172 @@ -"use strict"; +'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); -exports.evalCompiletimeValue = exports.evalRuntimeValues = exports.sanitizeReplacementValues = undefined; +exports.sanitizeReplacementValues = sanitizeReplacementValues; +exports.evalRuntimeValues = evalRuntimeValues; +exports.evalCompiletimeValue = evalCompiletimeValue; -var _termExpander = require("./term-expander"); +var _ramda = require('ramda'); -var _termExpander2 = _interopRequireDefault(_termExpander); +var _ = _interopRequireWildcard(_ramda); -var _immutable = require("immutable"); +var _immutable = require('immutable'); -var _parseReducer = require("./parse-reducer.js"); +var _parseReducer = require('./parse-reducer.js'); var _parseReducer2 = _interopRequireDefault(_parseReducer); -var _shiftReducer = require("shift-reducer"); +var _shiftReducer = require('shift-reducer'); var _shiftReducer2 = _interopRequireDefault(_shiftReducer); -var _serializer = require("./serializer"); +var _serializer = require('./serializer'); -var _syntax = require("./syntax"); +var _syntax = require('./syntax'); var _syntax2 = _interopRequireDefault(_syntax); -var _shiftCodegen = require("shift-codegen"); +var _shiftCodegen = require('shift-codegen'); var _shiftCodegen2 = _interopRequireDefault(_shiftCodegen); -var _transforms = require("./transforms"); - -var _terms = require("./terms"); +var _terms = require('./terms'); var _terms2 = _interopRequireDefault(_terms); -var _shiftReader = require("./shift-reader"); +var _shiftReader = require('./shift-reader'); var _shiftReader2 = _interopRequireDefault(_shiftReader); -var _macroContext = require("./macro-context"); +var _macroContext = require('./macro-context'); -var _templateProcessor = require("./template-processor"); +var _templateProcessor = require('./template-processor'); -var _vm = require("vm"); +var _vm = require('vm'); var _vm2 = _interopRequireDefault(_vm); -var _ramda = require("ramda"); - -var _ = _interopRequireWildcard(_ramda); +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - -let geval_361 = eval; -function sanitizeReplacementValues_362(values_365) { - if (Array.isArray(values_365)) { - return sanitizeReplacementValues_362((0, _immutable.List)(values_365)); - } else if (_immutable.List.isList(values_365)) { - return values_365.map(sanitizeReplacementValues_362); - } else if (values_365 == null) { +function sanitizeReplacementValues(values) { + if (Array.isArray(values)) { + return sanitizeReplacementValues((0, _immutable.List)(values)); + } else if (_immutable.List.isList(values)) { + return values.map(sanitizeReplacementValues); + } else if (values == null) { throw new Error("replacement values for syntax template must not be null or undefined"); - } else if (typeof values_365.next === "function") { - return sanitizeReplacementValues_362((0, _immutable.List)(values_365)); + } else if (typeof values.next === 'function') { + return sanitizeReplacementValues((0, _immutable.List)(values)); } - return (0, _macroContext.unwrap)(values_365); + return (0, _macroContext.unwrap)(values); } -function evalRuntimeValues_363(terms_366, context_367) { - let prepped_368 = terms_366.reduce((acc_374, term_375) => { - let result_376 = (0, _immutable.List)(); - if ((0, _terms.isExport)(term_375)) { - if ((0, _terms.isVariableDeclaration)(term_375.declaration)) { - return acc_374.concat(new _terms2.default("VariableDeclarationStatement", { declaration: term_375.declaration })).concat(term_375.declaration.declarators.map(decl_377 => { - return new _terms2.default("ExpressionStatement", { expression: new _terms2.default("AssignmentExpression", { binding: new _terms2.default("StaticMemberExpression", { object: new _terms2.default("IdentifierExpression", { name: _syntax2.default.fromIdentifier("exports") }), property: decl_377.binding.name }), expression: new _terms2.default("IdentifierExpression", { name: decl_377.binding.name }) }) }); + +function evalRuntimeValues(terms, context) { + let prepped = terms.reduce((acc, term) => { + if ((0, _terms.isExport)(term)) { + if ((0, _terms.isVariableDeclaration)(term.declaration)) { + return acc.concat(new _terms2.default('VariableDeclarationStatement', { + declaration: term.declaration + })).concat(term.declaration.declarators.map(decl => { + return new _terms2.default('ExpressionStatement', { + expression: new _terms2.default('AssignmentExpression', { + binding: new _terms2.default('StaticMemberExpression', { + object: new _terms2.default('IdentifierExpression', { + name: _syntax2.default.fromIdentifier('exports') + }), + property: decl.binding.name + }), + expression: new _terms2.default('IdentifierExpression', { + name: decl.binding.name + }) + }) + }); })); } - } else if ((0, _terms.isImport)(term_375)) { - return acc_374; + } else if ((0, _terms.isImport)(term)) { + return acc; } - return acc_374.concat(term_375); + return acc.concat(term); }, (0, _immutable.List)()); - let parsed_369 = (0, _shiftReducer2.default)(new _parseReducer2.default(context_367, false), new _terms2.default("Module", { directives: (0, _immutable.List)(), items: prepped_368 }).gen({ includeImports: false })); - let gen_370 = (0, _shiftCodegen2.default)(parsed_369, new _shiftCodegen.FormattedCodeGen()); - let result_371 = context_367.transform(gen_370, { babelrc: true, filename: context_367.filename }); - let exportsObj_372 = {}; - context_367.store.set("exports", exportsObj_372); - let val_373 = _vm2.default.runInContext(result_371.code, context_367.store.getNodeContext()); - return exportsObj_372; + let parsed = (0, _shiftReducer2.default)(new _parseReducer2.default(context, false), new _terms2.default('Module', { + directives: (0, _immutable.List)(), + items: prepped + }).gen(false)); + + let gen = (0, _shiftCodegen2.default)(parsed, new _shiftCodegen.FormattedCodeGen()); + let result = context.transform(gen, { + babelrc: true, + filename: context.filename + }); + + let exportsObj = {}; + context.store.set('exports', exportsObj); + + _vm2.default.runInContext(result.code, context.store.getNodeContext()); + return exportsObj; } -function evalCompiletimeValue_364(expr_378, context_379) { - let deserializer_380 = (0, _serializer.makeDeserializer)(context_379.bindings); - let sandbox_381 = { syntaxQuote: function syntaxQuote(strings_389) { - for (var _len = arguments.length, values_388 = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - values_388[_key - 1] = arguments[_key]; + +// (Expression, Context) -> [function] +function evalCompiletimeValue(expr, context) { + let deserializer = (0, _serializer.makeDeserializer)(context.bindings); + let sandbox = { + syntaxQuote: function syntaxQuote(strings) { + for (var _len = arguments.length, values = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + values[_key - 1] = arguments[_key]; } - let ctx_390 = deserializer_380.read(_.last(values_388)); - let reader_391 = new _shiftReader2.default(strings_389, ctx_390, _.take(values_388.length - 1, values_388)); - return reader_391.read(); - }, syntaxTemplate: function syntaxTemplate(str_393) { - for (var _len2 = arguments.length, values_392 = Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { - values_392[_key2 - 1] = arguments[_key2]; + let ctx = deserializer.read(_.last(values)); + let reader = new _shiftReader2.default(strings, ctx, _.take(values.length - 1, values)); + return reader.read(); + }, + syntaxTemplate: function syntaxTemplate(str) { + for (var _len2 = arguments.length, values = Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { + values[_key2 - 1] = arguments[_key2]; } - return (0, _templateProcessor.replaceTemplate)(deserializer_380.read(str_393), sanitizeReplacementValues_362(values_392)); - } }; - let sandboxKeys_382 = (0, _immutable.List)(Object.keys(sandbox_381)); - let sandboxVals_383 = sandboxKeys_382.map(k_394 => sandbox_381[k_394]).toArray(); - let parsed_384 = (0, _shiftReducer2.default)(new _parseReducer2.default(context_379), new _terms2.default("Module", { directives: (0, _immutable.List)(), items: _immutable.List.of(new _terms2.default("ExpressionStatement", { expression: new _terms2.default("FunctionExpression", { isGenerator: false, name: null, params: new _terms2.default("FormalParameters", { items: sandboxKeys_382.map(param_395 => { - return new _terms2.default("BindingIdentifier", { name: _syntax2.default.from("identifier", param_395) }); - }), rest: null }), body: new _terms2.default("FunctionBody", { directives: _immutable.List.of(new _terms2.default("Directive", { rawValue: "use strict" })), statements: _immutable.List.of(new _terms2.default("ReturnStatement", { expression: expr_378 })) }) }) })) })); - let gen_385 = (0, _shiftCodegen2.default)(parsed_384, new _shiftCodegen.FormattedCodeGen()); - let result_386 = context_379.transform(gen_385, { babelrc: true, filename: context_379.filename }); - let val_387 = _vm2.default.runInContext(result_386.code, context_379.store.getNodeContext()); - return val_387.apply(undefined, sandboxVals_383); + return (0, _templateProcessor.replaceTemplate)(deserializer.read(str), sanitizeReplacementValues(values)); + } + }; + + let sandboxKeys = (0, _immutable.List)(Object.keys(sandbox)); + let sandboxVals = sandboxKeys.map(k => sandbox[k]).toArray(); + + let parsed = (0, _shiftReducer2.default)(new _parseReducer2.default(context), new _terms2.default("Module", { + directives: (0, _immutable.List)(), + items: _immutable.List.of(new _terms2.default("ExpressionStatement", { + expression: new _terms2.default("FunctionExpression", { + isGenerator: false, + name: null, + params: new _terms2.default("FormalParameters", { + items: sandboxKeys.map(param => { + return new _terms2.default("BindingIdentifier", { + name: _syntax2.default.from("identifier", param) + }); + }), + rest: null + }), + body: new _terms2.default("FunctionBody", { + directives: _immutable.List.of(new _terms2.default('Directive', { + rawValue: 'use strict' + })), + statements: _immutable.List.of(new _terms2.default("ReturnStatement", { + expression: expr + })) + }) + }) + })) + })); + + let gen = (0, _shiftCodegen2.default)(parsed, new _shiftCodegen.FormattedCodeGen()); + let result = context.transform(gen, { + babelrc: true, + filename: context.filename + }); + + let val = _vm2.default.runInContext(result.code, context.store.getNodeContext()); + return val.apply(undefined, sandboxVals); } -exports.sanitizeReplacementValues = sanitizeReplacementValues_362; -exports.evalRuntimeValues = evalRuntimeValues_363; -exports.evalCompiletimeValue = evalCompiletimeValue_364; -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/load-syntax.js"],"names":[],"mappings":"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","file":"load-syntax.js","sourcesContent":["import TermExpander from \"./term-expander\";\nimport {List} from \"immutable\";\nimport ParseReducer from \"./parse-reducer.js\";\nimport reducer, {MonoidalReducer} from \"shift-reducer\";\nimport {makeDeserializer} from \"./serializer\";\nimport Syntax from \"./syntax\";\nimport codegen, {FormattedCodeGen} from \"shift-codegen\";\nimport {VarBindingTransform, CompiletimeTransform} from \"./transforms\";\nimport Term, {isEOF, isBindingIdentifier, isFunctionDeclaration, isFunctionExpression, isFunctionTerm, isFunctionWithName, isSyntaxDeclaration, isVariableDeclaration, isVariableDeclarationStatement, isImport, isExport} from \"./terms\";\nimport Reader from \"./shift-reader\";\nimport {unwrap} from \"./macro-context\";\nimport {replaceTemplate} from \"./template-processor\";\nimport vm from \"vm\";\nimport  * as _ from \"ramda\";\nlet geval_361 = eval;\nfunction sanitizeReplacementValues_362(values_365) {\n  if (Array.isArray(values_365)) {\n    return sanitizeReplacementValues_362(List(values_365));\n  } else if (List.isList(values_365)) {\n    return values_365.map(sanitizeReplacementValues_362);\n  } else if (values_365 == null) {\n    throw new Error(\"replacement values for syntax template must not be null or undefined\");\n  } else if (typeof values_365.next === \"function\") {\n    return sanitizeReplacementValues_362(List(values_365));\n  }\n  return unwrap(values_365);\n}\nfunction evalRuntimeValues_363(terms_366, context_367) {\n  let prepped_368 = terms_366.reduce((acc_374, term_375) => {\n    let result_376 = List();\n    if (isExport(term_375)) {\n      if (isVariableDeclaration(term_375.declaration)) {\n        return acc_374.concat(new Term(\"VariableDeclarationStatement\", {declaration: term_375.declaration})).concat(term_375.declaration.declarators.map(decl_377 => {\n          return new Term(\"ExpressionStatement\", {expression: new Term(\"AssignmentExpression\", {binding: new Term(\"StaticMemberExpression\", {object: new Term(\"IdentifierExpression\", {name: Syntax.fromIdentifier(\"exports\")}), property: decl_377.binding.name}), expression: new Term(\"IdentifierExpression\", {name: decl_377.binding.name})})});\n        }));\n      }\n    } else if (isImport(term_375)) {\n      return acc_374;\n    }\n    return acc_374.concat(term_375);\n  }, List());\n  let parsed_369 = reducer(new ParseReducer(context_367, false), new Term(\"Module\", {directives: List(), items: prepped_368}).gen({includeImports: false}));\n  let gen_370 = codegen(parsed_369, new FormattedCodeGen);\n  let result_371 = context_367.transform(gen_370, {babelrc: true, filename: context_367.filename});\n  let exportsObj_372 = {};\n  context_367.store.set(\"exports\", exportsObj_372);\n  let val_373 = vm.runInContext(result_371.code, context_367.store.getNodeContext());\n  return exportsObj_372;\n}\nfunction evalCompiletimeValue_364(expr_378, context_379) {\n  let deserializer_380 = makeDeserializer(context_379.bindings);\n  let sandbox_381 = {syntaxQuote: function (strings_389, ...values_388) {\n    let ctx_390 = deserializer_380.read(_.last(values_388));\n    let reader_391 = new Reader(strings_389, ctx_390, _.take(values_388.length - 1, values_388));\n    return reader_391.read();\n  }, syntaxTemplate: function (str_393, ...values_392) {\n    return replaceTemplate(deserializer_380.read(str_393), sanitizeReplacementValues_362(values_392));\n  }};\n  let sandboxKeys_382 = List(Object.keys(sandbox_381));\n  let sandboxVals_383 = sandboxKeys_382.map(k_394 => sandbox_381[k_394]).toArray();\n  let parsed_384 = reducer(new ParseReducer(context_379), new Term(\"Module\", {directives: List(), items: List.of(new Term(\"ExpressionStatement\", {expression: new Term(\"FunctionExpression\", {isGenerator: false, name: null, params: new Term(\"FormalParameters\", {items: sandboxKeys_382.map(param_395 => {\n    return new Term(\"BindingIdentifier\", {name: Syntax.from(\"identifier\", param_395)});\n  }), rest: null}), body: new Term(\"FunctionBody\", {directives: List.of(new Term(\"Directive\", {rawValue: \"use strict\"})), statements: List.of(new Term(\"ReturnStatement\", {expression: expr_378}))})})}))}));\n  let gen_385 = codegen(parsed_384, new FormattedCodeGen);\n  let result_386 = context_379.transform(gen_385, {babelrc: true, filename: context_379.filename});\n  let val_387 = vm.runInContext(result_386.code, context_379.store.getNodeContext());\n  return val_387.apply(undefined, sandboxVals_383);\n}\nexport {sanitizeReplacementValues_362 as sanitizeReplacementValues};\nexport {evalRuntimeValues_363 as evalRuntimeValues};\nexport {evalCompiletimeValue_364 as evalCompiletimeValue}"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/load-syntax.js"],"names":[],"mappings":"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","file":"load-syntax.js","sourcesContent":["import * as _ from 'ramda';\nimport { List } from 'immutable';\nimport ParseReducer from './parse-reducer.js';\nimport reducer from \"shift-reducer\";\nimport { makeDeserializer } from './serializer';\nimport Syntax from \"./syntax\";\nimport codegen, { FormattedCodeGen } from 'shift-codegen';\nimport Term, { isVariableDeclaration, isImport, isExport } from \"./terms\";\nimport Reader from './shift-reader';\n\nimport { unwrap } from './macro-context';\n\nimport { replaceTemplate } from './template-processor';\n\nimport vm from \"vm\";\n\nexport function sanitizeReplacementValues(values) {\n  if (Array.isArray(values)) {\n    return sanitizeReplacementValues(List(values));\n  } else if (List.isList(values)) {\n    return values.map(sanitizeReplacementValues);\n  } else if (values == null) {\n    throw new Error(\"replacement values for syntax template must not be null or undefined\");\n  } else if (typeof values.next === 'function') {\n    return sanitizeReplacementValues(List(values));\n  }\n  return unwrap(values);\n}\n\nexport function evalRuntimeValues(terms, context) {\n  let prepped = terms.reduce((acc, term) => {\n    if (isExport(term)) {\n      if (isVariableDeclaration(term.declaration)) {\n        return acc.concat(new Term('VariableDeclarationStatement', {\n          declaration: term.declaration\n        })).concat(term.declaration.declarators.map(decl => {\n          return new Term('ExpressionStatement', {\n            expression: new Term('AssignmentExpression', {\n              binding: new Term('StaticMemberExpression', {\n                object: new Term('IdentifierExpression', {\n                  name: Syntax.fromIdentifier('exports')\n                }),\n                property: decl.binding.name\n              }),\n              expression: new Term('IdentifierExpression', {\n                name: decl.binding.name\n              })\n            })\n          });\n        }));\n      }\n    } else if (isImport(term)) {\n      return acc;\n    }\n    return acc.concat(term);\n  }, List());\n  let parsed = reducer(new ParseReducer(context, false), new Term('Module', {\n    directives: List(),\n    items: prepped\n  }).gen(false));\n\n  let gen = codegen(parsed, new FormattedCodeGen);\n  let result = context.transform(gen, {\n    babelrc: true,\n    filename: context.filename\n  });\n\n  let exportsObj = {};\n  context.store.set('exports', exportsObj);\n\n  vm.runInContext(result.code, context.store.getNodeContext());\n  return exportsObj;\n}\n\n// (Expression, Context) -> [function]\nexport function evalCompiletimeValue(expr, context) {\n  let deserializer = makeDeserializer(context.bindings);\n  let sandbox = {\n    syntaxQuote: function (strings, ...values) {\n      let ctx = deserializer.read(_.last(values));\n      let reader = new Reader(strings, ctx, _.take(values.length - 1, values));\n      return reader.read();\n    },\n    syntaxTemplate: function(str, ...values) {\n      return replaceTemplate(deserializer.read(str), sanitizeReplacementValues(values));\n    }\n  };\n\n  let sandboxKeys = List(Object.keys(sandbox));\n  let sandboxVals = sandboxKeys.map(k => sandbox[k]).toArray();\n\n  let parsed = reducer(new ParseReducer(context), new Term(\"Module\", {\n    directives: List(),\n    items: List.of(new Term(\"ExpressionStatement\", {\n      expression: new Term(\"FunctionExpression\", {\n        isGenerator: false,\n        name: null,\n        params: new Term(\"FormalParameters\", {\n          items: sandboxKeys.map(param => {\n            return new Term(\"BindingIdentifier\", {\n              name: Syntax.from(\"identifier\", param)\n            });\n          }),\n          rest: null\n        }),\n        body: new Term(\"FunctionBody\", {\n          directives: List.of(new Term('Directive', {\n            rawValue: 'use strict'\n          })),\n          statements: List.of(new Term(\"ReturnStatement\", {\n            expression: expr\n          }))\n        })\n      })\n    }))\n  }));\n\n  let gen = codegen(parsed, new FormattedCodeGen);\n  let result = context.transform(gen, {\n    babelrc: true,\n    filename: context.filename\n  });\n\n  let val = vm.runInContext(result.code, context.store.getNodeContext());\n  return val.apply(undefined, sandboxVals);\n}\n"]} \ No newline at end of file diff --git a/dist/macro-context.js b/dist/macro-context.js index 7343083b..c73058a7 100644 --- a/dist/macro-context.js +++ b/dist/macro-context.js @@ -1,346 +1,406 @@ -"use strict"; +'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); -exports.unwrap = exports.SyntaxOrTermWrapper = undefined; +exports.SyntaxOrTermWrapper = undefined; +exports.unwrap = unwrap; -var _mapSyntaxReducer = require("./map-syntax-reducer"); +var _errors = require('./errors'); -var _mapSyntaxReducer2 = _interopRequireDefault(_mapSyntaxReducer); +var _immutable = require('immutable'); -var _shiftReducer = require("shift-reducer"); +var _enforester = require('./enforester'); -var _shiftReducer2 = _interopRequireDefault(_shiftReducer); +var _syntax = require('./syntax'); -var _errors = require("./errors"); - -var _immutable = require("immutable"); - -var _enforester = require("./enforester"); - -var _syntax = require("./syntax"); - -var _syntax2 = _interopRequireDefault(_syntax); - -var _ramdaFantasy = require("ramda-fantasy"); - -var _ramda = require("ramda"); +var _ramda = require('ramda'); var _ = _interopRequireWildcard(_ramda); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } +const symWrap = Symbol('wrapper'); +const privateData = new WeakMap(); -const Just_396 = _ramdaFantasy.Maybe.Just; -const Nothing_397 = _ramdaFantasy.Maybe.Nothing; -const symWrap_398 = Symbol("wrapper"); -const privateData_399 = new WeakMap(); -const getVal_400 = t_405 => { - if (t_405.match("delimiter")) { +const getVal = t => { + if (t.match("delimiter")) { return null; } - if (typeof t_405.val === "function") { - return t_405.val(); + if (typeof t.val === 'function') { + return t.val(); } return null; }; -class SyntaxOrTermWrapper_401 { - constructor(s_406) { - let context_407 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - this[symWrap_398] = s_406; - this.context = context_407; +class SyntaxOrTermWrapper { + constructor(s) { + let context = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + + this[symWrap] = s; + this.context = context; } - from(type_408, value_409) { - let stx_410 = this[symWrap_398]; - if (typeof stx_410.from === "function") { - return stx_410.from(type_408, value_409); + + from(type, value) { + let stx = this[symWrap]; + if (typeof stx.from === 'function') { + return stx.from(type, value); } } fromNull() { return this.from("null", null); } - fromNumber(value_411) { - return this.from("number", value_411); + + fromNumber(value) { + return this.from('number', value); } - fromString(value_412) { - return this.from("string", value_412); + + fromString(value) { + return this.from("string", value); } - fromPunctuator(value_413) { - return this.from("punctuator", value_413); + + fromPunctuator(value) { + return this.from("punctuator", value); } - fromKeyword(value_414) { - return this.from("keyword"); + + fromKeyword(value) { + return this.from("keyword", value); } - fromIdentifier(value_415) { - return this.from("identifier", value_415); + + fromIdentifier(value) { + return this.from("identifier", value); } - fromRegularExpression(value_416) { - return this.from("regularExpression", value_416); + + fromRegularExpression(value) { + return this.from("regularExpression", value); } - fromBraces(inner_417) { - return this.from("braces", inner_417); + + fromBraces(inner) { + return this.from("braces", inner); } - fromBrackets(inner_418) { - return this.from("brackets", inner_418); + + fromBrackets(inner) { + return this.from("brackets", inner); } - fromParens(inner_419) { - return this.from("parens", inner_419); + + fromParens(inner) { + return this.from("parens", inner); } - match(type_420, value_421) { - let stx_422 = this[symWrap_398]; - if (typeof stx_422.match === "function") { - return stx_422.match(type_420, value_421); + + match(type, value) { + let stx = this[symWrap]; + if (typeof stx.match === 'function') { + return stx.match(type, value); } } - isIdentifier(value_423) { - return this.match("identifier", value_423); + + isIdentifier(value) { + return this.match("identifier", value); } - isAssign(value_424) { - return this.match("assign", value_424); + + isAssign(value) { + return this.match("assign", value); } - isBooleanLiteral(value_425) { - return this.match("boolean", value_425); + + isBooleanLiteral(value) { + return this.match("boolean", value); } - isKeyword(value_426) { - return this.match("keyword", value_426); + + isKeyword(value) { + return this.match("keyword", value); } - isNullLiteral(value_427) { - return this.match("null", value_427); + + isNullLiteral(value) { + return this.match("null", value); } - isNumericLiteral(value_428) { - return this.match("number", value_428); + + isNumericLiteral(value) { + return this.match("number", value); } - isPunctuator(value_429) { - return this.match("punctuator", value_429); + + isPunctuator(value) { + return this.match("punctuator", value); } - isStringLiteral(value_430) { - return this.match("string", value_430); + + isStringLiteral(value) { + return this.match("string", value); } - isRegularExpression(value_431) { - return this.match("regularExpression", value_431); + + isRegularExpression(value) { + return this.match("regularExpression", value); } - isTemplate(value_432) { - return this.match("template", value_432); + + isTemplate(value) { + return this.match("template", value); } - isDelimiter(value_433) { - return this.match("delimiter", value_433); + + isDelimiter(value) { + return this.match("delimiter", value); } - isParens(value_434) { - return this.match("parens", value_434); + + isParens(value) { + return this.match("parens", value); } - isBraces(value_435) { - return this.match("braces", value_435); + + isBraces(value) { + return this.match("braces", value); } - isBrackets(value_436) { - return this.match("brackets", value_436); + + isBrackets(value) { + return this.match("brackets", value); } - isSyntaxTemplate(value_437) { - return this.match("syntaxTemplate", value_437); + + isSyntaxTemplate(value) { + return this.match("syntaxTemplate", value); } - isEOF(value_438) { - return this.match("eof", value_438); + + isEOF(value) { + return this.match("eof", value); } + lineNumber() { - return this[symWrap_398].lineNumber(); + return this[symWrap].lineNumber(); } + val() { - return getVal_400(this[symWrap_398]); + return getVal(this[symWrap]); } + inner() { - let stx_439 = this[symWrap_398]; - if (!stx_439.match("delimiter")) { - throw new Error("Can only get inner syntax on a delimiter"); + let stx = this[symWrap]; + if (!stx.match("delimiter")) { + throw new Error('Can only get inner syntax on a delimiter'); } - let enf_440 = new _enforester.Enforester(stx_439.inner(), (0, _immutable.List)(), this.context); - return new MacroContext(enf_440, "inner", this.context); + + let enf = new _enforester.Enforester(stx.inner(), (0, _immutable.List)(), this.context); + return new MacroContext(enf, 'inner', this.context); } } -function unwrap_402(x_441) { - if (x_441 instanceof SyntaxOrTermWrapper_401) { - return x_441[symWrap_398]; + +exports.SyntaxOrTermWrapper = SyntaxOrTermWrapper; +function unwrap(x) { + if (x instanceof SyntaxOrTermWrapper) { + return x[symWrap]; } - return x_441; + return x; } -function cloneEnforester_403(enf_442) { - const rest = enf_442.rest; - const prev = enf_442.prev; - const context = enf_442.context; + +function cloneEnforester(enf) { + const rest = enf.rest; + const prev = enf.prev; + const context = enf.context; return new _enforester.Enforester(rest, prev, context); } -function Marker_404() {} + +function Marker() {} + +/* +ctx :: { + of: (Syntax) -> ctx + next: (String) -> Syntax or Term +} +*/ class MacroContext { - constructor(enf_443, name_444, context_445, useScope_446, introducedScope_447) { - const startMarker_448 = new Marker_404(); - const startEnf_449 = cloneEnforester_403(enf_443); - const priv_450 = { name: name_444, context: context_445, startMarker: startMarker_448, markers: new Map([[startMarker_448, enf_443]]) }; - if (useScope_446 && introducedScope_447) { - priv_450.noScopes = false; - priv_450.useScope = useScope_446; - priv_450.introducedScope = introducedScope_447; + + constructor(enf, name, context, useScope, introducedScope) { + const startMarker = new Marker(); + const startEnf = cloneEnforester(enf); + const priv = { + name: name, + context: context, + enf: startEnf, + startMarker: startMarker, + markers: new Map([[startMarker, enf]]) + }; + + if (useScope && introducedScope) { + priv.noScopes = false; + priv.useScope = useScope; + priv.introducedScope = introducedScope; } else { - priv_450.noScopes = true; + priv.noScopes = true; } - privateData_399.set(this, priv_450); - this.reset(); + privateData.set(this, priv); + this.reset(); // set current enforester + this[Symbol.iterator] = () => this; } + name() { - var _privateData_399$get = privateData_399.get(this); + var _privateData$get = privateData.get(this); - const name = _privateData_399$get.name; - const context = _privateData_399$get.context; + const name = _privateData$get.name; + const context = _privateData$get.context; - return new SyntaxOrTermWrapper_401(name, context); + return new SyntaxOrTermWrapper(name, context); } - expand(type_451) { - var _privateData_399$get2 = privateData_399.get(this); - const enf = _privateData_399$get2.enf; - const context = _privateData_399$get2.context; + expand(type) { + var _privateData$get2 = privateData.get(this); + + const enf = _privateData$get2.enf; + const context = _privateData$get2.context; if (enf.rest.size === 0) { - return { done: true, value: null }; + return { + done: true, + value: null + }; } enf.expandMacro(); - let originalRest_452 = enf.rest; - let value_453; - switch (type_451) { - case "AssignmentExpression": - case "expr": - value_453 = enf.enforestExpressionLoop(); + let originalRest = enf.rest; + let value; + switch (type) { + case 'AssignmentExpression': + case 'expr': + value = enf.enforestExpressionLoop(); break; - case "Expression": - value_453 = enf.enforestExpression(); + case 'Expression': + value = enf.enforestExpression(); break; - case "Statement": - case "stmt": - value_453 = enf.enforestStatement(); + case 'Statement': + case 'stmt': + value = enf.enforestStatement(); break; - case "BlockStatement": - case "WhileStatement": - case "IfStatement": - case "ForStatement": - case "SwitchStatement": - case "BreakStatement": - case "ContinueStatement": - case "DebuggerStatement": - case "WithStatement": - case "TryStatement": - case "ThrowStatement": - case "ClassDeclaration": - case "FunctionDeclaration": - case "LabeledStatement": - case "VariableDeclarationStatement": - case "ReturnStatement": - case "ExpressionStatement": - value_453 = enf.enforestStatement(); - (0, _errors.expect)(_.whereEq({ type: type_451 }, value_453), `Expecting a ${ type_451 }`, value_453, originalRest_452); + case 'BlockStatement': + case 'WhileStatement': + case 'IfStatement': + case 'ForStatement': + case 'SwitchStatement': + case 'BreakStatement': + case 'ContinueStatement': + case 'DebuggerStatement': + case 'WithStatement': + case 'TryStatement': + case 'ThrowStatement': + case 'ClassDeclaration': + case 'FunctionDeclaration': + case 'LabeledStatement': + case 'VariableDeclarationStatement': + case 'ReturnStatement': + case 'ExpressionStatement': + value = enf.enforestStatement(); + (0, _errors.expect)(_.whereEq({ type: type }, value), `Expecting a ${ type }`, value, originalRest); break; - case "YieldExpression": - value_453 = enf.enforestYieldExpression(); + case 'YieldExpression': + value = enf.enforestYieldExpression(); break; - case "ClassExpression": - value_453 = enf.enforestClass({ isExpr: true }); + case 'ClassExpression': + value = enf.enforestClass({ isExpr: true }); break; - case "ArrowExpression": - value_453 = enf.enforestArrowExpression(); + case 'ArrowExpression': + value = enf.enforestArrowExpression(); break; - case "NewExpression": - value_453 = enf.enforestNewExpression(); + case 'NewExpression': + value = enf.enforestNewExpression(); break; - case "ThisExpression": - case "FunctionExpression": - case "IdentifierExpression": - case "LiteralNumericExpression": - case "LiteralInfinityExpression": - case "LiteralStringExpression": - case "TemplateExpression": - case "LiteralBooleanExpression": - case "LiteralNullExpression": - case "LiteralRegExpExpression": - case "ObjectExpression": - case "ArrayExpression": - value_453 = enf.enforestPrimaryExpression(); + case 'ThisExpression': + case 'FunctionExpression': + case 'IdentifierExpression': + case 'LiteralNumericExpression': + case 'LiteralInfinityExpression': + case 'LiteralStringExpression': + case 'TemplateExpression': + case 'LiteralBooleanExpression': + case 'LiteralNullExpression': + case 'LiteralRegExpExpression': + case 'ObjectExpression': + case 'ArrayExpression': + value = enf.enforestPrimaryExpression(); break; - case "UnaryExpression": - case "UpdateExpression": - case "BinaryExpression": - case "StaticMemberExpression": - case "ComputedMemberExpression": - case "AssignmentExpression": - case "CompoundAssignmentExpression": - case "ConditionalExpression": - value_453 = enf.enforestExpressionLoop(); - (0, _errors.expect)(_.whereEq({ type: type_451 }, value_453), `Expecting a ${ type_451 }`, value_453, originalRest_452); + case 'UnaryExpression': + case 'UpdateExpression': + case 'BinaryExpression': + case 'StaticMemberExpression': + case 'ComputedMemberExpression': + case 'CompoundAssignmentExpression': + case 'ConditionalExpression': + value = enf.enforestExpressionLoop(); + (0, _errors.expect)(_.whereEq({ type: type }, value), `Expecting a ${ type }`, value, originalRest); break; default: - throw new Error("Unknown term type: " + type_451); + throw new Error('Unknown term type: ' + type); } - return { done: false, value: new SyntaxOrTermWrapper_401(value_453, context) }; + return { + done: false, + value: new SyntaxOrTermWrapper(value, context) + }; } - _rest(enf_454) { - const priv_455 = privateData_399.get(this); - if (priv_455.markers.get(priv_455.startMarker) === enf_454) { - return priv_455.enf.rest; + + _rest(enf) { + const priv = privateData.get(this); + if (priv.markers.get(priv.startMarker) === enf) { + return priv.enf.rest; } throw Error("Unauthorized access!"); } - reset(marker_456) { - const priv_457 = privateData_399.get(this); - let enf_458; - if (marker_456 == null) { - enf_458 = priv_457.markers.get(priv_457.startMarker); - } else if (marker_456 && marker_456 instanceof Marker_404) { - if (priv_457.markers.has(marker_456)) { - enf_458 = priv_457.markers.get(marker_456); + + reset(marker) { + const priv = privateData.get(this); + let enf; + if (marker == null) { + // go to the beginning + enf = priv.markers.get(priv.startMarker); + } else if (marker && marker instanceof Marker) { + // marker could be from another context + if (priv.markers.has(marker)) { + enf = priv.markers.get(marker); } else { - throw new Error("marker must originate from this context"); + throw new Error('marker must originate from this context'); } } else { - throw new Error("marker must be an instance of Marker"); + throw new Error('marker must be an instance of Marker'); } - priv_457.enf = cloneEnforester_403(enf_458); + priv.enf = cloneEnforester(enf); } + mark() { - const priv_459 = privateData_399.get(this); - let marker_460; - if (priv_459.enf.rest === priv_459.markers.get(priv_459.startMarker).rest) { - marker_460 = priv_459.startMarker; - } else if (priv_459.enf.rest.isEmpty()) { - if (!priv_459.endMarker) priv_459.endMarker = new Marker_404(); - marker_460 = priv_459.endMarker; + const priv = privateData.get(this); + let marker; + + // the idea here is that marking at the beginning shouldn't happen more than once. + // We can reuse startMarker. + if (priv.enf.rest === priv.markers.get(priv.startMarker).rest) { + marker = priv.startMarker; + } else if (priv.enf.rest.isEmpty()) { + // same reason as above + if (!priv.endMarker) priv.endMarker = new Marker(); + marker = priv.endMarker; } else { - marker_460 = new Marker_404(); + //TODO(optimization/dubious): check that there isn't already a marker for this index? + marker = new Marker(); } - if (!priv_459.markers.has(marker_460)) { - priv_459.markers.set(marker_460, cloneEnforester_403(priv_459.enf)); + if (!priv.markers.has(marker)) { + priv.markers.set(marker, cloneEnforester(priv.enf)); } - return marker_460; + return marker; } + next() { - var _privateData_399$get3 = privateData_399.get(this); + var _privateData$get3 = privateData.get(this); - const enf = _privateData_399$get3.enf; - const noScopes = _privateData_399$get3.noScopes; - const useScope = _privateData_399$get3.useScope; - const introducedScope = _privateData_399$get3.introducedScope; - const context = _privateData_399$get3.context; + const enf = _privateData$get3.enf; + const noScopes = _privateData$get3.noScopes; + const useScope = _privateData$get3.useScope; + const introducedScope = _privateData$get3.introducedScope; + const context = _privateData$get3.context; if (enf.rest.size === 0) { - return { done: true, value: null }; + return { + done: true, + value: null + }; } - let value_461 = enf.advance(); + let value = enf.advance(); if (!noScopes) { - value_461 = value_461.addScope(useScope, context.bindings, _syntax.ALL_PHASES).addScope(introducedScope, context.bindings, _syntax.ALL_PHASES, { flip: true }); + value = value.addScope(useScope, context.bindings, _syntax.ALL_PHASES).addScope(introducedScope, context.bindings, _syntax.ALL_PHASES, { flip: true }); } - return { done: false, value: new SyntaxOrTermWrapper_401(value_461, context) }; + return { + done: false, + value: new SyntaxOrTermWrapper(value, context) + }; } } exports.default = MacroContext; -exports.SyntaxOrTermWrapper = SyntaxOrTermWrapper_401; -exports.unwrap = unwrap_402; -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/macro-context.js"],"names":[],"mappings":"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","file":"macro-context.js","sourcesContent":["import MapSyntaxReducer from \"./map-syntax-reducer\";\nimport reducer from \"shift-reducer\";\nimport {expect} from \"./errors\";\nimport {List} from \"immutable\";\nimport {Enforester} from \"./enforester\";\nimport Syntax, {ALL_PHASES} from \"./syntax\";\nimport {Maybe} from \"ramda-fantasy\";\nimport  * as _ from \"ramda\";\nconst Just_396 = Maybe.Just;\nconst Nothing_397 = Maybe.Nothing;\nconst symWrap_398 = Symbol(\"wrapper\");\nconst privateData_399 = new WeakMap;\nconst getVal_400 = t_405 => {\n  if (t_405.match(\"delimiter\")) {\n    return null;\n  }\n  if (typeof t_405.val === \"function\") {\n    return t_405.val();\n  }\n  return null;\n};\nclass SyntaxOrTermWrapper_401 {\n  constructor(s_406, context_407 = {}) {\n    this[symWrap_398] = s_406;\n    this.context = context_407;\n  }\n  from(type_408, value_409) {\n    let stx_410 = this[symWrap_398];\n    if (typeof stx_410.from === \"function\") {\n      return stx_410.from(type_408, value_409);\n    }\n  }\n  fromNull() {\n    return this.from(\"null\", null);\n  }\n  fromNumber(value_411) {\n    return this.from(\"number\", value_411);\n  }\n  fromString(value_412) {\n    return this.from(\"string\", value_412);\n  }\n  fromPunctuator(value_413) {\n    return this.from(\"punctuator\", value_413);\n  }\n  fromKeyword(value_414) {\n    return this.from(\"keyword\");\n  }\n  fromIdentifier(value_415) {\n    return this.from(\"identifier\", value_415);\n  }\n  fromRegularExpression(value_416) {\n    return this.from(\"regularExpression\", value_416);\n  }\n  fromBraces(inner_417) {\n    return this.from(\"braces\", inner_417);\n  }\n  fromBrackets(inner_418) {\n    return this.from(\"brackets\", inner_418);\n  }\n  fromParens(inner_419) {\n    return this.from(\"parens\", inner_419);\n  }\n  match(type_420, value_421) {\n    let stx_422 = this[symWrap_398];\n    if (typeof stx_422.match === \"function\") {\n      return stx_422.match(type_420, value_421);\n    }\n  }\n  isIdentifier(value_423) {\n    return this.match(\"identifier\", value_423);\n  }\n  isAssign(value_424) {\n    return this.match(\"assign\", value_424);\n  }\n  isBooleanLiteral(value_425) {\n    return this.match(\"boolean\", value_425);\n  }\n  isKeyword(value_426) {\n    return this.match(\"keyword\", value_426);\n  }\n  isNullLiteral(value_427) {\n    return this.match(\"null\", value_427);\n  }\n  isNumericLiteral(value_428) {\n    return this.match(\"number\", value_428);\n  }\n  isPunctuator(value_429) {\n    return this.match(\"punctuator\", value_429);\n  }\n  isStringLiteral(value_430) {\n    return this.match(\"string\", value_430);\n  }\n  isRegularExpression(value_431) {\n    return this.match(\"regularExpression\", value_431);\n  }\n  isTemplate(value_432) {\n    return this.match(\"template\", value_432);\n  }\n  isDelimiter(value_433) {\n    return this.match(\"delimiter\", value_433);\n  }\n  isParens(value_434) {\n    return this.match(\"parens\", value_434);\n  }\n  isBraces(value_435) {\n    return this.match(\"braces\", value_435);\n  }\n  isBrackets(value_436) {\n    return this.match(\"brackets\", value_436);\n  }\n  isSyntaxTemplate(value_437) {\n    return this.match(\"syntaxTemplate\", value_437);\n  }\n  isEOF(value_438) {\n    return this.match(\"eof\", value_438);\n  }\n  lineNumber() {\n    return this[symWrap_398].lineNumber();\n  }\n  val() {\n    return getVal_400(this[symWrap_398]);\n  }\n  inner() {\n    let stx_439 = this[symWrap_398];\n    if (!stx_439.match(\"delimiter\")) {\n      throw new Error(\"Can only get inner syntax on a delimiter\");\n    }\n    let enf_440 = new Enforester(stx_439.inner(), List(), this.context);\n    return new MacroContext(enf_440, \"inner\", this.context);\n  }\n}\nfunction unwrap_402(x_441) {\n  if (x_441 instanceof SyntaxOrTermWrapper_401) {\n    return x_441[symWrap_398];\n  }\n  return x_441;\n}\nfunction cloneEnforester_403(enf_442) {\n  const {rest, prev, context} = enf_442;\n  return new Enforester(rest, prev, context);\n}\nfunction Marker_404() {}\nexport default class MacroContext {\n  constructor(enf_443, name_444, context_445, useScope_446, introducedScope_447) {\n    const startMarker_448 = new Marker_404;\n    const startEnf_449 = cloneEnforester_403(enf_443);\n    const priv_450 = {name: name_444, context: context_445, startMarker: startMarker_448, markers: new Map([[startMarker_448, enf_443]])};\n    if (useScope_446 && introducedScope_447) {\n      priv_450.noScopes = false;\n      priv_450.useScope = useScope_446;\n      priv_450.introducedScope = introducedScope_447;\n    } else {\n      priv_450.noScopes = true;\n    }\n    privateData_399.set(this, priv_450);\n    this.reset();\n    this[Symbol.iterator] = () => this;\n  }\n  name() {\n    const {name, context} = privateData_399.get(this);\n    return new SyntaxOrTermWrapper_401(name, context);\n  }\n  expand(type_451) {\n    const {enf, context} = privateData_399.get(this);\n    if (enf.rest.size === 0) {\n      return {done: true, value: null};\n    }\n    enf.expandMacro();\n    let originalRest_452 = enf.rest;\n    let value_453;\n    switch (type_451) {\n      case \"AssignmentExpression\":\n      case \"expr\":\n        value_453 = enf.enforestExpressionLoop();\n        break;\n      case \"Expression\":\n        value_453 = enf.enforestExpression();\n        break;\n      case \"Statement\":\n      case \"stmt\":\n        value_453 = enf.enforestStatement();\n        break;\n      case \"BlockStatement\":\n      case \"WhileStatement\":\n      case \"IfStatement\":\n      case \"ForStatement\":\n      case \"SwitchStatement\":\n      case \"BreakStatement\":\n      case \"ContinueStatement\":\n      case \"DebuggerStatement\":\n      case \"WithStatement\":\n      case \"TryStatement\":\n      case \"ThrowStatement\":\n      case \"ClassDeclaration\":\n      case \"FunctionDeclaration\":\n      case \"LabeledStatement\":\n      case \"VariableDeclarationStatement\":\n      case \"ReturnStatement\":\n      case \"ExpressionStatement\":\n        value_453 = enf.enforestStatement();\n        expect(_.whereEq({type: type_451}, value_453), `Expecting a ${type_451}`, value_453, originalRest_452);\n        break;\n      case \"YieldExpression\":\n        value_453 = enf.enforestYieldExpression();\n        break;\n      case \"ClassExpression\":\n        value_453 = enf.enforestClass({isExpr: true});\n        break;\n      case \"ArrowExpression\":\n        value_453 = enf.enforestArrowExpression();\n        break;\n      case \"NewExpression\":\n        value_453 = enf.enforestNewExpression();\n        break;\n      case \"ThisExpression\":\n      case \"FunctionExpression\":\n      case \"IdentifierExpression\":\n      case \"LiteralNumericExpression\":\n      case \"LiteralInfinityExpression\":\n      case \"LiteralStringExpression\":\n      case \"TemplateExpression\":\n      case \"LiteralBooleanExpression\":\n      case \"LiteralNullExpression\":\n      case \"LiteralRegExpExpression\":\n      case \"ObjectExpression\":\n      case \"ArrayExpression\":\n        value_453 = enf.enforestPrimaryExpression();\n        break;\n      case \"UnaryExpression\":\n      case \"UpdateExpression\":\n      case \"BinaryExpression\":\n      case \"StaticMemberExpression\":\n      case \"ComputedMemberExpression\":\n      case \"AssignmentExpression\":\n      case \"CompoundAssignmentExpression\":\n      case \"ConditionalExpression\":\n        value_453 = enf.enforestExpressionLoop();\n        expect(_.whereEq({type: type_451}, value_453), `Expecting a ${type_451}`, value_453, originalRest_452);\n        break;\n      default:\n        throw new Error(\"Unknown term type: \" + type_451);\n    }\n    return {done: false, value: new SyntaxOrTermWrapper_401(value_453, context)};\n  }\n  _rest(enf_454) {\n    const priv_455 = privateData_399.get(this);\n    if (priv_455.markers.get(priv_455.startMarker) === enf_454) {\n      return priv_455.enf.rest;\n    }\n    throw Error(\"Unauthorized access!\");\n  }\n  reset(marker_456) {\n    const priv_457 = privateData_399.get(this);\n    let enf_458;\n    if (marker_456 == null) {\n      enf_458 = priv_457.markers.get(priv_457.startMarker);\n    } else if (marker_456 && marker_456 instanceof Marker_404) {\n      if (priv_457.markers.has(marker_456)) {\n        enf_458 = priv_457.markers.get(marker_456);\n      } else {\n        throw new Error(\"marker must originate from this context\");\n      }\n    } else {\n      throw new Error(\"marker must be an instance of Marker\");\n    }\n    priv_457.enf = cloneEnforester_403(enf_458);\n  }\n  mark() {\n    const priv_459 = privateData_399.get(this);\n    let marker_460;\n    if (priv_459.enf.rest === priv_459.markers.get(priv_459.startMarker).rest) {\n      marker_460 = priv_459.startMarker;\n    } else if (priv_459.enf.rest.isEmpty()) {\n      if (!priv_459.endMarker) priv_459.endMarker = new Marker_404;\n      marker_460 = priv_459.endMarker;\n    } else {\n      marker_460 = new Marker_404;\n    }\n    if (!priv_459.markers.has(marker_460)) {\n      priv_459.markers.set(marker_460, cloneEnforester_403(priv_459.enf));\n    }\n    return marker_460;\n  }\n  next() {\n    const {enf, noScopes, useScope, introducedScope, context} = privateData_399.get(this);\n    if (enf.rest.size === 0) {\n      return {done: true, value: null};\n    }\n    let value_461 = enf.advance();\n    if (!noScopes) {\n      value_461 = value_461.addScope(useScope, context.bindings, ALL_PHASES).addScope(introducedScope, context.bindings, ALL_PHASES, {flip: true});\n    }\n    return {done: false, value: new SyntaxOrTermWrapper_401(value_461, context)};\n  }\n}\nexport {SyntaxOrTermWrapper_401 as SyntaxOrTermWrapper};\nexport {unwrap_402 as unwrap}"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/macro-context.js"],"names":[],"mappings":"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","file":"macro-context.js","sourcesContent":["import { expect } from './errors';\nimport { List } from 'immutable';\nimport { Enforester } from './enforester';\nimport { ALL_PHASES } from './syntax';\nimport * as _ from 'ramda';\n\nconst symWrap = Symbol('wrapper');\nconst privateData = new WeakMap();\n\nconst getVal = t => {\n  if (t.match(\"delimiter\")) {\n    return null;\n  }\n  if (typeof t.val === 'function') {\n    return t.val();\n  }\n  return null;\n};\n\nexport class SyntaxOrTermWrapper {\n  constructor(s, context = {}) {\n    this[symWrap] = s;\n    this.context = context;\n  }\n\n  from(type, value) {\n    let stx = this[symWrap];\n    if (typeof stx.from === 'function') {\n      return stx.from(type, value);\n    }\n  }\n  fromNull() {\n    return this.from(\"null\", null);\n  }\n\n  fromNumber(value) {\n    return this.from('number', value);\n  }\n\n  fromString(value) {\n    return this.from(\"string\", value);\n  }\n\n  fromPunctuator(value) {\n    return this.from(\"punctuator\", value);\n  }\n\n  fromKeyword(value) {\n    return this.from(\"keyword\", value);\n  }\n\n  fromIdentifier(value) {\n    return this.from(\"identifier\", value);\n  }\n\n  fromRegularExpression(value) {\n    return this.from(\"regularExpression\", value);\n  }\n\n  fromBraces(inner) {\n    return this.from(\"braces\", inner);\n  }\n\n  fromBrackets(inner) {\n    return this.from(\"brackets\", inner);\n  }\n\n  fromParens(inner) {\n    return this.from(\"parens\", inner);\n  }\n\n  match(type, value) {\n    let stx = this[symWrap];\n    if (typeof stx.match === 'function') {\n      return stx.match(type, value);\n    }\n  }\n\n  isIdentifier(value) {\n    return this.match(\"identifier\", value);\n  }\n\n  isAssign(value) {\n    return this.match(\"assign\", value);\n  }\n\n  isBooleanLiteral(value) {\n    return this.match(\"boolean\", value);\n  }\n\n  isKeyword(value) {\n    return this.match(\"keyword\", value);\n  }\n\n  isNullLiteral(value) {\n    return this.match(\"null\", value);\n  }\n\n  isNumericLiteral(value) {\n    return this.match(\"number\", value);\n  }\n\n  isPunctuator(value) {\n    return this.match(\"punctuator\", value);\n  }\n\n  isStringLiteral(value) {\n    return this.match(\"string\", value);\n  }\n\n  isRegularExpression(value) {\n    return this.match(\"regularExpression\", value);\n  }\n\n  isTemplate(value) {\n    return this.match(\"template\", value);\n  }\n\n  isDelimiter(value) {\n    return this.match(\"delimiter\", value);\n  }\n\n  isParens(value) {\n    return this.match(\"parens\", value);\n  }\n\n  isBraces(value) {\n    return this.match(\"braces\", value);\n  }\n\n  isBrackets(value) {\n    return this.match(\"brackets\", value);\n  }\n\n  isSyntaxTemplate(value) {\n    return this.match(\"syntaxTemplate\", value);\n  }\n\n  isEOF(value) {\n    return this.match(\"eof\", value);\n  }\n\n  lineNumber() {\n    return this[symWrap].lineNumber();\n  }\n\n  val() {\n    return getVal(this[symWrap]);\n  }\n\n  inner() {\n    let stx = this[symWrap];\n    if (!stx.match(\"delimiter\")) {\n      throw new Error('Can only get inner syntax on a delimiter');\n    }\n\n    let enf = new Enforester(stx.inner(), List(), this.context);\n    return new MacroContext(enf, 'inner', this.context);\n  }\n}\n\nexport function unwrap(x) {\n  if (x instanceof SyntaxOrTermWrapper) {\n    return x[symWrap];\n  }\n  return x;\n}\n\nfunction cloneEnforester(enf) {\n  const { rest, prev, context } = enf;\n  return new Enforester(rest, prev, context);\n}\n\nfunction Marker () {}\n\n/*\nctx :: {\n  of: (Syntax) -> ctx\n  next: (String) -> Syntax or Term\n}\n*/\nexport default class MacroContext {\n\n  constructor(enf, name, context, useScope, introducedScope) {\n    const startMarker = new Marker();\n    const startEnf = cloneEnforester(enf);\n    const priv = {\n      name,\n      context,\n      enf: startEnf,\n      startMarker,\n      markers: new Map([[startMarker, enf]]),\n    };\n\n    if (useScope && introducedScope) {\n      priv.noScopes = false;\n      priv.useScope = useScope;\n      priv.introducedScope = introducedScope;\n    } else {\n      priv.noScopes = true;\n    }\n    privateData.set(this, priv);\n    this.reset(); // set current enforester\n\n    this[Symbol.iterator] = () => this;\n  }\n\n  name() {\n    const { name, context } = privateData.get(this);\n    return new SyntaxOrTermWrapper(name, context);\n  }\n\n  expand(type) {\n    const { enf, context } = privateData.get(this);\n    if (enf.rest.size === 0) {\n      return {\n        done: true,\n        value: null\n      };\n    }\n    enf.expandMacro();\n    let originalRest = enf.rest;\n    let value;\n    switch(type) {\n      case 'AssignmentExpression':\n      case 'expr':\n        value = enf.enforestExpressionLoop();\n        break;\n      case 'Expression':\n        value = enf.enforestExpression();\n        break;\n      case 'Statement':\n      case 'stmt':\n        value = enf.enforestStatement();\n        break;\n      case 'BlockStatement':\n      case 'WhileStatement':\n      case 'IfStatement':\n      case 'ForStatement':\n      case 'SwitchStatement':\n      case 'BreakStatement':\n      case 'ContinueStatement':\n      case 'DebuggerStatement':\n      case 'WithStatement':\n      case 'TryStatement':\n      case 'ThrowStatement':\n      case 'ClassDeclaration':\n      case 'FunctionDeclaration':\n      case 'LabeledStatement':\n      case 'VariableDeclarationStatement':\n      case 'ReturnStatement':\n      case 'ExpressionStatement':\n        value = enf.enforestStatement();\n        expect(_.whereEq({type}, value), `Expecting a ${type}`, value, originalRest);\n        break;\n      case 'YieldExpression':\n        value = enf.enforestYieldExpression();\n        break;\n      case 'ClassExpression':\n        value = enf.enforestClass({isExpr: true});\n        break;\n      case 'ArrowExpression':\n        value = enf.enforestArrowExpression();\n        break;\n      case 'NewExpression':\n        value = enf.enforestNewExpression();\n        break;\n      case 'ThisExpression':\n      case 'FunctionExpression':\n      case 'IdentifierExpression':\n      case 'LiteralNumericExpression':\n      case 'LiteralInfinityExpression':\n      case 'LiteralStringExpression':\n      case 'TemplateExpression':\n      case 'LiteralBooleanExpression':\n      case 'LiteralNullExpression':\n      case 'LiteralRegExpExpression':\n      case 'ObjectExpression':\n      case 'ArrayExpression':\n        value = enf.enforestPrimaryExpression();\n        break;\n      case 'UnaryExpression':\n      case 'UpdateExpression':\n      case 'BinaryExpression':\n      case 'StaticMemberExpression':\n      case 'ComputedMemberExpression':\n      case 'CompoundAssignmentExpression':\n      case 'ConditionalExpression':\n        value = enf.enforestExpressionLoop();\n        expect(_.whereEq({type}, value), `Expecting a ${type}`, value, originalRest);\n        break;\n      default:\n        throw new Error('Unknown term type: ' + type);\n    }\n    return {\n      done: false,\n      value: new SyntaxOrTermWrapper(value, context)\n    };\n  }\n\n  _rest(enf) {\n    const priv = privateData.get(this);\n    if (priv.markers.get(priv.startMarker) === enf) {\n      return priv.enf.rest;\n    }\n    throw Error(\"Unauthorized access!\");\n  }\n\n  reset(marker) {\n    const priv = privateData.get(this);\n    let enf;\n    if (marker == null) {\n      // go to the beginning\n      enf = priv.markers.get(priv.startMarker);\n    } else if (marker && marker instanceof Marker) {\n      // marker could be from another context\n      if (priv.markers.has(marker)) {\n        enf = priv.markers.get(marker);\n      } else {\n        throw new Error('marker must originate from this context');\n      }\n    } else {\n      throw new Error('marker must be an instance of Marker');\n    }\n    priv.enf = cloneEnforester(enf);\n  }\n\n  mark() {\n    const priv = privateData.get(this);\n    let marker;\n\n    // the idea here is that marking at the beginning shouldn't happen more than once.\n    // We can reuse startMarker.\n    if (priv.enf.rest === priv.markers.get(priv.startMarker).rest) {\n      marker = priv.startMarker;\n    } else if (priv.enf.rest.isEmpty()) {\n      // same reason as above\n      if (!priv.endMarker) priv.endMarker = new Marker();\n      marker = priv.endMarker;\n    } else {\n      //TODO(optimization/dubious): check that there isn't already a marker for this index?\n      marker = new Marker();\n    }\n    if (!priv.markers.has(marker)) {\n      priv.markers.set(marker, cloneEnforester(priv.enf));\n    }\n    return marker;\n  }\n\n  next() {\n    const { enf, noScopes, useScope, introducedScope, context } = privateData.get(this);\n    if (enf.rest.size === 0) {\n      return {\n        done: true,\n        value: null\n      };\n    }\n    let value = enf.advance();\n    if (!noScopes) {\n      value = value\n        .addScope(useScope, context.bindings, ALL_PHASES)\n        .addScope(introducedScope, context.bindings, ALL_PHASES, { flip: true });\n    }\n    return {\n      done: false,\n      value: new SyntaxOrTermWrapper(value, context)\n    };\n  }\n}\n"]} \ No newline at end of file diff --git a/dist/map-syntax-reducer.js b/dist/map-syntax-reducer.js index f74da315..0cf6167f 100644 --- a/dist/map-syntax-reducer.js +++ b/dist/map-syntax-reducer.js @@ -13,18 +13,26 @@ var _shiftReducer = require("shift-reducer"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } class MapSyntaxReducer extends _shiftReducer.CloneReducer { - constructor(fn_462) { + constructor(fn) { super(); - this.fn = fn_462; + this.fn = fn; } - reduceBindingIdentifier(node_463, state_464) { - let name_465 = this.fn(node_463.name); - return new _terms2.default("BindingIdentifier", { name: name_465 }); + + reduceBindingIdentifier(node) { + let name = this.fn(node.name); + + return new _terms2.default("BindingIdentifier", { + name: name + }); } - reduceIdentifierExpression(node_466, state_467) { - let name_468 = this.fn(node_466.name); - return new _terms2.default("IdentifierExpression", { name: name_468 }); + + reduceIdentifierExpression(node) { + let name = this.fn(node.name); + + return new _terms2.default("IdentifierExpression", { + name: name + }); } } exports.default = MapSyntaxReducer; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L21hcC1zeW50YXgtcmVkdWNlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7OztBQUNBOzs7O0FBQ2UsTUFBTSxnQkFBTixvQ0FBNEM7QUFDekQsY0FBWSxNQUFaLEVBQW9CO0FBQ2xCO0FBQ0EsU0FBSyxFQUFMLEdBQVUsTUFBVjtBQUNEO0FBQ0QsMEJBQXdCLFFBQXhCLEVBQWtDLFNBQWxDLEVBQTZDO0FBQzNDLFFBQUksV0FBVyxLQUFLLEVBQUwsQ0FBUSxTQUFTLElBQWpCLENBQWY7QUFDQSxXQUFPLG9CQUFTLG1CQUFULEVBQThCLEVBQUMsTUFBTSxRQUFQLEVBQTlCLENBQVA7QUFDRDtBQUNELDZCQUEyQixRQUEzQixFQUFxQyxTQUFyQyxFQUFnRDtBQUM5QyxRQUFJLFdBQVcsS0FBSyxFQUFMLENBQVEsU0FBUyxJQUFqQixDQUFmO0FBQ0EsV0FBTyxvQkFBUyxzQkFBVCxFQUFpQyxFQUFDLE1BQU0sUUFBUCxFQUFqQyxDQUFQO0FBQ0Q7QUFad0Q7a0JBQXRDLGdCIiwiZmlsZSI6Im1hcC1zeW50YXgtcmVkdWNlci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBUZXJtIGZyb20gXCIuL3Rlcm1zXCI7XG5pbXBvcnQge0Nsb25lUmVkdWNlcn0gZnJvbSBcInNoaWZ0LXJlZHVjZXJcIjtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIE1hcFN5bnRheFJlZHVjZXIgZXh0ZW5kcyBDbG9uZVJlZHVjZXIge1xuICBjb25zdHJ1Y3Rvcihmbl80NjIpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMuZm4gPSBmbl80NjI7XG4gIH1cbiAgcmVkdWNlQmluZGluZ0lkZW50aWZpZXIobm9kZV80NjMsIHN0YXRlXzQ2NCkge1xuICAgIGxldCBuYW1lXzQ2NSA9IHRoaXMuZm4obm9kZV80NjMubmFtZSk7XG4gICAgcmV0dXJuIG5ldyBUZXJtKFwiQmluZGluZ0lkZW50aWZpZXJcIiwge25hbWU6IG5hbWVfNDY1fSk7XG4gIH1cbiAgcmVkdWNlSWRlbnRpZmllckV4cHJlc3Npb24obm9kZV80NjYsIHN0YXRlXzQ2Nykge1xuICAgIGxldCBuYW1lXzQ2OCA9IHRoaXMuZm4obm9kZV80NjYubmFtZSk7XG4gICAgcmV0dXJuIG5ldyBUZXJtKFwiSWRlbnRpZmllckV4cHJlc3Npb25cIiwge25hbWU6IG5hbWVfNDY4fSk7XG4gIH1cbn1cbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9tYXAtc3ludGF4LXJlZHVjZXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7Ozs7QUFDQTs7OztBQUVlLE1BQU0sZ0JBQU4sb0NBQTRDO0FBQ3pELGNBQVksRUFBWixFQUFnQjtBQUNkO0FBQ0EsU0FBSyxFQUFMLEdBQVUsRUFBVjtBQUNEOztBQUVELDBCQUF3QixJQUF4QixFQUE4QjtBQUM1QixRQUFJLE9BQU8sS0FBSyxFQUFMLENBQVEsS0FBSyxJQUFiLENBQVg7O0FBRUEsV0FBTyxvQkFBUyxtQkFBVCxFQUE4QjtBQUNuQyxZQUFNO0FBRDZCLEtBQTlCLENBQVA7QUFHRDs7QUFFRCw2QkFBMkIsSUFBM0IsRUFBaUM7QUFDL0IsUUFBSSxPQUFPLEtBQUssRUFBTCxDQUFRLEtBQUssSUFBYixDQUFYOztBQUVBLFdBQU8sb0JBQVMsc0JBQVQsRUFBaUM7QUFDdEMsWUFBTTtBQURnQyxLQUFqQyxDQUFQO0FBR0Q7QUFwQndEO2tCQUF0QyxnQiIsImZpbGUiOiJtYXAtc3ludGF4LXJlZHVjZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgVGVybSBmcm9tIFwiLi90ZXJtc1wiO1xuaW1wb3J0IHsgQ2xvbmVSZWR1Y2VyIH0gZnJvbSBcInNoaWZ0LXJlZHVjZXJcIjtcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTWFwU3ludGF4UmVkdWNlciBleHRlbmRzIENsb25lUmVkdWNlciB7XG4gIGNvbnN0cnVjdG9yKGZuKSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLmZuID0gZm47XG4gIH1cblxuICByZWR1Y2VCaW5kaW5nSWRlbnRpZmllcihub2RlKSB7XG4gICAgbGV0IG5hbWUgPSB0aGlzLmZuKG5vZGUubmFtZSk7XG5cbiAgICByZXR1cm4gbmV3IFRlcm0oXCJCaW5kaW5nSWRlbnRpZmllclwiLCB7XG4gICAgICBuYW1lOiBuYW1lXG4gICAgfSk7XG4gIH1cblxuICByZWR1Y2VJZGVudGlmaWVyRXhwcmVzc2lvbihub2RlKSB7XG4gICAgbGV0IG5hbWUgPSB0aGlzLmZuKG5vZGUubmFtZSk7XG5cbiAgICByZXR1cm4gbmV3IFRlcm0oXCJJZGVudGlmaWVyRXhwcmVzc2lvblwiLCB7XG4gICAgICBuYW1lOiBuYW1lXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ== \ No newline at end of file diff --git a/dist/modules.js b/dist/modules.js index d3647a46..69d53b1c 100644 --- a/dist/modules.js +++ b/dist/modules.js @@ -19,23 +19,15 @@ var _shiftReader = require("./shift-reader"); var _shiftReader2 = _interopRequireDefault(_shiftReader); -var _tokenExpander = require("./token-expander.js"); - -var _tokenExpander2 = _interopRequireDefault(_tokenExpander); - -var _termExpander = require("./term-expander.js"); - -var _termExpander2 = _interopRequireDefault(_termExpander); - -var _bindingMap = require("./binding-map.js"); +var _ramda = require("ramda"); -var _bindingMap2 = _interopRequireDefault(_bindingMap); +var _ = _interopRequireWildcard(_ramda); var _symbol = require("./symbol"); var _terms = require("./terms"); -var _terms2 = _interopRequireDefault(_terms); +var T = _interopRequireWildcard(_terms); var _loadSyntax = require("./load-syntax"); @@ -57,180 +49,239 @@ var _utilsDirname = require("utils-dirname"); var _utilsDirname2 = _interopRequireDefault(_utilsDirname); -var _ramda = require("ramda"); - -var _ = _interopRequireWildcard(_ramda); - function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } -class Module_469 { - constructor(moduleSpecifier_474, isNative_475, importEntries_476, exportEntries_477, pragmas_478, body_479) { - this.moduleSpecifier = moduleSpecifier_474; - this.isNative = isNative_475; - this.importEntries = importEntries_476; - this.exportEntries = exportEntries_477; - this.pragmas = pragmas_478; - this.body = body_479; +class Module { + constructor(moduleSpecifier, isNative, importEntries, exportEntries, pragmas, body) { + this.moduleSpecifier = moduleSpecifier; + this.isNative = isNative; + this.importEntries = importEntries; + this.exportEntries = exportEntries; + this.pragmas = pragmas; + this.body = body; } } -const findBindingIdentifierName_470 = term_480 => { - (0, _errors.assert)(term_480.name, `not implemented yet for type ${ term_480.type }`); - return term_480.name; + +exports.Module = Module; +const findBindingIdentifierName = term => { + // TODO: handle destructuring + (0, _errors.assert)(term.name, `not implemented yet for type ${ term.type }`); + return term.name; }; -const convertExport_471 = term_481 => { - let declaration_482 = term_481.declaration; - let bindings_483 = []; - if ((0, _terms.isVariableDeclaration)(declaration_482)) { - bindings_483 = declaration_482.declarators.map(decl_485 => findBindingIdentifierName_470(decl_485.binding)); - } else if ((0, _terms.isFunctionDeclaration)(declaration_482) || (0, _terms.isClassDeclaration)(declaration_482)) { - bindings_483.push(findBindingIdentifierName_470(declaration_482.name)); + +const convertExport = term => { + let declaration = term.declaration; + let bindings = []; + if (T.isVariableDeclaration(declaration)) { + bindings = declaration.declarators.map(decl => findBindingIdentifierName(decl.binding)); + } else if (T.isFunctionDeclaration(declaration) || T.isClassDeclaration(declaration)) { + bindings.push(findBindingIdentifierName(declaration.name)); } - let namedExports_484 = bindings_483.map(binding_486 => { - return new _terms2.default("ExportSpecifier", { name: null, exportedName: binding_486 }); + + let namedExports = bindings.map(binding => { + return new T.default('ExportSpecifier', { + name: null, + exportedName: binding + }); + }); + return new T.default('ExportFrom', { + moduleSpecifier: null, + namedExports: (0, _immutable.List)(namedExports) }); - return new _terms2.default("ExportFrom", { moduleSpecifier: null, namedExports: (0, _immutable.List)(namedExports_484) }); }; -const pragmaRegep_472 = /^\s*#\w*/; -class Modules_473 { - constructor(context_487) { + +const pragmaRegep = /^\s*#\w*/; + +class Modules { + constructor(context) { this.compiledModules = new Map(); - this.context = context_487; + this.context = context; this.context.modules = this; } - loadString(str_488) { - let checkPragma_489 = arguments.length <= 1 || arguments[1] === undefined ? true : arguments[1]; - let hasPragma_490 = pragmaRegep_472.test(str_488); - if (checkPragma_489 && !hasPragma_490) { - return { isNative: true, body: (0, _immutable.List)() }; + loadString(str) { + let checkPragma = arguments.length <= 1 || arguments[1] === undefined ? true : arguments[1]; + + let hasPragma = pragmaRegep.test(str); + if (checkPragma && !hasPragma) { + return { + isNative: true, + body: (0, _immutable.List)() + }; } - return { isNative: !hasPragma_490, body: new _shiftReader2.default(str_488).read() }; + return { + isNative: !hasPragma, + body: new _shiftReader2.default(str).read() + }; } - load(path_491) { - return this.loadString(this.context.moduleLoader(path_491)); + + load(path) { + // TODO resolve and we need to carry the cwd through correctly + return this.loadString(this.context.moduleLoader(path)); } - compile(mod_492, path_493) { - let stxl_494 = mod_492.body; - let outScope_495 = (0, _scope.freshScope)("outsideEdge"); - let inScope_496 = (0, _scope.freshScope)(`insideEdge0`); - let compiler_497 = new _compiler2.default(0, new _env2.default(), new _store2.default(), _.merge(this.context, { currentScope: [outScope_495, inScope_496], cwd: path_493 === "<>" ? this.context.cwd : (0, _utilsDirname2.default)(path_493) })); - let terms_498 = compiler_497.compile(stxl_494.map(s_503 => s_503.addScope(outScope_495, this.context.bindings, _syntax.ALL_PHASES).addScope(inScope_496, this.context.bindings, 0))); - let importEntries_499 = []; - let exportEntries_500 = []; - let pragmas_501 = []; - let filteredTerms_502 = terms_498.reduce((acc_504, t_505) => { - return _.cond([[_terms.isImport, t_506 => { - importEntries_499.push(t_506); - return acc_504; - }], [_terms.isExport, t_507 => { - if (t_507.declaration) { - exportEntries_500.push(convertExport_471(t_507)); - if ((0, _terms.isVariableDeclaration)(t_507.declaration)) { - return acc_504.concat(new _terms2.default("VariableDeclarationStatement", { declaration: t_507.declaration })); + + compile(mod, path) { + let stxl = mod.body; + let outScope = (0, _scope.freshScope)('outsideEdge'); + let inScope = (0, _scope.freshScope)(`insideEdge0`); + // the compiler starts at phase 0, with an empty environment and store + let compiler = new _compiler2.default(0, new _env2.default(), new _store2.default(), _.merge(this.context, { + currentScope: [outScope, inScope], + cwd: path === '<>' ? this.context.cwd : (0, _utilsDirname2.default)(path) + })); + let terms = compiler.compile(stxl.map(s => s.addScope(outScope, this.context.bindings, _syntax.ALL_PHASES).addScope(inScope, this.context.bindings, 0))); + + let importEntries = []; + let exportEntries = []; + let pragmas = []; + let filteredTerms = terms.reduce((acc, t) => { + return _.cond([[T.isImport, t => { + importEntries.push(t); + return acc; + }], [T.isExport, t => { + // exportEntries.push(t); + // return acc.concat(t); + if (t.declaration) { + exportEntries.push(convertExport(t)); + if (T.isVariableDeclaration(t.declaration)) { + return acc.concat(new T.default('VariableDeclarationStatement', { + declaration: t.declaration + })); } - return acc_504.concat(t_507.declaration); + return acc.concat(t.declaration); } - exportEntries_500.push(t_507); - return acc_504; - }], [_terms.isPragma, t_508 => { - pragmas_501.push(t_508); - return acc_504; - }], [_.T, t_509 => acc_504.concat(t_509)]])(t_505); + exportEntries.push(t); + return acc; + }], [T.isPragma, t => { + pragmas.push(t);return acc; + }], [_.T, t => acc.concat(t)]])(t); }, (0, _immutable.List)()); - return new Module_469(path_493, mod_492.isNative, (0, _immutable.List)(importEntries_499), (0, _immutable.List)(exportEntries_500), (0, _immutable.List)(pragmas_501), filteredTerms_502); + return new Module(path, mod.isNative, (0, _immutable.List)(importEntries), (0, _immutable.List)(exportEntries), (0, _immutable.List)(pragmas), filteredTerms); } - compileEntrypoint(source_510, filename_511) { - let enforcePragma_512 = arguments.length <= 2 || arguments[2] === undefined ? false : arguments[2]; - let stxl_513 = this.loadString(source_510, false); - if (enforcePragma_512 && stxl_513.isNative) { - throw new Error(`Entrypoint ${ filename_511 } must begin with #lang pragma`); + compileEntrypoint(source, filename) { + let enforcePragma = arguments.length <= 2 || arguments[2] === undefined ? false : arguments[2]; + + let stxl = this.loadString(source, false); + if (enforcePragma && stxl.isNative) { + throw new Error(`Entrypoint ${ filename } must begin with #lang pragma`); } - return this.getAtPhase("<>", 0, this.context.cwd, stxl_513); + return this.getAtPhase('<>', 0, this.context.cwd, stxl); } - getAtPhase(rawPath_514, phase_515, cwd_516) { - let rawStxl_517 = arguments.length <= 3 || arguments[3] === undefined ? null : arguments[3]; - - let path_518 = rawPath_514 === "<>" ? rawPath_514 : this.context.moduleResolver(rawPath_514, cwd_516); - let mapKey_519 = `${ path_518 }:${ phase_515 }`; - if (!this.compiledModules.has(mapKey_519)) { - if (phase_515 === 0) { - let stxl = rawStxl_517 != null ? rawStxl_517 : this.load(path_518); - this.compiledModules.set(mapKey_519, this.compile(stxl, path_518)); + + // Modules have a unique scope per-phase. We compile each module once at + // phase 0 and store the compiled module in a map. Then, as we ask for + // the module in a particular phase, we add that new phase-specific scope + // to the compiled module and update the map with the module at that specific + // phase. + getAtPhase(rawPath, phase, cwd) { + let rawStxl = arguments.length <= 3 || arguments[3] === undefined ? null : arguments[3]; + + let path = rawPath === '<>' ? rawPath : this.context.moduleResolver(rawPath, cwd); + let mapKey = `${ path }:${ phase }`; + if (!this.compiledModules.has(mapKey)) { + if (phase === 0) { + let stxl = rawStxl != null ? rawStxl : this.load(path); + this.compiledModules.set(mapKey, this.compile(stxl, path)); } else { - let rawMod = this.getAtPhase(rawPath_514, 0, cwd_516, rawStxl_517); - let scope = (0, _scope.freshScope)(`insideEdge${ phase_515 }`); - this.compiledModules.set(mapKey_519, new Module_469(rawMod.moduleSpecifier, false, rawMod.importEntries.map(term_520 => term_520.addScope(scope, this.context.bindings, phase_515)), rawMod.exportEntries.map(term_521 => term_521.addScope(scope, this.context.bindings, phase_515)), rawMod.pragmas, rawMod.body.map(term_522 => term_522.addScope(scope, this.context.bindings, phase_515)))); + let rawMod = this.getAtPhase(rawPath, 0, cwd, rawStxl); + let scope = (0, _scope.freshScope)(`insideEdge${ phase }`); + this.compiledModules.set(mapKey, new Module(rawMod.moduleSpecifier, false, rawMod.importEntries.map(term => term.addScope(scope, this.context.bindings, phase)), rawMod.exportEntries.map(term => term.addScope(scope, this.context.bindings, phase)), rawMod.pragmas, rawMod.body.map(term => term.addScope(scope, this.context.bindings, phase)))); } } - return this.compiledModules.get(mapKey_519); + return this.compiledModules.get(mapKey); } - has(rawPath_523) { - let phase_524 = arguments.length <= 1 || arguments[1] === undefined ? 0 : arguments[1]; - let path_525 = rawPath_523 === "<>" ? rawPath_523 : this.context.moduleResolver(rawPath_523, this.context.cwd); - let key_526 = `${ path_525 }:${ phase_524 }`; - return this.compiledModules.has(key_526) && !this.compiledModules.get(key_526).isNative; + has(rawPath) { + let phase = arguments.length <= 1 || arguments[1] === undefined ? 0 : arguments[1]; + + let path = rawPath === '<>' ? rawPath : this.context.moduleResolver(rawPath, this.context.cwd); + let key = `${ path }:${ phase }`; + return this.compiledModules.has(key) && !this.compiledModules.get(key).isNative; } - registerSyntaxDeclaration(term_527, phase_528, store_529) { - term_527.declarators.forEach(decl_530 => { - let val_531 = (0, _loadSyntax.evalCompiletimeValue)(decl_530.init.gen(), _.merge(this.context, { phase: phase_528 + 1, store: store_529 })); - (0, _hygieneUtils.collectBindings)(decl_530.binding).forEach(stx_532 => { - if (phase_528 !== 0) { - let newBinding = (0, _symbol.gensym)(stx_532.val()); - this.context.bindings.add(stx_532, { binding: newBinding, phase: phase_528, skipDup: false }); + + registerSyntaxDeclaration(term, phase, store) { + term.declarators.forEach(decl => { + let val = (0, _loadSyntax.evalCompiletimeValue)(decl.init.gen(), _.merge(this.context, { + phase: phase + 1, store: store + })); + (0, _hygieneUtils.collectBindings)(decl.binding).forEach(stx => { + if (phase !== 0) { + // phase 0 bindings extend the binding map during compilation + let newBinding = (0, _symbol.gensym)(stx.val()); + this.context.bindings.add(stx, { + binding: newBinding, + phase: phase, + skipDup: false + }); } - let resolvedName_533 = stx_532.resolve(phase_528); - store_529.set(resolvedName_533, new _transforms.CompiletimeTransform(val_531)); + let resolvedName = stx.resolve(phase); + store.set(resolvedName, new _transforms.CompiletimeTransform(val)); }); }); } - registerVariableDeclaration(term_534, phase_535, store_536) { - term_534.declarators.forEach(decl_537 => { - (0, _hygieneUtils.collectBindings)(decl_537.binding).forEach(stx_538 => { - if (phase_535 !== 0) { - let newBinding = (0, _symbol.gensym)(stx_538.val()); - this.context.bindings.add(stx_538, { binding: newBinding, phase: phase_535, skipDup: term_534.kind === "var" }); + + registerVariableDeclaration(term, phase, store) { + term.declarators.forEach(decl => { + (0, _hygieneUtils.collectBindings)(decl.binding).forEach(stx => { + if (phase !== 0) { + // phase 0 bindings extend the binding map during compilation + let newBinding = (0, _symbol.gensym)(stx.val()); + this.context.bindings.add(stx, { + binding: newBinding, + phase: phase, + skipDup: term.kind === 'var' + }); } - let resolvedName_539 = stx_538.resolve(phase_535); - store_536.set(resolvedName_539, new _transforms.VarBindingTransform(stx_538)); + let resolvedName = stx.resolve(phase); + store.set(resolvedName, new _transforms.VarBindingTransform(stx)); }); }); } - registerFunctionOrClass(term_540, phase_541, store_542) { - (0, _hygieneUtils.collectBindings)(term_540.name).forEach(stx_543 => { - if (phase_541 !== 0) { - let newBinding = (0, _symbol.gensym)(stx_543.val()); - this.context.bindings.add(stx_543, { binding: newBinding, phase: phase_541, skipDup: false }); + + registerFunctionOrClass(term, phase, store) { + (0, _hygieneUtils.collectBindings)(term.name).forEach(stx => { + if (phase !== 0) { + let newBinding = (0, _symbol.gensym)(stx.val()); + this.context.bindings.add(stx, { + binding: newBinding, + phase: phase, + skipDup: false + }); } - let resolvedName_544 = stx_543.resolve(phase_541); - store_542.set(resolvedName_544, new _transforms.VarBindingTransform(stx_543)); + let resolvedName = stx.resolve(phase); + store.set(resolvedName, new _transforms.VarBindingTransform(stx)); }); } - visit(mod_545, phase_546, store_547) { - mod_545.body.forEach(term_548 => { - if ((0, _terms.isSyntaxDeclarationStatement)(term_548)) { - this.registerSyntaxDeclaration(term_548.declaration, phase_546, store_547); + + visit(mod, phase, store) { + // TODO: recursively visit imports + mod.body.forEach(term => { + if (T.isSyntaxDeclarationStatement(term)) { + this.registerSyntaxDeclaration(term.declaration, phase, store); } }); - return store_547; + return store; } - invoke(mod_549, phase_550, store_551) { - let body_552 = mod_549.body.filter(_.complement(_terms.isCompiletimeStatement)).map(term_554 => { - term_554 = term_554.gen(); - if ((0, _terms.isVariableDeclarationStatement)(term_554)) { - this.registerVariableDeclaration(term_554.declaration, phase_550, store_551); - } else if ((0, _terms.isFunctionDeclaration)(term_554)) { - this.registerFunctionOrClass(term_554, phase_550, store_551); + + invoke(mod, phase, store) { + // TODO: recursively visit imports + let body = mod.body.filter(_.complement(T.isCompiletimeStatement)).map(term => { + term = term.gen(); // TODO: can we remove the need for gen? have to deeply remove compiletime code + if (T.isVariableDeclarationStatement(term)) { + this.registerVariableDeclaration(term.declaration, phase, store); + } else if (T.isFunctionDeclaration(term)) { + this.registerFunctionOrClass(term, phase, store); } - return term_554; + return term; }); - let exportsObj_553 = (0, _loadSyntax.evalRuntimeValues)(body_552, _.merge(this.context, { store: store_551, phase: phase_550 })); - return store_551; + (0, _loadSyntax.evalRuntimeValues)(body, _.merge(this.context, { + store: store, phase: phase + })); + return store; } } -exports.Module = Module_469; -exports.Modules = Modules_473; -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/modules.js"],"names":[],"mappings":"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","file":"modules.js","sourcesContent":["import {List} from \"immutable\";\nimport Env from \"./env\";\nimport Store from \"./store\";\nimport Reader from \"./shift-reader\";\nimport TokenExpander from \"./token-expander.js\";\nimport TermExpander from \"./term-expander.js\";\nimport BindingMap from \"./binding-map.js\";\nimport {gensym} from \"./symbol\";\nimport Term, {isEOF, isBindingIdentifier, isFunctionDeclaration, isFunctionExpression, isFunctionTerm, isFunctionWithName, isSyntaxDeclaration, isSyntaxrecDeclaration, isVariableDeclaration, isVariableDeclarationStatement, isImport, isExport, isExportFrom, isExportAllFrom, isExportDefault, isExportSyntax, isSyntaxDeclarationStatement, isPragma, isCompiletimeDeclaration, isCompiletimeStatement, isClassDeclaration} from \"./terms\";\nimport {evalCompiletimeValue, evalRuntimeValues} from \"./load-syntax\";\nimport Compiler from \"./compiler\";\nimport {VarBindingTransform, CompiletimeTransform} from \"./transforms\";\nimport {Scope, freshScope} from \"./scope\";\nimport {assert} from \"./errors\";\nimport {collectBindings} from \"./hygiene-utils\";\nimport {ALL_PHASES} from \"./syntax\";\nimport dirname from \"utils-dirname\";\nimport  * as _ from \"ramda\";\nclass Module_469 {\n  constructor(moduleSpecifier_474, isNative_475, importEntries_476, exportEntries_477, pragmas_478, body_479) {\n    this.moduleSpecifier = moduleSpecifier_474;\n    this.isNative = isNative_475;\n    this.importEntries = importEntries_476;\n    this.exportEntries = exportEntries_477;\n    this.pragmas = pragmas_478;\n    this.body = body_479;\n  }\n}\nconst findBindingIdentifierName_470 = term_480 => {\n  assert(term_480.name, `not implemented yet for type ${term_480.type}`);\n  return term_480.name;\n};\nconst convertExport_471 = term_481 => {\n  let declaration_482 = term_481.declaration;\n  let bindings_483 = [];\n  if (isVariableDeclaration(declaration_482)) {\n    bindings_483 = declaration_482.declarators.map(decl_485 => findBindingIdentifierName_470(decl_485.binding));\n  } else if (isFunctionDeclaration(declaration_482) || isClassDeclaration(declaration_482)) {\n    bindings_483.push(findBindingIdentifierName_470(declaration_482.name));\n  }\n  let namedExports_484 = bindings_483.map(binding_486 => {\n    return new Term(\"ExportSpecifier\", {name: null, exportedName: binding_486});\n  });\n  return new Term(\"ExportFrom\", {moduleSpecifier: null, namedExports: List(namedExports_484)});\n};\nconst pragmaRegep_472 = /^\\s*#\\w*/;\nclass Modules_473 {\n  constructor(context_487) {\n    this.compiledModules = new Map;\n    this.context = context_487;\n    this.context.modules = this;\n  }\n  loadString(str_488, checkPragma_489 = true) {\n    let hasPragma_490 = pragmaRegep_472.test(str_488);\n    if (checkPragma_489 && !hasPragma_490) {\n      return {isNative: true, body: List()};\n    }\n    return {isNative: !hasPragma_490, body: new Reader(str_488).read()};\n  }\n  load(path_491) {\n    return this.loadString(this.context.moduleLoader(path_491));\n  }\n  compile(mod_492, path_493) {\n    let stxl_494 = mod_492.body;\n    let outScope_495 = freshScope(\"outsideEdge\");\n    let inScope_496 = freshScope(`insideEdge0`);\n    let compiler_497 = new Compiler(0, new Env, new Store, _.merge(this.context, {currentScope: [outScope_495, inScope_496], cwd: path_493 === \"<<entrypoint>>\" ? this.context.cwd : dirname(path_493)}));\n    let terms_498 = compiler_497.compile(stxl_494.map(s_503 => s_503.addScope(outScope_495, this.context.bindings, ALL_PHASES).addScope(inScope_496, this.context.bindings, 0)));\n    let importEntries_499 = [];\n    let exportEntries_500 = [];\n    let pragmas_501 = [];\n    let filteredTerms_502 = terms_498.reduce((acc_504, t_505) => {\n      return _.cond([[isImport, t_506 => {\n        importEntries_499.push(t_506);\n        return acc_504;\n      }], [isExport, t_507 => {\n        if (t_507.declaration) {\n          exportEntries_500.push(convertExport_471(t_507));\n          if (isVariableDeclaration(t_507.declaration)) {\n            return acc_504.concat(new Term(\"VariableDeclarationStatement\", {declaration: t_507.declaration}));\n          }\n          return acc_504.concat(t_507.declaration);\n        }\n        exportEntries_500.push(t_507);\n        return acc_504;\n      }], [isPragma, t_508 => {\n        pragmas_501.push(t_508);\n        return acc_504;\n      }], [_.T, t_509 => acc_504.concat(t_509)]])(t_505);\n    }, List());\n    return new Module_469(path_493, mod_492.isNative, List(importEntries_499), List(exportEntries_500), List(pragmas_501), filteredTerms_502);\n  }\n  compileEntrypoint(source_510, filename_511, enforcePragma_512 = false) {\n    let stxl_513 = this.loadString(source_510, false);\n    if (enforcePragma_512 && stxl_513.isNative) {\n      throw new Error(`Entrypoint ${filename_511} must begin with #lang pragma`);\n    }\n    return this.getAtPhase(\"<<entrypoint>>\", 0, this.context.cwd, stxl_513);\n  }\n  getAtPhase(rawPath_514, phase_515, cwd_516, rawStxl_517 = null) {\n    let path_518 = rawPath_514 === \"<<entrypoint>>\" ? rawPath_514 : this.context.moduleResolver(rawPath_514, cwd_516);\n    let mapKey_519 = `${path_518}:${phase_515}`;\n    if (!this.compiledModules.has(mapKey_519)) {\n      if (phase_515 === 0) {\n        let stxl = rawStxl_517 != null ? rawStxl_517 : this.load(path_518);\n        this.compiledModules.set(mapKey_519, this.compile(stxl, path_518));\n      } else {\n        let rawMod = this.getAtPhase(rawPath_514, 0, cwd_516, rawStxl_517);\n        let scope = freshScope(`insideEdge${phase_515}`);\n        this.compiledModules.set(mapKey_519, new Module_469(rawMod.moduleSpecifier, false, rawMod.importEntries.map(term_520 => term_520.addScope(scope, this.context.bindings, phase_515)), rawMod.exportEntries.map(term_521 => term_521.addScope(scope, this.context.bindings, phase_515)), rawMod.pragmas, rawMod.body.map(term_522 => term_522.addScope(scope, this.context.bindings, phase_515))));\n      }\n    }\n    return this.compiledModules.get(mapKey_519);\n  }\n  has(rawPath_523, phase_524 = 0) {\n    let path_525 = rawPath_523 === \"<<entrypoint>>\" ? rawPath_523 : this.context.moduleResolver(rawPath_523, this.context.cwd);\n    let key_526 = `${path_525}:${phase_524}`;\n    return this.compiledModules.has(key_526) && !this.compiledModules.get(key_526).isNative;\n  }\n  registerSyntaxDeclaration(term_527, phase_528, store_529) {\n    term_527.declarators.forEach(decl_530 => {\n      let val_531 = evalCompiletimeValue(decl_530.init.gen(), _.merge(this.context, {phase: phase_528 + 1, store: store_529}));\n      collectBindings(decl_530.binding).forEach(stx_532 => {\n        if (phase_528 !== 0) {\n          let newBinding = gensym(stx_532.val());\n          this.context.bindings.add(stx_532, {binding: newBinding, phase: phase_528, skipDup: false});\n        }\n        let resolvedName_533 = stx_532.resolve(phase_528);\n        store_529.set(resolvedName_533, new CompiletimeTransform(val_531));\n      });\n    });\n  }\n  registerVariableDeclaration(term_534, phase_535, store_536) {\n    term_534.declarators.forEach(decl_537 => {\n      collectBindings(decl_537.binding).forEach(stx_538 => {\n        if (phase_535 !== 0) {\n          let newBinding = gensym(stx_538.val());\n          this.context.bindings.add(stx_538, {binding: newBinding, phase: phase_535, skipDup: term_534.kind === \"var\"});\n        }\n        let resolvedName_539 = stx_538.resolve(phase_535);\n        store_536.set(resolvedName_539, new VarBindingTransform(stx_538));\n      });\n    });\n  }\n  registerFunctionOrClass(term_540, phase_541, store_542) {\n    collectBindings(term_540.name).forEach(stx_543 => {\n      if (phase_541 !== 0) {\n        let newBinding = gensym(stx_543.val());\n        this.context.bindings.add(stx_543, {binding: newBinding, phase: phase_541, skipDup: false});\n      }\n      let resolvedName_544 = stx_543.resolve(phase_541);\n      store_542.set(resolvedName_544, new VarBindingTransform(stx_543));\n    });\n  }\n  visit(mod_545, phase_546, store_547) {\n    mod_545.body.forEach(term_548 => {\n      if (isSyntaxDeclarationStatement(term_548)) {\n        this.registerSyntaxDeclaration(term_548.declaration, phase_546, store_547);\n      }\n    });\n    return store_547;\n  }\n  invoke(mod_549, phase_550, store_551) {\n    let body_552 = mod_549.body.filter(_.complement(isCompiletimeStatement)).map(term_554 => {\n      term_554 = term_554.gen();\n      if (isVariableDeclarationStatement(term_554)) {\n        this.registerVariableDeclaration(term_554.declaration, phase_550, store_551);\n      } else if (isFunctionDeclaration(term_554)) {\n        this.registerFunctionOrClass(term_554, phase_550, store_551);\n      }\n      return term_554;\n    });\n    let exportsObj_553 = evalRuntimeValues(body_552, _.merge(this.context, {store: store_551, phase: phase_550}));\n    return store_551;\n  }\n}\nexport {Module_469 as Module};\nexport {Modules_473 as Modules}"]} \ No newline at end of file +exports.Modules = Modules; +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/modules.js"],"names":[],"mappings":"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","file":"modules.js","sourcesContent":["import { List } from 'immutable';\nimport Env from \"./env\";\nimport Store from \"./store\";\nimport Reader from \"./shift-reader\";\nimport * as _ from \"ramda\";\nimport { gensym } from './symbol';\nimport Term, * as T from \"./terms\";\nimport { evalCompiletimeValue, evalRuntimeValues } from './load-syntax';\nimport Compiler from \"./compiler\";\nimport { VarBindingTransform, CompiletimeTransform } from './transforms';\nimport { freshScope } from \"./scope\";\nimport { assert } from './errors';\nimport { collectBindings } from './hygiene-utils';\n\nimport { ALL_PHASES } from './syntax';\n\nimport dirname from 'utils-dirname';\n\n\nexport class Module {\n  constructor(moduleSpecifier, isNative, importEntries, exportEntries, pragmas, body) {\n    this.moduleSpecifier = moduleSpecifier;\n    this.isNative = isNative;\n    this.importEntries = importEntries;\n    this.exportEntries = exportEntries;\n    this.pragmas = pragmas;\n    this.body = body;\n  }\n}\n\nconst findBindingIdentifierName = term => {\n  // TODO: handle destructuring\n  assert(term.name, `not implemented yet for type ${term.type}`);\n  return term.name;\n};\n\nconst convertExport = term => {\n  let declaration = term.declaration;\n  let bindings = [];\n  if (T.isVariableDeclaration(declaration)) {\n    bindings = declaration.declarators.map(decl =>  findBindingIdentifierName(decl.binding));\n  } else if (T.isFunctionDeclaration(declaration) || T.isClassDeclaration(declaration)) {\n    bindings.push(findBindingIdentifierName(declaration.name));\n  }\n\n  let namedExports = bindings.map(binding => {\n    return new Term('ExportSpecifier', {\n      name: null,\n      exportedName: binding\n    });\n  });\n  return new Term('ExportFrom', {\n    moduleSpecifier: null,\n    namedExports: List(namedExports)\n  });\n};\n\nconst pragmaRegep = /^\\s*#\\w*/;\n\nexport class Modules {\n  constructor(context) {\n    this.compiledModules = new Map();\n    this.context = context;\n    this.context.modules = this;\n  }\n\n  loadString(str, checkPragma = true) {\n    let hasPragma = pragmaRegep.test(str);\n    if (checkPragma && !hasPragma) {\n      return {\n        isNative: true,\n        body: List()\n      };\n    }\n    return {\n      isNative: !hasPragma,\n      body: new Reader(str).read()\n    };\n  }\n\n  load(path) {\n    // TODO resolve and we need to carry the cwd through correctly\n    return this.loadString(this.context.moduleLoader(path));\n  }\n\n  compile(mod, path) {\n    let stxl = mod.body;\n    let outScope = freshScope('outsideEdge');\n    let inScope = freshScope(`insideEdge0`);\n    // the compiler starts at phase 0, with an empty environment and store\n    let compiler = new Compiler(0, new Env(), new Store(), _.merge(this.context, {\n      currentScope: [outScope, inScope],\n      cwd: path === '<<entrypoint>>' ? this.context.cwd : dirname(path)\n    }));\n    let terms = compiler.compile(stxl.map(s =>\n      s.addScope(outScope, this.context.bindings, ALL_PHASES)\n       .addScope(inScope, this.context.bindings, 0)\n    ));\n\n    let importEntries = [];\n    let exportEntries = [];\n    let pragmas = [];\n    let filteredTerms = terms.reduce((acc, t) => {\n      return _.cond([\n        [T.isImport, t => {\n          importEntries.push(t);\n          return acc;\n        }],\n        [T.isExport, t => {\n          // exportEntries.push(t);\n          // return acc.concat(t);\n          if (t.declaration) {\n            exportEntries.push(convertExport(t));\n            if (T.isVariableDeclaration(t.declaration)) {\n              return acc.concat(new Term('VariableDeclarationStatement', {\n                declaration: t.declaration\n              }));\n            }\n            return acc.concat(t.declaration);\n          }\n          exportEntries.push(t);\n          return acc;\n        }],\n        [T.isPragma, t => { pragmas.push(t); return acc; } ],\n        [_.T, t => acc.concat(t) ]\n      ])(t);\n    }, List());\n    return new Module(\n      path,\n      mod.isNative,\n      List(importEntries),\n      List(exportEntries),\n      List(pragmas),\n      filteredTerms\n    );\n  }\n\n  compileEntrypoint(source, filename, enforcePragma = false) {\n    let stxl = this.loadString(source, false);\n    if (enforcePragma && stxl.isNative) {\n      throw new Error(`Entrypoint ${filename} must begin with #lang pragma`);\n    }\n    return this.getAtPhase('<<entrypoint>>', 0, this.context.cwd, stxl);\n  }\n\n  // Modules have a unique scope per-phase. We compile each module once at\n  // phase 0 and store the compiled module in a map. Then, as we ask for\n  // the module in a particular phase, we add that new phase-specific scope\n  // to the compiled module and update the map with the module at that specific\n  // phase.\n  getAtPhase(rawPath, phase, cwd, rawStxl = null) {\n    let path = rawPath === '<<entrypoint>>' ? rawPath : this.context.moduleResolver(rawPath, cwd);\n    let mapKey = `${path}:${phase}`;\n    if (!this.compiledModules.has(mapKey)) {\n      if (phase === 0) {\n        let stxl = rawStxl != null ? rawStxl : this.load(path);\n        this.compiledModules.set(mapKey, this.compile(stxl, path));\n      } else {\n        let rawMod = this.getAtPhase(rawPath, 0, cwd, rawStxl);\n        let scope = freshScope(`insideEdge${phase}`);\n        this.compiledModules.set(mapKey, new Module(\n          rawMod.moduleSpecifier,\n          false,\n          rawMod.importEntries.map(term => term.addScope(scope, this.context.bindings, phase)),\n          rawMod.exportEntries.map(term => term.addScope(scope, this.context.bindings, phase)),\n          rawMod.pragmas,\n          rawMod.body.map(term => term.addScope(scope, this.context.bindings, phase))\n        ));\n      }\n    }\n    return this.compiledModules.get(mapKey);\n  }\n\n  has(rawPath, phase = 0) {\n    let path = rawPath === '<<entrypoint>>' ? rawPath : this.context.moduleResolver(rawPath, this.context.cwd);\n    let key = `${path}:${phase}`;\n    return this.compiledModules.has(key) && !this.compiledModules.get(key).isNative;\n  }\n\n  registerSyntaxDeclaration(term, phase, store) {\n    term.declarators.forEach(decl => {\n      let val = evalCompiletimeValue(decl.init.gen(), _.merge(this.context, {\n        phase: phase + 1, store\n      }));\n      collectBindings(decl.binding).forEach(stx => {\n        if (phase !== 0) { // phase 0 bindings extend the binding map during compilation\n          let newBinding = gensym(stx.val());\n          this.context.bindings.add(stx, {\n            binding: newBinding,\n            phase: phase,\n            skipDup: false\n          });\n        }\n        let resolvedName = stx.resolve(phase);\n        store.set(resolvedName, new CompiletimeTransform(val));\n      });\n    });\n  }\n\n  registerVariableDeclaration(term, phase, store) {\n    term.declarators.forEach(decl => {\n      collectBindings(decl.binding).forEach(stx => {\n        if (phase !== 0) { // phase 0 bindings extend the binding map during compilation\n          let newBinding = gensym(stx.val());\n          this.context.bindings.add(stx, {\n            binding: newBinding,\n            phase: phase,\n            skipDup: term.kind === 'var'\n          });\n        }\n        let resolvedName = stx.resolve(phase);\n        store.set(resolvedName, new VarBindingTransform(stx));\n      });\n    });\n  }\n\n  registerFunctionOrClass(term, phase, store) {\n    collectBindings(term.name).forEach(stx => {\n      if (phase !== 0) {\n        let newBinding = gensym(stx.val());\n        this.context.bindings.add(stx, {\n          binding: newBinding,\n          phase: phase,\n          skipDup: false\n        });\n      }\n      let resolvedName = stx.resolve(phase);\n      store.set(resolvedName, new VarBindingTransform(stx));\n    });\n  }\n\n  visit(mod, phase, store) {\n    // TODO: recursively visit imports\n    mod.body.forEach(term => {\n      if (T.isSyntaxDeclarationStatement(term)) {\n        this.registerSyntaxDeclaration(term.declaration, phase, store);\n      }\n    });\n    return store;\n  }\n\n  invoke(mod, phase, store) {\n    // TODO: recursively visit imports\n    let body = mod.body.filter(_.complement(T.isCompiletimeStatement)).map(term => {\n      term = term.gen(); // TODO: can we remove the need for gen? have to deeply remove compiletime code\n      if (T.isVariableDeclarationStatement(term)) {\n        this.registerVariableDeclaration(term.declaration, phase, store);\n      } else if (T.isFunctionDeclaration(term)) {\n        this.registerFunctionOrClass(term, phase, store);\n      }\n      return term;\n    });\n    evalRuntimeValues(body, _.merge(this.context, {\n      store, phase\n    }));\n    return store;\n  }\n}\n"]} \ No newline at end of file diff --git a/dist/node-module-loader.js b/dist/node-module-loader.js index b6aedf95..d1a6f577 100644 --- a/dist/node-module-loader.js +++ b/dist/node-module-loader.js @@ -1,17 +1,17 @@ -"use strict"; +'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = moduleLoader; -var _fs = require("fs"); +var _fs = require('fs'); -function moduleLoader(path_555) { +function moduleLoader(path) { try { - return (0, _fs.readFileSync)(path_555, "utf8"); + return (0, _fs.readFileSync)(path, 'utf8'); } catch (e) { return ""; } } -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L25vZGUtbW9kdWxlLWxvYWRlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztrQkFDd0IsWTs7QUFEeEI7O0FBQ2UsU0FBUyxZQUFULENBQXNCLFFBQXRCLEVBQWdDO0FBQzdDLE1BQUk7QUFDRixXQUFPLHNCQUFhLFFBQWIsRUFBdUIsTUFBdkIsQ0FBUDtBQUNELEdBRkQsQ0FFRSxPQUFPLENBQVAsRUFBVTtBQUNWLFdBQU8sRUFBUDtBQUNEO0FBQ0YiLCJmaWxlIjoibm9kZS1tb2R1bGUtbG9hZGVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtyZWFkRmlsZVN5bmMsIHN0YXRTeW5jfSBmcm9tIFwiZnNcIjtcbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIG1vZHVsZUxvYWRlcihwYXRoXzU1NSkge1xuICB0cnkge1xuICAgIHJldHVybiByZWFkRmlsZVN5bmMocGF0aF81NTUsIFwidXRmOFwiKTtcbiAgfSBjYXRjaCAoZSkge1xuICAgIHJldHVybiBcIlwiO1xuICB9XG59XG4iXX0= \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ub2RlLW1vZHVsZS1sb2FkZXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7a0JBRXdCLFk7O0FBRnhCOztBQUVlLFNBQVMsWUFBVCxDQUFzQixJQUF0QixFQUE0QjtBQUN6QyxNQUFJO0FBQ0YsV0FBTyxzQkFBYSxJQUFiLEVBQW1CLE1BQW5CLENBQVA7QUFDRCxHQUZELENBRUUsT0FBTyxDQUFQLEVBQVU7QUFDVixXQUFPLEVBQVA7QUFDRDtBQUNGIiwiZmlsZSI6Im5vZGUtbW9kdWxlLWxvYWRlci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHJlYWRGaWxlU3luYyB9IGZyb20gJ2ZzJztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gbW9kdWxlTG9hZGVyKHBhdGgpIHtcbiAgdHJ5IHtcbiAgICByZXR1cm4gcmVhZEZpbGVTeW5jKHBhdGgsICd1dGY4Jyk7XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICByZXR1cm4gXCJcIjtcbiAgfVxufVxuIl19 \ No newline at end of file diff --git a/dist/node-module-resolver.js b/dist/node-module-resolver.js index 5c1e335c..3869a152 100644 --- a/dist/node-module-resolver.js +++ b/dist/node-module-resolver.js @@ -1,17 +1,17 @@ -"use strict"; +'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = resolveModule; -var _resolve = require("resolve"); +var _resolve = require('resolve'); var _resolve2 = _interopRequireDefault(_resolve); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } -function resolveModule(path_556, cwd_557) { - return _resolve2.default.sync(path_556, { basedir: cwd_557 }); +function resolveModule(path, cwd) { + return _resolve2.default.sync(path, { basedir: cwd }); } -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L25vZGUtbW9kdWxlLXJlc29sdmVyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O2tCQUN3QixhOztBQUR4Qjs7Ozs7O0FBQ2UsU0FBUyxhQUFULENBQXVCLFFBQXZCLEVBQWlDLE9BQWpDLEVBQTBDO0FBQ3ZELFNBQU8sa0JBQVEsSUFBUixDQUFhLFFBQWIsRUFBdUIsRUFBQyxTQUFTLE9BQVYsRUFBdkIsQ0FBUDtBQUNEIiwiZmlsZSI6Im5vZGUtbW9kdWxlLXJlc29sdmVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHJlc29sdmUgZnJvbSBcInJlc29sdmVcIjtcbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIHJlc29sdmVNb2R1bGUocGF0aF81NTYsIGN3ZF81NTcpIHtcbiAgcmV0dXJuIHJlc29sdmUuc3luYyhwYXRoXzU1Niwge2Jhc2VkaXI6IGN3ZF81NTd9KTtcbn1cbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ub2RlLW1vZHVsZS1yZXNvbHZlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztrQkFFd0IsYTs7QUFGeEI7Ozs7OztBQUVlLFNBQVMsYUFBVCxDQUF1QixJQUF2QixFQUE2QixHQUE3QixFQUFrQztBQUMvQyxTQUFPLGtCQUFRLElBQVIsQ0FBYSxJQUFiLEVBQW1CLEVBQUUsU0FBUyxHQUFYLEVBQW5CLENBQVA7QUFDRCIsImZpbGUiOiJub2RlLW1vZHVsZS1yZXNvbHZlci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCByZXNvbHZlIGZyb20gJ3Jlc29sdmUnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiByZXNvbHZlTW9kdWxlKHBhdGgsIGN3ZCkge1xuICByZXR1cm4gcmVzb2x2ZS5zeW5jKHBhdGgsIHsgYmFzZWRpcjogY3dkIH0pO1xufVxuIl19 \ No newline at end of file diff --git a/dist/operators.js b/dist/operators.js index 03b1155b..b8046153 100644 --- a/dist/operators.js +++ b/dist/operators.js @@ -1,36 +1,99 @@ -"use strict"; +'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); -const unaryOperators_558 = { "+": true, "-": true, "!": true, "~": true, "++": true, "--": true, typeof: true, void: true, delete: true }; -const binaryOperatorPrecedence_559 = { "*": 13, "/": 13, "%": 13, "+": 12, "-": 12, ">>": 11, "<<": 11, ">>>": 11, "<": 10, "<=": 10, ">": 10, ">=": 10, in: 10, instanceof: 10, "==": 9, "!=": 9, "===": 9, "!==": 9, "&": 8, "^": 7, "|": 6, "&&": 5, "||": 4 }; -var operatorAssoc_560 = { "*": "left", "/": "left", "%": "left", "+": "left", "-": "left", ">>": "left", "<<": "left", ">>>": "left", "<": "left", "<=": "left", ">": "left", ">=": "left", in: "left", instanceof: "left", "==": "left", "!=": "left", "===": "left", "!==": "left", "&": "left", "^": "left", "|": "left", "&&": "left", "||": "left" }; -function operatorLt_561(left_566, right_567, assoc_568) { - if (assoc_568 === "left") { - return left_566 < right_567; +exports.operatorLt = operatorLt; +exports.getOperatorPrec = getOperatorPrec; +exports.getOperatorAssoc = getOperatorAssoc; +exports.isUnaryOperator = isUnaryOperator; +exports.isOperator = isOperator; +const unaryOperators = { + '+': true, + '-': true, + '!': true, + '~': true, + '++': true, + '--': true, + 'typeof': true, + 'void': true, + 'delete': true +}; +const binaryOperatorPrecedence = { + "*": 13, + "/": 13, + "%": 13, + "+": 12, + "-": 12, + ">>": 11, + "<<": 11, + ">>>": 11, + "<": 10, + "<=": 10, + ">": 10, + ">=": 10, + "in": 10, + "instanceof": 10, + "==": 9, + "!=": 9, + "===": 9, + "!==": 9, + "&": 8, + "^": 7, + "|": 6, + "&&": 5, + "||": 4 +}; + +var operatorAssoc = { + "*": "left", + "/": "left", + "%": "left", + "+": "left", + "-": "left", + ">>": "left", + "<<": "left", + ">>>": "left", + "<": "left", + "<=": "left", + ">": "left", + ">=": "left", + "in": "left", + "instanceof": "left", + "==": "left", + "!=": "left", + "===": "left", + "!==": "left", + "&": "left", + "^": "left", + "|": "left", + "&&": "left", + "||": "left" +}; + +function operatorLt(left, right, assoc) { + if (assoc === "left") { + return left < right; } else { - return left_566 <= right_567; + return left <= right; } } -function getOperatorPrec_562(op_569) { - return binaryOperatorPrecedence_559[op_569]; + +function getOperatorPrec(op) { + return binaryOperatorPrecedence[op]; } -function getOperatorAssoc_563(op_570) { - return operatorAssoc_560[op_570]; +function getOperatorAssoc(op) { + return operatorAssoc[op]; } -function isUnaryOperator_564(op_571) { - return (op_571.match("punctuator") || op_571.match("identifier") || op_571.match("keyword")) && unaryOperators_558.hasOwnProperty(op_571.val()); + +function isUnaryOperator(op) { + return (op.match("punctuator") || op.match("identifier") || op.match("keyword")) && unaryOperators.hasOwnProperty(op.val()); } -function isOperator_565(op_572) { - if (op_572.match("punctuator") || op_572.match("identifier") || op_572.match("keyword")) { - return binaryOperatorPrecedence_559.hasOwnProperty(op_572) || unaryOperators_558.hasOwnProperty(op_572.val()); + +function isOperator(op) { + if (op.match("punctuator") || op.match("identifier") || op.match("keyword")) { + return binaryOperatorPrecedence.hasOwnProperty(op) || unaryOperators.hasOwnProperty(op.val()); } return false; } -exports.operatorLt = operatorLt_561; -exports.getOperatorPrec = getOperatorPrec_562; -exports.getOperatorAssoc = getOperatorAssoc_563; -exports.isUnaryOperator = isUnaryOperator_564; -exports.isOperator = isOperator_565; -//# sourceMappingURL=data:application/json;base64,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QixjO1FBQ3VCLGUsR0FBdkIsbUI7UUFDd0IsZ0IsR0FBeEIsb0I7UUFDdUIsZSxHQUF2QixtQjtRQUNrQixVLEdBQWxCLGMiLCJmaWxlIjoib3BlcmF0b3JzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgdW5hcnlPcGVyYXRvcnNfNTU4ID0ge1wiK1wiOiB0cnVlLCBcIi1cIjogdHJ1ZSwgXCIhXCI6IHRydWUsIFwiflwiOiB0cnVlLCBcIisrXCI6IHRydWUsIFwiLS1cIjogdHJ1ZSwgdHlwZW9mOiB0cnVlLCB2b2lkOiB0cnVlLCBkZWxldGU6IHRydWV9O1xuY29uc3QgYmluYXJ5T3BlcmF0b3JQcmVjZWRlbmNlXzU1OSA9IHtcIipcIjogMTMsIFwiL1wiOiAxMywgXCIlXCI6IDEzLCBcIitcIjogMTIsIFwiLVwiOiAxMiwgXCI+PlwiOiAxMSwgXCI8PFwiOiAxMSwgXCI+Pj5cIjogMTEsIFwiPFwiOiAxMCwgXCI8PVwiOiAxMCwgXCI+XCI6IDEwLCBcIj49XCI6IDEwLCBpbjogMTAsIGluc3RhbmNlb2Y6IDEwLCBcIj09XCI6IDksIFwiIT1cIjogOSwgXCI9PT1cIjogOSwgXCIhPT1cIjogOSwgXCImXCI6IDgsIFwiXlwiOiA3LCBcInxcIjogNiwgXCImJlwiOiA1LCBcInx8XCI6IDR9O1xudmFyIG9wZXJhdG9yQXNzb2NfNTYwID0ge1wiKlwiOiBcImxlZnRcIiwgXCIvXCI6IFwibGVmdFwiLCBcIiVcIjogXCJsZWZ0XCIsIFwiK1wiOiBcImxlZnRcIiwgXCItXCI6IFwibGVmdFwiLCBcIj4+XCI6IFwibGVmdFwiLCBcIjw8XCI6IFwibGVmdFwiLCBcIj4+PlwiOiBcImxlZnRcIiwgXCI8XCI6IFwibGVmdFwiLCBcIjw9XCI6IFwibGVmdFwiLCBcIj5cIjogXCJsZWZ0XCIsIFwiPj1cIjogXCJsZWZ0XCIsIGluOiBcImxlZnRcIiwgaW5zdGFuY2VvZjogXCJsZWZ0XCIsIFwiPT1cIjogXCJsZWZ0XCIsIFwiIT1cIjogXCJsZWZ0XCIsIFwiPT09XCI6IFwibGVmdFwiLCBcIiE9PVwiOiBcImxlZnRcIiwgXCImXCI6IFwibGVmdFwiLCBcIl5cIjogXCJsZWZ0XCIsIFwifFwiOiBcImxlZnRcIiwgXCImJlwiOiBcImxlZnRcIiwgXCJ8fFwiOiBcImxlZnRcIn07XG5mdW5jdGlvbiBvcGVyYXRvckx0XzU2MShsZWZ0XzU2NiwgcmlnaHRfNTY3LCBhc3NvY181NjgpIHtcbiAgaWYgKGFzc29jXzU2OCA9PT0gXCJsZWZ0XCIpIHtcbiAgICByZXR1cm4gbGVmdF81NjYgPCByaWdodF81Njc7XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIGxlZnRfNTY2IDw9IHJpZ2h0XzU2NztcbiAgfVxufVxuZnVuY3Rpb24gZ2V0T3BlcmF0b3JQcmVjXzU2MihvcF81NjkpIHtcbiAgcmV0dXJuIGJpbmFyeU9wZXJhdG9yUHJlY2VkZW5jZV81NTlbb3BfNTY5XTtcbn1cbmZ1bmN0aW9uIGdldE9wZXJhdG9yQXNzb2NfNTYzKG9wXzU3MCkge1xuICByZXR1cm4gb3BlcmF0b3JBc3NvY181NjBbb3BfNTcwXTtcbn1cbmZ1bmN0aW9uIGlzVW5hcnlPcGVyYXRvcl81NjQob3BfNTcxKSB7XG4gIHJldHVybiAob3BfNTcxLm1hdGNoKFwicHVuY3R1YXRvclwiKSB8fCBvcF81NzEubWF0Y2goXCJpZGVudGlmaWVyXCIpIHx8IG9wXzU3MS5tYXRjaChcImtleXdvcmRcIikpICYmIHVuYXJ5T3BlcmF0b3JzXzU1OC5oYXNPd25Qcm9wZXJ0eShvcF81NzEudmFsKCkpO1xufVxuZnVuY3Rpb24gaXNPcGVyYXRvcl81NjUob3BfNTcyKSB7XG4gIGlmIChvcF81NzIubWF0Y2goXCJwdW5jdHVhdG9yXCIpIHx8IG9wXzU3Mi5tYXRjaChcImlkZW50aWZpZXJcIikgfHwgb3BfNTcyLm1hdGNoKFwia2V5d29yZFwiKSkge1xuICAgIHJldHVybiBiaW5hcnlPcGVyYXRvclByZWNlZGVuY2VfNTU5Lmhhc093blByb3BlcnR5KG9wXzU3MikgfHwgdW5hcnlPcGVyYXRvcnNfNTU4Lmhhc093blByb3BlcnR5KG9wXzU3Mi52YWwoKSk7XG4gIH1cbiAgcmV0dXJuIGZhbHNlO1xufVxuZXhwb3J0IHtvcGVyYXRvckx0XzU2MSBhcyBvcGVyYXRvckx0fTtcbmV4cG9ydCB7Z2V0T3BlcmF0b3JQcmVjXzU2MiBhcyBnZXRPcGVyYXRvclByZWN9O1xuZXhwb3J0IHtnZXRPcGVyYXRvckFzc29jXzU2MyBhcyBnZXRPcGVyYXRvckFzc29jfTtcbmV4cG9ydCB7aXNVbmFyeU9wZXJhdG9yXzU2NCBhcyBpc1VuYXJ5T3BlcmF0b3J9O1xuZXhwb3J0IHtpc09wZXJhdG9yXzU2NSBhcyBpc09wZXJhdG9yfSJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,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eEMsS0FBK0MsZUFBZSxjQUFmLENBQThCLEdBQUcsR0FBSCxFQUE5QixDQUF0RDtBQUNEO0FBQ0QsU0FBTyxLQUFQO0FBQ0QiLCJmaWxlIjoib3BlcmF0b3JzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgdW5hcnlPcGVyYXRvcnMgPSB7XG4gICcrJzogdHJ1ZSxcbiAgJy0nOiB0cnVlLFxuICAnISc6IHRydWUsXG4gICd+JzogdHJ1ZSxcbiAgJysrJzogdHJ1ZSxcbiAgJy0tJzogdHJ1ZSxcbiAgJ3R5cGVvZic6IHRydWUsXG4gICd2b2lkJzogdHJ1ZSxcbiAgJ2RlbGV0ZSc6IHRydWUsXG59O1xuY29uc3QgYmluYXJ5T3BlcmF0b3JQcmVjZWRlbmNlID0ge1xuICBcIipcIjogMTMsXG4gIFwiL1wiOiAxMyxcbiAgXCIlXCI6IDEzLFxuICBcIitcIjogMTIsXG4gIFwiLVwiOiAxMixcbiAgXCI+PlwiOiAxMSxcbiAgXCI8PFwiOiAxMSxcbiAgXCI+Pj5cIjogMTEsXG4gIFwiPFwiOiAxMCxcbiAgXCI8PVwiOiAxMCxcbiAgXCI+XCI6IDEwLFxuICBcIj49XCI6IDEwLFxuICBcImluXCI6IDEwLFxuICBcImluc3RhbmNlb2ZcIjogMTAsXG4gIFwiPT1cIjogOSxcbiAgXCIhPVwiOiA5LFxuICBcIj09PVwiOiA5LFxuICBcIiE9PVwiOiA5LFxuICBcIiZcIjogOCxcbiAgXCJeXCI6IDcsXG4gIFwifFwiOiA2LFxuICBcIiYmXCI6IDUsXG4gIFwifHxcIjogNCxcbn07XG5cbnZhciBvcGVyYXRvckFzc29jID0ge1xuICBcIipcIjogXCJsZWZ0XCIsXG4gIFwiL1wiOiBcImxlZnRcIixcbiAgXCIlXCI6IFwibGVmdFwiLFxuICBcIitcIjogXCJsZWZ0XCIsXG4gIFwiLVwiOiBcImxlZnRcIixcbiAgXCI+PlwiOiBcImxlZnRcIixcbiAgXCI8PFwiOiBcImxlZnRcIixcbiAgXCI+Pj5cIjogXCJsZWZ0XCIsXG4gIFwiPFwiOiBcImxlZnRcIixcbiAgXCI8PVwiOiBcImxlZnRcIixcbiAgXCI+XCI6IFwibGVmdFwiLFxuICBcIj49XCI6IFwibGVmdFwiLFxuICBcImluXCI6IFwibGVmdFwiLFxuICBcImluc3RhbmNlb2ZcIjogXCJsZWZ0XCIsXG4gIFwiPT1cIjogXCJsZWZ0XCIsXG4gIFwiIT1cIjogXCJsZWZ0XCIsXG4gIFwiPT09XCI6IFwibGVmdFwiLFxuICBcIiE9PVwiOiBcImxlZnRcIixcbiAgXCImXCI6IFwibGVmdFwiLFxuICBcIl5cIjogXCJsZWZ0XCIsXG4gIFwifFwiOiBcImxlZnRcIixcbiAgXCImJlwiOiBcImxlZnRcIixcbiAgXCJ8fFwiOiBcImxlZnRcIixcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBvcGVyYXRvckx0KGxlZnQsIHJpZ2h0LCBhc3NvYykge1xuICBpZiAoYXNzb2MgPT09IFwibGVmdFwiKSB7XG4gICAgcmV0dXJuIGxlZnQgPCByaWdodDtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gbGVmdCA8PSByaWdodDtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0T3BlcmF0b3JQcmVjKG9wKSB7XG4gIHJldHVybiBiaW5hcnlPcGVyYXRvclByZWNlZGVuY2Vbb3BdO1xufVxuZXhwb3J0IGZ1bmN0aW9uIGdldE9wZXJhdG9yQXNzb2Mob3ApIHtcbiAgcmV0dXJuIG9wZXJhdG9yQXNzb2Nbb3BdO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNVbmFyeU9wZXJhdG9yKG9wKSB7XG4gIHJldHVybiAob3AubWF0Y2goXCJwdW5jdHVhdG9yXCIpIHx8IG9wLm1hdGNoKFwiaWRlbnRpZmllclwiKSB8fCBvcC5tYXRjaChcImtleXdvcmRcIikpICYmXG4gICAgICAgIHVuYXJ5T3BlcmF0b3JzLmhhc093blByb3BlcnR5KG9wLnZhbCgpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzT3BlcmF0b3Iob3ApIHtcbiAgaWYgKG9wLm1hdGNoKFwicHVuY3R1YXRvclwiKSB8fCBvcC5tYXRjaChcImlkZW50aWZpZXJcIikgfHwgb3AubWF0Y2goXCJrZXl3b3JkXCIpKSB7XG4gICAgcmV0dXJuIGJpbmFyeU9wZXJhdG9yUHJlY2VkZW5jZS5oYXNPd25Qcm9wZXJ0eShvcCkgfHwgdW5hcnlPcGVyYXRvcnMuaGFzT3duUHJvcGVydHkob3AudmFsKCkpO1xuICB9XG4gIHJldHVybiBmYWxzZTtcbn1cbiJdfQ== \ No newline at end of file diff --git a/dist/parse-reducer.js b/dist/parse-reducer.js index 0251d0d8..3945ab94 100644 --- a/dist/parse-reducer.js +++ b/dist/parse-reducer.js @@ -13,90 +13,170 @@ var _shiftReducer = require("shift-reducer"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } class ParseReducer extends _shiftReducer.CloneReducer { - constructor(context_573) { + constructor(context) { super(); - this.context = context_573; + this.context = context; } - reduceModule(node_574, state_575) { - return new _terms2.default("Module", { directives: state_575.directives.toArray(), items: state_575.items.toArray() }); + reduceModule(node, state) { + return new _terms2.default("Module", { + directives: state.directives.toArray(), + items: state.items.toArray() + }); } - reduceImport(node_576, state_577) { - let moduleSpecifier_578 = state_577.moduleSpecifier ? state_577.moduleSpecifier.val() : null; - return new _terms2.default("Import", { defaultBinding: state_577.defaultBinding, namedImports: state_577.namedImports.toArray(), moduleSpecifier: moduleSpecifier_578, forSyntax: node_576.forSyntax }); + + reduceImport(node, state) { + let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null; + return new _terms2.default('Import', { + defaultBinding: state.defaultBinding, + namedImports: state.namedImports.toArray(), + moduleSpecifier: moduleSpecifier, + forSyntax: node.forSyntax + }); } - reduceImportNamespace(node_579, state_580) { - let moduleSpecifier_581 = state_580.moduleSpecifier ? state_580.moduleSpecifier.val() : null; - return new _terms2.default("ImportNamespace", { defaultBinding: state_580.defaultBinding, namespaceBinding: state_580.namespaceBinding, moduleSpecifier: moduleSpecifier_581, forSyntax: node_579.forSyntax }); + + reduceImportNamespace(node, state) { + let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null; + return new _terms2.default('ImportNamespace', { + defaultBinding: state.defaultBinding, + namespaceBinding: state.namespaceBinding, + moduleSpecifier: moduleSpecifier, + forSyntax: node.forSyntax + }); } - reduceExport(node_582, state_583) { - return new _terms2.default("Export", { declaration: state_583.declaration }); + + reduceExport(node, state) { + return new _terms2.default('Export', { + declaration: state.declaration + }); } - reduceExportAllFrom(node_584, state_585) { - let moduleSpecifier_586 = state_585.moduleSpecifier ? state_585.moduleSpecifier.val() : null; - return new _terms2.default("ExportAllFrom", { moduleSpecifier: moduleSpecifier_586 }); + + reduceExportAllFrom(node, state) { + let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null; + return new _terms2.default('ExportAllFrom', { moduleSpecifier: moduleSpecifier }); } - reduceExportFrom(node_587, state_588) { - let moduleSpecifier_589 = state_588.moduleSpecifier ? state_588.moduleSpecifier.val() : null; - return new _terms2.default("ExportFrom", { moduleSpecifier: moduleSpecifier_589, namedExports: state_588.namedExports.toArray() }); + + reduceExportFrom(node, state) { + let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null; + return new _terms2.default('ExportFrom', { + moduleSpecifier: moduleSpecifier, + namedExports: state.namedExports.toArray() + }); } - reduceExportSpecifier(node_590, state_591) { - let name_592 = state_591.name, - exportedName_593 = state_591.exportedName; - if (name_592 == null) { - name_592 = exportedName_593.resolve(this.context.phase); - exportedName_593 = exportedName_593.val(); + + reduceExportSpecifier(node, state) { + let name = state.name, + exportedName = state.exportedName; + if (name == null) { + name = exportedName.resolve(this.context.phase); + exportedName = exportedName.val(); } else { - name_592 = name_592.resolve(this.context.phase); - exportedName_593 = exportedName_593.val(); + name = name.resolve(this.context.phase); + exportedName = exportedName.val(); } - return new _terms2.default("ExportSpecifier", { name: name_592, exportedName: exportedName_593 }); + return new _terms2.default('ExportSpecifier', { + name: name, exportedName: exportedName + }); } - reduceImportSpecifier(node_594, state_595) { - let name_596 = state_595.name ? state_595.name.resolve(this.context.phase) : null; - return new _terms2.default("ImportSpecifier", { name: name_596, binding: state_595.binding }); + + reduceImportSpecifier(node, state) { + let name = state.name ? state.name.resolve(this.context.phase) : null; + return new _terms2.default('ImportSpecifier', { + name: name, + binding: state.binding + }); } - reduceIdentifierExpression(node_597, state_598) { - return new _terms2.default("IdentifierExpression", { name: node_597.name.resolve(this.context.phase) }); + + reduceIdentifierExpression(node) { + return new _terms2.default("IdentifierExpression", { + name: node.name.resolve(this.context.phase) + }); } - reduceLiteralNumericExpression(node_599, state_600) { - return new _terms2.default("LiteralNumericExpression", { value: node_599.value.val() }); + + reduceLiteralNumericExpression(node) { + return new _terms2.default("LiteralNumericExpression", { + value: node.value.val() + }); } - reduceLiteralBooleanExpression(node_601, state_602) { - return new _terms2.default("LiteralBooleanExpression", { value: node_601.value.val() === "true" }); + + reduceLiteralBooleanExpression(node) { + return new _terms2.default("LiteralBooleanExpression", { + value: node.value.val() === 'true' + }); } - reduceLiteralStringExpression(node_603, state_604) { - return new _terms2.default("LiteralStringExpression", { value: node_603.value.token.str }); + + reduceLiteralStringExpression(node) { + return new _terms2.default("LiteralStringExpression", { + value: node.value.token.str + }); } - reduceCallExpression(node_605, state_606) { - return new _terms2.default("CallExpression", { callee: state_606.callee, arguments: state_606.arguments.toArray() }); + + reduceCallExpression(node, state) { + return new _terms2.default("CallExpression", { + callee: state.callee, + arguments: state.arguments.toArray() + }); } - reduceFunctionBody(node_607, state_608) { - return new _terms2.default("FunctionBody", { directives: state_608.directives.toArray(), statements: state_608.statements.toArray() }); + + reduceFunctionBody(node, state) { + return new _terms2.default("FunctionBody", { + directives: state.directives.toArray(), + statements: state.statements.toArray() + }); } - reduceFormalParameters(node_609, state_610) { - return new _terms2.default("FormalParameters", { items: state_610.items.toArray(), rest: state_610.rest }); + + reduceFormalParameters(node, state) { + return new _terms2.default("FormalParameters", { + items: state.items.toArray(), + rest: state.rest + }); } - reduceBindingIdentifier(node_611, state_612) { - return new _terms2.default("BindingIdentifier", { name: node_611.name.resolve(this.context.phase) }); + + reduceBindingIdentifier(node) { + return new _terms2.default("BindingIdentifier", { + name: node.name.resolve(this.context.phase) + }); } - reduceBinaryExpression(node_613, state_614) { - return new _terms2.default("BinaryExpression", { left: state_614.left, operator: node_613.operator.val(), right: state_614.right }); + + reduceBinaryExpression(node, state) { + return new _terms2.default("BinaryExpression", { + left: state.left, + operator: node.operator.val(), + right: state.right + }); } - reduceObjectExpression(node_615, state_616) { - return new _terms2.default("ObjectExpression", { properties: state_616.properties.toArray() }); + + reduceObjectExpression(node, state) { + return new _terms2.default("ObjectExpression", { + properties: state.properties.toArray() + }); } - reduceVariableDeclaration(node_617, state_618) { - return new _terms2.default("VariableDeclaration", { kind: state_618.kind, declarators: state_618.declarators.toArray() }); + + reduceVariableDeclaration(node, state) { + return new _terms2.default("VariableDeclaration", { + kind: state.kind, + declarators: state.declarators.toArray() + }); } - reduceStaticPropertyName(node_619, state_620) { - return new _terms2.default("StaticPropertyName", { value: node_619.value.val().toString() }); + + reduceStaticPropertyName(node) { + return new _terms2.default("StaticPropertyName", { + value: node.value.val().toString() + }); } - reduceArrayExpression(node_621, state_622) { - return new _terms2.default("ArrayExpression", { elements: state_622.elements.toArray() }); + + reduceArrayExpression(node, state) { + return new _terms2.default("ArrayExpression", { + elements: state.elements.toArray() + }); } - reduceStaticMemberExpression(node_623, state_624) { - return new _terms2.default("StaticMemberExpression", { object: state_624.object, property: state_624.property.val() }); + + reduceStaticMemberExpression(node, state) { + return new _terms2.default("StaticMemberExpression", { + object: state.object, + property: state.property.val() + }); } + } exports.default = ParseReducer; -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/parse-reducer.js"],"names":[],"mappings":"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","file":"parse-reducer.js","sourcesContent":["import Term from \"./terms\";\nimport {CloneReducer} from \"shift-reducer\";\nexport default class ParseReducer extends CloneReducer {\n  constructor(context_573) {\n    super();\n    this.context = context_573;\n  }\n  reduceModule(node_574, state_575) {\n    return new Term(\"Module\", {directives: state_575.directives.toArray(), items: state_575.items.toArray()});\n  }\n  reduceImport(node_576, state_577) {\n    let moduleSpecifier_578 = state_577.moduleSpecifier ? state_577.moduleSpecifier.val() : null;\n    return new Term(\"Import\", {defaultBinding: state_577.defaultBinding, namedImports: state_577.namedImports.toArray(), moduleSpecifier: moduleSpecifier_578, forSyntax: node_576.forSyntax});\n  }\n  reduceImportNamespace(node_579, state_580) {\n    let moduleSpecifier_581 = state_580.moduleSpecifier ? state_580.moduleSpecifier.val() : null;\n    return new Term(\"ImportNamespace\", {defaultBinding: state_580.defaultBinding, namespaceBinding: state_580.namespaceBinding, moduleSpecifier: moduleSpecifier_581, forSyntax: node_579.forSyntax});\n  }\n  reduceExport(node_582, state_583) {\n    return new Term(\"Export\", {declaration: state_583.declaration});\n  }\n  reduceExportAllFrom(node_584, state_585) {\n    let moduleSpecifier_586 = state_585.moduleSpecifier ? state_585.moduleSpecifier.val() : null;\n    return new Term(\"ExportAllFrom\", {moduleSpecifier: moduleSpecifier_586});\n  }\n  reduceExportFrom(node_587, state_588) {\n    let moduleSpecifier_589 = state_588.moduleSpecifier ? state_588.moduleSpecifier.val() : null;\n    return new Term(\"ExportFrom\", {moduleSpecifier: moduleSpecifier_589, namedExports: state_588.namedExports.toArray()});\n  }\n  reduceExportSpecifier(node_590, state_591) {\n    let name_592 = state_591.name, exportedName_593 = state_591.exportedName;\n    if (name_592 == null) {\n      name_592 = exportedName_593.resolve(this.context.phase);\n      exportedName_593 = exportedName_593.val();\n    } else {\n      name_592 = name_592.resolve(this.context.phase);\n      exportedName_593 = exportedName_593.val();\n    }\n    return new Term(\"ExportSpecifier\", {name: name_592, exportedName: exportedName_593});\n  }\n  reduceImportSpecifier(node_594, state_595) {\n    let name_596 = state_595.name ? state_595.name.resolve(this.context.phase) : null;\n    return new Term(\"ImportSpecifier\", {name: name_596, binding: state_595.binding});\n  }\n  reduceIdentifierExpression(node_597, state_598) {\n    return new Term(\"IdentifierExpression\", {name: node_597.name.resolve(this.context.phase)});\n  }\n  reduceLiteralNumericExpression(node_599, state_600) {\n    return new Term(\"LiteralNumericExpression\", {value: node_599.value.val()});\n  }\n  reduceLiteralBooleanExpression(node_601, state_602) {\n    return new Term(\"LiteralBooleanExpression\", {value: node_601.value.val() === \"true\"});\n  }\n  reduceLiteralStringExpression(node_603, state_604) {\n    return new Term(\"LiteralStringExpression\", {value: node_603.value.token.str});\n  }\n  reduceCallExpression(node_605, state_606) {\n    return new Term(\"CallExpression\", {callee: state_606.callee, arguments: state_606.arguments.toArray()});\n  }\n  reduceFunctionBody(node_607, state_608) {\n    return new Term(\"FunctionBody\", {directives: state_608.directives.toArray(), statements: state_608.statements.toArray()});\n  }\n  reduceFormalParameters(node_609, state_610) {\n    return new Term(\"FormalParameters\", {items: state_610.items.toArray(), rest: state_610.rest});\n  }\n  reduceBindingIdentifier(node_611, state_612) {\n    return new Term(\"BindingIdentifier\", {name: node_611.name.resolve(this.context.phase)});\n  }\n  reduceBinaryExpression(node_613, state_614) {\n    return new Term(\"BinaryExpression\", {left: state_614.left, operator: node_613.operator.val(), right: state_614.right});\n  }\n  reduceObjectExpression(node_615, state_616) {\n    return new Term(\"ObjectExpression\", {properties: state_616.properties.toArray()});\n  }\n  reduceVariableDeclaration(node_617, state_618) {\n    return new Term(\"VariableDeclaration\", {kind: state_618.kind, declarators: state_618.declarators.toArray()});\n  }\n  reduceStaticPropertyName(node_619, state_620) {\n    return new Term(\"StaticPropertyName\", {value: node_619.value.val().toString()});\n  }\n  reduceArrayExpression(node_621, state_622) {\n    return new Term(\"ArrayExpression\", {elements: state_622.elements.toArray()});\n  }\n  reduceStaticMemberExpression(node_623, state_624) {\n    return new Term(\"StaticMemberExpression\", {object: state_624.object, property: state_624.property.val()});\n  }\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/parse-reducer.js"],"names":[],"mappings":"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","file":"parse-reducer.js","sourcesContent":["import Term from \"./terms\";\nimport { CloneReducer } from \"shift-reducer\";\n\nexport default class ParseReducer extends CloneReducer {\n  constructor(context) {\n    super();\n    this.context = context;\n  }\n  reduceModule(node, state) {\n    return new Term(\"Module\", {\n      directives: state.directives.toArray(),\n      items: state.items.toArray()\n    });\n  }\n\n  reduceImport(node, state) {\n    let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null;\n    return new Term('Import', {\n      defaultBinding: state.defaultBinding,\n      namedImports: state.namedImports.toArray(),\n      moduleSpecifier,\n      forSyntax: node.forSyntax\n    });\n  }\n\n  reduceImportNamespace(node, state) {\n    let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null;\n    return new Term('ImportNamespace', {\n      defaultBinding: state.defaultBinding,\n      namespaceBinding: state.namespaceBinding,\n      moduleSpecifier,\n      forSyntax: node.forSyntax\n    });\n  }\n\n  reduceExport(node, state) {\n    return new Term('Export', {\n      declaration: state.declaration\n    });\n  }\n\n  reduceExportAllFrom(node, state) {\n    let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null;\n    return new Term('ExportAllFrom', { moduleSpecifier });\n  }\n\n  reduceExportFrom(node, state) {\n    let moduleSpecifier = state.moduleSpecifier ? state.moduleSpecifier.val() : null;\n    return new Term('ExportFrom', {\n      moduleSpecifier,\n      namedExports: state.namedExports.toArray()\n    });\n  }\n\n  reduceExportSpecifier(node, state) {\n    let name = state.name, exportedName = state.exportedName;\n    if (name == null) {\n      name = exportedName.resolve(this.context.phase);\n      exportedName = exportedName.val();\n    } else {\n      name = name.resolve(this.context.phase);\n      exportedName = exportedName.val();\n    }\n    return new Term('ExportSpecifier', {\n      name, exportedName\n    });\n  }\n\n  reduceImportSpecifier(node, state) {\n    let name = state.name ? state.name.resolve(this.context.phase) : null;\n    return new Term('ImportSpecifier', {\n      name,\n      binding: state.binding\n    });\n  }\n\n  reduceIdentifierExpression(node) {\n    return new Term(\"IdentifierExpression\", {\n      name: node.name.resolve(this.context.phase)\n    });\n  }\n\n  reduceLiteralNumericExpression(node) {\n    return new Term(\"LiteralNumericExpression\", {\n      value: node.value.val()\n    });\n  }\n\n  reduceLiteralBooleanExpression(node) {\n    return new Term(\"LiteralBooleanExpression\", {\n      value: node.value.val() === 'true'\n    });\n  }\n\n  reduceLiteralStringExpression(node) {\n    return new Term(\"LiteralStringExpression\", {\n      value: node.value.token.str\n    });\n  }\n\n  reduceCallExpression(node, state) {\n    return new Term(\"CallExpression\", {\n      callee: state.callee,\n      arguments: state.arguments.toArray()\n    });\n  }\n\n  reduceFunctionBody(node, state) {\n    return new Term(\"FunctionBody\", {\n      directives: state.directives.toArray(),\n      statements: state.statements.toArray()\n    });\n  }\n\n  reduceFormalParameters(node, state) {\n    return new Term(\"FormalParameters\", {\n      items: state.items.toArray(),\n      rest: state.rest\n    });\n  }\n\n  reduceBindingIdentifier(node) {\n    return new Term(\"BindingIdentifier\", {\n      name: node.name.resolve(this.context.phase)\n    });\n  }\n\n  reduceBinaryExpression(node, state) {\n    return new Term(\"BinaryExpression\", {\n      left: state.left,\n      operator: node.operator.val(),\n      right: state.right\n    });\n  }\n\n  reduceObjectExpression(node, state) {\n    return new Term(\"ObjectExpression\", {\n      properties: state.properties.toArray()\n    });\n  }\n\n  reduceVariableDeclaration(node, state) {\n    return new Term(\"VariableDeclaration\", {\n      kind: state.kind,\n      declarators: state.declarators.toArray()\n    });\n  }\n\n  reduceStaticPropertyName(node) {\n    return new Term(\"StaticPropertyName\", {\n      value: node.value.val().toString()\n    });\n  }\n\n  reduceArrayExpression(node, state) {\n    return new Term(\"ArrayExpression\", {\n      elements: state.elements.toArray()\n    });\n  }\n\n  reduceStaticMemberExpression(node, state) {\n    return new Term(\"StaticMemberExpression\", {\n      object: state.object,\n      property: state.property.val()\n    });\n  }\n\n}\n"]} \ No newline at end of file diff --git a/dist/scope.js b/dist/scope.js index 00b53e61..0c4d7784 100644 --- a/dist/scope.js +++ b/dist/scope.js @@ -3,23 +3,21 @@ Object.defineProperty(exports, "__esModule", { value: true }); -exports.Scope = exports.freshScope = undefined; - -var _errors = require("./errors"); +exports.freshScope = freshScope; +exports.Scope = Scope; var _symbol = require("./symbol"); -let scopeIndex_625 = 0; -function freshScope_626() { - let name_628 = arguments.length <= 0 || arguments[0] === undefined ? "scope" : arguments[0]; +let scopeIndex = 0; + +function freshScope() { + let name = arguments.length <= 0 || arguments[0] === undefined ? "scope" : arguments[0]; - scopeIndex_625++; - return (0, _symbol.Symbol)(name_628 + "_" + scopeIndex_625); + scopeIndex++; + return (0, _symbol.Symbol)(name + "_" + scopeIndex); } -; -function Scope_627(name_629) { - return (0, _symbol.Symbol)(name_629); + +function Scope(name) { + return (0, _symbol.Symbol)(name); } -exports.freshScope = freshScope_626; -exports.Scope = Scope_627; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L3Njb3BlLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQSxJQUFJLGlCQUFpQixDQUFyQjtBQUNBLFNBQVMsY0FBVCxHQUE0QztBQUFBLE1BQXBCLFFBQW9CLHlEQUFULE9BQVM7O0FBQzFDO0FBQ0EsU0FBTyxvQkFBTyxXQUFXLEdBQVgsR0FBaUIsY0FBeEIsQ0FBUDtBQUNEO0FBQ0Q7QUFDQSxTQUFTLFNBQVQsQ0FBbUIsUUFBbkIsRUFBNkI7QUFDM0IsU0FBTyxvQkFBTyxRQUFQLENBQVA7QUFDRDtRQUN5QixVLEdBQWxCLGM7UUFDYSxLLEdBQWIsUyIsImZpbGUiOiJzY29wZS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7ZXhwZWN0LCBhc3NlcnR9IGZyb20gXCIuL2Vycm9yc1wiO1xuaW1wb3J0IHtTeW1ib2wsIGdlbnN5bX0gZnJvbSBcIi4vc3ltYm9sXCI7XG5sZXQgc2NvcGVJbmRleF82MjUgPSAwO1xuZnVuY3Rpb24gZnJlc2hTY29wZV82MjYobmFtZV82MjggPSBcInNjb3BlXCIpIHtcbiAgc2NvcGVJbmRleF82MjUrKztcbiAgcmV0dXJuIFN5bWJvbChuYW1lXzYyOCArIFwiX1wiICsgc2NvcGVJbmRleF82MjUpO1xufVxuO1xuZnVuY3Rpb24gU2NvcGVfNjI3KG5hbWVfNjI5KSB7XG4gIHJldHVybiBTeW1ib2wobmFtZV82MjkpO1xufVxuZXhwb3J0IHtmcmVzaFNjb3BlXzYyNiBhcyBmcmVzaFNjb3BlfTtcbmV4cG9ydCB7U2NvcGVfNjI3IGFzIFNjb3BlfSJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY29wZS5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztRQUlnQixVLEdBQUEsVTtRQUtBLEssR0FBQSxLOztBQVRoQjs7QUFFQSxJQUFJLGFBQWEsQ0FBakI7O0FBRU8sU0FBUyxVQUFULEdBQW9DO0FBQUEsTUFBaEIsSUFBZ0IseURBQVQsT0FBUzs7QUFDekM7QUFDQSxTQUFPLG9CQUFPLE9BQU8sR0FBUCxHQUFhLFVBQXBCLENBQVA7QUFDRDs7QUFFTSxTQUFTLEtBQVQsQ0FBZSxJQUFmLEVBQXFCO0FBQzFCLFNBQU8sb0JBQU8sSUFBUCxDQUFQO0FBQ0QiLCJmaWxlIjoic2NvcGUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTeW1ib2wgfSBmcm9tIFwiLi9zeW1ib2xcIjtcblxubGV0IHNjb3BlSW5kZXggPSAwO1xuXG5leHBvcnQgZnVuY3Rpb24gZnJlc2hTY29wZShuYW1lID0gXCJzY29wZVwiKSB7XG4gIHNjb3BlSW5kZXgrKztcbiAgcmV0dXJuIFN5bWJvbChuYW1lICsgXCJfXCIgKyBzY29wZUluZGV4KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIFNjb3BlKG5hbWUpIHtcbiAgcmV0dXJuIFN5bWJvbChuYW1lKTtcbn1cbiJdfQ== \ No newline at end of file diff --git a/dist/serializer.js b/dist/serializer.js index 3a993467..b22de225 100644 --- a/dist/serializer.js +++ b/dist/serializer.js @@ -21,51 +21,88 @@ var _tokenizer = require("shift-parser/dist/tokenizer"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } -let typeMap_630 = [_tokenizer.TokenType.STRING, _tokenizer.TokenType.EOS, _tokenizer.TokenType.LPAREN, _tokenizer.TokenType.RPAREN, _tokenizer.TokenType.LBRACK, _tokenizer.TokenType.RBRACK, _tokenizer.TokenType.LBRACE, _tokenizer.TokenType.RBRACE, _tokenizer.TokenType.COLON, _tokenizer.TokenType.SEMICOLON, _tokenizer.TokenType.PERIOD, _tokenizer.TokenType.ELLIPSIS, _tokenizer.TokenType.ARROW, _tokenizer.TokenType.CONDITIONAL, _tokenizer.TokenType.INC, _tokenizer.TokenType.DEC, _tokenizer.TokenType.ASSIGN, _tokenizer.TokenType.ASSIGN_BIT_OR, _tokenizer.TokenType.ASSIGN_BIT_XOR, _tokenizer.TokenType.ASSIGN_BIT_AND, _tokenizer.TokenType.ASSIGN_SHL, _tokenizer.TokenType.ASSIGN_SHR, _tokenizer.TokenType.ASSIGN_SHR_UNSIGNED, _tokenizer.TokenType.ASSIGN_ADD, _tokenizer.TokenType.ASSIGN_SUB, _tokenizer.TokenType.ASSIGN_MUL, _tokenizer.TokenType.ASSIGN_DIV, _tokenizer.TokenType.ASSIGN_MOD, _tokenizer.TokenType.COMMA, _tokenizer.TokenType.OR, _tokenizer.TokenType.AND, _tokenizer.TokenType.BIT_OR, _tokenizer.TokenType.BIT_XOR, _tokenizer.TokenType.BIT_AND, _tokenizer.TokenType.SHL, _tokenizer.TokenType.SHR, _tokenizer.TokenType.SHR_UNSIGNED, _tokenizer.TokenType.ADD, _tokenizer.TokenType.SUB, _tokenizer.TokenType.MUL, _tokenizer.TokenType.DIV, _tokenizer.TokenType.MOD, _tokenizer.TokenType.EQ, _tokenizer.TokenType.NE, _tokenizer.TokenType.EQ_STRICT, _tokenizer.TokenType.NE_STRICT, _tokenizer.TokenType.LT, _tokenizer.TokenType.GT, _tokenizer.TokenType.LTE, _tokenizer.TokenType.GTE, _tokenizer.TokenType.INSTANCEOF, _tokenizer.TokenType.IN, _tokenizer.TokenType.NOT, _tokenizer.TokenType.BIT_NOT, _tokenizer.TokenType.AWAIT, _tokenizer.TokenType.DELETE, _tokenizer.TokenType.TYPEOF, _tokenizer.TokenType.VOID, _tokenizer.TokenType.BREAK, _tokenizer.TokenType.CASE, _tokenizer.TokenType.CATCH, _tokenizer.TokenType.CLASS, _tokenizer.TokenType.CONTINUE, _tokenizer.TokenType.DEBUGGER, _tokenizer.TokenType.DEFAULT, _tokenizer.TokenType.DO, _tokenizer.TokenType.ELSE, _tokenizer.TokenType.EXPORT, _tokenizer.TokenType.EXTENDS, _tokenizer.TokenType.FINALLY, _tokenizer.TokenType.FOR, _tokenizer.TokenType.FUNCTION, _tokenizer.TokenType.IF, _tokenizer.TokenType.IMPORT, _tokenizer.TokenType.LET, _tokenizer.TokenType.NEW, _tokenizer.TokenType.RETURN, _tokenizer.TokenType.SUPER, _tokenizer.TokenType.SWITCH, _tokenizer.TokenType.THIS, _tokenizer.TokenType.THROW, _tokenizer.TokenType.TRY, _tokenizer.TokenType.VAR, _tokenizer.TokenType.WHILE, _tokenizer.TokenType.WITH, _tokenizer.TokenType.NULL, _tokenizer.TokenType.TRUE, _tokenizer.TokenType.FALSE, _tokenizer.TokenType.YIELD, _tokenizer.TokenType.NUMBER, _tokenizer.TokenType.STRING, _tokenizer.TokenType.REGEXP, _tokenizer.TokenType.IDENTIFIER, _tokenizer.TokenType.CONST, _tokenizer.TokenType.TEMPLATE, _tokenizer.TokenType.ILLEGAL]; -let ListHandler_631 = _transitJs2.default.makeWriteHandler({ tag: () => "array", rep: v_637 => v_637 }); -let MapHandler_632 = _transitJs2.default.makeWriteHandler({ tag: function tag(v_638) { +let typeMap = [_tokenizer.TokenType.STRING, _tokenizer.TokenType.EOS, _tokenizer.TokenType.LPAREN, _tokenizer.TokenType.RPAREN, _tokenizer.TokenType.LBRACK, _tokenizer.TokenType.RBRACK, _tokenizer.TokenType.LBRACE, _tokenizer.TokenType.RBRACE, _tokenizer.TokenType.COLON, _tokenizer.TokenType.SEMICOLON, _tokenizer.TokenType.PERIOD, _tokenizer.TokenType.ELLIPSIS, _tokenizer.TokenType.ARROW, _tokenizer.TokenType.CONDITIONAL, _tokenizer.TokenType.INC, _tokenizer.TokenType.DEC, _tokenizer.TokenType.ASSIGN, _tokenizer.TokenType.ASSIGN_BIT_OR, _tokenizer.TokenType.ASSIGN_BIT_XOR, _tokenizer.TokenType.ASSIGN_BIT_AND, _tokenizer.TokenType.ASSIGN_SHL, _tokenizer.TokenType.ASSIGN_SHR, _tokenizer.TokenType.ASSIGN_SHR_UNSIGNED, _tokenizer.TokenType.ASSIGN_ADD, _tokenizer.TokenType.ASSIGN_SUB, _tokenizer.TokenType.ASSIGN_MUL, _tokenizer.TokenType.ASSIGN_DIV, _tokenizer.TokenType.ASSIGN_MOD, _tokenizer.TokenType.COMMA, _tokenizer.TokenType.OR, _tokenizer.TokenType.AND, _tokenizer.TokenType.BIT_OR, _tokenizer.TokenType.BIT_XOR, _tokenizer.TokenType.BIT_AND, _tokenizer.TokenType.SHL, _tokenizer.TokenType.SHR, _tokenizer.TokenType.SHR_UNSIGNED, _tokenizer.TokenType.ADD, _tokenizer.TokenType.SUB, _tokenizer.TokenType.MUL, _tokenizer.TokenType.DIV, _tokenizer.TokenType.MOD, _tokenizer.TokenType.EQ, _tokenizer.TokenType.NE, _tokenizer.TokenType.EQ_STRICT, _tokenizer.TokenType.NE_STRICT, _tokenizer.TokenType.LT, _tokenizer.TokenType.GT, _tokenizer.TokenType.LTE, _tokenizer.TokenType.GTE, _tokenizer.TokenType.INSTANCEOF, _tokenizer.TokenType.IN, _tokenizer.TokenType.NOT, _tokenizer.TokenType.BIT_NOT, _tokenizer.TokenType.AWAIT, _tokenizer.TokenType.DELETE, _tokenizer.TokenType.TYPEOF, _tokenizer.TokenType.VOID, _tokenizer.TokenType.BREAK, _tokenizer.TokenType.CASE, _tokenizer.TokenType.CATCH, _tokenizer.TokenType.CLASS, _tokenizer.TokenType.CONTINUE, _tokenizer.TokenType.DEBUGGER, _tokenizer.TokenType.DEFAULT, _tokenizer.TokenType.DO, _tokenizer.TokenType.ELSE, _tokenizer.TokenType.EXPORT, _tokenizer.TokenType.EXTENDS, _tokenizer.TokenType.FINALLY, _tokenizer.TokenType.FOR, _tokenizer.TokenType.FUNCTION, _tokenizer.TokenType.IF, _tokenizer.TokenType.IMPORT, _tokenizer.TokenType.LET, _tokenizer.TokenType.NEW, _tokenizer.TokenType.RETURN, _tokenizer.TokenType.SUPER, _tokenizer.TokenType.SWITCH, _tokenizer.TokenType.THIS, _tokenizer.TokenType.THROW, _tokenizer.TokenType.TRY, _tokenizer.TokenType.VAR, _tokenizer.TokenType.WHILE, _tokenizer.TokenType.WITH, _tokenizer.TokenType.NULL, _tokenizer.TokenType.TRUE, _tokenizer.TokenType.FALSE, _tokenizer.TokenType.YIELD, _tokenizer.TokenType.NUMBER, _tokenizer.TokenType.STRING, _tokenizer.TokenType.REGEXP, _tokenizer.TokenType.IDENTIFIER, _tokenizer.TokenType.CONST, _tokenizer.TokenType.TEMPLATE, _tokenizer.TokenType.ILLEGAL]; + +let ListHandler = _transitJs2.default.makeWriteHandler({ + tag: () => "array", + rep: v => v +}); + +let MapHandler = _transitJs2.default.makeWriteHandler({ + tag: function tag() { return "map"; - }, rep: function rep(v_639) { - return v_639; - }, stringRep: function stringRep(v_640) { + }, + rep: function rep(v) { + return v; + }, + stringRep: function stringRep() { return null; - } }); -let SyntaxHandler_633 = _transitJs2.default.makeWriteHandler({ tag: () => "stx", rep: v_641 => { - if (_immutable.List.isList(v_641.token)) { - return [v_641.token, v_641.scopesets]; + } +}); + +let SyntaxHandler = _transitJs2.default.makeWriteHandler({ + tag: () => "stx", + rep: v => { + if (_immutable.List.isList(v.token)) { + return [v.token, v.scopesets]; } else { - let t = _transitJs2.default.objectToMap(v_641.token); - t.set("type", typeMap_630.indexOf(v_641.token.type)); - return [t, v_641.scopesets]; + let t = _transitJs2.default.objectToMap(v.token); + t.set("type", typeMap.indexOf(v.token.type)); + return [t, v.scopesets]; } - } }); -let SymbolHandler_634 = _transitJs2.default.makeWriteHandler({ tag: () => "symb", rep: v_642 => [v_642.name] }); -let writer_635 = _transitJs2.default.writer("json", { handlers: _transitJs2.default.map([_immutable.List, ListHandler_631, _immutable.Map, MapHandler_632, _syntax2.default, SyntaxHandler_633, _symbol.SymbolClass, SymbolHandler_634]) }); -function makeReader_636(bindings_643) { - return _transitJs2.default.reader("json", { arrayBuilder: { init: node_644 => (0, _immutable.List)().asMutable(), add: (ret_645, val_646, node_647) => ret_645.push(val_646), finalize: (ret_648, node_649) => ret_648.asImmutable(), fromArray: (arr_650, node_651) => (0, _immutable.List)(arr_650) }, mapBuilder: { init: function init(node_652) { + } +}); +let SymbolHandler = _transitJs2.default.makeWriteHandler({ + tag: () => "symb", + rep: v => [v.name] +}); + +let writer = _transitJs2.default.writer("json", { + handlers: _transitJs2.default.map([_immutable.List, ListHandler, _immutable.Map, MapHandler, _syntax2.default, SyntaxHandler, _symbol.SymbolClass, SymbolHandler]) +}); + +function makeReader(bindings) { + return _transitJs2.default.reader("json", { + arrayBuilder: { + init: () => (0, _immutable.List)().asMutable(), + add: (ret, val) => ret.push(val), + finalize: ret => ret.asImmutable(), + fromArray: arr => (0, _immutable.List)(arr) + }, + mapBuilder: { + init: function init() { return (0, _immutable.Map)().asMutable(); - }, add: function add(ret_653, key_654, val_655, node_656) { - return ret_653.set(key_654, val_655); - }, finalize: function finalize(ret_657, node_658) { - return ret_657.asImmutable(); - } }, handlers: { stx: rep_659 => { - let scopesets_660 = _transitJs2.default.mapToObject(rep_659[1]); - if (_immutable.List.isList(rep_659[0])) { - let token = rep_659[0]; - return new _syntax2.default(token, { bindings: bindings_643, scopesets: scopesets_660 }); + }, + add: function add(ret, key, val) { + return ret.set(key, val); + }, + finalize: function finalize(ret) { + return ret.asImmutable(); + } + }, + handlers: { + "stx": rep => { + let scopesets = _transitJs2.default.mapToObject(rep[1]); + if (_immutable.List.isList(rep[0])) { + let token = rep[0]; + return new _syntax2.default(token, { bindings: bindings, scopesets: scopesets }); } else { - let token = _transitJs2.default.mapToObject(rep_659[0]); - token.type = typeMap_630[rep_659[0].get("type")]; - token.slice = rep_659[0].has("slice") ? _transitJs2.default.mapToObject(rep_659[0].get("slice")) : undefined; + let token = _transitJs2.default.mapToObject(rep[0]); + token.type = typeMap[rep[0].get("type")]; + token.slice = rep[0].has("slice") ? _transitJs2.default.mapToObject(rep[0].get("slice")) : undefined; if (token.slice) { token.slice.startLocation = _transitJs2.default.mapToObject(token.slice.startLocation); } - return new _syntax2.default(token, { bindings: bindings_643, scopesets: scopesets_660 }); + return new _syntax2.default(token, { bindings: bindings, scopesets: scopesets }); } - }, symb: rep_661 => { - return (0, _symbol.Symbol)(rep_661[0]); - } } }); + }, + "symb": rep => { + return (0, _symbol.Symbol)(rep[0]); + } + } + }); } -exports.makeDeserializer = makeReader_636; -exports.serializer = writer_635; -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/serializer.js"],"names":[],"mappings":"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","file":"serializer.js","sourcesContent":["import transit from \"transit-js\";\nimport {List, Map} from \"immutable\";\nimport Syntax from \"./syntax\";\nimport {Symbol, gensym, SymbolClass} from \"./symbol\";\nimport {TokenClass, TokenType} from \"shift-parser/dist/tokenizer\";\nlet typeMap_630 = [TokenType.STRING, TokenType.EOS, TokenType.LPAREN, TokenType.RPAREN, TokenType.LBRACK, TokenType.RBRACK, TokenType.LBRACE, TokenType.RBRACE, TokenType.COLON, TokenType.SEMICOLON, TokenType.PERIOD, TokenType.ELLIPSIS, TokenType.ARROW, TokenType.CONDITIONAL, TokenType.INC, TokenType.DEC, TokenType.ASSIGN, TokenType.ASSIGN_BIT_OR, TokenType.ASSIGN_BIT_XOR, TokenType.ASSIGN_BIT_AND, TokenType.ASSIGN_SHL, TokenType.ASSIGN_SHR, TokenType.ASSIGN_SHR_UNSIGNED, TokenType.ASSIGN_ADD, TokenType.ASSIGN_SUB, TokenType.ASSIGN_MUL, TokenType.ASSIGN_DIV, TokenType.ASSIGN_MOD, TokenType.COMMA, TokenType.OR, TokenType.AND, TokenType.BIT_OR, TokenType.BIT_XOR, TokenType.BIT_AND, TokenType.SHL, TokenType.SHR, TokenType.SHR_UNSIGNED, TokenType.ADD, TokenType.SUB, TokenType.MUL, TokenType.DIV, TokenType.MOD, TokenType.EQ, TokenType.NE, TokenType.EQ_STRICT, TokenType.NE_STRICT, TokenType.LT, TokenType.GT, TokenType.LTE, TokenType.GTE, TokenType.INSTANCEOF, TokenType.IN, TokenType.NOT, TokenType.BIT_NOT, TokenType.AWAIT, TokenType.DELETE, TokenType.TYPEOF, TokenType.VOID, TokenType.BREAK, TokenType.CASE, TokenType.CATCH, TokenType.CLASS, TokenType.CONTINUE, TokenType.DEBUGGER, TokenType.DEFAULT, TokenType.DO, TokenType.ELSE, TokenType.EXPORT, TokenType.EXTENDS, TokenType.FINALLY, TokenType.FOR, TokenType.FUNCTION, TokenType.IF, TokenType.IMPORT, TokenType.LET, TokenType.NEW, TokenType.RETURN, TokenType.SUPER, TokenType.SWITCH, TokenType.THIS, TokenType.THROW, TokenType.TRY, TokenType.VAR, TokenType.WHILE, TokenType.WITH, TokenType.NULL, TokenType.TRUE, TokenType.FALSE, TokenType.YIELD, TokenType.NUMBER, TokenType.STRING, TokenType.REGEXP, TokenType.IDENTIFIER, TokenType.CONST, TokenType.TEMPLATE, TokenType.ILLEGAL];\nlet ListHandler_631 = transit.makeWriteHandler({tag: () => \"array\", rep: v_637 => v_637});\nlet MapHandler_632 = transit.makeWriteHandler({tag: function (v_638) {\n  return \"map\";\n}, rep: function (v_639) {\n  return v_639;\n}, stringRep: function (v_640) {\n  return null;\n}});\nlet SyntaxHandler_633 = transit.makeWriteHandler({tag: () => \"stx\", rep: v_641 => {\n  if (List.isList(v_641.token)) {\n    return [v_641.token, v_641.scopesets];\n  } else {\n    let t = transit.objectToMap(v_641.token);\n    t.set(\"type\", typeMap_630.indexOf(v_641.token.type));\n    return [t, v_641.scopesets];\n  }\n}});\nlet SymbolHandler_634 = transit.makeWriteHandler({tag: () => \"symb\", rep: v_642 => [v_642.name]});\nlet writer_635 = transit.writer(\"json\", {handlers: transit.map([List, ListHandler_631, Map, MapHandler_632, Syntax, SyntaxHandler_633, SymbolClass, SymbolHandler_634])});\nfunction makeReader_636(bindings_643) {\n  return transit.reader(\"json\", {arrayBuilder: {init: node_644 => List().asMutable(), add: (ret_645, val_646, node_647) => ret_645.push(val_646), finalize: (ret_648, node_649) => ret_648.asImmutable(), fromArray: (arr_650, node_651) => List(arr_650)}, mapBuilder: {init: function (node_652) {\n    return Map().asMutable();\n  }, add: function (ret_653, key_654, val_655, node_656) {\n    return ret_653.set(key_654, val_655);\n  }, finalize: function (ret_657, node_658) {\n    return ret_657.asImmutable();\n  }}, handlers: {stx: rep_659 => {\n    let scopesets_660 = transit.mapToObject(rep_659[1]);\n    if (List.isList(rep_659[0])) {\n      let token = rep_659[0];\n      return new Syntax(token, {bindings: bindings_643, scopesets: scopesets_660});\n    } else {\n      let token = transit.mapToObject(rep_659[0]);\n      token.type = typeMap_630[rep_659[0].get(\"type\")];\n      token.slice = rep_659[0].has(\"slice\") ? transit.mapToObject(rep_659[0].get(\"slice\")) : undefined;\n      if (token.slice) {\n        token.slice.startLocation = transit.mapToObject(token.slice.startLocation);\n      }\n      return new Syntax(token, {bindings: bindings_643, scopesets: scopesets_660});\n    }\n  }, symb: rep_661 => {\n    return Symbol(rep_661[0]);\n  }}});\n}\nexport {makeReader_636 as makeDeserializer, writer_635 as serializer};\n"]} \ No newline at end of file + +exports.makeDeserializer = makeReader; +exports.serializer = writer; +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/serializer.js"],"names":[],"mappings":"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","file":"serializer.js","sourcesContent":["import transit from \"transit-js\";\nimport { List, Map } from \"immutable\";\nimport Syntax from \"./syntax\";\nimport { Symbol,  SymbolClass } from \"./symbol\";\nimport { TokenType } from \"shift-parser/dist/tokenizer\";\n\nlet typeMap = [TokenType.STRING, TokenType.EOS, TokenType.LPAREN, TokenType.RPAREN,\n               TokenType.LBRACK, TokenType.RBRACK, TokenType.LBRACE, TokenType.RBRACE,\n               TokenType.COLON, TokenType.SEMICOLON, TokenType.PERIOD, TokenType.ELLIPSIS,\n               TokenType.ARROW, TokenType.CONDITIONAL, TokenType.INC, TokenType.DEC,\n               TokenType.ASSIGN, TokenType.ASSIGN_BIT_OR, TokenType.ASSIGN_BIT_XOR,\n               TokenType.ASSIGN_BIT_AND, TokenType.ASSIGN_SHL, TokenType.ASSIGN_SHR,\n               TokenType.ASSIGN_SHR_UNSIGNED, TokenType.ASSIGN_ADD, TokenType.ASSIGN_SUB,\n               TokenType.ASSIGN_MUL, TokenType.ASSIGN_DIV, TokenType.ASSIGN_MOD,\n               TokenType.COMMA, TokenType.OR, TokenType.AND, TokenType.BIT_OR,\n               TokenType.BIT_XOR, TokenType.BIT_AND, TokenType.SHL, TokenType.SHR,\n               TokenType.SHR_UNSIGNED, TokenType.ADD, TokenType.SUB, TokenType.MUL,\n               TokenType.DIV, TokenType.MOD, TokenType.EQ, TokenType.NE,\n               TokenType.EQ_STRICT, TokenType.NE_STRICT, TokenType.LT, TokenType.GT,\n               TokenType.LTE, TokenType.GTE, TokenType.INSTANCEOF, TokenType.IN,\n               TokenType.NOT, TokenType.BIT_NOT, TokenType.AWAIT, TokenType.DELETE,\n               TokenType.TYPEOF, TokenType.VOID, TokenType.BREAK, TokenType.CASE,\n               TokenType.CATCH, TokenType.CLASS, TokenType.CONTINUE, TokenType.DEBUGGER,\n               TokenType.DEFAULT, TokenType.DO, TokenType.ELSE, TokenType.EXPORT,\n               TokenType.EXTENDS, TokenType.FINALLY, TokenType.FOR, TokenType.FUNCTION,\n               TokenType.IF, TokenType.IMPORT, TokenType.LET, TokenType.NEW,\n               TokenType.RETURN, TokenType.SUPER, TokenType.SWITCH, TokenType.THIS,\n               TokenType.THROW, TokenType.TRY, TokenType.VAR, TokenType.WHILE,\n               TokenType.WITH, TokenType.NULL, TokenType.TRUE, TokenType.FALSE,\n               TokenType.YIELD, TokenType.NUMBER, TokenType.STRING, TokenType.REGEXP,\n               TokenType.IDENTIFIER, TokenType.CONST, TokenType.TEMPLATE,\n               TokenType.ILLEGAL];\n\nlet ListHandler = transit.makeWriteHandler({\n  tag: () => \"array\",\n  rep: (v) => v\n});\n\nlet MapHandler = transit.makeWriteHandler({\n  tag: function() { return \"map\"; },\n  rep: function(v) { return v; },\n  stringRep: function() { return null; }\n});\n\nlet SyntaxHandler = transit.makeWriteHandler({\n  tag: () => \"stx\",\n  rep: (v) => {\n    if (List.isList(v.token)) {\n      return [v.token, v.scopesets];\n    } else {\n      let t = transit.objectToMap(v.token);\n      t.set(\"type\", typeMap.indexOf(v.token.type));\n      return [t, v.scopesets];\n    }\n  }\n});\nlet SymbolHandler = transit.makeWriteHandler({\n  tag: () => \"symb\",\n  rep: (v) =>  [v.name]\n});\n\nlet writer = transit.writer(\"json\", {\n  handlers: transit.map([\n    List, ListHandler,\n    Map, MapHandler,\n    Syntax, SyntaxHandler,\n    SymbolClass, SymbolHandler\n  ])\n});\n\nfunction makeReader(bindings) {\n  return transit.reader(\"json\", {\n    arrayBuilder: {\n      init: () => List().asMutable(),\n      add: (ret, val) => ret.push(val),\n      finalize: (ret) => ret.asImmutable(),\n      fromArray: (arr) => List(arr)\n    },\n    mapBuilder: {\n      init: function() { return Map().asMutable(); },\n      add: function(ret, key, val) { return ret.set(key, val); },\n      finalize: function(ret) { return ret.asImmutable(); }\n    },\n    handlers: {\n      \"stx\": (rep) => {\n        let scopesets = transit.mapToObject(rep[1]);\n        if (List.isList(rep[0])) {\n          let token = rep[0];\n          return new Syntax(token, {bindings, scopesets: scopesets});\n        } else {\n          let token = transit.mapToObject(rep[0]);\n          token.type = typeMap[rep[0].get(\"type\")];\n          token.slice = rep[0].has(\"slice\") ? transit.mapToObject(rep[0].get(\"slice\")) : undefined;\n          if (token.slice) {\n            token.slice.startLocation = transit.mapToObject(token.slice.startLocation);\n          }\n          return new Syntax(token, {bindings, scopesets: scopesets});\n        }\n      },\n      \"symb\": (rep) => {\n        return Symbol(rep[0]);\n      }\n    }\n  });\n}\n\nexport {\n  makeReader as makeDeserializer, writer as serializer\n};\n"]} \ No newline at end of file diff --git a/dist/shift-reader.js b/dist/shift-reader.js index 82209c0f..32ead8f0 100644 --- a/dist/shift-reader.js +++ b/dist/shift-reader.js @@ -14,6 +14,10 @@ var _syntax = require("./syntax"); var _syntax2 = _interopRequireDefault(_syntax); +var _ramda = require("ramda"); + +var R = _interopRequireWildcard(_ramda); + var _ramdaFantasy = require("ramda-fantasy"); var _errors = require("./errors"); @@ -22,251 +26,380 @@ var _terms = require("./terms"); var _terms2 = _interopRequireDefault(_terms); -var _ramda = require("ramda"); - -var R = _interopRequireWildcard(_ramda); - function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } -const Just_662 = _ramdaFantasy.Maybe.Just; -const Nothing_663 = _ramdaFantasy.Maybe.Nothing; -const LSYNTAX_664 = { name: "left-syntax" }; -const RSYNTAX_665 = { name: "right-syntax" }; -const AT_666 = { klass: _tokenizer.TokenClass.Punctuator, name: "@" }; -const literalKeywords_667 = ["this", "null", "true", "false"]; -const isLeftBracket_668 = R.whereEq({ type: _tokenizer.TokenType.LBRACK }); -const isLeftBrace_669 = R.whereEq({ type: _tokenizer.TokenType.LBRACE }); -const isLeftParen_670 = R.whereEq({ type: _tokenizer.TokenType.LPAREN }); -const isRightBracket_671 = R.whereEq({ type: _tokenizer.TokenType.RBRACK }); -const isRightBrace_672 = R.whereEq({ type: _tokenizer.TokenType.RBRACE }); -const isRightParen_673 = R.whereEq({ type: _tokenizer.TokenType.RPAREN }); -const isEOS_674 = R.whereEq({ type: _tokenizer.TokenType.EOS }); -const isHash_675 = R.whereEq({ type: _tokenizer.TokenType.IDENTIFIER, value: "#" }); -const isLeftSyntax_676 = R.whereEq({ type: LSYNTAX_664 }); -const isRightSyntax_677 = R.whereEq({ type: RSYNTAX_665 }); -const isLeftDelimiter_678 = R.anyPass([isLeftBracket_668, isLeftBrace_669, isLeftParen_670, isLeftSyntax_676]); -const isRightDelimiter_679 = R.anyPass([isRightBracket_671, isRightBrace_672, isRightParen_673, isRightSyntax_677]); -const isMatchingDelimiters_680 = R.cond([[isLeftBracket_668, (__721, b_722) => isRightBracket_671(b_722)], [isLeftBrace_669, (__723, b_724) => isRightBrace_672(b_724)], [isLeftParen_670, (__725, b_726) => isRightParen_673(b_726)], [isLeftSyntax_676, (__727, b_728) => isRightSyntax_677(b_728)], [R.T, R.F]]); -const assignOps_681 = ["=", "+=", "-=", "*=", "/=", "%=", "<<=", ">>=", ">>>=", "&=", "|=", "^=", ","]; -const binaryOps_682 = ["+", "-", "*", "/", "%", "<<", ">>", ">>>", "&", "|", "^", "&&", "||", "?", ":", "===", "==", ">=", "<=", "<", ">", "!=", "!==", "instanceof"]; -const unaryOps_683 = ["++", "--", "~", "!", "delete", "void", "typeof", "yield", "throw", "new"]; -const isEmpty_684 = R.whereEq({ size: 0 }); -const isPunctuator_685 = s_729 => s_729.match("punctuator"); -const isKeyword_686 = s_730 => s_730.match("keyword"); -const isDelimiter_687 = s_731 => s_731.match("delimiter"); -const isParens_688 = s_732 => s_732.match("parens"); -const isBraces_689 = s_733 => s_733.match("braces"); -const isBrackets_690 = s_734 => s_734.match("brackets"); -const isIdentifier_691 = s_735 => s_735.match("identifier"); -const val_692 = s_736 => s_736.val(); -const isVal_693 = R.curry((v_737, s_738) => s_738.val() === v_737); -const isDot_694 = R.allPass([isPunctuator_685, isVal_693(".")]); -const isColon_695 = R.allPass([isPunctuator_685, isVal_693(":")]); -const isFunctionKeyword_696 = R.allPass([isKeyword_686, isVal_693("function")]); -const isOperator_697 = s_739 => (s_739.match("punctuator") || s_739.match("keyword")) && R.any(R.equals(s_739.val()), assignOps_681.concat(binaryOps_682).concat(unaryOps_683)); -const isNonLiteralKeyword_698 = R.allPass([isKeyword_686, s_740 => R.none(R.equals(s_740.val()), literalKeywords_667)]); -const isKeywordExprPrefix_699 = R.allPass([isKeyword_686, s_741 => R.any(R.equals(s_741.val()), ["instanceof", "typeof", "delete", "void", "yield", "throw", "new", "case"])]); -let last_700 = p_742 => p_742.last(); -let safeLast_701 = R.pipe(R.cond([[isEmpty_684, R.always(Nothing_663())], [R.T, R.compose(_ramdaFantasy.Maybe.of, last_700)]])); -let stuffTrue_702 = R.curry((p_743, b_744) => b_744 ? Just_662(p_743) : Nothing_663()); -let stuffFalse_703 = R.curry((p_745, b_746) => !b_746 ? Just_662(p_745) : Nothing_663()); -let isTopColon_704 = R.pipe(safeLast_701, R.map(isColon_695), _ramdaFantasy.Maybe.maybe(false, R.identity)); -let isTopPunctuator_705 = R.pipe(safeLast_701, R.map(isPunctuator_685), _ramdaFantasy.Maybe.maybe(false, R.identity)); -let isExprReturn_706 = R.curry((l_747, p_748) => { - let retKwd_749 = safeLast_701(p_748); - let maybeDot_750 = pop_717(p_748).chain(safeLast_701); - if (maybeDot_750.map(isDot_694).getOrElse(false)) { +const Just = _ramdaFantasy.Maybe.Just; +const Nothing = _ramdaFantasy.Maybe.Nothing; + + +const LSYNTAX = { name: 'left-syntax' }; +const RSYNTAX = { name: 'right-syntax' }; +const AT = { klass: _tokenizer.TokenClass.Punctuator, name: "@" }; + +// TODO: also, need to handle contextual yield +const literalKeywords = ['this', 'null', 'true', 'false']; + +// Token -> Boolean +const isLeftBracket = R.whereEq({ type: _tokenizer.TokenType.LBRACK }); +const isLeftBrace = R.whereEq({ type: _tokenizer.TokenType.LBRACE }); +const isLeftParen = R.whereEq({ type: _tokenizer.TokenType.LPAREN }); +const isRightBracket = R.whereEq({ type: _tokenizer.TokenType.RBRACK }); +const isRightBrace = R.whereEq({ type: _tokenizer.TokenType.RBRACE }); +const isRightParen = R.whereEq({ type: _tokenizer.TokenType.RPAREN }); + +const isEOS = R.whereEq({ type: _tokenizer.TokenType.EOS }); + +// const isHash = R.whereEq({ type: TokenType.IDENTIFIER, value: '#'}); +const isLeftSyntax = R.whereEq({ type: LSYNTAX }); +const isRightSyntax = R.whereEq({ type: RSYNTAX }); + +const isLeftDelimiter = R.anyPass([isLeftBracket, isLeftBrace, isLeftParen, isLeftSyntax]); + +const isRightDelimiter = R.anyPass([isRightBracket, isRightBrace, isRightParen, isRightSyntax]); + +const isMatchingDelimiters = R.cond([[isLeftBracket, (_, b) => isRightBracket(b)], [isLeftBrace, (_, b) => isRightBrace(b)], [isLeftParen, (_, b) => isRightParen(b)], [isLeftSyntax, (_, b) => isRightSyntax(b)], [R.T, R.F]]); + +const assignOps = ["=", "+=", "-=", "*=", "/=", "%=", "<<=", ">>=", ">>>=", "&=", "|=", "^=", ","]; + +const binaryOps = ["+", "-", "*", "/", "%", "<<", ">>", ">>>", "&", "|", "^", "&&", "||", "?", ":", "===", "==", ">=", "<=", "<", ">", "!=", "!==", "instanceof"]; + +const unaryOps = ["++", "--", "~", "!", "delete", "void", "typeof", "yield", "throw", "new"]; + +// List -> Boolean +const isEmpty = R.whereEq({ size: 0 }); + +// Syntax -> Boolean +const isPunctuator = s => s.match("punctuator"); +const isKeyword = s => s.match("keyword"); +const isParens = s => s.match("parens"); +const isBraces = s => s.match("braces"); +const isIdentifier = s => s.match("identifier"); + +// Any -> Syntax -> Boolean +const isVal = R.curry((v, s) => s.val() === v); + +// Syntax -> Boolean +const isDot = R.allPass([isPunctuator, isVal('.')]); +const isColon = R.allPass([isPunctuator, isVal(':')]); +const isFunctionKeyword = R.allPass([isKeyword, isVal('function')]); +const isOperator = s => (s.match("punctuator") || s.match("keyword")) && R.any(R.equals(s.val()), assignOps.concat(binaryOps).concat(unaryOps)); +const isNonLiteralKeyword = R.allPass([isKeyword, s => R.none(R.equals(s.val()), literalKeywords)]); +const isKeywordExprPrefix = R.allPass([isKeyword, s => R.any(R.equals(s.val()), ['instanceof', 'typeof', 'delete', 'void', 'yield', 'throw', 'new', 'case'])]); +// List a -> a? +let last = p => p.last(); +// List a -> Maybe a +let safeLast = R.pipe(R.cond([[isEmpty, R.always(Nothing())], [R.T, R.compose(_ramdaFantasy.Maybe.of, last)]])); + +// TODO: better name +// List -> Boolean -> Maybe List +let stuffTrue = R.curry((p, b) => b ? Just(p) : Nothing()); +let stuffFalse = R.curry((p, b) => !b ? Just(p) : Nothing()); + +// List a -> Boolean +let isTopColon = R.pipe(safeLast, R.map(isColon), _ramdaFantasy.Maybe.maybe(false, R.identity)); +// List a -> Boolean +let isTopPunctuator = R.pipe(safeLast, R.map(isPunctuator), _ramdaFantasy.Maybe.maybe(false, R.identity)); + +// Number -> List -> Boolean +let isExprReturn = R.curry((l, p) => { + let retKwd = safeLast(p); + let maybeDot = pop(p).chain(safeLast); + + if (maybeDot.map(isDot).getOrElse(false)) { return true; } - return retKwd_749.map(s_751 => { - return s_751.match("keyword") && s_751.val() === "return" && s_751.lineNumber() === l_747; + return retKwd.map(s => { + return s.match("keyword") && s.val() === 'return' && s.lineNumber() === l; }).getOrElse(false); }); -const isTopOperator_707 = R.pipe(safeLast_701, R.map(isOperator_697), _ramdaFantasy.Maybe.maybe(false, R.identity)); -const isTopKeywordExprPrefix_708 = R.pipe(safeLast_701, R.map(isKeywordExprPrefix_699), _ramdaFantasy.Maybe.maybe(false, R.identity)); -let isExprPrefix_709 = R.curry((l_752, b_753) => R.cond([[isEmpty_684, R.always(b_753)], [isTopColon_704, R.always(b_753)], [isTopKeywordExprPrefix_708, R.T], [isTopOperator_707, R.T], [isTopPunctuator_705, R.always(b_753)], [isExprReturn_706(l_752), R.T], [R.T, R.F]])); -let curly_710 = p_754 => safeLast_701(p_754).map(isBraces_689).chain(stuffTrue_702(p_754)); -let paren_711 = p_755 => safeLast_701(p_755).map(isParens_688).chain(stuffTrue_702(p_755)); -let func_712 = p_756 => safeLast_701(p_756).map(isFunctionKeyword_696).chain(stuffTrue_702(p_756)); -let ident_713 = p_757 => safeLast_701(p_757).map(isIdentifier_691).chain(stuffTrue_702(p_757)); -let nonLiteralKeyword_714 = p_758 => safeLast_701(p_758).map(isNonLiteralKeyword_698).chain(stuffTrue_702(p_758)); -let opt_715 = R.curry((a_759, b_760, p_761) => { - let result_762 = R.pipeK(a_759, b_760)(_ramdaFantasy.Maybe.of(p_761)); - return _ramdaFantasy.Maybe.isJust(result_762) ? result_762 : _ramdaFantasy.Maybe.of(p_761); + +const isTopOperator = R.pipe(safeLast, R.map(isOperator), _ramdaFantasy.Maybe.maybe(false, R.identity)); + +const isTopKeywordExprPrefix = R.pipe(safeLast, R.map(isKeywordExprPrefix), _ramdaFantasy.Maybe.maybe(false, R.identity)); + +// Number -> Boolean -> List -> Boolean +let isExprPrefix = R.curry((l, b) => R.cond([ +// ... ({x: 42} /r/i) +[isEmpty, R.always(b)], +// ... ({x: {x: 42} /r/i }) +[isTopColon, R.always(b)], +// ... throw {x: 42} /r/i +[isTopKeywordExprPrefix, R.T], +// ... 42 + {x: 42} /r/i +[isTopOperator, R.T], +// ... for ( ; {x: 42}/r/i) +[isTopPunctuator, R.always(b)], +// ... return {x: 42} /r /i +// ... return\n{x: 42} /r /i +[isExprReturn(l), R.T], [R.T, R.F]])); + +// List a -> Maybe List a +let curly = p => safeLast(p).map(isBraces).chain(stuffTrue(p)); +let paren = p => safeLast(p).map(isParens).chain(stuffTrue(p)); +let func = p => safeLast(p).map(isFunctionKeyword).chain(stuffTrue(p)); +let ident = p => safeLast(p).map(isIdentifier).chain(stuffTrue(p)); +let nonLiteralKeyword = p => safeLast(p).map(isNonLiteralKeyword).chain(stuffTrue(p)); + +let opt = R.curry((a, b, p) => { + let result = R.pipeK(a, b)(_ramdaFantasy.Maybe.of(p)); + return _ramdaFantasy.Maybe.isJust(result) ? result : _ramdaFantasy.Maybe.of(p); }); -let notDot_716 = R.ifElse(R.whereEq({ size: 0 }), Just_662, p_763 => safeLast_701(p_763).map(s_764 => !(s_764.match("punctuator") && s_764.val() === ".")).chain(stuffTrue_702(p_763))); -let pop_717 = R.compose(Just_662, p_765 => p_765.pop()); -const functionPrefix_718 = R.pipeK(curly_710, pop_717, paren_711, pop_717, opt_715(ident_713, pop_717), func_712); -const isRegexPrefix_719 = b_766 => R.anyPass([isEmpty_684, isTopPunctuator_705, R.pipe(_ramdaFantasy.Maybe.of, R.pipeK(nonLiteralKeyword_714, pop_717, notDot_716), _ramdaFantasy.Maybe.isJust), R.pipe(_ramdaFantasy.Maybe.of, R.pipeK(paren_711, pop_717, nonLiteralKeyword_714, pop_717, notDot_716), _ramdaFantasy.Maybe.isJust), R.pipe(_ramdaFantasy.Maybe.of, functionPrefix_718, R.chain(p_767 => { - return safeLast_701(p_767).map(s_768 => s_768.lineNumber()).chain(fnLine_769 => { - return pop_717(p_767).map(isExprPrefix_709(fnLine_769, b_766)); - }).chain(stuffFalse_703(p_767)); -}), _ramdaFantasy.Maybe.isJust), p_770 => { - let isCurly_771 = _ramdaFantasy.Maybe.isJust(safeLast_701(p_770).map(isBraces_689)); - let alreadyCheckedFunction_772 = R.pipe(_ramdaFantasy.Maybe.of, functionPrefix_718, _ramdaFantasy.Maybe.isJust)(p_770); - if (alreadyCheckedFunction_772) { + +let notDot = R.ifElse(R.whereEq({ size: 0 }), Just, p => safeLast(p).map(s => !(s.match("punctuator") && s.val() === '.')).chain(stuffTrue(p))); + +// List a -> Maybe List a +let pop = R.compose(Just, p => p.pop()); + +// Maybe List a -> Maybe List a +const functionPrefix = R.pipeK(curly, pop, paren, pop, opt(ident, pop), func); + +// Boolean -> List a -> Boolean +const isRegexPrefix = b => R.anyPass([ +// ε +isEmpty, +// P . t where t ∈ Punctuator +isTopPunctuator, +// P . t . t' where t \not = "." and t' ∈ (Keyword \setminus LiteralKeyword) +R.pipe(_ramdaFantasy.Maybe.of, R.pipeK(nonLiteralKeyword, pop, notDot), _ramdaFantasy.Maybe.isJust), +// P . t . t' . (T) where t \not = "." and t' ∈ (Keyword \setminus LiteralKeyword) +R.pipe(_ramdaFantasy.Maybe.of, R.pipeK(paren, pop, nonLiteralKeyword, pop, notDot), _ramdaFantasy.Maybe.isJust), +// P . function^l . x? . () . {} where isExprPrefix(P, b, l) = false +R.pipe(_ramdaFantasy.Maybe.of, functionPrefix, R.chain(p => { + return safeLast(p).map(s => s.lineNumber()).chain(fnLine => { + return pop(p).map(isExprPrefix(fnLine, b)); + }).chain(stuffFalse(p)); +}), _ramdaFantasy.Maybe.isJust), +// P . {T}^l where isExprPrefix(P, b, l) = false +p => { + let alreadyCheckedFunction = R.pipe(_ramdaFantasy.Maybe.of, functionPrefix, _ramdaFantasy.Maybe.isJust)(p); + if (alreadyCheckedFunction) { return false; } - return R.pipe(_ramdaFantasy.Maybe.of, R.chain(curly_710), R.chain(p_773 => { - return safeLast_701(p_773).map(s_774 => s_774.lineNumber()).chain(curlyLine_775 => { - return pop_717(p_773).map(isExprPrefix_709(curlyLine_775, b_766)); - }).chain(stuffFalse_703(p_773)); - }), _ramdaFantasy.Maybe.isJust)(p_770); + return R.pipe(_ramdaFantasy.Maybe.of, R.chain(curly), R.chain(p => { + return safeLast(p).map(s => s.lineNumber()).chain(curlyLine => { + return pop(p).map(isExprPrefix(curlyLine, b)); + }).chain(stuffFalse(p)); + }), _ramdaFantasy.Maybe.isJust)(p); }]); -function lastEl_720(l_776) { - return l_776[l_776.length - 1]; + +function lastEl(l) { + return l[l.length - 1]; } + class Reader extends _tokenizer2.default { - constructor(strings_777, context_778, replacements_779) { - super(Array.isArray(strings_777) ? strings_777.join("") : strings_777); + constructor(strings, context, replacements) { + super(Array.isArray(strings) ? strings.join('') : strings); this.delimStack = new Map(); this.insideSyntaxTemplate = [false]; - this.context = context_778; - if (Array.isArray(strings_777)) { + this.context = context; + + // setup splicing replacement array + if (Array.isArray(strings)) { let totalIndex = 0; - this.replacementIndex = R.reduce((acc_780, strRep_781) => { - acc_780.push({ index: totalIndex + strRep_781[0].length, replacement: strRep_781[1] }); - totalIndex += strRep_781[0].length; - return acc_780; - }, [], R.zip(strings_777, replacements_779)); + this.replacementIndex = R.reduce((acc, strRep) => { + acc.push({ + index: totalIndex + strRep[0].length, + replacement: strRep[1] + }); + totalIndex += strRep[0].length; + return acc; + }, [], R.zip(strings, replacements)); } } + read() { - let stack_782 = arguments.length <= 0 || arguments[0] === undefined ? [] : arguments[0]; - let b_783 = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1]; - let singleDelimiter_784 = arguments.length <= 2 || arguments[2] === undefined ? false : arguments[2]; + let stack = arguments.length <= 0 || arguments[0] === undefined ? [] : arguments[0]; + let b = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1]; + let singleDelimiter = arguments.length <= 2 || arguments[2] === undefined ? false : arguments[2]; - let prefix_785 = (0, _immutable.List)(); + let prefix = (0, _immutable.List)(); while (true) { - let tok = this.advance(prefix_785, b_783); + let tok = this.advance(prefix, b); + + // splicing allows syntax and terms if (tok.scopesets || tok instanceof _terms2.default) { - stack_782.push(tok); + stack.push(tok); continue; } if (Array.isArray(tok)) { - Array.prototype.push.apply(stack_782, tok); + Array.prototype.push.apply(stack, tok); continue; } if (_immutable.List.isList(tok)) { - Array.prototype.push.apply(stack_782, tok.toArray()); + Array.prototype.push.apply(stack, tok.toArray()); continue; } - if (isEOS_674(tok)) { - if (stack_782[0] && isLeftDelimiter_678(stack_782[0].token)) { + + if (isEOS(tok)) { + if (stack[0] && isLeftDelimiter(stack[0].token)) { throw this.createUnexpected(tok); } break; } - if (isLeftDelimiter_678(tok)) { - if (isLeftSyntax_676(tok)) { + + if (isLeftDelimiter(tok)) { + if (isLeftSyntax(tok)) { this.insideSyntaxTemplate.push(true); } let line = tok.slice.startLocation.line; - let innerB = isLeftBrace_669(tok) ? isExprPrefix_709(line, b_783)(prefix_785) : true; + let innerB = isLeftBrace(tok) ? isExprPrefix(line, b)(prefix) : true; let inner = this.read([new _syntax2.default(tok, this.context)], innerB, false); let stx = new _syntax2.default(inner, this.context); - prefix_785 = prefix_785.concat(stx); - stack_782.push(stx); - if (singleDelimiter_784) { + prefix = prefix.concat(stx); + stack.push(stx); + if (singleDelimiter) { break; } - } else if (isRightDelimiter_679(tok)) { - if (stack_782[0] && !isMatchingDelimiters_680(stack_782[0].token, tok)) { + } else if (isRightDelimiter(tok)) { + if (stack[0] && !isMatchingDelimiters(stack[0].token, tok)) { throw this.createUnexpected(tok); } let stx = new _syntax2.default(tok, this.context); - stack_782.push(stx); - if (lastEl_720(this.insideSyntaxTemplate) && isRightSyntax_677(tok)) { + stack.push(stx); + if (lastEl(this.insideSyntaxTemplate) && isRightSyntax(tok)) { this.insideSyntaxTemplate.pop(); } break; } else { let stx = new _syntax2.default(tok, this.context); - prefix_785 = prefix_785.concat(stx); - stack_782.push(stx); + prefix = prefix.concat(stx); + stack.push(stx); } } - return (0, _immutable.List)(stack_782); + return (0, _immutable.List)(stack); } - advance(prefix_786, b_787) { - let startLocation_788 = this.getLocation(); + + advance(prefix, b) { this.lastIndex = this.index; this.lastLine = this.line; this.lastLineStart = this.lineStart; + this.skipComment(); + this.startIndex = this.index; this.startLine = this.line; this.startLineStart = this.lineStart; + if (this.replacementIndex && this.replacementIndex[0] && this.index >= this.replacementIndex[0].index) { let rep = this.replacementIndex[0].replacement; this.replacementIndex.shift(); return rep; } - let charCode_789 = this.source.charCodeAt(this.index); - if (charCode_789 === 96) { + + let charCode = this.source.charCodeAt(this.index); + + if (charCode === 0x60) { + // ` let element, items = []; - let startLocation_788 = this.getLocation(); + let startLocation = this.getLocation(); let start = this.index; this.index++; - if (lastEl_720(this.insideSyntaxTemplate)) { - let slice = this.getSlice(start, startLocation_788); - return { type: RSYNTAX_665, value: "`", slice: slice }; + if (lastEl(this.insideSyntaxTemplate)) { + + let slice = this.getSlice(start, startLocation); + return { + type: RSYNTAX, + value: '`', + slice: slice + }; } do { element = this.scanTemplateElement(); items.push(element); if (element.interp) { + // only read the single delimiter element = this.read([], false, true); (0, _errors.assert)(element.size === 1, "should only have read a single delimiter inside a template"); items.push(element.get(0)); } } while (!element.tail); - return { type: _tokenizer.TokenType.TEMPLATE, items: (0, _immutable.List)(items), slice: this.getSlice(start, startLocation_788) }; - } else if (charCode_789 === 35) { - let startLocation_788 = this.getLocation(); + return { + type: _tokenizer.TokenType.TEMPLATE, + items: (0, _immutable.List)(items), + slice: this.getSlice(start, startLocation) + }; + } else if (charCode === 35) { + // # + let startLocation = this.getLocation(); let start = this.index; - let slice = this.getSlice(start, startLocation_788); + let slice = this.getSlice(start, startLocation); this.index++; - if (this.source.charCodeAt(this.index) === 96) { + // TODO: handle ` inside of syntax template interpolations + if (this.source.charCodeAt(this.index) === 0x60) { + // ` this.index++; - return { type: LSYNTAX_664, value: "#`", slice: slice }; + return { + type: LSYNTAX, + value: '#`', + slice: slice + }; } - return { type: _tokenizer.TokenType.IDENTIFIER, value: "#", slice: slice }; - } else if (charCode_789 === 64) { - let startLocation_788 = this.getLocation(); + return { + type: _tokenizer.TokenType.IDENTIFIER, + value: '#', + slice: slice + }; + } else if (charCode === 64) { + // @ + let startLocation = this.getLocation(); let start = this.index; - let slice = this.getSlice(start, startLocation_788); + let slice = this.getSlice(start, startLocation); this.index++; - return { type: AT_666, value: "@", slice: slice }; + return { + type: AT, + value: '@', + slice: slice + }; } - let lookahead_790 = super.advance(); - if (lookahead_790.type === _tokenizer.TokenType.DIV && isRegexPrefix_719(b_787)(prefix_786)) { + + let lookahead = super.advance(); + if (lookahead.type === _tokenizer.TokenType.DIV && isRegexPrefix(b)(prefix)) { return super.scanRegExp("/"); } - return lookahead_790; + return lookahead; } + + // need to override how templates are lexed because of delimiters scanTemplateElement() { - let startLocation_791 = this.getLocation(); - let start_792 = this.index; + let startLocation = this.getLocation(); + let start = this.index; while (this.index < this.source.length) { let ch = this.source.charCodeAt(this.index); switch (ch) { - case 96: - let slice = this.getSlice(start_792, startLocation_791); - this.index++; - return { type: _tokenizer.TokenType.TEMPLATE, tail: true, interp: false, slice: slice }; - case 36: - if (this.source.charCodeAt(this.index + 1) === 123) { - let slice = this.getSlice(start_792, startLocation_791); + case 0x60: + { + // ` + // don't include the traling "`" + let slice = this.getSlice(start, startLocation); + this.index++; + return { + type: _tokenizer.TokenType.TEMPLATE, + tail: true, + interp: false, + slice: slice + }; + } + case 0x24: + // $ + if (this.source.charCodeAt(this.index + 1) === 0x7B) { + // { + // don't include the trailing "$" + let slice = this.getSlice(start, startLocation); this.index += 1; - return { type: _tokenizer.TokenType.TEMPLATE, tail: false, interp: true, slice: slice }; + return { + type: _tokenizer.TokenType.TEMPLATE, + tail: false, + interp: true, + slice: slice + }; } this.index++; break; - case 92: + case 0x5C: + // \\ { let octal = this.scanStringEscape("", null)[1]; if (octal != null) { @@ -278,8 +411,9 @@ class Reader extends _tokenizer2.default { this.index++; } } + throw this.createILLEGAL(); } } exports.default = Reader; -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/shift-reader.js"],"names":[],"mappings":"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","file":"shift-reader.js","sourcesContent":["import Tokenizer from \"shift-parser/dist/tokenizer\";\nimport {TokenClass, TokenType} from \"shift-parser/dist/tokenizer\";\nimport {List} from \"immutable\";\nimport Syntax from \"./syntax\";\nimport {Maybe} from \"ramda-fantasy\";\nimport {assert} from \"./errors\";\nimport Term from \"./terms\";\nimport  * as R from \"ramda\";\nconst Just_662 = Maybe.Just;\nconst Nothing_663 = Maybe.Nothing;\nconst LSYNTAX_664 = {name: \"left-syntax\"};\nconst RSYNTAX_665 = {name: \"right-syntax\"};\nconst AT_666 = {klass: TokenClass.Punctuator, name: \"@\"};\nconst literalKeywords_667 = [\"this\", \"null\", \"true\", \"false\"];\nconst isLeftBracket_668 = R.whereEq({type: TokenType.LBRACK});\nconst isLeftBrace_669 = R.whereEq({type: TokenType.LBRACE});\nconst isLeftParen_670 = R.whereEq({type: TokenType.LPAREN});\nconst isRightBracket_671 = R.whereEq({type: TokenType.RBRACK});\nconst isRightBrace_672 = R.whereEq({type: TokenType.RBRACE});\nconst isRightParen_673 = R.whereEq({type: TokenType.RPAREN});\nconst isEOS_674 = R.whereEq({type: TokenType.EOS});\nconst isHash_675 = R.whereEq({type: TokenType.IDENTIFIER, value: \"#\"});\nconst isLeftSyntax_676 = R.whereEq({type: LSYNTAX_664});\nconst isRightSyntax_677 = R.whereEq({type: RSYNTAX_665});\nconst isLeftDelimiter_678 = R.anyPass([isLeftBracket_668, isLeftBrace_669, isLeftParen_670, isLeftSyntax_676]);\nconst isRightDelimiter_679 = R.anyPass([isRightBracket_671, isRightBrace_672, isRightParen_673, isRightSyntax_677]);\nconst isMatchingDelimiters_680 = R.cond([[isLeftBracket_668, (__721, b_722) => isRightBracket_671(b_722)], [isLeftBrace_669, (__723, b_724) => isRightBrace_672(b_724)], [isLeftParen_670, (__725, b_726) => isRightParen_673(b_726)], [isLeftSyntax_676, (__727, b_728) => isRightSyntax_677(b_728)], [R.T, R.F]]);\nconst assignOps_681 = [\"=\", \"+=\", \"-=\", \"*=\", \"/=\", \"%=\", \"<<=\", \">>=\", \">>>=\", \"&=\", \"|=\", \"^=\", \",\"];\nconst binaryOps_682 = [\"+\", \"-\", \"*\", \"/\", \"%\", \"<<\", \">>\", \">>>\", \"&\", \"|\", \"^\", \"&&\", \"||\", \"?\", \":\", \"===\", \"==\", \">=\", \"<=\", \"<\", \">\", \"!=\", \"!==\", \"instanceof\"];\nconst unaryOps_683 = [\"++\", \"--\", \"~\", \"!\", \"delete\", \"void\", \"typeof\", \"yield\", \"throw\", \"new\"];\nconst isEmpty_684 = R.whereEq({size: 0});\nconst isPunctuator_685 = s_729 => s_729.match(\"punctuator\");\nconst isKeyword_686 = s_730 => s_730.match(\"keyword\");\nconst isDelimiter_687 = s_731 => s_731.match(\"delimiter\");\nconst isParens_688 = s_732 => s_732.match(\"parens\");\nconst isBraces_689 = s_733 => s_733.match(\"braces\");\nconst isBrackets_690 = s_734 => s_734.match(\"brackets\");\nconst isIdentifier_691 = s_735 => s_735.match(\"identifier\");\nconst val_692 = s_736 => s_736.val();\nconst isVal_693 = R.curry((v_737, s_738) => s_738.val() === v_737);\nconst isDot_694 = R.allPass([isPunctuator_685, isVal_693(\".\")]);\nconst isColon_695 = R.allPass([isPunctuator_685, isVal_693(\":\")]);\nconst isFunctionKeyword_696 = R.allPass([isKeyword_686, isVal_693(\"function\")]);\nconst isOperator_697 = s_739 => (s_739.match(\"punctuator\") || s_739.match(\"keyword\")) && R.any(R.equals(s_739.val()), assignOps_681.concat(binaryOps_682).concat(unaryOps_683));\nconst isNonLiteralKeyword_698 = R.allPass([isKeyword_686, s_740 => R.none(R.equals(s_740.val()), literalKeywords_667)]);\nconst isKeywordExprPrefix_699 = R.allPass([isKeyword_686, s_741 => R.any(R.equals(s_741.val()), [\"instanceof\", \"typeof\", \"delete\", \"void\", \"yield\", \"throw\", \"new\", \"case\"])]);\nlet last_700 = p_742 => p_742.last();\nlet safeLast_701 = R.pipe(R.cond([[isEmpty_684, R.always(Nothing_663())], [R.T, R.compose(Maybe.of, last_700)]]));\nlet stuffTrue_702 = R.curry((p_743, b_744) => b_744 ? Just_662(p_743) : Nothing_663());\nlet stuffFalse_703 = R.curry((p_745, b_746) => !b_746 ? Just_662(p_745) : Nothing_663());\nlet isTopColon_704 = R.pipe(safeLast_701, R.map(isColon_695), Maybe.maybe(false, R.identity));\nlet isTopPunctuator_705 = R.pipe(safeLast_701, R.map(isPunctuator_685), Maybe.maybe(false, R.identity));\nlet isExprReturn_706 = R.curry((l_747, p_748) => {\n  let retKwd_749 = safeLast_701(p_748);\n  let maybeDot_750 = pop_717(p_748).chain(safeLast_701);\n  if (maybeDot_750.map(isDot_694).getOrElse(false)) {\n    return true;\n  }\n  return retKwd_749.map(s_751 => {\n    return s_751.match(\"keyword\") && s_751.val() === \"return\" && s_751.lineNumber() === l_747;\n  }).getOrElse(false);\n});\nconst isTopOperator_707 = R.pipe(safeLast_701, R.map(isOperator_697), Maybe.maybe(false, R.identity));\nconst isTopKeywordExprPrefix_708 = R.pipe(safeLast_701, R.map(isKeywordExprPrefix_699), Maybe.maybe(false, R.identity));\nlet isExprPrefix_709 = R.curry((l_752, b_753) => R.cond([[isEmpty_684, R.always(b_753)], [isTopColon_704, R.always(b_753)], [isTopKeywordExprPrefix_708, R.T], [isTopOperator_707, R.T], [isTopPunctuator_705, R.always(b_753)], [isExprReturn_706(l_752), R.T], [R.T, R.F]]));\nlet curly_710 = p_754 => safeLast_701(p_754).map(isBraces_689).chain(stuffTrue_702(p_754));\nlet paren_711 = p_755 => safeLast_701(p_755).map(isParens_688).chain(stuffTrue_702(p_755));\nlet func_712 = p_756 => safeLast_701(p_756).map(isFunctionKeyword_696).chain(stuffTrue_702(p_756));\nlet ident_713 = p_757 => safeLast_701(p_757).map(isIdentifier_691).chain(stuffTrue_702(p_757));\nlet nonLiteralKeyword_714 = p_758 => safeLast_701(p_758).map(isNonLiteralKeyword_698).chain(stuffTrue_702(p_758));\nlet opt_715 = R.curry((a_759, b_760, p_761) => {\n  let result_762 = R.pipeK(a_759, b_760)(Maybe.of(p_761));\n  return Maybe.isJust(result_762) ? result_762 : Maybe.of(p_761);\n});\nlet notDot_716 = R.ifElse(R.whereEq({size: 0}), Just_662, p_763 => safeLast_701(p_763).map(s_764 => !(s_764.match(\"punctuator\") && s_764.val() === \".\")).chain(stuffTrue_702(p_763)));\nlet pop_717 = R.compose(Just_662, p_765 => p_765.pop());\nconst functionPrefix_718 = R.pipeK(curly_710, pop_717, paren_711, pop_717, opt_715(ident_713, pop_717), func_712);\nconst isRegexPrefix_719 = b_766 => R.anyPass([isEmpty_684, isTopPunctuator_705, R.pipe(Maybe.of, R.pipeK(nonLiteralKeyword_714, pop_717, notDot_716), Maybe.isJust), R.pipe(Maybe.of, R.pipeK(paren_711, pop_717, nonLiteralKeyword_714, pop_717, notDot_716), Maybe.isJust), R.pipe(Maybe.of, functionPrefix_718, R.chain(p_767 => {\n  return safeLast_701(p_767).map(s_768 => s_768.lineNumber()).chain(fnLine_769 => {\n    return pop_717(p_767).map(isExprPrefix_709(fnLine_769, b_766));\n  }).chain(stuffFalse_703(p_767));\n}), Maybe.isJust), p_770 => {\n  let isCurly_771 = Maybe.isJust(safeLast_701(p_770).map(isBraces_689));\n  let alreadyCheckedFunction_772 = R.pipe(Maybe.of, functionPrefix_718, Maybe.isJust)(p_770);\n  if (alreadyCheckedFunction_772) {\n    return false;\n  }\n  return R.pipe(Maybe.of, R.chain(curly_710), R.chain(p_773 => {\n    return safeLast_701(p_773).map(s_774 => s_774.lineNumber()).chain(curlyLine_775 => {\n      return pop_717(p_773).map(isExprPrefix_709(curlyLine_775, b_766));\n    }).chain(stuffFalse_703(p_773));\n  }), Maybe.isJust)(p_770);\n}]);\nfunction lastEl_720(l_776) {\n  return l_776[l_776.length - 1];\n}\nexport default class Reader extends Tokenizer {\n  constructor(strings_777, context_778, replacements_779) {\n    super(Array.isArray(strings_777) ? strings_777.join(\"\") : strings_777);\n    this.delimStack = new Map;\n    this.insideSyntaxTemplate = [false];\n    this.context = context_778;\n    if (Array.isArray(strings_777)) {\n      let totalIndex = 0;\n      this.replacementIndex = R.reduce((acc_780, strRep_781) => {\n        acc_780.push({index: totalIndex + strRep_781[0].length, replacement: strRep_781[1]});\n        totalIndex += strRep_781[0].length;\n        return acc_780;\n      }, [], R.zip(strings_777, replacements_779));\n    }\n  }\n  read(stack_782 = [], b_783 = false, singleDelimiter_784 = false) {\n    let prefix_785 = List();\n    while (true) {\n      let tok = this.advance(prefix_785, b_783);\n      if (tok.scopesets || tok instanceof Term) {\n        stack_782.push(tok);\n        continue;\n      }\n      if (Array.isArray(tok)) {\n        Array.prototype.push.apply(stack_782, tok);\n        continue;\n      }\n      if (List.isList(tok)) {\n        Array.prototype.push.apply(stack_782, tok.toArray());\n        continue;\n      }\n      if (isEOS_674(tok)) {\n        if (stack_782[0] && isLeftDelimiter_678(stack_782[0].token)) {\n          throw this.createUnexpected(tok);\n        }\n        break;\n      }\n      if (isLeftDelimiter_678(tok)) {\n        if (isLeftSyntax_676(tok)) {\n          this.insideSyntaxTemplate.push(true);\n        }\n        let line = tok.slice.startLocation.line;\n        let innerB = isLeftBrace_669(tok) ? isExprPrefix_709(line, b_783)(prefix_785) : true;\n        let inner = this.read([new Syntax(tok, this.context)], innerB, false);\n        let stx = new Syntax(inner, this.context);\n        prefix_785 = prefix_785.concat(stx);\n        stack_782.push(stx);\n        if (singleDelimiter_784) {\n          break;\n        }\n      } else if (isRightDelimiter_679(tok)) {\n        if (stack_782[0] && !isMatchingDelimiters_680(stack_782[0].token, tok)) {\n          throw this.createUnexpected(tok);\n        }\n        let stx = new Syntax(tok, this.context);\n        stack_782.push(stx);\n        if (lastEl_720(this.insideSyntaxTemplate) && isRightSyntax_677(tok)) {\n          this.insideSyntaxTemplate.pop();\n        }\n        break;\n      } else {\n        let stx = new Syntax(tok, this.context);\n        prefix_785 = prefix_785.concat(stx);\n        stack_782.push(stx);\n      }\n    }\n    return List(stack_782);\n  }\n  advance(prefix_786, b_787) {\n    let startLocation_788 = this.getLocation();\n    this.lastIndex = this.index;\n    this.lastLine = this.line;\n    this.lastLineStart = this.lineStart;\n    this.skipComment();\n    this.startIndex = this.index;\n    this.startLine = this.line;\n    this.startLineStart = this.lineStart;\n    if (this.replacementIndex && this.replacementIndex[0] && this.index >= this.replacementIndex[0].index) {\n      let rep = this.replacementIndex[0].replacement;\n      this.replacementIndex.shift();\n      return rep;\n    }\n    let charCode_789 = this.source.charCodeAt(this.index);\n    if (charCode_789 === 96) {\n      let element, items = [];\n      let startLocation_788 = this.getLocation();\n      let start = this.index;\n      this.index++;\n      if (lastEl_720(this.insideSyntaxTemplate)) {\n        let slice = this.getSlice(start, startLocation_788);\n        return {type: RSYNTAX_665, value: \"`\", slice: slice};\n      }\n      do {\n        element = this.scanTemplateElement();\n        items.push(element);\n        if (element.interp) {\n          element = this.read([], false, true);\n          assert(element.size === 1, \"should only have read a single delimiter inside a template\");\n          items.push(element.get(0));\n        }\n      } while (!element.tail);\n      return {type: TokenType.TEMPLATE, items: List(items), slice: this.getSlice(start, startLocation_788)};\n    } else if (charCode_789 === 35) {\n      let startLocation_788 = this.getLocation();\n      let start = this.index;\n      let slice = this.getSlice(start, startLocation_788);\n      this.index++;\n      if (this.source.charCodeAt(this.index) === 96) {\n        this.index++;\n        return {type: LSYNTAX_664, value: \"#`\", slice: slice};\n      }\n      return {type: TokenType.IDENTIFIER, value: \"#\", slice: slice};\n    } else if (charCode_789 === 64) {\n      let startLocation_788 = this.getLocation();\n      let start = this.index;\n      let slice = this.getSlice(start, startLocation_788);\n      this.index++;\n      return {type: AT_666, value: \"@\", slice: slice};\n    }\n    let lookahead_790 = super.advance();\n    if (lookahead_790.type === TokenType.DIV && isRegexPrefix_719(b_787)(prefix_786)) {\n      return super.scanRegExp(\"/\");\n    }\n    return lookahead_790;\n  }\n  scanTemplateElement() {\n    let startLocation_791 = this.getLocation();\n    let start_792 = this.index;\n    while (this.index < this.source.length) {\n      let ch = this.source.charCodeAt(this.index);\n      switch (ch) {\n        case 96:\n          let slice = this.getSlice(start_792, startLocation_791);\n          this.index++;\n          return {type: TokenType.TEMPLATE, tail: true, interp: false, slice: slice};\n        case 36:\n          if (this.source.charCodeAt(this.index + 1) === 123) {\n            let slice = this.getSlice(start_792, startLocation_791);\n            this.index += 1;\n            return {type: TokenType.TEMPLATE, tail: false, interp: true, slice: slice};\n          }\n          this.index++;\n          break;\n        case 92:\n          {\n            let octal = this.scanStringEscape(\"\", null)[1];\n            if (octal != null) {\n              throw this.createILLEGAL();\n            }\n            break;\n          }\n        default:\n          this.index++;\n      }\n    }\n    throw this.createILLEGAL();\n  }\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/shift-reader.js"],"names":[],"mappings":"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","file":"shift-reader.js","sourcesContent":["import Tokenizer from \"shift-parser/dist/tokenizer\";\nimport { TokenClass, TokenType } from \"shift-parser/dist/tokenizer\";\nimport { List } from \"immutable\";\nimport Syntax from \"./syntax\";\nimport * as R from 'ramda';\nimport { Maybe } from 'ramda-fantasy';\nimport { assert } from './errors';\nconst Just = Maybe.Just;\nconst Nothing = Maybe.Nothing;\nimport Term from './terms';\n\nconst LSYNTAX = { name: 'left-syntax' };\nconst RSYNTAX = { name: 'right-syntax' };\nconst AT = { klass: TokenClass.Punctuator, name: \"@\" };\n\n\n// TODO: also, need to handle contextual yield\nconst literalKeywords = ['this', 'null', 'true', 'false'];\n\n// Token -> Boolean\nconst isLeftBracket  = R.whereEq({ type: TokenType.LBRACK });\nconst isLeftBrace    = R.whereEq({ type: TokenType.LBRACE });\nconst isLeftParen    = R.whereEq({ type: TokenType.LPAREN });\nconst isRightBracket = R.whereEq({ type: TokenType.RBRACK });\nconst isRightBrace   = R.whereEq({ type: TokenType.RBRACE });\nconst isRightParen   = R.whereEq({ type: TokenType.RPAREN });\n\nconst isEOS = R.whereEq({ type: TokenType.EOS });\n\n// const isHash = R.whereEq({ type: TokenType.IDENTIFIER, value: '#'});\nconst isLeftSyntax = R.whereEq({ type: LSYNTAX });\nconst isRightSyntax = R.whereEq({ type: RSYNTAX });\n\nconst isLeftDelimiter = R.anyPass([isLeftBracket,\n                                   isLeftBrace,\n                                   isLeftParen,\n                                   isLeftSyntax]);\n\nconst isRightDelimiter = R.anyPass([isRightBracket,\n                                    isRightBrace,\n                                    isRightParen,\n                                    isRightSyntax]);\n\nconst isMatchingDelimiters = R.cond([\n  [isLeftBracket, (_, b) => isRightBracket(b)],\n  [isLeftBrace, (_, b) => isRightBrace(b)],\n  [isLeftParen, (_, b) => isRightParen(b)],\n  [isLeftSyntax, (_, b) => isRightSyntax(b)],\n  [R.T, R.F]\n]);\n\nconst assignOps =  [\"=\", \"+=\", \"-=\", \"*=\", \"/=\", \"%=\", \"<<=\", \">>=\", \">>>=\",\n                  \"&=\", \"|=\", \"^=\", \",\"];\n\nconst binaryOps = [\"+\", \"-\", \"*\", \"/\", \"%\",\"<<\", \">>\", \">>>\", \"&\", \"|\", \"^\",\n                 \"&&\", \"||\", \"?\", \":\",\n                 \"===\", \"==\", \">=\", \"<=\", \"<\", \">\", \"!=\", \"!==\", \"instanceof\"];\n\nconst unaryOps = [\"++\", \"--\", \"~\", \"!\", \"delete\", \"void\", \"typeof\", \"yield\", \"throw\", \"new\"];\n\n// List -> Boolean\nconst isEmpty = R.whereEq({size: 0});\n\n// Syntax -> Boolean\nconst isPunctuator = s => s.match(\"punctuator\");\nconst isKeyword = s => s.match(\"keyword\");\nconst isParens = s => s.match(\"parens\");\nconst isBraces = s => s.match(\"braces\");\nconst isIdentifier = s => s.match(\"identifier\");\n\n// Any -> Syntax -> Boolean\nconst isVal = R.curry((v, s) => s.val() === v);\n\n// Syntax -> Boolean\nconst isDot = R.allPass([isPunctuator, isVal('.')]);\nconst isColon = R.allPass([isPunctuator, isVal(':')]);\nconst isFunctionKeyword = R.allPass([isKeyword, isVal('function')]);\nconst isOperator = s => (s.match(\"punctuator\") || s.match(\"keyword\")) &&\n                          R.any(R.equals(s.val()),\n                                assignOps.concat(binaryOps).concat(unaryOps));\nconst isNonLiteralKeyword = R.allPass([isKeyword,\n                                       s => R.none(R.equals(s.val()), literalKeywords)]);\nconst isKeywordExprPrefix = R.allPass([isKeyword,\n  s => R.any(R.equals(s.val()), ['instanceof', 'typeof', 'delete', 'void',\n                                  'yield', 'throw', 'new', 'case'])]);\n// List a -> a?\nlet last = p => p.last();\n// List a -> Maybe a\nlet safeLast = R.pipe(R.cond([\n  [isEmpty, R.always(Nothing())],\n  [R.T, R.compose(Maybe.of, last)]\n]));\n\n// TODO: better name\n// List -> Boolean -> Maybe List\nlet stuffTrue = R.curry((p, b) => b ? Just(p) : Nothing());\nlet stuffFalse = R.curry((p, b) => !b ? Just(p) : Nothing());\n\n// List a -> Boolean\nlet isTopColon = R.pipe(\n  safeLast,\n  R.map(isColon),\n  Maybe.maybe(false, R.identity)\n);\n// List a -> Boolean\nlet isTopPunctuator = R.pipe(\n  safeLast,\n  R.map(isPunctuator),\n  Maybe.maybe(false, R.identity)\n);\n\n// Number -> List -> Boolean\nlet isExprReturn = R.curry((l, p) => {\n  let retKwd = safeLast(p);\n  let maybeDot = pop(p).chain(safeLast);\n\n  if (maybeDot.map(isDot).getOrElse(false)) {\n    return true;\n  }\n  return retKwd.map(s => {\n    return s.match(\"keyword\") && s.val() === 'return' && s.lineNumber() === l;\n  }).getOrElse(false);\n});\n\nconst isTopOperator = R.pipe(\n  safeLast,\n  R.map(isOperator),\n  Maybe.maybe(false, R.identity)\n);\n\nconst isTopKeywordExprPrefix = R.pipe(\n  safeLast,\n  R.map(isKeywordExprPrefix),\n  Maybe.maybe(false, R.identity)\n);\n\n// Number -> Boolean -> List -> Boolean\nlet isExprPrefix = R.curry((l, b) => R.cond([\n  // ... ({x: 42} /r/i)\n  [isEmpty, R.always(b)],\n  // ... ({x: {x: 42} /r/i })\n  [isTopColon, R.always(b)],\n  // ... throw {x: 42} /r/i\n  [isTopKeywordExprPrefix, R.T],\n  // ... 42 + {x: 42} /r/i\n  [isTopOperator, R.T],\n  // ... for ( ; {x: 42}/r/i)\n  [isTopPunctuator, R.always(b)],\n  // ... return {x: 42} /r /i\n  // ... return\\n{x: 42} /r /i\n  [isExprReturn(l), R.T],\n  [R.T, R.F],\n]));\n\n// List a -> Maybe List a\nlet curly = p => safeLast(p).map(isBraces).chain(stuffTrue(p));\nlet paren = p => safeLast(p).map(isParens).chain(stuffTrue(p));\nlet func = p => safeLast(p).map(isFunctionKeyword).chain(stuffTrue(p));\nlet ident = p => safeLast(p).map(isIdentifier).chain(stuffTrue(p));\nlet nonLiteralKeyword = p => safeLast(p).map(isNonLiteralKeyword).chain(stuffTrue(p));\n\nlet opt = R.curry((a, b, p) => {\n  let result = R.pipeK(a, b)(Maybe.of(p));\n  return Maybe.isJust(result) ? result : Maybe.of(p);\n});\n\nlet notDot = R.ifElse(\n  R.whereEq({size: 0}),\n  Just,\n  p => safeLast(p).map(s => !(s.match(\"punctuator\") && s.val() === '.')).chain(stuffTrue(p))\n);\n\n// List a -> Maybe List a\nlet pop = R.compose(Just, p => p.pop());\n\n// Maybe List a -> Maybe List a\nconst functionPrefix = R.pipeK(\n    curly,\n    pop,\n    paren,\n    pop,\n    opt(ident, pop),\n    func);\n\n// Boolean -> List a -> Boolean\nconst isRegexPrefix = b => R.anyPass([\n  // ε\n  isEmpty,\n  // P . t   where t ∈ Punctuator\n  isTopPunctuator,\n  // P . t . t'  where t \\not = \".\" and t' ∈ (Keyword \\setminus  LiteralKeyword)\n  R.pipe(\n    Maybe.of,\n    R.pipeK(\n      nonLiteralKeyword,\n      pop,\n      notDot\n    ),\n    Maybe.isJust\n  ),\n  // P . t . t' . (T)  where t \\not = \".\" and t' ∈ (Keyword \\setminus LiteralKeyword)\n  R.pipe(\n    Maybe.of,\n    R.pipeK(\n      paren,\n      pop,\n      nonLiteralKeyword,\n      pop,\n      notDot\n    ),\n    Maybe.isJust\n  ),\n  // P . function^l . x? . () . {}     where isExprPrefix(P, b, l) = false\n  R.pipe(\n    Maybe.of,\n    functionPrefix,\n    R.chain(p => {\n        return safeLast(p)\n          .map(s => s.lineNumber())\n          .chain(fnLine => {\n            return pop(p).map(isExprPrefix(fnLine, b));\n          })\n          .chain(stuffFalse(p));\n      }\n    ),\n    Maybe.isJust\n  ),\n  // P . {T}^l  where isExprPrefix(P, b, l) = false\n  p => {\n    let alreadyCheckedFunction = R.pipe(\n      Maybe.of,\n      functionPrefix,\n      Maybe.isJust\n    )(p);\n    if (alreadyCheckedFunction) {\n      return false;\n    }\n    return R.pipe(\n      Maybe.of,\n      R.chain(curly),\n      R.chain(p => {\n        return safeLast(p)\n        .map(s => s.lineNumber())\n        .chain(curlyLine => {\n          return pop(p).map(isExprPrefix(curlyLine, b));\n        })\n        .chain(stuffFalse(p));\n      }),\n      Maybe.isJust\n    )(p);\n  }\n\n\n]);\n\nfunction lastEl(l) {\n  return l[l.length - 1];\n}\n\nexport default class Reader extends Tokenizer {\n  constructor(strings, context, replacements) {\n    super(Array.isArray(strings) ? strings.join('') : strings);\n    this.delimStack = new Map();\n    this.insideSyntaxTemplate = [false];\n    this.context = context;\n\n    // setup splicing replacement array\n    if (Array.isArray(strings)) {\n      let totalIndex = 0;\n      this.replacementIndex = R.reduce((acc, strRep) => {\n        acc.push({\n          index: totalIndex + strRep[0].length,\n          replacement: strRep[1]\n        });\n        totalIndex += strRep[0].length;\n        return acc;\n      }, [], R.zip(strings, replacements));\n    }\n  }\n\n  read(stack = [], b = false, singleDelimiter = false) {\n    let prefix = List();\n    while (true) {\n      let tok = this.advance(prefix, b);\n\n      // splicing allows syntax and terms\n      if (tok.scopesets || tok instanceof Term) {\n        stack.push(tok);\n        continue;\n      }\n      if (Array.isArray(tok)) {\n        Array.prototype.push.apply(stack, tok);\n        continue;\n      }\n      if (List.isList(tok)) {\n        Array.prototype.push.apply(stack, tok.toArray());\n        continue;\n      }\n\n      if (isEOS(tok)) {\n        if (stack[0] && isLeftDelimiter(stack[0].token)) {\n          throw this.createUnexpected(tok);\n        }\n        break;\n      }\n\n      if (isLeftDelimiter(tok)) {\n        if (isLeftSyntax(tok)) {\n          this.insideSyntaxTemplate.push(true);\n        }\n        let line = tok.slice.startLocation.line;\n        let innerB = isLeftBrace(tok) ? isExprPrefix(line, b)(prefix) : true;\n        let inner = this.read([new Syntax(tok, this.context)],\n                              innerB,\n                              false);\n        let stx = new Syntax(inner, this.context);\n        prefix = prefix.concat(stx);\n        stack.push(stx);\n        if (singleDelimiter) {\n          break;\n        }\n      } else if (isRightDelimiter(tok)) {\n        if (stack[0] && !isMatchingDelimiters(stack[0].token, tok)) {\n          throw this.createUnexpected(tok);\n        }\n        let stx = new Syntax(tok, this.context);\n        stack.push(stx);\n        if (lastEl(this.insideSyntaxTemplate) && isRightSyntax(tok)) {\n          this.insideSyntaxTemplate.pop();\n        }\n        break;\n      } else {\n        let stx = new Syntax(tok, this.context);\n        prefix = prefix.concat(stx);\n        stack.push(stx);\n      }\n    }\n    return List(stack);\n  }\n\n  advance(prefix, b) {\n    this.lastIndex = this.index;\n    this.lastLine = this.line;\n    this.lastLineStart = this.lineStart;\n\n    this.skipComment();\n\n    this.startIndex = this.index;\n    this.startLine = this.line;\n    this.startLineStart = this.lineStart;\n\n    if (this.replacementIndex && this.replacementIndex[0] && this.index >= this.replacementIndex[0].index) {\n      let rep = this.replacementIndex[0].replacement;\n      this.replacementIndex.shift();\n      return rep;\n    }\n\n    let charCode = this.source.charCodeAt(this.index);\n\n    if (charCode === 0x60) { // `\n      let element, items = [];\n      let startLocation = this.getLocation();\n      let start = this.index;\n      this.index++;\n      if (lastEl(this.insideSyntaxTemplate)) {\n\n        let slice = this.getSlice(start, startLocation);\n        return {\n          type: RSYNTAX,\n          value: '`',\n          slice: slice\n        };\n      }\n      do {\n        element = this.scanTemplateElement();\n        items.push(element);\n        if (element.interp) {\n          // only read the single delimiter\n          element = this.read([], false, true);\n          assert(element.size === 1, \"should only have read a single delimiter inside a template\");\n          items.push(element.get(0));\n        }\n      } while (!element.tail);\n      return {\n        type: TokenType.TEMPLATE,\n        items: List(items),\n        slice: this.getSlice(start, startLocation)\n      };\n    } else if (charCode === 35) { // #\n      let startLocation = this.getLocation();\n      let start = this.index;\n      let slice = this.getSlice(start, startLocation);\n      this.index++;\n      // TODO: handle ` inside of syntax template interpolations\n      if (this.source.charCodeAt(this.index) === 0x60) { // `\n        this.index++;\n        return {\n          type: LSYNTAX,\n          value: '#`',\n          slice: slice\n        };\n      }\n      return {\n        type: TokenType.IDENTIFIER,\n        value: '#',\n        slice: slice\n      };\n    } else if (charCode === 64) { // @\n      let startLocation = this.getLocation();\n      let start = this.index;\n      let slice = this.getSlice(start, startLocation);\n      this.index++;\n      return {\n        type: AT,\n        value: '@',\n        slice\n      };\n    }\n\n    let lookahead = super.advance();\n    if (lookahead.type === TokenType.DIV && isRegexPrefix(b)(prefix)) {\n      return super.scanRegExp(\"/\");\n    }\n    return lookahead;\n  }\n\n  // need to override how templates are lexed because of delimiters\n  scanTemplateElement() {\n    let startLocation = this.getLocation();\n    let start = this.index;\n    while (this.index < this.source.length) {\n      let ch = this.source.charCodeAt(this.index);\n      switch (ch) {\n        case 0x60: { // `\n          // don't include the traling \"`\"\n          let slice = this.getSlice(start, startLocation);\n          this.index++;\n          return {\n            type: TokenType.TEMPLATE,\n            tail: true,\n            interp: false,\n            slice: slice\n          };\n        }\n        case 0x24:  // $\n          if (this.source.charCodeAt(this.index + 1) === 0x7B) {  // {\n            // don't include the trailing \"$\"\n            let slice = this.getSlice(start, startLocation);\n            this.index += 1;\n            return {\n              type: TokenType.TEMPLATE,\n              tail: false,\n              interp: true,\n              slice: slice\n            };\n          }\n          this.index++;\n          break;\n        case 0x5C:  // \\\\\n        {\n          let octal = this.scanStringEscape(\"\", null)[1];\n          if (octal != null) {\n            throw this.createILLEGAL();\n          }\n          break;\n        }\n        default:\n          this.index++;\n      }\n    }\n\n    throw this.createILLEGAL();\n  }\n}\n"]} \ No newline at end of file diff --git a/dist/store.js b/dist/store.js index 4944c76b..c23a8b1f 100644 --- a/dist/store.js +++ b/dist/store.js @@ -1,10 +1,10 @@ -"use strict"; +'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); -var _vm = require("vm"); +var _vm = require('vm'); var _vm2 = _interopRequireDefault(_vm); @@ -15,19 +15,23 @@ class Store { this.map = new Map(); this.nodeContext = _vm2.default.createContext(); } - has(key_793) { - return this.map.has(key_793); + + has(key) { + return this.map.has(key); } - get(key_794) { - return this.map.get(key_794); + + get(key) { + return this.map.get(key); } - set(key_795, val_796) { - this.nodeContext[key_795] = val_796; - return this.map.set(key_795, val_796); + + set(key, val) { + this.nodeContext[key] = val; + return this.map.set(key, val); } + getNodeContext() { return this.nodeContext; } } exports.default = Store; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L3N0b3JlLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOzs7Ozs7QUFDZSxNQUFNLEtBQU4sQ0FBWTtBQUN6QixnQkFBYztBQUNaLFNBQUssR0FBTCxHQUFXLElBQUksR0FBSixFQUFYO0FBQ0EsU0FBSyxXQUFMLEdBQW1CLGFBQUcsYUFBSCxFQUFuQjtBQUNEO0FBQ0QsTUFBSSxPQUFKLEVBQWE7QUFDWCxXQUFPLEtBQUssR0FBTCxDQUFTLEdBQVQsQ0FBYSxPQUFiLENBQVA7QUFDRDtBQUNELE1BQUksT0FBSixFQUFhO0FBQ1gsV0FBTyxLQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsT0FBYixDQUFQO0FBQ0Q7QUFDRCxNQUFJLE9BQUosRUFBYSxPQUFiLEVBQXNCO0FBQ3BCLFNBQUssV0FBTCxDQUFpQixPQUFqQixJQUE0QixPQUE1QjtBQUNBLFdBQU8sS0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLE9BQWIsRUFBc0IsT0FBdEIsQ0FBUDtBQUNEO0FBQ0QsbUJBQWlCO0FBQ2YsV0FBTyxLQUFLLFdBQVo7QUFDRDtBQWpCd0I7a0JBQU4sSyIsImZpbGUiOiJzdG9yZS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB2bSBmcm9tIFwidm1cIjtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFN0b3JlIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5tYXAgPSBuZXcgTWFwO1xuICAgIHRoaXMubm9kZUNvbnRleHQgPSB2bS5jcmVhdGVDb250ZXh0KCk7XG4gIH1cbiAgaGFzKGtleV83OTMpIHtcbiAgICByZXR1cm4gdGhpcy5tYXAuaGFzKGtleV83OTMpO1xuICB9XG4gIGdldChrZXlfNzk0KSB7XG4gICAgcmV0dXJuIHRoaXMubWFwLmdldChrZXlfNzk0KTtcbiAgfVxuICBzZXQoa2V5Xzc5NSwgdmFsXzc5Nikge1xuICAgIHRoaXMubm9kZUNvbnRleHRba2V5Xzc5NV0gPSB2YWxfNzk2O1xuICAgIHJldHVybiB0aGlzLm1hcC5zZXQoa2V5Xzc5NSwgdmFsXzc5Nik7XG4gIH1cbiAgZ2V0Tm9kZUNvbnRleHQoKSB7XG4gICAgcmV0dXJuIHRoaXMubm9kZUNvbnRleHQ7XG4gIH1cbn1cbiJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zdG9yZS5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7Ozs7O0FBRWUsTUFBTSxLQUFOLENBQVk7QUFDekIsZ0JBQWM7QUFDWixTQUFLLEdBQUwsR0FBVyxJQUFJLEdBQUosRUFBWDtBQUNBLFNBQUssV0FBTCxHQUFtQixhQUFHLGFBQUgsRUFBbkI7QUFDRDs7QUFFRCxNQUFJLEdBQUosRUFBUztBQUNQLFdBQU8sS0FBSyxHQUFMLENBQVMsR0FBVCxDQUFhLEdBQWIsQ0FBUDtBQUNEOztBQUVELE1BQUksR0FBSixFQUFTO0FBQ1AsV0FBTyxLQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsR0FBYixDQUFQO0FBQ0Q7O0FBRUQsTUFBSSxHQUFKLEVBQVMsR0FBVCxFQUFjO0FBQ1osU0FBSyxXQUFMLENBQWlCLEdBQWpCLElBQXdCLEdBQXhCO0FBQ0EsV0FBTyxLQUFLLEdBQUwsQ0FBUyxHQUFULENBQWEsR0FBYixFQUFrQixHQUFsQixDQUFQO0FBQ0Q7O0FBRUQsbUJBQWlCO0FBQ2YsV0FBTyxLQUFLLFdBQVo7QUFDRDtBQXJCd0I7a0JBQU4sSyIsImZpbGUiOiJzdG9yZS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB2bSBmcm9tICd2bSc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFN0b3JlIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5tYXAgPSBuZXcgTWFwKCk7XG4gICAgdGhpcy5ub2RlQ29udGV4dCA9IHZtLmNyZWF0ZUNvbnRleHQoKTtcbiAgfVxuXG4gIGhhcyhrZXkpIHtcbiAgICByZXR1cm4gdGhpcy5tYXAuaGFzKGtleSk7XG4gIH1cblxuICBnZXQoa2V5KSB7XG4gICAgcmV0dXJuIHRoaXMubWFwLmdldChrZXkpO1xuICB9XG5cbiAgc2V0KGtleSwgdmFsKSB7XG4gICAgdGhpcy5ub2RlQ29udGV4dFtrZXldID0gdmFsO1xuICAgIHJldHVybiB0aGlzLm1hcC5zZXQoa2V5LCB2YWwpO1xuICB9XG5cbiAgZ2V0Tm9kZUNvbnRleHQoKSB7XG4gICAgcmV0dXJuIHRoaXMubm9kZUNvbnRleHQ7XG4gIH1cbn1cbiJdfQ== \ No newline at end of file diff --git a/dist/sweet.js b/dist/sweet.js index 5047e198..da6c2c37 100644 --- a/dist/sweet.js +++ b/dist/sweet.js @@ -3,22 +3,12 @@ Object.defineProperty(exports, "__esModule", { value: true }); -exports.compile = exports.parse = exports.expand = undefined; - -var _shiftReader = require("./shift-reader"); - -var _shiftReader2 = _interopRequireDefault(_shiftReader); +exports.expand = expand; +exports.parse = parse; +exports.compile = compile; var _immutable = require("immutable"); -var _syntax = require("./syntax"); - -var _syntax2 = _interopRequireDefault(_syntax); - -var _env = require("./env"); - -var _env2 = _interopRequireDefault(_env); - var _shiftReducer = require("shift-reducer"); var _shiftReducer2 = _interopRequireDefault(_shiftReducer); @@ -31,8 +21,6 @@ var _shiftCodegen = require("shift-codegen"); var _shiftCodegen2 = _interopRequireDefault(_shiftCodegen); -var _scope = require("./scope"); - var _bindingMap = require("./binding-map.js"); var _bindingMap2 = _interopRequireDefault(_bindingMap); @@ -55,30 +43,44 @@ var _nodeModuleLoader2 = _interopRequireDefault(_nodeModuleLoader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } -function expand_797(source_800) { - let options_801 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - - let bindings_802 = new _bindingMap2.default(); - let modules_803 = new _modules.Modules({ bindings: bindings_802, cwd: options_801.cwd || process.cwd(), filename: options_801.filename, transform: options_801.transform || _babelCore.transform || function (c_806) { - return { code: c_806 }; - }, moduleResolver: options_801.moduleResolver || _nodeModuleResolver2.default, moduleLoader: options_801.moduleLoader || _nodeModuleLoader2.default }); - let compiledMod_804 = modules_803.compileEntrypoint(source_800, options_801.filename, options_801.enforcePragma); - let nativeImports_805 = compiledMod_804.importEntries.filter(imp_807 => !modules_803.has(imp_807.moduleSpecifier.val())); - return new _terms2.default("Module", { directives: (0, _immutable.List)(), items: nativeImports_805.concat(compiledMod_804.body).concat(compiledMod_804.exportEntries.interpose(new _terms2.default("EmptyStatement", {}))) }); +function expand(source) { + let options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + + let bindings = new _bindingMap2.default(); + let modules = new _modules.Modules({ + bindings: bindings, + cwd: options.cwd || process.cwd(), + filename: options.filename, + transform: options.transform || _babelCore.transform || function (c) { + return { code: c }; + }, + moduleResolver: options.moduleResolver || _nodeModuleResolver2.default, + moduleLoader: options.moduleLoader || _nodeModuleLoader2.default + }); + let compiledMod = modules.compileEntrypoint(source, options.filename, options.enforcePragma); + let nativeImports = compiledMod.importEntries.filter(imp => !modules.has(imp.moduleSpecifier.val())); + return new _terms2.default("Module", { + directives: (0, _immutable.List)(), + items: nativeImports.concat(compiledMod.body).concat(compiledMod.exportEntries.interpose(new _terms2.default('EmptyStatement', {}))) + }); } -function parse_798(source_808, options_809) { - let includeImports_810 = arguments.length <= 2 || arguments[2] === undefined ? true : arguments[2]; - return (0, _shiftReducer2.default)(new _parseReducer2.default({ phase: 0 }), expand_797(source_808, options_809).gen({ includeImports: includeImports_810 })); +// not available in browser + +function parse(source, options) { + let includeImports = arguments.length <= 2 || arguments[2] === undefined ? true : arguments[2]; + + return (0, _shiftReducer2.default)(new _parseReducer2.default({ phase: 0 }), expand(source, options).gen(includeImports)); } -function compile_799(source_811) { - let options_812 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - let ast_813 = parse_798(source_811, options_812, options_812.includeImports); - let gen_814 = (0, _shiftCodegen2.default)(ast_813, new _shiftCodegen.FormattedCodeGen()); - return options_812.transform && !options_812.noBabel ? options_812.transform(gen_814, { babelrc: true, filename: options_812.filename }) : { code: gen_814 }; +function compile(source) { + let options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + + let ast = parse(source, options, options.includeImports); + let gen = (0, _shiftCodegen2.default)(ast, new _shiftCodegen.FormattedCodeGen()); + return options.transform && !options.noBabel ? options.transform(gen, { + babelrc: true, + filename: options.filename + }) : { code: gen }; } -exports.expand = expand_797; -exports.parse = parse_798; -exports.compile = compile_799; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L3N3ZWV0LmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7OztBQUNBOztBQUNBOzs7O0FBQ0E7Ozs7QUFDQTs7OztBQUNBOzs7O0FBQ0E7Ozs7QUFDQTs7QUFDQTs7OztBQUNBOzs7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7QUFDQTs7Ozs7O0FBQ0EsU0FBUyxVQUFULENBQW9CLFVBQXBCLEVBQWtEO0FBQUEsTUFBbEIsV0FBa0IseURBQUosRUFBSTs7QUFDaEQsTUFBSSxlQUFlLDBCQUFuQjtBQUNBLE1BQUksY0FBYyxxQkFBWSxFQUFDLFVBQVUsWUFBWCxFQUF5QixLQUFLLFlBQVksR0FBWixJQUFtQixRQUFRLEdBQVIsRUFBakQsRUFBZ0UsVUFBVSxZQUFZLFFBQXRGLEVBQWdHLFdBQVcsWUFBWSxTQUFaLDRCQUEyQyxVQUFVLEtBQVYsRUFBaUI7QUFDbk0sYUFBTyxFQUFDLE1BQU0sS0FBUCxFQUFQO0FBQ0QsS0FGNkIsRUFFM0IsZ0JBQWdCLFlBQVksY0FBWixnQ0FGVyxFQUVpQyxjQUFjLFlBQVksWUFBWiw4QkFGL0MsRUFBWixDQUFsQjtBQUdBLE1BQUksa0JBQWtCLFlBQVksaUJBQVosQ0FBOEIsVUFBOUIsRUFBMEMsWUFBWSxRQUF0RCxFQUFnRSxZQUFZLGFBQTVFLENBQXRCO0FBQ0EsTUFBSSxvQkFBb0IsZ0JBQWdCLGFBQWhCLENBQThCLE1BQTlCLENBQXFDLFdBQVcsQ0FBQyxZQUFZLEdBQVosQ0FBZ0IsUUFBUSxlQUFSLENBQXdCLEdBQXhCLEVBQWhCLENBQWpELENBQXhCO0FBQ0EsU0FBTyxvQkFBUyxRQUFULEVBQW1CLEVBQUMsWUFBWSxzQkFBYixFQUFxQixPQUFPLGtCQUFrQixNQUFsQixDQUF5QixnQkFBZ0IsSUFBekMsRUFBK0MsTUFBL0MsQ0FBc0QsZ0JBQWdCLGFBQWhCLENBQThCLFNBQTlCLENBQXdDLG9CQUFTLGdCQUFULEVBQTJCLEVBQTNCLENBQXhDLENBQXRELENBQTVCLEVBQW5CLENBQVA7QUFDRDtBQUNELFNBQVMsU0FBVCxDQUFtQixVQUFuQixFQUErQixXQUEvQixFQUF1RTtBQUFBLE1BQTNCLGtCQUEyQix5REFBTixJQUFNOztBQUNyRSxTQUFPLDRCQUFPLDJCQUFpQixFQUFDLE9BQU8sQ0FBUixFQUFqQixDQUFQLEVBQXFDLFdBQVcsVUFBWCxFQUF1QixXQUF2QixFQUFvQyxHQUFwQyxDQUF3QyxFQUFDLGdCQUFnQixrQkFBakIsRUFBeEMsQ0FBckMsQ0FBUDtBQUNEO0FBQ0QsU0FBUyxXQUFULENBQXFCLFVBQXJCLEVBQW1EO0FBQUEsTUFBbEIsV0FBa0IseURBQUosRUFBSTs7QUFDakQsTUFBSSxVQUFVLFVBQVUsVUFBVixFQUFzQixXQUF0QixFQUFtQyxZQUFZLGNBQS9DLENBQWQ7QUFDQSxNQUFJLFVBQVUsNEJBQVEsT0FBUixFQUFpQixvQ0FBakIsQ0FBZDtBQUNBLFNBQU8sWUFBWSxTQUFaLElBQXlCLENBQUMsWUFBWSxPQUF0QyxHQUFnRCxZQUFZLFNBQVosQ0FBc0IsT0FBdEIsRUFBK0IsRUFBQyxTQUFTLElBQVYsRUFBZ0IsVUFBVSxZQUFZLFFBQXRDLEVBQS9CLENBQWhELEdBQWtJLEVBQUMsTUFBTSxPQUFQLEVBQXpJO0FBQ0Q7UUFDcUIsTSxHQUFkLFU7UUFDYSxLLEdBQWIsUztRQUNlLE8sR0FBZixXIiwiZmlsZSI6InN3ZWV0LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWRlciBmcm9tIFwiLi9zaGlmdC1yZWFkZXJcIjtcbmltcG9ydCB7TGlzdH0gZnJvbSBcImltbXV0YWJsZVwiO1xuaW1wb3J0IFN5bnRheCBmcm9tIFwiLi9zeW50YXhcIjtcbmltcG9ydCBFbnYgZnJvbSBcIi4vZW52XCI7XG5pbXBvcnQgcmVkdWNlIGZyb20gXCJzaGlmdC1yZWR1Y2VyXCI7XG5pbXBvcnQgUGFyc2VSZWR1Y2VyIGZyb20gXCIuL3BhcnNlLXJlZHVjZXJcIjtcbmltcG9ydCBjb2RlZ2VuLCB7Rm9ybWF0dGVkQ29kZUdlbn0gZnJvbSBcInNoaWZ0LWNvZGVnZW5cIjtcbmltcG9ydCB7U2NvcGUsIGZyZXNoU2NvcGV9IGZyb20gXCIuL3Njb3BlXCI7XG5pbXBvcnQgQmluZGluZ01hcCBmcm9tIFwiLi9iaW5kaW5nLW1hcC5qc1wiO1xuaW1wb3J0IFRlcm0gZnJvbSBcIi4vdGVybXNcIjtcbmltcG9ydCB7TW9kdWxlc30gZnJvbSBcIi4vbW9kdWxlc1wiO1xuaW1wb3J0IHt0cmFuc2Zvcm0gYXMgYmFiZWxUcmFuc2Zvcm19IGZyb20gXCJiYWJlbC1jb3JlXCI7XG5pbXBvcnQgbm9kZVJlc29sdmVyIGZyb20gXCIuL25vZGUtbW9kdWxlLXJlc29sdmVyXCI7XG5pbXBvcnQgbm9kZUxvYWRlciBmcm9tIFwiLi9ub2RlLW1vZHVsZS1sb2FkZXJcIjtcbmZ1bmN0aW9uIGV4cGFuZF83OTcoc291cmNlXzgwMCwgb3B0aW9uc184MDEgPSB7fSkge1xuICBsZXQgYmluZGluZ3NfODAyID0gbmV3IEJpbmRpbmdNYXA7XG4gIGxldCBtb2R1bGVzXzgwMyA9IG5ldyBNb2R1bGVzKHtiaW5kaW5nczogYmluZGluZ3NfODAyLCBjd2Q6IG9wdGlvbnNfODAxLmN3ZCB8fCBwcm9jZXNzLmN3ZCgpLCBmaWxlbmFtZTogb3B0aW9uc184MDEuZmlsZW5hbWUsIHRyYW5zZm9ybTogb3B0aW9uc184MDEudHJhbnNmb3JtIHx8IGJhYmVsVHJhbnNmb3JtIHx8IGZ1bmN0aW9uIChjXzgwNikge1xuICAgIHJldHVybiB7Y29kZTogY184MDZ9O1xuICB9LCBtb2R1bGVSZXNvbHZlcjogb3B0aW9uc184MDEubW9kdWxlUmVzb2x2ZXIgfHwgbm9kZVJlc29sdmVyLCBtb2R1bGVMb2FkZXI6IG9wdGlvbnNfODAxLm1vZHVsZUxvYWRlciB8fCBub2RlTG9hZGVyfSk7XG4gIGxldCBjb21waWxlZE1vZF84MDQgPSBtb2R1bGVzXzgwMy5jb21waWxlRW50cnlwb2ludChzb3VyY2VfODAwLCBvcHRpb25zXzgwMS5maWxlbmFtZSwgb3B0aW9uc184MDEuZW5mb3JjZVByYWdtYSk7XG4gIGxldCBuYXRpdmVJbXBvcnRzXzgwNSA9IGNvbXBpbGVkTW9kXzgwNC5pbXBvcnRFbnRyaWVzLmZpbHRlcihpbXBfODA3ID0+ICFtb2R1bGVzXzgwMy5oYXMoaW1wXzgwNy5tb2R1bGVTcGVjaWZpZXIudmFsKCkpKTtcbiAgcmV0dXJuIG5ldyBUZXJtKFwiTW9kdWxlXCIsIHtkaXJlY3RpdmVzOiBMaXN0KCksIGl0ZW1zOiBuYXRpdmVJbXBvcnRzXzgwNS5jb25jYXQoY29tcGlsZWRNb2RfODA0LmJvZHkpLmNvbmNhdChjb21waWxlZE1vZF84MDQuZXhwb3J0RW50cmllcy5pbnRlcnBvc2UobmV3IFRlcm0oXCJFbXB0eVN0YXRlbWVudFwiLCB7fSkpKX0pO1xufVxuZnVuY3Rpb24gcGFyc2VfNzk4KHNvdXJjZV84MDgsIG9wdGlvbnNfODA5LCBpbmNsdWRlSW1wb3J0c184MTAgPSB0cnVlKSB7XG4gIHJldHVybiByZWR1Y2UobmV3IFBhcnNlUmVkdWNlcih7cGhhc2U6IDB9KSwgZXhwYW5kXzc5Nyhzb3VyY2VfODA4LCBvcHRpb25zXzgwOSkuZ2VuKHtpbmNsdWRlSW1wb3J0czogaW5jbHVkZUltcG9ydHNfODEwfSkpO1xufVxuZnVuY3Rpb24gY29tcGlsZV83OTkoc291cmNlXzgxMSwgb3B0aW9uc184MTIgPSB7fSkge1xuICBsZXQgYXN0XzgxMyA9IHBhcnNlXzc5OChzb3VyY2VfODExLCBvcHRpb25zXzgxMiwgb3B0aW9uc184MTIuaW5jbHVkZUltcG9ydHMpO1xuICBsZXQgZ2VuXzgxNCA9IGNvZGVnZW4oYXN0XzgxMywgbmV3IEZvcm1hdHRlZENvZGVHZW4pO1xuICByZXR1cm4gb3B0aW9uc184MTIudHJhbnNmb3JtICYmICFvcHRpb25zXzgxMi5ub0JhYmVsID8gb3B0aW9uc184MTIudHJhbnNmb3JtKGdlbl84MTQsIHtiYWJlbHJjOiB0cnVlLCBmaWxlbmFtZTogb3B0aW9uc184MTIuZmlsZW5hbWV9KSA6IHtjb2RlOiBnZW5fODE0fTtcbn1cbmV4cG9ydCB7ZXhwYW5kXzc5NyBhcyBleHBhbmR9O1xuZXhwb3J0IHtwYXJzZV83OTggYXMgcGFyc2V9O1xuZXhwb3J0IHtjb21waWxlXzc5OSBhcyBjb21waWxlfSJdfQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zd2VldC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztRQTZCZ0IsTSxHQUFBLE07UUFvQkEsSyxHQUFBLEs7UUFJQSxPLEdBQUEsTzs7QUFwRGhCOztBQUNBOzs7O0FBQ0E7Ozs7QUFDQTs7OztBQUVBOzs7O0FBRUE7Ozs7QUFDQTs7QUFJQTs7QUFDQTs7OztBQUNBOzs7Ozs7QUFjTyxTQUFTLE1BQVQsQ0FBZ0IsTUFBaEIsRUFBaUU7QUFBQSxNQUFqQyxPQUFpQyx5REFBVCxFQUFTOztBQUN0RSxNQUFJLFdBQVcsMEJBQWY7QUFDQSxNQUFJLFVBQVUscUJBQVk7QUFDeEIsc0JBRHdCO0FBRXhCLFNBQUssUUFBUSxHQUFSLElBQWUsUUFBUSxHQUFSLEVBRkk7QUFHeEIsY0FBVSxRQUFRLFFBSE07QUFJeEIsZUFBVyxRQUFRLFNBQVIsNEJBQXVDLFVBQVMsQ0FBVCxFQUFZO0FBQzVELGFBQU8sRUFBQyxNQUFNLENBQVAsRUFBUDtBQUNELEtBTnVCO0FBT3hCLG9CQUFnQixRQUFRLGNBQVIsZ0NBUFE7QUFReEIsa0JBQWMsUUFBUSxZQUFSO0FBUlUsR0FBWixDQUFkO0FBVUEsTUFBSSxjQUFjLFFBQVEsaUJBQVIsQ0FBMEIsTUFBMUIsRUFBa0MsUUFBUSxRQUExQyxFQUFvRCxRQUFRLGFBQTVELENBQWxCO0FBQ0EsTUFBSSxnQkFBZ0IsWUFBWSxhQUFaLENBQTBCLE1BQTFCLENBQWlDLE9BQU8sQ0FBQyxRQUFRLEdBQVIsQ0FBWSxJQUFJLGVBQUosQ0FBb0IsR0FBcEIsRUFBWixDQUF6QyxDQUFwQjtBQUNBLFNBQU8sb0JBQVMsUUFBVCxFQUFtQjtBQUN4QixnQkFBWSxzQkFEWTtBQUV4QixXQUFPLGNBQWMsTUFBZCxDQUFxQixZQUFZLElBQWpDLEVBQXVDLE1BQXZDLENBQThDLFlBQVksYUFBWixDQUEwQixTQUExQixDQUFvQyxvQkFBUyxnQkFBVCxFQUEyQixFQUEzQixDQUFwQyxDQUE5QztBQUZpQixHQUFuQixDQUFQO0FBSUQ7O0FBcENEOztBQXNDTyxTQUFTLEtBQVQsQ0FBZSxNQUFmLEVBQStCLE9BQS9CLEVBQTJGO0FBQUEsTUFBckMsY0FBcUMseURBQVgsSUFBVzs7QUFDaEcsU0FBTyw0QkFBTywyQkFBaUIsRUFBQyxPQUFPLENBQVIsRUFBakIsQ0FBUCxFQUFxQyxPQUFPLE1BQVAsRUFBZSxPQUFmLEVBQXdCLEdBQXhCLENBQTRCLGNBQTVCLENBQXJDLENBQVA7QUFDRDs7QUFFTSxTQUFTLE9BQVQsQ0FBaUIsTUFBakIsRUFBeUU7QUFBQSxNQUF4QyxPQUF3Qyx5REFBaEIsRUFBZ0I7O0FBQzlFLE1BQUksTUFBTSxNQUFNLE1BQU4sRUFBYyxPQUFkLEVBQXVCLFFBQVEsY0FBL0IsQ0FBVjtBQUNBLE1BQUksTUFBTSw0QkFBUSxHQUFSLEVBQWEsb0NBQWIsQ0FBVjtBQUNBLFNBQU8sUUFBUSxTQUFSLElBQXNCLENBQUMsUUFBUSxPQUEvQixHQUEwQyxRQUFRLFNBQVIsQ0FBa0IsR0FBbEIsRUFBdUI7QUFDdEUsYUFBUyxJQUQ2RDtBQUV0RSxjQUFVLFFBQVE7QUFGb0QsR0FBdkIsQ0FBMUMsR0FHRixFQUFFLE1BQU0sR0FBUixFQUhMO0FBSUQiLCJmaWxlIjoic3dlZXQuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBAZmxvd1xuaW1wb3J0IHsgTGlzdCB9IGZyb20gXCJpbW11dGFibGVcIjtcbmltcG9ydCByZWR1Y2UgZnJvbSBcInNoaWZ0LXJlZHVjZXJcIjtcbmltcG9ydCBQYXJzZVJlZHVjZXIgZnJvbSBcIi4vcGFyc2UtcmVkdWNlclwiO1xuaW1wb3J0IGNvZGVnZW4sIHsgRm9ybWF0dGVkQ29kZUdlbiB9IGZyb20gXCJzaGlmdC1jb2RlZ2VuXCI7XG5cbmltcG9ydCBCaW5kaW5nTWFwIGZyb20gXCIuL2JpbmRpbmctbWFwLmpzXCI7XG5cbmltcG9ydCBUZXJtIGZyb20gXCIuL3Rlcm1zXCI7XG5pbXBvcnQgeyBNb2R1bGVzIH0gZnJvbSAnLi9tb2R1bGVzJztcblxuLy8gbm90IGF2YWlsYWJsZSBpbiBicm93c2VyXG5cbmltcG9ydCB7IHRyYW5zZm9ybSBhcyBiYWJlbFRyYW5zZm9ybSB9IGZyb20gXCJiYWJlbC1jb3JlXCI7XG5pbXBvcnQgbm9kZVJlc29sdmVyIGZyb20gXCIuL25vZGUtbW9kdWxlLXJlc29sdmVyXCI7XG5pbXBvcnQgbm9kZUxvYWRlciBmcm9tIFwiLi9ub2RlLW1vZHVsZS1sb2FkZXJcIjtcblxudHlwZSBDb2RlT3V0cHV0ID0ge1xuICBjb2RlOiBzdHJpbmdcbn1cblxudHlwZSBTd2VldE9wdGlvbnMgPSB7XG4gIGluY2x1ZGVJbXBvcnRzPzogYm9vbGVhbjtcbiAgY3dkPzogc3RyaW5nO1xuICBlbmZvcmNlUHJhZ21hPzogYm9vbGVhbjtcbiAgZmlsZW5hbWU/OiBzdHJpbmc7XG4gIHRyYW5zZm9ybT86IChzOiBzdHJpbmcpID0+IHsgY29kZTogc3RyaW5nIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBleHBhbmQoc291cmNlOiBzdHJpbmcsIG9wdGlvbnM6IFN3ZWV0T3B0aW9ucyA9IHt9KTogYW55IHtcbiAgbGV0IGJpbmRpbmdzID0gbmV3IEJpbmRpbmdNYXAoKTtcbiAgbGV0IG1vZHVsZXMgPSBuZXcgTW9kdWxlcyh7XG4gICAgYmluZGluZ3MsXG4gICAgY3dkOiBvcHRpb25zLmN3ZCB8fCBwcm9jZXNzLmN3ZCgpLFxuICAgIGZpbGVuYW1lOiBvcHRpb25zLmZpbGVuYW1lLFxuICAgIHRyYW5zZm9ybTogb3B0aW9ucy50cmFuc2Zvcm0gfHwgYmFiZWxUcmFuc2Zvcm0gfHwgZnVuY3Rpb24oYykge1xuICAgICAgcmV0dXJuIHtjb2RlOiBjfTtcbiAgICB9LFxuICAgIG1vZHVsZVJlc29sdmVyOiBvcHRpb25zLm1vZHVsZVJlc29sdmVyIHx8IG5vZGVSZXNvbHZlcixcbiAgICBtb2R1bGVMb2FkZXI6IG9wdGlvbnMubW9kdWxlTG9hZGVyIHx8IG5vZGVMb2FkZXJcbiAgfSk7XG4gIGxldCBjb21waWxlZE1vZCA9IG1vZHVsZXMuY29tcGlsZUVudHJ5cG9pbnQoc291cmNlLCBvcHRpb25zLmZpbGVuYW1lLCBvcHRpb25zLmVuZm9yY2VQcmFnbWEpO1xuICBsZXQgbmF0aXZlSW1wb3J0cyA9IGNvbXBpbGVkTW9kLmltcG9ydEVudHJpZXMuZmlsdGVyKGltcCA9PiAhbW9kdWxlcy5oYXMoaW1wLm1vZHVsZVNwZWNpZmllci52YWwoKSkpO1xuICByZXR1cm4gbmV3IFRlcm0oXCJNb2R1bGVcIiwge1xuICAgIGRpcmVjdGl2ZXM6IExpc3QoKSxcbiAgICBpdGVtczogbmF0aXZlSW1wb3J0cy5jb25jYXQoY29tcGlsZWRNb2QuYm9keSkuY29uY2F0KGNvbXBpbGVkTW9kLmV4cG9ydEVudHJpZXMuaW50ZXJwb3NlKG5ldyBUZXJtKCdFbXB0eVN0YXRlbWVudCcsIHt9KSkpXG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcGFyc2Uoc291cmNlOiBzdHJpbmcsIG9wdGlvbnM6IFN3ZWV0T3B0aW9ucywgaW5jbHVkZUltcG9ydHM6IGJvb2xlYW4gPSB0cnVlKTogYW55IHtcbiAgcmV0dXJuIHJlZHVjZShuZXcgUGFyc2VSZWR1Y2VyKHtwaGFzZTogMH0pLCBleHBhbmQoc291cmNlLCBvcHRpb25zKS5nZW4oaW5jbHVkZUltcG9ydHMpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNvbXBpbGUoc291cmNlOiBzdHJpbmcsIG9wdGlvbnM6IFN3ZWV0T3B0aW9ucyA9IHt9KTogQ29kZU91dHB1dCB7XG4gIGxldCBhc3QgPSBwYXJzZShzb3VyY2UsIG9wdGlvbnMsIG9wdGlvbnMuaW5jbHVkZUltcG9ydHMpO1xuICBsZXQgZ2VuID0gY29kZWdlbihhc3QsIG5ldyBGb3JtYXR0ZWRDb2RlR2VuKCkpO1xuICByZXR1cm4gb3B0aW9ucy50cmFuc2Zvcm0gJiYgKCFvcHRpb25zLm5vQmFiZWwpID8gb3B0aW9ucy50cmFuc2Zvcm0oZ2VuLCB7XG4gICAgYmFiZWxyYzogdHJ1ZSxcbiAgICBmaWxlbmFtZTogb3B0aW9ucy5maWxlbmFtZVxuICB9KSA6IHsgY29kZTogZ2VuIH07XG59XG4iXX0= \ No newline at end of file diff --git a/dist/symbol.js b/dist/symbol.js index 57dac680..6bb1e950 100644 --- a/dist/symbol.js +++ b/dist/symbol.js @@ -3,30 +3,35 @@ Object.defineProperty(exports, "__esModule", { value: true }); -let internedMap_815 = new Map(); -let counter_816 = 0; -function gensym_817(name_820) { - let prefix_821 = name_820 == null ? "s_" : name_820 + "_"; - let sym_822 = new Symbol_818(prefix_821 + counter_816); - counter_816++; - return sym_822; +exports.gensym = gensym; +let internedMap = new Map(); + +let counter = 0; + +function gensym(name) { + let prefix = name == null ? "s_" : name + "_"; + let sym = new Symbol(prefix + counter); + counter++; + return sym; } -function Symbol_818(name_823) { - this.name = name_823; + +function Symbol(name) { + this.name = name; } -Symbol_818.prototype.toString = function () { +Symbol.prototype.toString = function () { return this.name; }; -function makeSymbol_819(name_824) { - if (internedMap_815.has(name_824)) { - return internedMap_815.get(name_824); + +function makeSymbol(name) { + if (internedMap.has(name)) { + return internedMap.get(name); } else { - let sym = new Symbol_818(name_824); - internedMap_815.set(name_824, sym); + let sym = new Symbol(name); + internedMap.set(name, sym); return sym; } } -exports.Symbol = makeSymbol_819; -exports.SymbolClass = Symbol_818; -exports.gensym = gensym_817; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L3N5bWJvbC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLElBQUksa0JBQWtCLElBQUksR0FBSixFQUF0QjtBQUNBLElBQUksY0FBYyxDQUFsQjtBQUNBLFNBQVMsVUFBVCxDQUFvQixRQUFwQixFQUE4QjtBQUM1QixNQUFJLGFBQWEsWUFBWSxJQUFaLEdBQW1CLElBQW5CLEdBQTBCLFdBQVcsR0FBdEQ7QUFDQSxNQUFJLFVBQVUsSUFBSSxVQUFKLENBQWUsYUFBYSxXQUE1QixDQUFkO0FBQ0E7QUFDQSxTQUFPLE9BQVA7QUFDRDtBQUNELFNBQVMsVUFBVCxDQUFvQixRQUFwQixFQUE4QjtBQUM1QixPQUFLLElBQUwsR0FBWSxRQUFaO0FBQ0Q7QUFDRCxXQUFXLFNBQVgsQ0FBcUIsUUFBckIsR0FBZ0MsWUFBWTtBQUMxQyxTQUFPLEtBQUssSUFBWjtBQUNELENBRkQ7QUFHQSxTQUFTLGNBQVQsQ0FBd0IsUUFBeEIsRUFBa0M7QUFDaEMsTUFBSSxnQkFBZ0IsR0FBaEIsQ0FBb0IsUUFBcEIsQ0FBSixFQUFtQztBQUNqQyxXQUFPLGdCQUFnQixHQUFoQixDQUFvQixRQUFwQixDQUFQO0FBQ0QsR0FGRCxNQUVPO0FBQ0wsUUFBSSxNQUFNLElBQUksVUFBSixDQUFlLFFBQWYsQ0FBVjtBQUNBLG9CQUFnQixHQUFoQixDQUFvQixRQUFwQixFQUE4QixHQUE5QjtBQUNBLFdBQU8sR0FBUDtBQUNEO0FBQ0Y7UUFDeUIsTSxHQUFsQixjO1FBQXdDLFcsR0FBZCxVO1FBQ1osTSxHQUFkLFUiLCJmaWxlIjoic3ltYm9sLmpzIiwic291cmNlc0NvbnRlbnQiOlsibGV0IGludGVybmVkTWFwXzgxNSA9IG5ldyBNYXA7XG5sZXQgY291bnRlcl84MTYgPSAwO1xuZnVuY3Rpb24gZ2Vuc3ltXzgxNyhuYW1lXzgyMCkge1xuICBsZXQgcHJlZml4XzgyMSA9IG5hbWVfODIwID09IG51bGwgPyBcInNfXCIgOiBuYW1lXzgyMCArIFwiX1wiO1xuICBsZXQgc3ltXzgyMiA9IG5ldyBTeW1ib2xfODE4KHByZWZpeF84MjEgKyBjb3VudGVyXzgxNik7XG4gIGNvdW50ZXJfODE2Kys7XG4gIHJldHVybiBzeW1fODIyO1xufVxuZnVuY3Rpb24gU3ltYm9sXzgxOChuYW1lXzgyMykge1xuICB0aGlzLm5hbWUgPSBuYW1lXzgyMztcbn1cblN5bWJvbF84MTgucHJvdG90eXBlLnRvU3RyaW5nID0gZnVuY3Rpb24gKCkge1xuICByZXR1cm4gdGhpcy5uYW1lO1xufTtcbmZ1bmN0aW9uIG1ha2VTeW1ib2xfODE5KG5hbWVfODI0KSB7XG4gIGlmIChpbnRlcm5lZE1hcF84MTUuaGFzKG5hbWVfODI0KSkge1xuICAgIHJldHVybiBpbnRlcm5lZE1hcF84MTUuZ2V0KG5hbWVfODI0KTtcbiAgfSBlbHNlIHtcbiAgICBsZXQgc3ltID0gbmV3IFN5bWJvbF84MTgobmFtZV84MjQpO1xuICAgIGludGVybmVkTWFwXzgxNS5zZXQobmFtZV84MjQsIHN5bSk7XG4gICAgcmV0dXJuIHN5bTtcbiAgfVxufVxuZXhwb3J0IHttYWtlU3ltYm9sXzgxOSBhcyBTeW1ib2wsIFN5bWJvbF84MTggYXMgU3ltYm9sQ2xhc3N9O1xuZXhwb3J0IHtnZW5zeW1fODE3IGFzIGdlbnN5bX0iXX0= \ No newline at end of file + +exports.Symbol = makeSymbol; +exports.SymbolClass = Symbol; +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zeW1ib2wuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7UUFJZ0IsTSxHQUFBLE07QUFKaEIsSUFBSSxjQUFjLElBQUksR0FBSixFQUFsQjs7QUFFQSxJQUFJLFVBQVUsQ0FBZDs7QUFFTyxTQUFTLE1BQVQsQ0FBZ0IsSUFBaEIsRUFBc0I7QUFDM0IsTUFBSSxTQUFTLFFBQVEsSUFBUixHQUFlLElBQWYsR0FBc0IsT0FBTyxHQUExQztBQUNBLE1BQUksTUFBTSxJQUFJLE1BQUosQ0FBVyxTQUFTLE9BQXBCLENBQVY7QUFDQTtBQUNBLFNBQU8sR0FBUDtBQUNEOztBQUVELFNBQVMsTUFBVCxDQUFnQixJQUFoQixFQUFzQjtBQUNwQixPQUFLLElBQUwsR0FBWSxJQUFaO0FBQ0Q7QUFDRCxPQUFPLFNBQVAsQ0FBaUIsUUFBakIsR0FBNEIsWUFBWTtBQUN0QyxTQUFPLEtBQUssSUFBWjtBQUNELENBRkQ7O0FBSUEsU0FBUyxVQUFULENBQW9CLElBQXBCLEVBQTBCO0FBQ3hCLE1BQUksWUFBWSxHQUFaLENBQWdCLElBQWhCLENBQUosRUFBMkI7QUFDekIsV0FBTyxZQUFZLEdBQVosQ0FBZ0IsSUFBaEIsQ0FBUDtBQUNELEdBRkQsTUFFTztBQUNMLFFBQUksTUFBTSxJQUFJLE1BQUosQ0FBVyxJQUFYLENBQVY7QUFDQSxnQkFBWSxHQUFaLENBQWdCLElBQWhCLEVBQXNCLEdBQXRCO0FBQ0EsV0FBTyxHQUFQO0FBQ0Q7QUFDRjs7UUFHZSxNLEdBQWQsVTtRQUNVLFcsR0FBVixNIiwiZmlsZSI6InN5bWJvbC5qcyIsInNvdXJjZXNDb250ZW50IjpbImxldCBpbnRlcm5lZE1hcCA9IG5ldyBNYXAoKTtcblxubGV0IGNvdW50ZXIgPSAwO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2Vuc3ltKG5hbWUpIHtcbiAgbGV0IHByZWZpeCA9IG5hbWUgPT0gbnVsbCA/IFwic19cIiA6IG5hbWUgKyBcIl9cIjtcbiAgbGV0IHN5bSA9IG5ldyBTeW1ib2wocHJlZml4ICsgY291bnRlcik7XG4gIGNvdW50ZXIrKztcbiAgcmV0dXJuIHN5bTtcbn1cblxuZnVuY3Rpb24gU3ltYm9sKG5hbWUpIHtcbiAgdGhpcy5uYW1lID0gbmFtZTtcbn1cblN5bWJvbC5wcm90b3R5cGUudG9TdHJpbmcgPSBmdW5jdGlvbiAoKSB7XG4gIHJldHVybiB0aGlzLm5hbWU7XG59O1xuXG5mdW5jdGlvbiBtYWtlU3ltYm9sKG5hbWUpIHtcbiAgaWYgKGludGVybmVkTWFwLmhhcyhuYW1lKSkge1xuICAgIHJldHVybiBpbnRlcm5lZE1hcC5nZXQobmFtZSk7XG4gIH0gZWxzZSB7XG4gICAgbGV0IHN5bSA9IG5ldyBTeW1ib2wobmFtZSk7XG4gICAgaW50ZXJuZWRNYXAuc2V0KG5hbWUsIHN5bSk7XG4gICAgcmV0dXJuIHN5bTtcbiAgfVxufVxuXG5leHBvcnQge1xuICBtYWtlU3ltYm9sIGFzIFN5bWJvbCxcbiAgU3ltYm9sIGFzIFN5bWJvbENsYXNzXG59O1xuIl19 \ No newline at end of file diff --git a/dist/syntax.js b/dist/syntax.js index 1bd5f661..1cf4aec1 100644 --- a/dist/syntax.js +++ b/dist/syntax.js @@ -15,49 +15,143 @@ var _bindingMap2 = _interopRequireDefault(_bindingMap); var _ramdaFantasy = require("ramda-fantasy"); -var _tokenizer = require("shift-parser/dist/tokenizer"); - var _ramda = require("ramda"); var _ = _interopRequireWildcard(_ramda); +var _tokenizer = require("shift-parser/dist/tokenizer"); + function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } -const Just_825 = _ramdaFantasy.Maybe.Just; -const Nothing_826 = _ramdaFantasy.Maybe.Nothing; -function getFirstSlice_827(stx_831) { - if (!stx_831 || typeof stx_831.isDelimiter !== "function") return null; - if (!stx_831.isDelimiter()) { - return stx_831.token.slice; +function getFirstSlice(stx) { + if (!stx || typeof stx.isDelimiter !== 'function') return null; // TODO: should not have to do this + if (!stx.isDelimiter()) { + return stx.token.slice; } - return stx_831.token.get(0).token.slice; + return stx.token.get(0).token.slice; } -function sizeDecending_828(a_832, b_833) { - if (a_832.scopes.size > b_833.scopes.size) { + +function sizeDecending(a, b) { + if (a.scopes.size > b.scopes.size) { return -1; - } else if (b_833.scopes.size > a_832.scopes.size) { + } else if (b.scopes.size > a.scopes.size) { return 1; } else { return 0; } } -let Types_829 = { null: { match: token_834 => !Types_829.delimiter.match(token_834) && token_834.type === _tokenizer.TokenType.NULL, create: (value_835, stx_836) => new Syntax({ type: _tokenizer.TokenType.NULL, value: null }, stx_836) }, number: { match: token_837 => !Types_829.delimiter.match(token_837) && token_837.type.klass === _tokenizer.TokenClass.NumericLiteral, create: (value_838, stx_839) => new Syntax({ type: _tokenizer.TokenType.NUMBER, value: value_838 }, stx_839) }, string: { match: token_840 => !Types_829.delimiter.match(token_840) && token_840.type.klass === _tokenizer.TokenClass.StringLiteral, create: (value_841, stx_842) => new Syntax({ type: _tokenizer.TokenType.STRING, str: value_841 }, stx_842) }, punctuator: { match: token_843 => !Types_829.delimiter.match(token_843) && token_843.type.klass === _tokenizer.TokenClass.Punctuator, create: (value_844, stx_845) => new Syntax({ type: { klass: _tokenizer.TokenClass.Punctuator, name: value_844 }, value: value_844 }, stx_845) }, keyword: { match: token_846 => !Types_829.delimiter.match(token_846) && token_846.type.klass === _tokenizer.TokenClass.Keyword, create: (value_847, stx_848) => new Syntax({ type: { klass: _tokenizer.TokenClass.Keyword, name: value_847 }, value: value_847 }, stx_848) }, identifier: { match: token_849 => !Types_829.delimiter.match(token_849) && token_849.type.klass === _tokenizer.TokenClass.Ident, create: (value_850, stx_851) => new Syntax({ type: _tokenizer.TokenType.IDENTIFIER, value: value_850 }, stx_851) }, regularExpression: { match: token_852 => !Types_829.delimiter.match(token_852) && token_852.type.klass === _tokenizer.TokenClass.RegularExpression, create: (value_853, stx_854) => new Syntax({ type: _tokenizer.TokenType.REGEXP, value: value_853 }, stx_854) }, braces: { match: token_855 => Types_829.delimiter.match(token_855) && token_855.get(0).token.type === _tokenizer.TokenType.LBRACE, create: (inner_856, stx_857) => { - let left_858 = new Syntax({ type: _tokenizer.TokenType.LBRACE, value: "{", slice: getFirstSlice_827(stx_857) }); - let right_859 = new Syntax({ type: _tokenizer.TokenType.RBRACE, value: "}", slice: getFirstSlice_827(stx_857) }); - return new Syntax(_immutable.List.of(left_858).concat(inner_856).push(right_859), stx_857); - } }, brackets: { match: token_860 => Types_829.delimiter.match(token_860) && token_860.get(0).token.type === _tokenizer.TokenType.LBRACK, create: (inner_861, stx_862) => { - let left_863 = new Syntax({ type: _tokenizer.TokenType.LBRACK, value: "[", slice: getFirstSlice_827(stx_862) }); - let right_864 = new Syntax({ type: _tokenizer.TokenType.RBRACK, value: "]", slice: getFirstSlice_827(stx_862) }); - return new Syntax(_immutable.List.of(left_863).concat(inner_861).push(right_864), stx_862); - } }, parens: { match: token_865 => Types_829.delimiter.match(token_865) && token_865.get(0).token.type === _tokenizer.TokenType.LPAREN, create: (inner_866, stx_867) => { - let left_868 = new Syntax({ type: _tokenizer.TokenType.LPAREN, value: "(", slice: getFirstSlice_827(stx_867) }); - let right_869 = new Syntax({ type: _tokenizer.TokenType.RPAREN, value: ")", slice: getFirstSlice_827(stx_867) }); - return new Syntax(_immutable.List.of(left_868).concat(inner_866).push(right_869), stx_867); - } }, assign: { match: token_870 => { - if (Types_829.punctuator.match(token_870)) { - switch (token_870.value) { + +let Types = exports.Types = { + null: { + match: token => !Types.delimiter.match(token) && token.type === _tokenizer.TokenType.NULL, + create: (value, stx) => new Syntax({ + type: _tokenizer.TokenType.NULL, + value: null + }, stx) + }, + number: { + match: token => !Types.delimiter.match(token) && token.type.klass === _tokenizer.TokenClass.NumericLiteral, + create: (value, stx) => new Syntax({ + type: _tokenizer.TokenType.NUMBER, + value: value + }, stx) + }, + string: { + match: token => !Types.delimiter.match(token) && token.type.klass === _tokenizer.TokenClass.StringLiteral, + create: (value, stx) => new Syntax({ + type: _tokenizer.TokenType.STRING, + str: value + }, stx) + }, + punctuator: { + match: token => !Types.delimiter.match(token) && token.type.klass === _tokenizer.TokenClass.Punctuator, + create: (value, stx) => new Syntax({ + type: { + klass: _tokenizer.TokenClass.Punctuator, + name: value + }, + value: value + }, stx) + }, + keyword: { + match: token => !Types.delimiter.match(token) && token.type.klass === _tokenizer.TokenClass.Keyword, + create: (value, stx) => new Syntax({ + type: { + klass: _tokenizer.TokenClass.Keyword, + name: value + }, + value: value + }, stx) + }, + identifier: { + match: token => !Types.delimiter.match(token) && token.type.klass === _tokenizer.TokenClass.Ident, + create: (value, stx) => new Syntax({ + type: _tokenizer.TokenType.IDENTIFIER, + value: value + }, stx) + }, + regularExpression: { + match: token => !Types.delimiter.match(token) && token.type.klass === _tokenizer.TokenClass.RegularExpression, + create: (value, stx) => new Syntax({ + type: _tokenizer.TokenType.REGEXP, + value: value + }, stx) + }, + braces: { + match: token => Types.delimiter.match(token) && token.get(0).token.type === _tokenizer.TokenType.LBRACE, + create: (inner, stx) => { + let left = new Syntax({ + type: _tokenizer.TokenType.LBRACE, + value: "{", + slice: getFirstSlice(stx) + }); + let right = new Syntax({ + type: _tokenizer.TokenType.RBRACE, + value: "}", + slice: getFirstSlice(stx) + }); + return new Syntax(_immutable.List.of(left).concat(inner).push(right), stx); + } + }, + brackets: { + match: token => Types.delimiter.match(token) && token.get(0).token.type === _tokenizer.TokenType.LBRACK, + create: (inner, stx) => { + let left = new Syntax({ + type: _tokenizer.TokenType.LBRACK, + value: "[", + slice: getFirstSlice(stx) + }); + let right = new Syntax({ + type: _tokenizer.TokenType.RBRACK, + value: "]", + slice: getFirstSlice(stx) + }); + return new Syntax(_immutable.List.of(left).concat(inner).push(right), stx); + } + }, + parens: { + match: token => Types.delimiter.match(token) && token.get(0).token.type === _tokenizer.TokenType.LPAREN, + create: (inner, stx) => { + let left = new Syntax({ + type: _tokenizer.TokenType.LPAREN, + value: "(", + slice: getFirstSlice(stx) + }); + let right = new Syntax({ + type: _tokenizer.TokenType.RPAREN, + value: ")", + slice: getFirstSlice(stx) + }); + return new Syntax(_immutable.List.of(left).concat(inner).push(right), stx); + } + }, + + assign: { + match: token => { + if (Types.punctuator.match(token)) { + switch (token.value) { case "=": case "|=": case "^=": @@ -76,153 +170,183 @@ let Types_829 = { null: { match: token_834 => !Types_829.delimiter.match(token_8 } } return false; - } }, boolean: { match: token_871 => !Types_829.delimiter.match(token_871) && token_871.type === _tokenizer.TokenType.TRUE || token_871.type === _tokenizer.TokenType.FALSE }, template: { match: token_872 => !Types_829.delimiter.match(token_872) && token_872.type === _tokenizer.TokenType.TEMPLATE }, delimiter: { match: token_873 => _immutable.List.isList(token_873) }, syntaxTemplate: { match: token_874 => Types_829.delimiter.match(token_874) && token_874.get(0).val() === "#`" }, eof: { match: token_875 => !Types_829.delimiter.match(token_875) && token_875.type === _tokenizer.TokenType.EOS } }; -; -const ALL_PHASES_830 = {}; -; + } + }, + + boolean: { + match: token => !Types.delimiter.match(token) && token.type === _tokenizer.TokenType.TRUE || token.type === _tokenizer.TokenType.FALSE + }, + + template: { + match: token => !Types.delimiter.match(token) && token.type === _tokenizer.TokenType.TEMPLATE + }, + + delimiter: { + match: token => _immutable.List.isList(token) + }, + + syntaxTemplate: { + match: token => Types.delimiter.match(token) && token.get(0).val() === '#`' + }, + + eof: { + match: token => !Types.delimiter.match(token) && token.type === _tokenizer.TokenType.EOS + } +}; +const ALL_PHASES = exports.ALL_PHASES = {}; + class Syntax { - constructor(token_876) { - let oldstx_877 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - this.token = token_876; - this.bindings = oldstx_877.bindings != null ? oldstx_877.bindings : new _bindingMap2.default(); - this.scopesets = oldstx_877.scopesets != null ? oldstx_877.scopesets : { all: (0, _immutable.List)(), phase: (0, _immutable.Map)() }; + constructor(token, oldstx) { + this.token = token; + this.bindings = oldstx && oldstx.bindings != null ? oldstx.bindings : new _bindingMap2.default(); + this.scopesets = oldstx && oldstx.scopesets != null ? oldstx.scopesets : { + all: (0, _immutable.List)(), + phase: (0, _immutable.Map)() + }; Object.freeze(this); } - static of(token_878) { - let stx_879 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + // token: Token | List; - return new Syntax(token_878, stx_879); + + static of(token, stx) { + return new Syntax(token, stx); } - static from(type_880, value_881) { - let stx_882 = arguments.length <= 2 || arguments[2] === undefined ? {} : arguments[2]; - if (!Types_829[type_880]) { - throw new Error(type_880 + " is not a valid type"); - } else if (!Types_829[type_880].create) { - throw new Error("Cannot create a syntax from type " + type_880); + static from(type, value, stx) { + if (!Types[type]) { + throw new Error(type + " is not a valid type"); + } else if (!Types[type].create) { + throw new Error("Cannot create a syntax from type " + type); } - let newstx_883 = Types_829[type_880].create(value_881, stx_882); - let slice_884 = getFirstSlice_827(stx_882); - if (slice_884 != null) { - newstx_883.token.slice = slice_884; + let newstx = Types[type].create(value, stx); + let slice = getFirstSlice(stx); + if (slice != null) { + newstx.token.slice = slice; } - return newstx_883; + return newstx; } - from(type_885, value_886) { - return Syntax.from(type_885, value_886, this); + + from(type, value) { + return Syntax.from(type, value, this); } + fromNull() { return this.from("null", null); } - fromNumber(value_887) { - return this.from("number", value_887); + + fromNumber(value) { + return this.from('number', value); } - fromString(value_888) { - return this.from("string", value_888); + + fromString(value) { + return this.from("string", value); } - fromPunctuator(value_889) { - return this.from("punctuator", value_889); + + fromPunctuator(value) { + return this.from("punctuator", value); } - fromKeyword(value_890) { - return this.from("keyword"); + + fromKeyword(value) { + return this.from("keyword", value); } - fromIdentifier(value_891) { - return this.from("identifier", value_891); + + fromIdentifier(value) { + return this.from("identifier", value); } - fromRegularExpression(value_892) { - return this.from("regularExpression", value_892); + + fromRegularExpression(value) { + return this.from("regularExpression", value); } - fromBraces(inner_893) { - return this.from("braces", inner_893); + + fromBraces(inner) { + return this.from("braces", inner); } - fromBrackets(inner_894) { - return this.from("brackets", inner_894); + + fromBrackets(inner) { + return this.from("brackets", inner); } - fromParens(inner_895) { - return this.from("parens", inner_895); + + fromParens(inner) { + return this.from("parens", inner); } - static fromNull() { - let stx_896 = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; - return Syntax.from("null", null, stx_896); + static fromNull(stx) { + return Syntax.from("null", null, stx); } - static fromNumber(value_897) { - let stx_898 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("number", value_897, stx_898); + static fromNumber(value, stx) { + return Syntax.from("number", value, stx); } - static fromString(value_899) { - let stx_900 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("string", value_899, stx_900); + static fromString(value, stx) { + return Syntax.from("string", value, stx); } - static fromPunctuator(value_901) { - let stx_902 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("punctuator", value_901, stx_902); + static fromPunctuator(value, stx) { + return Syntax.from("punctuator", value, stx); } - static fromKeyword(value_903) { - let stx_904 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("keyword", value_903, stx_904); + static fromKeyword(value, stx) { + return Syntax.from("keyword", value, stx); } - static fromIdentifier(value_905) { - let stx_906 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("identifier", value_905, stx_906); + static fromIdentifier(value, stx) { + return Syntax.from("identifier", value, stx); } - static fromRegularExpression(value_907) { - let stx_908 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("regularExpression", value_907, stx_908); + static fromRegularExpression(value, stx) { + return Syntax.from("regularExpression", value, stx); } - static fromBraces(inner_909) { - let stx_910 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("braces", inner_909, stx_910); + static fromBraces(inner, stx) { + return Syntax.from("braces", inner, stx); } - static fromBrackets(inner_911) { - let stx_912 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("brackets", inner_911, stx_912); + static fromBrackets(inner, stx) { + return Syntax.from("brackets", inner, stx); } - static fromParens(inner_913) { - let stx_914 = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; - return Syntax.from("parens", inner_913, stx_914); + static fromParens(inner, stx) { + return Syntax.from("parens", inner, stx); } - resolve(phase_915) { - (0, _errors.assert)(phase_915 != null, "must provide a phase to resolve"); - let allScopes_916 = this.scopesets.all; - let stxScopes_917 = this.scopesets.phase.has(phase_915) ? this.scopesets.phase.get(phase_915) : (0, _immutable.List)(); - stxScopes_917 = allScopes_916.concat(stxScopes_917); - if (stxScopes_917.size === 0 || !(this.match("identifier") || this.match("keyword"))) { + + // () -> string + resolve(phase) { + (0, _errors.assert)(phase != null, "must provide a phase to resolve"); + let allScopes = this.scopesets.all; + let stxScopes = this.scopesets.phase.has(phase) ? this.scopesets.phase.get(phase) : (0, _immutable.List)(); + stxScopes = allScopes.concat(stxScopes); + if (stxScopes.size === 0 || !(this.match('identifier') || this.match('keyword'))) { return this.token.value; } - let scope_918 = stxScopes_917.last(); - let bindings_919 = this.bindings; - if (scope_918) { - let scopesetBindingList = bindings_919.get(this); + let scope = stxScopes.last(); + let bindings = this.bindings; + if (scope) { + // List<{ scopes: List, binding: Symbol }> + let scopesetBindingList = bindings.get(this); + if (scopesetBindingList) { + // { scopes: List, binding: Symbol } let biggestBindingPair = scopesetBindingList.filter(_ref => { let scopes = _ref.scopes; - let binding = _ref.binding; - return scopes.isSubset(stxScopes_917); - }).sort(sizeDecending_828); + return scopes.isSubset(stxScopes); + }).sort(sizeDecending); + if (biggestBindingPair.size >= 2 && biggestBindingPair.get(0).scopes.size === biggestBindingPair.get(1).scopes.size) { - let debugBase = "{" + stxScopes_917.map(s_920 => s_920.toString()).join(", ") + "}"; + let debugBase = '{' + stxScopes.map(s => s.toString()).join(', ') + '}'; let debugAmbigousScopesets = biggestBindingPair.map(_ref2 => { let scopes = _ref2.scopes; - return "{" + scopes.map(s_921 => s_921.toString()).join(", ") + "}"; - }).join(", "); - throw new Error("Scopeset " + debugBase + " has ambiguous subsets " + debugAmbigousScopesets); + return '{' + scopes.map(s => s.toString()).join(', ') + '}'; + }).join(', '); + throw new Error('Scopeset ' + debugBase + ' has ambiguous subsets ' + debugAmbigousScopesets); } else if (biggestBindingPair.size !== 0) { let bindingStr = biggestBindingPair.get(0).binding.toString(); if (_ramdaFantasy.Maybe.isJust(biggestBindingPair.get(0).alias)) { - return biggestBindingPair.get(0).alias.getOrElse(null).resolve(phase_915); + // null never happens because we just checked if it is a Just + return biggestBindingPair.get(0).alias.getOrElse(null).resolve(phase); } return bindingStr; } @@ -230,21 +354,23 @@ class Syntax { } return this.token.value; } + val() { (0, _errors.assert)(!this.match("delimiter"), "cannot get the val of a delimiter"); if (this.match("string")) { return this.token.str; } if (this.match("template")) { - return this.token.items.map(el_922 => { - if (typeof el_922.match === "function" && el_922.match("delimiter")) { - return "${...}"; + return this.token.items.map(el => { + if (typeof el.match === 'function' && el.match("delimiter")) { + return '${...}'; } - return el_922.slice.text; - }).join(""); + return el.slice.text; + }).join(''); } return this.token.value; } + lineNumber() { if (!this.match("delimiter")) { return this.token.slice.startLocation.line; @@ -252,131 +378,170 @@ class Syntax { return this.token.get(0).lineNumber(); } } - setLineNumber(line_923) { - let newTok_924 = {}; + + setLineNumber(line) { + let newTok = {}; if (this.isDelimiter()) { - newTok_924 = this.token.map(s_925 => s_925.setLineNumber(line_923)); + newTok = this.token.map(s => s.setLineNumber(line)); } else { for (let key of Object.keys(this.token)) { - newTok_924[key] = this.token[key]; + newTok[key] = this.token[key]; } - (0, _errors.assert)(newTok_924.slice && newTok_924.slice.startLocation, "all tokens must have line info"); - newTok_924.slice.startLocation.line = line_923; + (0, _errors.assert)(newTok.slice && newTok.slice.startLocation, 'all tokens must have line info'); + newTok.slice.startLocation.line = line; } - return new Syntax(newTok_924, this); + return new Syntax(newTok, this); } + + // () -> List inner() { (0, _errors.assert)(this.match("delimiter"), "can only get the inner of a delimiter"); return this.token.slice(1, this.token.size - 1); } - addScope(scope_926, bindings_927, phase_928) { - let options_929 = arguments.length <= 3 || arguments[3] === undefined ? { flip: false } : arguments[3]; - let token_930 = this.match("delimiter") ? this.token.map(s_934 => s_934.addScope(scope_926, bindings_927, phase_928, options_929)) : this.token; - if (this.match("template")) { - token_930 = _.merge(token_930, { items: token_930.items.map(it_935 => { - if (it_935 instanceof Syntax && it_935.match("delimiter")) { - return it_935.addScope(scope_926, bindings_927, phase_928, options_929); + addScope(scope, bindings, phase) { + let options = arguments.length <= 3 || arguments[3] === undefined ? { flip: false } : arguments[3]; + + let token = this.match('delimiter') ? this.token.map(s => s.addScope(scope, bindings, phase, options)) : this.token; + if (this.match('template')) { + token = _.merge(token, { + items: token.items.map(it => { + if (it instanceof Syntax && it.match('delimiter')) { + return it.addScope(scope, bindings, phase, options); } - return it_935; - }) }); + return it; + }) + }); } - let oldScopeset_931; - if (phase_928 === ALL_PHASES_830) { - oldScopeset_931 = this.scopesets.all; + let oldScopeset; + if (phase === ALL_PHASES) { + oldScopeset = this.scopesets.all; } else { - oldScopeset_931 = this.scopesets.phase.has(phase_928) ? this.scopesets.phase.get(phase_928) : (0, _immutable.List)(); + oldScopeset = this.scopesets.phase.has(phase) ? this.scopesets.phase.get(phase) : (0, _immutable.List)(); } - let newScopeset_932; - if (options_929.flip) { - let index = oldScopeset_931.indexOf(scope_926); + let newScopeset; + if (options.flip) { + let index = oldScopeset.indexOf(scope); if (index !== -1) { - newScopeset_932 = oldScopeset_931.remove(index); + newScopeset = oldScopeset.remove(index); } else { - newScopeset_932 = oldScopeset_931.push(scope_926); + newScopeset = oldScopeset.push(scope); } } else { - newScopeset_932 = oldScopeset_931.push(scope_926); + newScopeset = oldScopeset.push(scope); } - let newstx_933 = { bindings: bindings_927, scopesets: { all: this.scopesets.all, phase: this.scopesets.phase } }; - if (phase_928 === ALL_PHASES_830) { - newstx_933.scopesets.all = newScopeset_932; + let newstx = { + bindings: bindings, + scopesets: { + all: this.scopesets.all, + phase: this.scopesets.phase + } + }; + + if (phase === ALL_PHASES) { + newstx.scopesets.all = newScopeset; } else { - newstx_933.scopesets.phase = newstx_933.scopesets.phase.set(phase_928, newScopeset_932); + newstx.scopesets.phase = newstx.scopesets.phase.set(phase, newScopeset); } - return new Syntax(token_930, newstx_933); - } - removeScope(scope_936, phase_937) { - let token_938 = this.match("delimiter") ? this.token.map(s_944 => s_944.removeScope(scope_936, phase_937)) : this.token; - let phaseScopeset_939 = this.scopesets.phase.has(phase_937) ? this.scopesets.phase.get(phase_937) : (0, _immutable.List)(); - let allScopeset_940 = this.scopesets.all; - let newstx_941 = { bindings: this.bindings, scopesets: { all: this.scopesets.all, phase: this.scopesets.phase } }; - let phaseIndex_942 = phaseScopeset_939.indexOf(scope_936); - let allIndex_943 = allScopeset_940.indexOf(scope_936); - if (phaseIndex_942 !== -1) { - newstx_941.scopesets.phase = this.scopesets.phase.set(phase_937, phaseScopeset_939.remove(phaseIndex_942)); - } else if (allIndex_943 !== -1) { - newstx_941.scopesets.all = allScopeset_940.remove(allIndex_943); + return new Syntax(token, newstx); + } + + removeScope(scope, phase) { + let token = this.match('delimiter') ? this.token.map(s => s.removeScope(scope, phase)) : this.token; + let phaseScopeset = this.scopesets.phase.has(phase) ? this.scopesets.phase.get(phase) : (0, _immutable.List)(); + let allScopeset = this.scopesets.all; + let newstx = { + bindings: this.bindings, + scopesets: { + all: this.scopesets.all, + phase: this.scopesets.phase + } + }; + + let phaseIndex = phaseScopeset.indexOf(scope); + let allIndex = allScopeset.indexOf(scope); + if (phaseIndex !== -1) { + newstx.scopesets.phase = this.scopesets.phase.set(phase, phaseScopeset.remove(phaseIndex)); + } else if (allIndex !== -1) { + newstx.scopesets.all = allScopeset.remove(allIndex); } - return new Syntax(token_938, newstx_941); + return new Syntax(token, newstx); } - match(type_945, value_946) { - if (!Types_829[type_945]) { - throw new Error(type_945 + " is an invalid type"); + + match(type, value) { + if (!Types[type]) { + throw new Error(type + " is an invalid type"); } - return Types_829[type_945].match(this.token) && (value_946 == null || (value_946 instanceof RegExp ? value_946.test(this.val()) : this.val() == value_946)); + return Types[type].match(this.token) && (value == null || (value instanceof RegExp ? value.test(this.val()) : this.val() == value)); } - isIdentifier(value_947) { - return this.match("identifier", value_947); + + isIdentifier(value) { + return this.match("identifier", value); } - isAssign(value_948) { - return this.match("assign", value_948); + + isAssign(value) { + return this.match("assign", value); } - isBooleanLiteral(value_949) { - return this.match("boolean", value_949); + + isBooleanLiteral(value) { + return this.match("boolean", value); } - isKeyword(value_950) { - return this.match("keyword", value_950); + + isKeyword(value) { + return this.match("keyword", value); } - isNullLiteral(value_951) { - return this.match("null", value_951); + + isNullLiteral(value) { + return this.match("null", value); } - isNumericLiteral(value_952) { - return this.match("number", value_952); + + isNumericLiteral(value) { + return this.match("number", value); } - isPunctuator(value_953) { - return this.match("punctuator", value_953); + + isPunctuator(value) { + return this.match("punctuator", value); } - isStringLiteral(value_954) { - return this.match("string", value_954); + + isStringLiteral(value) { + return this.match("string", value); } - isRegularExpression(value_955) { - return this.match("regularExpression", value_955); + + isRegularExpression(value) { + return this.match("regularExpression", value); } - isTemplate(value_956) { - return this.match("template", value_956); + + isTemplate(value) { + return this.match("template", value); } - isDelimiter(value_957) { - return this.match("delimiter", value_957); + + isDelimiter(value) { + return this.match("delimiter", value); } - isParens(value_958) { - return this.match("parens", value_958); + + isParens(value) { + return this.match("parens", value); } - isBraces(value_959) { - return this.match("braces", value_959); + + isBraces(value) { + return this.match("braces", value); } - isBrackets(value_960) { - return this.match("brackets", value_960); + + isBrackets(value) { + return this.match("brackets", value); } - isSyntaxTemplate(value_961) { - return this.match("syntaxTemplate", value_961); + + isSyntaxTemplate(value) { + return this.match("syntaxTemplate", value); } - isEOF(value_962) { - return this.match("eof", value_962); + + isEOF(value) { + return this.match("eof", value); } + toString() { if (this.match("delimiter")) { - return this.token.map(s_963 => s_963.toString()).join(" "); + return this.token.map(s => s.toString()).join(" "); } if (this.match("string")) { return "'" + this.token.str; @@ -388,6 +553,4 @@ class Syntax { } } exports.default = Syntax; -exports.Types = Types_829; -exports.ALL_PHASES = ALL_PHASES_830; -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/syntax.js"],"names":[],"mappings":"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","file":"syntax.js","sourcesContent":["import {List, Map} from \"immutable\";\nimport {assert} from \"./errors\";\nimport BindingMap from \"./binding-map\";\nimport {Maybe} from \"ramda-fantasy\";\nimport {TokenType, TokenClass} from \"shift-parser/dist/tokenizer\";\nimport  * as _ from \"ramda\";\nconst Just_825 = Maybe.Just;\nconst Nothing_826 = Maybe.Nothing;\nfunction getFirstSlice_827(stx_831) {\n  if (!stx_831 || typeof stx_831.isDelimiter !== \"function\") return null;\n  if (!stx_831.isDelimiter()) {\n    return stx_831.token.slice;\n  }\n  return stx_831.token.get(0).token.slice;\n}\nfunction sizeDecending_828(a_832, b_833) {\n  if (a_832.scopes.size > b_833.scopes.size) {\n    return -1;\n  } else if (b_833.scopes.size > a_832.scopes.size) {\n    return 1;\n  } else {\n    return 0;\n  }\n}\nlet Types_829 = {null: {match: token_834 => !Types_829.delimiter.match(token_834) && token_834.type === TokenType.NULL, create: (value_835, stx_836) => new Syntax({type: TokenType.NULL, value: null}, stx_836)}, number: {match: token_837 => !Types_829.delimiter.match(token_837) && token_837.type.klass === TokenClass.NumericLiteral, create: (value_838, stx_839) => new Syntax({type: TokenType.NUMBER, value: value_838}, stx_839)}, string: {match: token_840 => !Types_829.delimiter.match(token_840) && token_840.type.klass === TokenClass.StringLiteral, create: (value_841, stx_842) => new Syntax({type: TokenType.STRING, str: value_841}, stx_842)}, punctuator: {match: token_843 => !Types_829.delimiter.match(token_843) && token_843.type.klass === TokenClass.Punctuator, create: (value_844, stx_845) => new Syntax({type: {klass: TokenClass.Punctuator, name: value_844}, value: value_844}, stx_845)}, keyword: {match: token_846 => !Types_829.delimiter.match(token_846) && token_846.type.klass === TokenClass.Keyword, create: (value_847, stx_848) => new Syntax({type: {klass: TokenClass.Keyword, name: value_847}, value: value_847}, stx_848)}, identifier: {match: token_849 => !Types_829.delimiter.match(token_849) && token_849.type.klass === TokenClass.Ident, create: (value_850, stx_851) => new Syntax({type: TokenType.IDENTIFIER, value: value_850}, stx_851)}, regularExpression: {match: token_852 => !Types_829.delimiter.match(token_852) && token_852.type.klass === TokenClass.RegularExpression, create: (value_853, stx_854) => new Syntax({type: TokenType.REGEXP, value: value_853}, stx_854)}, braces: {match: token_855 => Types_829.delimiter.match(token_855) && token_855.get(0).token.type === TokenType.LBRACE, create: (inner_856, stx_857) => {\n  let left_858 = new Syntax({type: TokenType.LBRACE, value: \"{\", slice: getFirstSlice_827(stx_857)});\n  let right_859 = new Syntax({type: TokenType.RBRACE, value: \"}\", slice: getFirstSlice_827(stx_857)});\n  return new Syntax(List.of(left_858).concat(inner_856).push(right_859), stx_857);\n}}, brackets: {match: token_860 => Types_829.delimiter.match(token_860) && token_860.get(0).token.type === TokenType.LBRACK, create: (inner_861, stx_862) => {\n  let left_863 = new Syntax({type: TokenType.LBRACK, value: \"[\", slice: getFirstSlice_827(stx_862)});\n  let right_864 = new Syntax({type: TokenType.RBRACK, value: \"]\", slice: getFirstSlice_827(stx_862)});\n  return new Syntax(List.of(left_863).concat(inner_861).push(right_864), stx_862);\n}}, parens: {match: token_865 => Types_829.delimiter.match(token_865) && token_865.get(0).token.type === TokenType.LPAREN, create: (inner_866, stx_867) => {\n  let left_868 = new Syntax({type: TokenType.LPAREN, value: \"(\", slice: getFirstSlice_827(stx_867)});\n  let right_869 = new Syntax({type: TokenType.RPAREN, value: \")\", slice: getFirstSlice_827(stx_867)});\n  return new Syntax(List.of(left_868).concat(inner_866).push(right_869), stx_867);\n}}, assign: {match: token_870 => {\n  if (Types_829.punctuator.match(token_870)) {\n    switch (token_870.value) {\n      case \"=\":\n      case \"|=\":\n      case \"^=\":\n      case \"&=\":\n      case \"<<=\":\n      case \">>=\":\n      case \">>>=\":\n      case \"+=\":\n      case \"-=\":\n      case \"*=\":\n      case \"/=\":\n      case \"%=\":\n        return true;\n      default:\n        return false;\n    }\n  }\n  return false;\n}}, boolean: {match: token_871 => !Types_829.delimiter.match(token_871) && token_871.type === TokenType.TRUE || token_871.type === TokenType.FALSE}, template: {match: token_872 => !Types_829.delimiter.match(token_872) && token_872.type === TokenType.TEMPLATE}, delimiter: {match: token_873 => List.isList(token_873)}, syntaxTemplate: {match: token_874 => Types_829.delimiter.match(token_874) && token_874.get(0).val() === \"#`\"}, eof: {match: token_875 => !Types_829.delimiter.match(token_875) && token_875.type === TokenType.EOS}};\n;\nconst ALL_PHASES_830 = {};\n;\nexport default class Syntax {\n  constructor(token_876, oldstx_877 = {}) {\n    this.token = token_876;\n    this.bindings = oldstx_877.bindings != null ? oldstx_877.bindings : new BindingMap;\n    this.scopesets = oldstx_877.scopesets != null ? oldstx_877.scopesets : {all: List(), phase: Map()};\n    Object.freeze(this);\n  }\n  static of(token_878, stx_879 = {}) {\n    return new Syntax(token_878, stx_879);\n  }\n  static from(type_880, value_881, stx_882 = {}) {\n    if (!Types_829[type_880]) {\n      throw new Error(type_880 + \" is not a valid type\");\n    } else if (!Types_829[type_880].create) {\n      throw new Error(\"Cannot create a syntax from type \" + type_880);\n    }\n    let newstx_883 = Types_829[type_880].create(value_881, stx_882);\n    let slice_884 = getFirstSlice_827(stx_882);\n    if (slice_884 != null) {\n      newstx_883.token.slice = slice_884;\n    }\n    return newstx_883;\n  }\n  from(type_885, value_886) {\n    return Syntax.from(type_885, value_886, this);\n  }\n  fromNull() {\n    return this.from(\"null\", null);\n  }\n  fromNumber(value_887) {\n    return this.from(\"number\", value_887);\n  }\n  fromString(value_888) {\n    return this.from(\"string\", value_888);\n  }\n  fromPunctuator(value_889) {\n    return this.from(\"punctuator\", value_889);\n  }\n  fromKeyword(value_890) {\n    return this.from(\"keyword\");\n  }\n  fromIdentifier(value_891) {\n    return this.from(\"identifier\", value_891);\n  }\n  fromRegularExpression(value_892) {\n    return this.from(\"regularExpression\", value_892);\n  }\n  fromBraces(inner_893) {\n    return this.from(\"braces\", inner_893);\n  }\n  fromBrackets(inner_894) {\n    return this.from(\"brackets\", inner_894);\n  }\n  fromParens(inner_895) {\n    return this.from(\"parens\", inner_895);\n  }\n  static fromNull(stx_896 = {}) {\n    return Syntax.from(\"null\", null, stx_896);\n  }\n  static fromNumber(value_897, stx_898 = {}) {\n    return Syntax.from(\"number\", value_897, stx_898);\n  }\n  static fromString(value_899, stx_900 = {}) {\n    return Syntax.from(\"string\", value_899, stx_900);\n  }\n  static fromPunctuator(value_901, stx_902 = {}) {\n    return Syntax.from(\"punctuator\", value_901, stx_902);\n  }\n  static fromKeyword(value_903, stx_904 = {}) {\n    return Syntax.from(\"keyword\", value_903, stx_904);\n  }\n  static fromIdentifier(value_905, stx_906 = {}) {\n    return Syntax.from(\"identifier\", value_905, stx_906);\n  }\n  static fromRegularExpression(value_907, stx_908 = {}) {\n    return Syntax.from(\"regularExpression\", value_907, stx_908);\n  }\n  static fromBraces(inner_909, stx_910 = {}) {\n    return Syntax.from(\"braces\", inner_909, stx_910);\n  }\n  static fromBrackets(inner_911, stx_912 = {}) {\n    return Syntax.from(\"brackets\", inner_911, stx_912);\n  }\n  static fromParens(inner_913, stx_914 = {}) {\n    return Syntax.from(\"parens\", inner_913, stx_914);\n  }\n  resolve(phase_915) {\n    assert(phase_915 != null, \"must provide a phase to resolve\");\n    let allScopes_916 = this.scopesets.all;\n    let stxScopes_917 = this.scopesets.phase.has(phase_915) ? this.scopesets.phase.get(phase_915) : List();\n    stxScopes_917 = allScopes_916.concat(stxScopes_917);\n    if (stxScopes_917.size === 0 || !(this.match(\"identifier\") || this.match(\"keyword\"))) {\n      return this.token.value;\n    }\n    let scope_918 = stxScopes_917.last();\n    let bindings_919 = this.bindings;\n    if (scope_918) {\n      let scopesetBindingList = bindings_919.get(this);\n      if (scopesetBindingList) {\n        let biggestBindingPair = scopesetBindingList.filter(({scopes, binding}) => {\n          return scopes.isSubset(stxScopes_917);\n        }).sort(sizeDecending_828);\n        if (biggestBindingPair.size >= 2 && biggestBindingPair.get(0).scopes.size === biggestBindingPair.get(1).scopes.size) {\n          let debugBase = \"{\" + stxScopes_917.map(s_920 => s_920.toString()).join(\", \") + \"}\";\n          let debugAmbigousScopesets = biggestBindingPair.map(({scopes}) => {\n            return \"{\" + scopes.map(s_921 => s_921.toString()).join(\", \") + \"}\";\n          }).join(\", \");\n          throw new Error(\"Scopeset \" + debugBase + \" has ambiguous subsets \" + debugAmbigousScopesets);\n        } else if (biggestBindingPair.size !== 0) {\n          let bindingStr = biggestBindingPair.get(0).binding.toString();\n          if (Maybe.isJust(biggestBindingPair.get(0).alias)) {\n            return biggestBindingPair.get(0).alias.getOrElse(null).resolve(phase_915);\n          }\n          return bindingStr;\n        }\n      }\n    }\n    return this.token.value;\n  }\n  val() {\n    assert(!this.match(\"delimiter\"), \"cannot get the val of a delimiter\");\n    if (this.match(\"string\")) {\n      return this.token.str;\n    }\n    if (this.match(\"template\")) {\n      return this.token.items.map(el_922 => {\n        if (typeof el_922.match === \"function\" && el_922.match(\"delimiter\")) {\n          return \"${...}\";\n        }\n        return el_922.slice.text;\n      }).join(\"\");\n    }\n    return this.token.value;\n  }\n  lineNumber() {\n    if (!this.match(\"delimiter\")) {\n      return this.token.slice.startLocation.line;\n    } else {\n      return this.token.get(0).lineNumber();\n    }\n  }\n  setLineNumber(line_923) {\n    let newTok_924 = {};\n    if (this.isDelimiter()) {\n      newTok_924 = this.token.map(s_925 => s_925.setLineNumber(line_923));\n    } else {\n      for (let key of Object.keys(this.token)) {\n        newTok_924[key] = this.token[key];\n      }\n      assert(newTok_924.slice && newTok_924.slice.startLocation, \"all tokens must have line info\");\n      newTok_924.slice.startLocation.line = line_923;\n    }\n    return new Syntax(newTok_924, this);\n  }\n  inner() {\n    assert(this.match(\"delimiter\"), \"can only get the inner of a delimiter\");\n    return this.token.slice(1, this.token.size - 1);\n  }\n  addScope(scope_926, bindings_927, phase_928, options_929 = {flip: false}) {\n    let token_930 = this.match(\"delimiter\") ? this.token.map(s_934 => s_934.addScope(scope_926, bindings_927, phase_928, options_929)) : this.token;\n    if (this.match(\"template\")) {\n      token_930 = _.merge(token_930, {items: token_930.items.map(it_935 => {\n        if (it_935 instanceof Syntax && it_935.match(\"delimiter\")) {\n          return it_935.addScope(scope_926, bindings_927, phase_928, options_929);\n        }\n        return it_935;\n      })});\n    }\n    let oldScopeset_931;\n    if (phase_928 === ALL_PHASES_830) {\n      oldScopeset_931 = this.scopesets.all;\n    } else {\n      oldScopeset_931 = this.scopesets.phase.has(phase_928) ? this.scopesets.phase.get(phase_928) : List();\n    }\n    let newScopeset_932;\n    if (options_929.flip) {\n      let index = oldScopeset_931.indexOf(scope_926);\n      if (index !== -1) {\n        newScopeset_932 = oldScopeset_931.remove(index);\n      } else {\n        newScopeset_932 = oldScopeset_931.push(scope_926);\n      }\n    } else {\n      newScopeset_932 = oldScopeset_931.push(scope_926);\n    }\n    let newstx_933 = {bindings: bindings_927, scopesets: {all: this.scopesets.all, phase: this.scopesets.phase}};\n    if (phase_928 === ALL_PHASES_830) {\n      newstx_933.scopesets.all = newScopeset_932;\n    } else {\n      newstx_933.scopesets.phase = newstx_933.scopesets.phase.set(phase_928, newScopeset_932);\n    }\n    return new Syntax(token_930, newstx_933);\n  }\n  removeScope(scope_936, phase_937) {\n    let token_938 = this.match(\"delimiter\") ? this.token.map(s_944 => s_944.removeScope(scope_936, phase_937)) : this.token;\n    let phaseScopeset_939 = this.scopesets.phase.has(phase_937) ? this.scopesets.phase.get(phase_937) : List();\n    let allScopeset_940 = this.scopesets.all;\n    let newstx_941 = {bindings: this.bindings, scopesets: {all: this.scopesets.all, phase: this.scopesets.phase}};\n    let phaseIndex_942 = phaseScopeset_939.indexOf(scope_936);\n    let allIndex_943 = allScopeset_940.indexOf(scope_936);\n    if (phaseIndex_942 !== -1) {\n      newstx_941.scopesets.phase = this.scopesets.phase.set(phase_937, phaseScopeset_939.remove(phaseIndex_942));\n    } else if (allIndex_943 !== -1) {\n      newstx_941.scopesets.all = allScopeset_940.remove(allIndex_943);\n    }\n    return new Syntax(token_938, newstx_941);\n  }\n  match(type_945, value_946) {\n    if (!Types_829[type_945]) {\n      throw new Error(type_945 + \" is an invalid type\");\n    }\n    return Types_829[type_945].match(this.token) && (value_946 == null || (value_946 instanceof RegExp ? value_946.test(this.val()) : this.val() == value_946));\n  }\n  isIdentifier(value_947) {\n    return this.match(\"identifier\", value_947);\n  }\n  isAssign(value_948) {\n    return this.match(\"assign\", value_948);\n  }\n  isBooleanLiteral(value_949) {\n    return this.match(\"boolean\", value_949);\n  }\n  isKeyword(value_950) {\n    return this.match(\"keyword\", value_950);\n  }\n  isNullLiteral(value_951) {\n    return this.match(\"null\", value_951);\n  }\n  isNumericLiteral(value_952) {\n    return this.match(\"number\", value_952);\n  }\n  isPunctuator(value_953) {\n    return this.match(\"punctuator\", value_953);\n  }\n  isStringLiteral(value_954) {\n    return this.match(\"string\", value_954);\n  }\n  isRegularExpression(value_955) {\n    return this.match(\"regularExpression\", value_955);\n  }\n  isTemplate(value_956) {\n    return this.match(\"template\", value_956);\n  }\n  isDelimiter(value_957) {\n    return this.match(\"delimiter\", value_957);\n  }\n  isParens(value_958) {\n    return this.match(\"parens\", value_958);\n  }\n  isBraces(value_959) {\n    return this.match(\"braces\", value_959);\n  }\n  isBrackets(value_960) {\n    return this.match(\"brackets\", value_960);\n  }\n  isSyntaxTemplate(value_961) {\n    return this.match(\"syntaxTemplate\", value_961);\n  }\n  isEOF(value_962) {\n    return this.match(\"eof\", value_962);\n  }\n  toString() {\n    if (this.match(\"delimiter\")) {\n      return this.token.map(s_963 => s_963.toString()).join(\" \");\n    }\n    if (this.match(\"string\")) {\n      return \"'\" + this.token.str;\n    }\n    if (this.match(\"template\")) {\n      return this.val();\n    }\n    return this.token.value;\n  }\n}\nexport {Types_829 as Types};\nexport {ALL_PHASES_830 as ALL_PHASES}"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/syntax.js"],"names":[],"mappings":"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","file":"syntax.js","sourcesContent":["// @flow\nimport { List, Map } from \"immutable\";\nimport { assert } from \"./errors\";\nimport BindingMap from \"./binding-map\";\nimport { Maybe } from \"ramda-fantasy\";\nimport * as _ from 'ramda';\n\nimport { TokenType, TokenClass } from \"shift-parser/dist/tokenizer\";\n\ntype Token = {\n  type: any;\n  value: any;\n  slice: any;\n};\n\ntype TokenTag =\n  'null' |\n  'number' |\n  'string' |\n  'punctuator' |\n  'keyword' |\n  'identifier' |\n  'regularExpression' |\n  'boolean' |\n  'braces' |\n  'parens' |\n  'delimiter' |\n  'eof' |\n  'template' |\n  'assign' |\n  'syntaxTemplate' |\n  'brackets'\n\nfunction getFirstSlice(stx: ?Syntax) {\n  if ((!stx) || typeof stx.isDelimiter !== 'function') return null; // TODO: should not have to do this\n  if (!stx.isDelimiter()) {\n    return stx.token.slice;\n  }\n  return stx.token.get(0).token.slice;\n}\n\nfunction sizeDecending(a, b) {\n  if (a.scopes.size > b.scopes.size) {\n    return -1;\n  } else if (b.scopes.size > a.scopes.size) {\n    return 1;\n  } else {\n    return 0;\n  }\n}\n\ntype TypesHelper = {\n  [key: TokenTag]: {\n    match(token: any): boolean;\n    create?: (value: any, stx: ?Syntax) => Syntax;\n  }\n}\n\nexport let Types: TypesHelper = {\n  null: {\n    match: token => !Types.delimiter.match(token) && token.type === TokenType.NULL,\n    create: (value, stx) => new Syntax({\n      type: TokenType.NULL,\n      value: null\n    }, stx)\n  },\n  number: {\n    match: token => !Types.delimiter.match(token) && token.type.klass === TokenClass.NumericLiteral,\n    create: (value, stx) => new Syntax({\n      type: TokenType.NUMBER,\n      value\n    }, stx)\n  },\n  string: {\n\t\tmatch: token => !Types.delimiter.match(token) && token.type.klass === TokenClass.StringLiteral,\n    create: (value, stx) => new Syntax({\n      type: TokenType.STRING,\n      str: value\n    }, stx)\n  },\n  punctuator: {\n\t\tmatch: token => !Types.delimiter.match(token) && token.type.klass === TokenClass.Punctuator,\n    create: (value, stx) => new Syntax({\n      type: {\n        klass: TokenClass.Punctuator,\n        name: value\n      },\n      value\n    }, stx)\n  },\n  keyword: {\n\t\tmatch: token => !Types.delimiter.match(token) && token.type.klass === TokenClass.Keyword,\n    create: (value, stx) => new Syntax({\n      type: {\n        klass: TokenClass.Keyword,\n        name: value\n      },\n      value\n    }, stx)\n  },\n  identifier: {\n\t\tmatch: token => !Types.delimiter.match(token) && token.type.klass === TokenClass.Ident,\n    create: (value, stx) => new Syntax({\n      type: TokenType.IDENTIFIER,\n      value\n    }, stx)\n  },\n  regularExpression: {\n\t\tmatch: token => !Types.delimiter.match(token) && token.type.klass === TokenClass.RegularExpression,\n    create: (value, stx) => new Syntax({\n      type: TokenType.REGEXP,\n      value\n    }, stx)\n  },\n  braces: {\n\t\tmatch: token => Types.delimiter.match(token) &&\n           token.get(0).token.type === TokenType.LBRACE,\n    create: (inner, stx) => {\n      let left = new Syntax({\n        type: TokenType.LBRACE,\n        value: \"{\",\n        slice: getFirstSlice(stx)\n      });\n      let right = new Syntax({\n        type: TokenType.RBRACE,\n        value: \"}\",\n        slice: getFirstSlice(stx)\n      });\n      return new Syntax(List.of(left).concat(inner).push(right), stx);\n    }\n  },\n  brackets: {\n\t\tmatch: token => Types.delimiter.match(token) &&\n           token.get(0).token.type === TokenType.LBRACK,\n    create: (inner, stx) => {\n      let left = new Syntax({\n        type: TokenType.LBRACK,\n        value: \"[\",\n        slice: getFirstSlice(stx)\n      });\n      let right = new Syntax({\n        type: TokenType.RBRACK,\n        value: \"]\",\n        slice: getFirstSlice(stx)\n      });\n      return new Syntax(List.of(left).concat(inner).push(right), stx);\n    }\n  },\n  parens: {\n\t\tmatch: token => Types.delimiter.match(token) &&\n           token.get(0).token.type === TokenType.LPAREN,\n    create: (inner, stx) => {\n      let left = new Syntax({\n        type: TokenType.LPAREN,\n        value: \"(\",\n        slice: getFirstSlice(stx)\n      });\n      let right = new Syntax({\n        type: TokenType.RPAREN,\n        value: \")\",\n        slice: getFirstSlice(stx)\n      });\n      return new Syntax(List.of(left).concat(inner).push(right), stx);\n    }\n  },\n\n  assign: {\n    match: token => {\n      if (Types.punctuator.match(token)) {\n        switch (token.value) {\n          case \"=\":\n          case \"|=\":\n          case \"^=\":\n          case \"&=\":\n          case \"<<=\":\n          case \">>=\":\n          case \">>>=\":\n          case \"+=\":\n          case \"-=\":\n          case \"*=\":\n          case \"/=\":\n          case \"%=\":\n            return true;\n          default:\n            return false;\n        }\n      }\n      return false;\n    }\n  },\n\n  boolean: {\n    match: token => !Types.delimiter.match(token) && token.type === TokenType.TRUE ||\n           token.type === TokenType.FALSE\n  },\n\n  template: {\n    match: token => !Types.delimiter.match(token) && token.type === TokenType.TEMPLATE\n  },\n\n  delimiter: {\n    match: token => List.isList(token)\n  },\n\n  syntaxTemplate: {\n    match: token => Types.delimiter.match(token) && token.get(0).val() === '#`'\n  },\n\n  eof: {\n    match: token => !Types.delimiter.match(token) && token.type === TokenType.EOS\n  },\n};\nexport const ALL_PHASES = {};\n\ntype Scopeset = {\n  all: List<any>;\n  phase: Map<number, any>;\n}\n\nexport default class Syntax {\n  // token: Token | List<Token>;\n  token: any;\n  bindings: BindingMap;\n  scopesets: Scopeset;\n\n  constructor(token: any, oldstx: ?{ bindings: any; scopesets: any}) {\n    this.token = token;\n    this.bindings = oldstx && (oldstx.bindings != null) ? oldstx.bindings : new BindingMap();\n    this.scopesets = oldstx && (oldstx.scopesets != null) ? oldstx.scopesets : {\n      all: List(),\n      phase: Map()\n    };\n    Object.freeze(this);\n  }\n\n  static of(token: Token, stx: ?Syntax) {\n    return new Syntax(token, stx);\n  }\n\n  static from(type, value, stx: ?Syntax) {\n    if (!Types[type]) {\n      throw new Error(type + \" is not a valid type\");\n    }\n    else if (!Types[type].create) {\n      throw new Error(\"Cannot create a syntax from type \" + type);\n    }\n    let newstx = Types[type].create(value, stx);\n    let slice = getFirstSlice(stx);\n    if (slice != null) {\n      newstx.token.slice = slice;\n    }\n    return newstx;\n  }\n\n  from(type: TokenTag, value: any) {\n    return Syntax.from(type, value, this);\n  }\n\n  fromNull() {\n    return this.from(\"null\", null);\n  }\n\n  fromNumber(value: number) {\n    return this.from('number', value);\n  }\n\n  fromString(value: string) {\n    return this.from(\"string\", value);\n  }\n\n  fromPunctuator(value: string) {\n    return this.from(\"punctuator\", value);\n  }\n\n  fromKeyword(value: string) {\n    return this.from(\"keyword\", value);\n  }\n\n  fromIdentifier(value: string) {\n    return this.from(\"identifier\", value);\n  }\n\n  fromRegularExpression(value: any) {\n    return this.from(\"regularExpression\", value);\n  }\n\n  fromBraces(inner: List<Syntax>) {\n    return this.from(\"braces\", inner);\n  }\n\n  fromBrackets(inner: List<Syntax>) {\n    return this.from(\"brackets\", inner);\n  }\n\n  fromParens(inner: List<Syntax>) {\n    return this.from(\"parens\", inner);\n  }\n\n  static fromNull(stx: Syntax) {\n    return Syntax.from(\"null\", null, stx);\n  }\n\n  static fromNumber(value, stx) {\n    return Syntax.from(\"number\", value, stx);\n  }\n\n  static fromString(value, stx) {\n    return Syntax.from(\"string\", value, stx);\n  }\n\n  static fromPunctuator(value, stx) {\n    return Syntax.from(\"punctuator\", value, stx);\n  }\n\n  static fromKeyword(value, stx) {\n    return Syntax.from(\"keyword\", value, stx);\n  }\n\n  static fromIdentifier(value, stx) {\n    return Syntax.from(\"identifier\", value, stx);\n  }\n\n  static fromRegularExpression(value, stx) {\n    return Syntax.from(\"regularExpression\", value, stx);\n  }\n\n  static fromBraces(inner, stx) {\n    return Syntax.from(\"braces\", inner, stx);\n  }\n\n  static fromBrackets(inner, stx) {\n    return Syntax.from(\"brackets\", inner, stx);\n  }\n\n  static fromParens(inner, stx) {\n    return Syntax.from(\"parens\", inner, stx);\n  }\n\n  // () -> string\n  resolve(phase: any) {\n    assert(phase != null, \"must provide a phase to resolve\");\n    let allScopes = this.scopesets.all;\n    let stxScopes = this.scopesets.phase.has(phase) ? this.scopesets.phase.get(phase) : List();\n    stxScopes = allScopes.concat(stxScopes);\n    if (stxScopes.size === 0 || !(this.match('identifier') || this.match('keyword'))) {\n      return this.token.value;\n    }\n    let scope = stxScopes.last();\n    let bindings = this.bindings;\n    if (scope) {\n      // List<{ scopes: List<Scope>, binding: Symbol }>\n      let scopesetBindingList = bindings.get(this);\n\n      if (scopesetBindingList) {\n        // { scopes: List<Scope>, binding: Symbol }\n        let biggestBindingPair = scopesetBindingList.filter(({scopes}) => {\n          return scopes.isSubset(stxScopes);\n        }).sort(sizeDecending);\n\n        if (biggestBindingPair.size >= 2 &&\n            biggestBindingPair.get(0).scopes.size === biggestBindingPair.get(1).scopes.size) {\n          let debugBase = '{' + stxScopes.map(s => s.toString()).join(', ') + '}';\n          let debugAmbigousScopesets = biggestBindingPair.map(({scopes}) => {\n            return '{' + scopes.map(s => s.toString()).join(', ') + '}';\n          }).join(', ');\n          throw new Error('Scopeset ' + debugBase + ' has ambiguous subsets ' + debugAmbigousScopesets);\n        } else if (biggestBindingPair.size !== 0) {\n          let bindingStr = biggestBindingPair.get(0).binding.toString();\n          if (Maybe.isJust(biggestBindingPair.get(0).alias)) {\n            // null never happens because we just checked if it is a Just\n            return biggestBindingPair.get(0).alias.getOrElse(null).resolve(phase);\n          }\n          return bindingStr;\n        }\n      }\n    }\n    return this.token.value;\n  }\n\n  val() {\n    assert(!this.match(\"delimiter\"), \"cannot get the val of a delimiter\");\n    if (this.match(\"string\")) {\n      return this.token.str;\n    }\n    if (this.match(\"template\")) {\n      return this.token.items.map(el => {\n        if (typeof el.match === 'function' && el.match(\"delimiter\")) {\n          return '${...}';\n        }\n        return el.slice.text;\n      }).join('');\n    }\n    return this.token.value;\n  }\n\n  lineNumber() {\n    if (!this.match(\"delimiter\")) {\n      return this.token.slice.startLocation.line;\n    } else {\n      return this.token.get(0).lineNumber();\n    }\n  }\n\n  setLineNumber(line: number) {\n    let newTok = {};\n    if (this.isDelimiter()) {\n      newTok = this.token.map(s => s.setLineNumber(line));\n    } else {\n      for (let key of Object.keys(this.token)) {\n        newTok[key] = this.token[key];\n      }\n      assert(newTok.slice && newTok.slice.startLocation, 'all tokens must have line info');\n      newTok.slice.startLocation.line = line;\n    }\n    return new Syntax(newTok, this);\n  }\n\n  // () -> List<Syntax>\n  inner() {\n    assert(this.match(\"delimiter\"), \"can only get the inner of a delimiter\");\n    return this.token.slice(1, this.token.size - 1);\n  }\n\n  addScope(scope: any, bindings: any, phase: number, options: any = { flip: false }) {\n    let token = this.match('delimiter') ? this.token.map(s => s.addScope(scope, bindings, phase, options)) : this.token;\n    if (this.match('template')) {\n      token = _.merge(token, {\n        items: token.items.map(it => {\n          if (it instanceof Syntax && it.match('delimiter')) {\n            return it.addScope(scope, bindings, phase, options);\n          }\n          return it;\n        })\n      });\n    }\n    let oldScopeset;\n    if (phase === ALL_PHASES) {\n      oldScopeset = this.scopesets.all;\n    } else {\n      oldScopeset = this.scopesets.phase.has(phase) ? this.scopesets.phase.get(phase) : List();\n    }\n    let newScopeset;\n    if (options.flip) {\n      let index = oldScopeset.indexOf(scope);\n      if (index !== -1) {\n        newScopeset = oldScopeset.remove(index);\n      } else {\n        newScopeset = oldScopeset.push(scope);\n      }\n    } else {\n      newScopeset = oldScopeset.push(scope);\n    }\n    let newstx = {\n      bindings,\n      scopesets: {\n        all: this.scopesets.all,\n        phase: this.scopesets.phase\n      }\n    };\n\n    if (phase === ALL_PHASES) {\n      newstx.scopesets.all = newScopeset;\n    } else {\n      newstx.scopesets.phase = newstx.scopesets.phase.set(phase, newScopeset);\n    }\n    return new Syntax(token, newstx);\n  }\n\n  removeScope(scope: any, phase: number) {\n    let token = this.match('delimiter') ? this.token.map(s => s.removeScope(scope, phase)) : this.token;\n    let phaseScopeset = this.scopesets.phase.has(phase) ? this.scopesets.phase.get(phase) : List();\n    let allScopeset = this.scopesets.all;\n    let newstx = {\n      bindings: this.bindings,\n      scopesets: {\n        all: this.scopesets.all,\n        phase: this.scopesets.phase\n      }\n    };\n\n    let phaseIndex = phaseScopeset.indexOf(scope);\n    let allIndex = allScopeset.indexOf(scope);\n    if (phaseIndex !== -1) {\n      newstx.scopesets.phase = this.scopesets.phase.set(phase, phaseScopeset.remove(phaseIndex));\n    } else if (allIndex !== -1) {\n      newstx.scopesets.all = allScopeset.remove(allIndex);\n    }\n    return new Syntax(token, newstx);\n  }\n\n  match(type: TokenTag, value: any) {\n    if (!Types[type]) {\n      throw new Error(type + \" is an invalid type\");\n    }\n    return Types[type].match(this.token) && (value == null ||\n      (value instanceof RegExp ? value.test(this.val()) : this.val() == value));\n  }\n\n  isIdentifier(value: string) {\n    return this.match(\"identifier\", value);\n  }\n\n  isAssign(value: string) {\n    return this.match(\"assign\", value);\n  }\n\n  isBooleanLiteral(value: boolean) {\n    return this.match(\"boolean\", value);\n  }\n\n  isKeyword(value: string) {\n    return this.match(\"keyword\", value);\n  }\n\n  isNullLiteral(value: any) {\n    return this.match(\"null\", value);\n  }\n\n  isNumericLiteral(value: number) {\n    return this.match(\"number\", value);\n  }\n\n  isPunctuator(value: string) {\n    return this.match(\"punctuator\", value);\n  }\n\n  isStringLiteral(value: string) {\n    return this.match(\"string\", value);\n  }\n\n  isRegularExpression(value: any) {\n    return this.match(\"regularExpression\", value);\n  }\n\n  isTemplate(value: any) {\n    return this.match(\"template\", value);\n  }\n\n  isDelimiter(value: any) {\n    return this.match(\"delimiter\", value);\n  }\n\n  isParens(value: any) {\n    return this.match(\"parens\", value);\n  }\n\n  isBraces(value: any) {\n    return this.match(\"braces\", value);\n  }\n\n  isBrackets(value: any) {\n    return this.match(\"brackets\", value);\n  }\n\n  isSyntaxTemplate(value: any) {\n    return this.match(\"syntaxTemplate\", value);\n  }\n\n  isEOF(value: any) {\n    return this.match(\"eof\", value);\n  }\n\n  toString() {\n    if (this.match(\"delimiter\")) {\n      return this.token.map(s => s.toString()).join(\" \");\n    }\n    if (this.match(\"string\")) {\n      return \"'\" + this.token.str;\n    }\n    if (this.match(\"template\")) {\n      return this.val();\n    }\n    return this.token.value;\n  }\n}\n"]} \ No newline at end of file diff --git a/dist/template-processor.js b/dist/template-processor.js index aea95698..732c156f 100644 --- a/dist/template-processor.js +++ b/dist/template-processor.js @@ -1,75 +1,111 @@ -"use strict"; +'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); -exports.replaceTemplate = exports.processTemplate = undefined; +exports.processTemplate = processTemplate; +exports.replaceTemplate = replaceTemplate; -var _immutable = require("immutable"); +var _immutable = require('immutable'); -var _ramdaFantasy = require("ramda-fantasy"); - -var _ramda = require("ramda"); +var _ramda = require('ramda'); var _ramda2 = _interopRequireDefault(_ramda); -var _syntax = require("./syntax"); +var _syntax = require('./syntax'); var _syntax2 = _interopRequireDefault(_syntax); -var _errors = require("./errors"); +var _errors = require('./errors'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } -const isDolar_964 = s_975 => s_975 && typeof s_975.match === "function" && s_975.match("identifier") && s_975.val() === "$"; -const isDelimiter_965 = s_976 => s_976 && typeof s_976.match === "function" && s_976.match("delimiter"); -const isBraces_966 = s_977 => s_977 && typeof s_977.match === "function" && s_977.match("braces"); -const isParens_967 = s_978 => s_978 && typeof s_978.match === "function" && s_978.match("parens"); -const isBrackets_968 = s_979 => s_979 && typeof s_979.match === "function" && s_979.match("brackets"); -const insertIntoDelimiter_969 = _ramda2.default.cond([[isBraces_966, (s_980, r_981) => _syntax2.default.from("braces", r_981, s_980)], [isParens_967, (s_982, r_983) => _syntax2.default.from("parens", r_983, s_982)], [isBrackets_968, (s_984, r_985) => _syntax2.default.from("brackets", r_985, s_984)]]); -const process_970 = (acc_986, s_987) => { - if (isBraces_966(s_987) && isDolar_964(acc_986.template.last())) { - return { template: acc_986.template.push(_syntax2.default.from("braces", _immutable.List.of(_syntax2.default.from("number", acc_986.interp.size)), s_987)), interp: acc_986.interp.push(s_987.inner()) }; - } else if (isDelimiter_965(s_987)) { - let innerResult = processTemplate_973(s_987.inner(), acc_986.interp); - return { template: acc_986.template.push(insertIntoDelimiter_969(s_987, innerResult.template)), interp: innerResult.interp }; +/* +Given a syntax list like: + + [foo, bar, $, { 42, +, 24 }, baz] + +convert it to: + + [foo, bar, $, { 0 }, baz] + +and return another list with the interpolated values at the corresponding +positions. + +Requires either lookahead/lookbehind of one (to see the $). +*/ + +const isDolar = s => s && typeof s.match === 'function' && s.match("identifier") && s.val() === '$'; +const isDelimiter = s => s && typeof s.match === 'function' && s.match("delimiter"); +const isBraces = s => s && typeof s.match === 'function' && s.match("braces"); +const isParens = s => s && typeof s.match === 'function' && s.match("parens"); +const isBrackets = s => s && typeof s.match === 'function' && s.match("brackets"); + +const insertIntoDelimiter = _ramda2.default.cond([[isBraces, (s, r) => _syntax2.default.from("braces", r, s)], [isParens, (s, r) => _syntax2.default.from("parens", r, s)], [isBrackets, (s, r) => _syntax2.default.from("brackets", r, s)]]); + +const process = (acc, s) => { + if (isBraces(s) && isDolar(acc.template.last())) { + return { + template: acc.template.push(_syntax2.default.from("braces", _immutable.List.of(_syntax2.default.from("number", acc.interp.size)), s)), + interp: acc.interp.push(s.inner()) + }; + } else if (isDelimiter(s)) { + let innerResult = processTemplate(s.inner(), acc.interp); + return { + template: acc.template.push(insertIntoDelimiter(s, innerResult.template)), + interp: innerResult.interp + }; } else { - return { template: acc_986.template.push(s_987), interp: acc_986.interp }; + return { + template: acc.template.push(s), + interp: acc.interp + }; } }; -function cloneLineNumber_971(to_988, from_989) { - if (from_989 && to_988) { - if (typeof to_988.setLineNumber === "function") { - return to_988.setLineNumber(from_989.lineNumber()); - } else if (_immutable.List.isList(to_988)) { - return to_988.map(x_990 => cloneLineNumber_971(x_990, from_989)); + +function cloneLineNumber(to, from) { + if (from && to) { + if (typeof to.setLineNumber === 'function') { + return to.setLineNumber(from.lineNumber()); + } else if (_immutable.List.isList(to)) { + return to.map(x => cloneLineNumber(x, from)); } } - return to_988; + return to; } -const replace_972 = (acc_991, s_992) => { - let last_993 = acc_991.template.get(-1); - let beforeLast_994 = acc_991.template.get(-2); - if (isBraces_966(s_992) && isDolar_964(last_993)) { - let index = s_992.inner().first().val(); - (0, _errors.assert)(acc_991.rep.size > index, "unknown replacement value"); - let replacement = cloneLineNumber_971(acc_991.rep.get(index), beforeLast_994); - return { template: acc_991.template.pop().concat(replacement), rep: acc_991.rep }; - } else if (isDelimiter_965(s_992)) { - let innerResult = replaceTemplate_974(s_992.inner(), acc_991.rep); - return { template: acc_991.template.push(insertIntoDelimiter_969(s_992, innerResult)), rep: acc_991.rep }; + +const replace = (acc, s) => { + let last = acc.template.get(-1); + let beforeLast = acc.template.get(-2); + if (isBraces(s) && isDolar(last)) { + let index = s.inner().first().val(); + (0, _errors.assert)(acc.rep.size > index, "unknown replacement value"); + let replacement = cloneLineNumber(acc.rep.get(index), beforeLast); + return { + template: acc.template.pop().concat(replacement), + rep: acc.rep + }; + } else if (isDelimiter(s)) { + let innerResult = replaceTemplate(s.inner(), acc.rep); + return { + template: acc.template.push(insertIntoDelimiter(s, innerResult)), + rep: acc.rep + }; } else { - return { template: acc_991.template.push(s_992), rep: acc_991.rep }; + return { + template: acc.template.push(s), + rep: acc.rep + }; } }; -function processTemplate_973(temp_995) { - let interp_996 = arguments.length <= 1 || arguments[1] === undefined ? (0, _immutable.List)() : arguments[1]; - return temp_995.reduce(process_970, { template: (0, _immutable.List)(), interp: interp_996 }); +function processTemplate(temp) { + let interp = arguments.length <= 1 || arguments[1] === undefined ? (0, _immutable.List)() : arguments[1]; + + return temp.reduce(process, { template: (0, _immutable.List)(), interp: interp }); } -function replaceTemplate_974(temp_997, rep_998) { - return temp_997.reduce(replace_972, { template: (0, _immutable.List)(), rep: rep_998 }).template; + +function replaceTemplate(temp, rep) { + return temp.reduce(replace, { template: (0, _immutable.List)(), rep: rep }).template; } -exports.processTemplate = processTemplate_973; -exports.replaceTemplate = replaceTemplate_974; -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/template-processor.js"],"names":[],"mappings":"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","file":"template-processor.js","sourcesContent":["import {List} from \"immutable\";\nimport {Maybe} from \"ramda-fantasy\";\nimport _ from \"ramda\";\nimport Syntax from \"./syntax\";\nimport {assert} from \"./errors\";\nconst isDolar_964 = s_975 => s_975 && typeof s_975.match === \"function\" && s_975.match(\"identifier\") && s_975.val() === \"$\";\nconst isDelimiter_965 = s_976 => s_976 && typeof s_976.match === \"function\" && s_976.match(\"delimiter\");\nconst isBraces_966 = s_977 => s_977 && typeof s_977.match === \"function\" && s_977.match(\"braces\");\nconst isParens_967 = s_978 => s_978 && typeof s_978.match === \"function\" && s_978.match(\"parens\");\nconst isBrackets_968 = s_979 => s_979 && typeof s_979.match === \"function\" && s_979.match(\"brackets\");\nconst insertIntoDelimiter_969 = _.cond([[isBraces_966, (s_980, r_981) => Syntax.from(\"braces\", r_981, s_980)], [isParens_967, (s_982, r_983) => Syntax.from(\"parens\", r_983, s_982)], [isBrackets_968, (s_984, r_985) => Syntax.from(\"brackets\", r_985, s_984)]]);\nconst process_970 = (acc_986, s_987) => {\n  if (isBraces_966(s_987) && isDolar_964(acc_986.template.last())) {\n    return {template: acc_986.template.push(Syntax.from(\"braces\", List.of(Syntax.from(\"number\", acc_986.interp.size)), s_987)), interp: acc_986.interp.push(s_987.inner())};\n  } else if (isDelimiter_965(s_987)) {\n    let innerResult = processTemplate_973(s_987.inner(), acc_986.interp);\n    return {template: acc_986.template.push(insertIntoDelimiter_969(s_987, innerResult.template)), interp: innerResult.interp};\n  } else {\n    return {template: acc_986.template.push(s_987), interp: acc_986.interp};\n  }\n};\nfunction cloneLineNumber_971(to_988, from_989) {\n  if (from_989 && to_988) {\n    if (typeof to_988.setLineNumber === \"function\") {\n      return to_988.setLineNumber(from_989.lineNumber());\n    } else if (List.isList(to_988)) {\n      return to_988.map(x_990 => cloneLineNumber_971(x_990, from_989));\n    }\n  }\n  return to_988;\n}\nconst replace_972 = (acc_991, s_992) => {\n  let last_993 = acc_991.template.get(-1);\n  let beforeLast_994 = acc_991.template.get(-2);\n  if (isBraces_966(s_992) && isDolar_964(last_993)) {\n    let index = s_992.inner().first().val();\n    assert(acc_991.rep.size > index, \"unknown replacement value\");\n    let replacement = cloneLineNumber_971(acc_991.rep.get(index), beforeLast_994);\n    return {template: acc_991.template.pop().concat(replacement), rep: acc_991.rep};\n  } else if (isDelimiter_965(s_992)) {\n    let innerResult = replaceTemplate_974(s_992.inner(), acc_991.rep);\n    return {template: acc_991.template.push(insertIntoDelimiter_969(s_992, innerResult)), rep: acc_991.rep};\n  } else {\n    return {template: acc_991.template.push(s_992), rep: acc_991.rep};\n  }\n};\nfunction processTemplate_973(temp_995, interp_996 = List()) {\n  return temp_995.reduce(process_970, {template: List(), interp: interp_996});\n}\nfunction replaceTemplate_974(temp_997, rep_998) {\n  return temp_997.reduce(replace_972, {template: List(), rep: rep_998}).template;\n}\nexport {processTemplate_973 as processTemplate};\nexport {replaceTemplate_974 as replaceTemplate}"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/template-processor.js"],"names":[],"mappings":";;;;;QAwFgB,e,GAAA,e;QAIA,e,GAAA,e;;AA5FhB;;AACA;;;;AACA;;;;AACA;;;;AAEA;;;;;;;;;;;;;;;AAeA,MAAM,UAAc,KAAK,KAAK,OAAO,EAAE,KAAT,KAAmB,UAAxB,IAAsC,EAAE,KAAF,CAAQ,YAAR,CAAtC,IAA+D,EAAE,GAAF,OAAY,GAApG;AACA,MAAM,cAAc,KAAK,KAAK,OAAO,EAAE,KAAT,KAAmB,UAAxB,IAAsC,EAAE,KAAF,CAAQ,WAAR,CAA/D;AACA,MAAM,WAAc,KAAK,KAAK,OAAO,EAAE,KAAT,KAAmB,UAAxB,IAAsC,EAAE,KAAF,CAAQ,QAAR,CAA/D;AACA,MAAM,WAAc,KAAK,KAAK,OAAO,EAAE,KAAT,KAAmB,UAAxB,IAAsC,EAAE,KAAF,CAAQ,QAAR,CAA/D;AACA,MAAM,aAAc,KAAK,KAAK,OAAO,EAAE,KAAT,KAAmB,UAAxB,IAAsC,EAAE,KAAF,CAAQ,UAAR,CAA/D;;AAEA,MAAM,sBAAsB,gBAAE,IAAF,CAAO,CACjC,CAAC,QAAD,EAAW,CAAC,CAAD,EAAI,CAAJ,KAAU,iBAAO,IAAP,CAAY,QAAZ,EAAsB,CAAtB,EAAyB,CAAzB,CAArB,CADiC,EAEjC,CAAC,QAAD,EAAW,CAAC,CAAD,EAAI,CAAJ,KAAU,iBAAO,IAAP,CAAY,QAAZ,EAAsB,CAAtB,EAAyB,CAAzB,CAArB,CAFiC,EAGjC,CAAC,UAAD,EAAa,CAAC,CAAD,EAAI,CAAJ,KAAU,iBAAO,IAAP,CAAY,UAAZ,EAAwB,CAAxB,EAA2B,CAA3B,CAAvB,CAHiC,CAAP,CAA5B;;AAMA,MAAM,UAAU,CAAC,GAAD,EAAM,CAAN,KAAY;AAC1B,MAAI,SAAS,CAAT,KAAe,QAAQ,IAAI,QAAJ,CAAa,IAAb,EAAR,CAAnB,EAAiD;AAC/C,WAAO;AACL,gBAAU,IAAI,QAAJ,CAAa,IAAb,CAAkB,iBAAO,IAAP,CAAY,QAAZ,EAAsB,gBAAK,EAAL,CAAQ,iBAAO,IAAP,CAAY,QAAZ,EAAsB,IAAI,MAAJ,CAAW,IAAjC,CAAR,CAAtB,EAAuE,CAAvE,CAAlB,CADL;AAEL,cAAQ,IAAI,MAAJ,CAAW,IAAX,CAAgB,EAAE,KAAF,EAAhB;AAFH,KAAP;AAID,GALD,MAKO,IAAI,YAAY,CAAZ,CAAJ,EAAoB;AACzB,QAAI,cAAc,gBAAgB,EAAE,KAAF,EAAhB,EAA2B,IAAI,MAA/B,CAAlB;AACA,WAAO;AACL,gBAAU,IAAI,QAAJ,CAAa,IAAb,CAAkB,oBAAoB,CAApB,EAAuB,YAAY,QAAnC,CAAlB,CADL;AAEL,cAAQ,YAAY;AAFf,KAAP;AAID,GANM,MAMA;AACL,WAAO;AACL,gBAAU,IAAI,QAAJ,CAAa,IAAb,CAAkB,CAAlB,CADL;AAEL,cAAQ,IAAI;AAFP,KAAP;AAID;AACF,CAlBD;;AAoBA,SAAS,eAAT,CAAyB,EAAzB,EAA6B,IAA7B,EAAmC;AACjC,MAAI,QAAQ,EAAZ,EAAiB;AACf,QAAI,OAAO,GAAG,aAAV,KAA4B,UAAhC,EAA4C;AAC1C,aAAO,GAAG,aAAH,CAAiB,KAAK,UAAL,EAAjB,CAAP;AACD,KAFD,MAEO,IAAI,gBAAK,MAAL,CAAY,EAAZ,CAAJ,EAAqB;AAC1B,aAAO,GAAG,GAAH,CAAO,KAAK,gBAAgB,CAAhB,EAAmB,IAAnB,CAAZ,CAAP;AACD;AACF;AACD,SAAO,EAAP;AACD;;AAED,MAAM,UAAU,CAAC,GAAD,EAAM,CAAN,KAAY;AAC1B,MAAI,OAAO,IAAI,QAAJ,CAAa,GAAb,CAAiB,CAAC,CAAlB,CAAX;AACA,MAAI,aAAa,IAAI,QAAJ,CAAa,GAAb,CAAiB,CAAC,CAAlB,CAAjB;AACA,MAAI,SAAS,CAAT,KAAe,QAAQ,IAAR,CAAnB,EAAkC;AAChC,QAAI,QAAQ,EAAE,KAAF,GAAU,KAAV,GAAkB,GAAlB,EAAZ;AACA,wBAAO,IAAI,GAAJ,CAAQ,IAAR,GAAe,KAAtB,EAA6B,2BAA7B;AACA,QAAI,cAAc,gBAAgB,IAAI,GAAJ,CAAQ,GAAR,CAAY,KAAZ,CAAhB,EAAoC,UAApC,CAAlB;AACA,WAAO;AACL,gBAAU,IAAI,QAAJ,CAAa,GAAb,GAAmB,MAAnB,CAA0B,WAA1B,CADL;AAEL,WAAK,IAAI;AAFJ,KAAP;AAID,GARD,MAQO,IAAI,YAAY,CAAZ,CAAJ,EAAoB;AACzB,QAAI,cAAc,gBAAgB,EAAE,KAAF,EAAhB,EAA2B,IAAI,GAA/B,CAAlB;AACA,WAAO;AACL,gBAAU,IAAI,QAAJ,CAAa,IAAb,CAAkB,oBAAoB,CAApB,EAAuB,WAAvB,CAAlB,CADL;AAEL,WAAK,IAAI;AAFJ,KAAP;AAID,GANM,MAMA;AACL,WAAO;AACL,gBAAU,IAAI,QAAJ,CAAa,IAAb,CAAkB,CAAlB,CADL;AAEL,WAAK,IAAI;AAFJ,KAAP;AAID;AACF,CAvBD;;AAyBO,SAAS,eAAT,CAAyB,IAAzB,EAAgD;AAAA,MAAjB,MAAiB,yDAAR,sBAAQ;;AACrD,SAAO,KAAK,MAAL,CAAY,OAAZ,EAAqB,EAAE,UAAU,sBAAZ,EAAoB,cAApB,EAArB,CAAP;AACD;;AAEM,SAAS,eAAT,CAAyB,IAAzB,EAA+B,GAA/B,EAAoC;AACzC,SAAO,KAAK,MAAL,CAAY,OAAZ,EAAqB,EAAE,UAAU,sBAAZ,EAAoB,QAApB,EAArB,EAAgD,QAAvD;AACD","file":"template-processor.js","sourcesContent":["import { List } from 'immutable';\nimport _ from 'ramda';\nimport Syntax from './syntax';\nimport { assert } from './errors';\n\n/*\nGiven a syntax list like:\n\n  [foo, bar, $, { 42, +, 24 }, baz]\n\nconvert it to:\n\n  [foo, bar, $, { 0 }, baz]\n\nand return another list with the interpolated values at the corresponding\npositions.\n\nRequires either lookahead/lookbehind of one (to see the $).\n*/\n\nconst isDolar     = s => s && typeof s.match === 'function' && s.match(\"identifier\") && s.val() === '$';\nconst isDelimiter = s => s && typeof s.match === 'function' && s.match(\"delimiter\");\nconst isBraces    = s => s && typeof s.match === 'function' && s.match(\"braces\");\nconst isParens    = s => s && typeof s.match === 'function' && s.match(\"parens\");\nconst isBrackets  = s => s && typeof s.match === 'function' && s.match(\"brackets\");\n\nconst insertIntoDelimiter = _.cond([\n  [isBraces, (s, r) => Syntax.from(\"braces\", r, s)],\n  [isParens, (s, r) => Syntax.from(\"parens\", r, s)],\n  [isBrackets, (s, r) => Syntax.from(\"brackets\", r, s)]\n]);\n\nconst process = (acc, s) => {\n  if (isBraces(s) && isDolar(acc.template.last())) {\n    return {\n      template: acc.template.push(Syntax.from(\"braces\", List.of(Syntax.from(\"number\", acc.interp.size)), s)),\n      interp: acc.interp.push(s.inner())\n    };\n  } else if (isDelimiter(s)) {\n    let innerResult = processTemplate(s.inner(), acc.interp);\n    return {\n      template: acc.template.push(insertIntoDelimiter(s, innerResult.template)),\n      interp: innerResult.interp\n    };\n  } else {\n    return {\n      template: acc.template.push(s),\n      interp: acc.interp\n    };\n  }\n};\n\nfunction cloneLineNumber(to, from) {\n  if (from && to ) {\n    if (typeof to.setLineNumber === 'function') {\n      return to.setLineNumber(from.lineNumber());\n    } else if (List.isList(to)) {\n      return to.map(x => cloneLineNumber(x, from));\n    }\n  }\n  return to;\n}\n\nconst replace = (acc, s) => {\n  let last = acc.template.get(-1);\n  let beforeLast = acc.template.get(-2);\n  if (isBraces(s) && isDolar(last)) {\n    let index = s.inner().first().val();\n    assert(acc.rep.size > index, \"unknown replacement value\");\n    let replacement = cloneLineNumber(acc.rep.get(index), beforeLast);\n    return {\n      template: acc.template.pop().concat(replacement),\n      rep: acc.rep\n    };\n  } else if (isDelimiter(s)) {\n    let innerResult = replaceTemplate(s.inner(), acc.rep);\n    return {\n      template: acc.template.push(insertIntoDelimiter(s, innerResult)),\n      rep: acc.rep\n    };\n  } else {\n    return {\n      template: acc.template.push(s),\n      rep: acc.rep\n    };\n  }\n};\n\nexport function processTemplate(temp, interp = List()) {\n  return temp.reduce(process, { template: List(), interp });\n}\n\nexport function replaceTemplate(temp, rep) {\n  return temp.reduce(replace, { template: List(), rep }).template;\n}\n"]} \ No newline at end of file diff --git a/dist/term-expander.js b/dist/term-expander.js index b8e54c6f..97e03903 100644 --- a/dist/term-expander.js +++ b/dist/term-expander.js @@ -16,10 +16,6 @@ var _applyScopeInParamsReducer = require("./apply-scope-in-params-reducer"); var _applyScopeInParamsReducer2 = _interopRequireDefault(_applyScopeInParamsReducer); -var _shiftReducer = require("shift-reducer"); - -var _shiftReducer2 = _interopRequireDefault(_shiftReducer); - var _compiler = require("./compiler"); var _compiler2 = _interopRequireDefault(_compiler); @@ -32,8 +28,6 @@ var _serializer = require("./serializer"); var _enforester = require("./enforester"); -var _errors = require("./errors"); - var _templateProcessor = require("./template-processor.js"); var _astDispatcher = require("./ast-dispatcher"); @@ -43,346 +37,626 @@ var _astDispatcher2 = _interopRequireDefault(_astDispatcher); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } class TermExpander extends _astDispatcher2.default { - constructor(context_999) { - super("expand", true); - this.context = context_999; + constructor(context) { + super('expand', true); + this.context = context; } - expand(term_1000) { - return this.dispatch(term_1000); + + expand(term) { + return this.dispatch(term); } - expandPragma(term_1001) { - return term_1001; + + expandPragma(term) { + return term; } - expandTemplateExpression(term_1002) { - return new _terms2.default("TemplateExpression", { tag: term_1002.tag == null ? null : this.expand(term_1002.tag), elements: term_1002.elements.toArray() }); + + expandTemplateExpression(term) { + return new _terms2.default('TemplateExpression', { + tag: term.tag == null ? null : this.expand(term.tag), + elements: term.elements.toArray() + }); } - expandBreakStatement(term_1003) { - return new _terms2.default("BreakStatement", { label: term_1003.label ? term_1003.label.val() : null }); + + expandBreakStatement(term) { + return new _terms2.default('BreakStatement', { + label: term.label ? term.label.val() : null + }); } - expandDoWhileStatement(term_1004) { - return new _terms2.default("DoWhileStatement", { body: this.expand(term_1004.body), test: this.expand(term_1004.test) }); + + expandDoWhileStatement(term) { + return new _terms2.default('DoWhileStatement', { + body: this.expand(term.body), + test: this.expand(term.test) + }); } - expandWithStatement(term_1005) { - return new _terms2.default("WithStatement", { body: this.expand(term_1005.body), object: this.expand(term_1005.object) }); + + expandWithStatement(term) { + return new _terms2.default('WithStatement', { + body: this.expand(term.body), + object: this.expand(term.object) + }); } - expandDebuggerStatement(term_1006) { - return term_1006; + + expandDebuggerStatement(term) { + return term; } - expandContinueStatement(term_1007) { - return new _terms2.default("ContinueStatement", { label: term_1007.label ? term_1007.label.val() : null }); + + expandContinueStatement(term) { + return new _terms2.default('ContinueStatement', { + label: term.label ? term.label.val() : null + }); } - expandSwitchStatementWithDefault(term_1008) { - return new _terms2.default("SwitchStatementWithDefault", { discriminant: this.expand(term_1008.discriminant), preDefaultCases: term_1008.preDefaultCases.map(c_1009 => this.expand(c_1009)).toArray(), defaultCase: this.expand(term_1008.defaultCase), postDefaultCases: term_1008.postDefaultCases.map(c_1010 => this.expand(c_1010)).toArray() }); + + expandSwitchStatementWithDefault(term) { + return new _terms2.default('SwitchStatementWithDefault', { + discriminant: this.expand(term.discriminant), + preDefaultCases: term.preDefaultCases.map(c => this.expand(c)).toArray(), + defaultCase: this.expand(term.defaultCase), + postDefaultCases: term.postDefaultCases.map(c => this.expand(c)).toArray() + }); } - expandComputedMemberExpression(term_1011) { - return new _terms2.default("ComputedMemberExpression", { object: this.expand(term_1011.object), expression: this.expand(term_1011.expression) }); + + expandComputedMemberExpression(term) { + return new _terms2.default('ComputedMemberExpression', { + object: this.expand(term.object), + expression: this.expand(term.expression) + }); } - expandSwitchStatement(term_1012) { - return new _terms2.default("SwitchStatement", { discriminant: this.expand(term_1012.discriminant), cases: term_1012.cases.map(c_1013 => this.expand(c_1013)).toArray() }); + + expandSwitchStatement(term) { + return new _terms2.default('SwitchStatement', { + discriminant: this.expand(term.discriminant), + cases: term.cases.map(c => this.expand(c)).toArray() + }); } - expandFormalParameters(term_1014) { - let rest_1015 = term_1014.rest == null ? null : this.expand(term_1014.rest); - return new _terms2.default("FormalParameters", { items: term_1014.items.map(i_1016 => this.expand(i_1016)), rest: rest_1015 }); + + expandFormalParameters(term) { + let rest = term.rest == null ? null : this.expand(term.rest); + return new _terms2.default('FormalParameters', { + items: term.items.map(i => this.expand(i)), + rest: rest + }); } - expandArrowExpression(term_1017) { - return this.doFunctionExpansion(term_1017, "ArrowExpression"); + + expandArrowExpression(term) { + return this.doFunctionExpansion(term, 'ArrowExpression'); } - expandSwitchDefault(term_1018) { - return new _terms2.default("SwitchDefault", { consequent: term_1018.consequent.map(c_1019 => this.expand(c_1019)).toArray() }); + + expandSwitchDefault(term) { + return new _terms2.default('SwitchDefault', { + consequent: term.consequent.map(c => this.expand(c)).toArray() + }); } - expandSwitchCase(term_1020) { - return new _terms2.default("SwitchCase", { test: this.expand(term_1020.test), consequent: term_1020.consequent.map(c_1021 => this.expand(c_1021)).toArray() }); + + expandSwitchCase(term) { + return new _terms2.default('SwitchCase', { + test: this.expand(term.test), + consequent: term.consequent.map(c => this.expand(c)).toArray() + }); } - expandForInStatement(term_1022) { - return new _terms2.default("ForInStatement", { left: this.expand(term_1022.left), right: this.expand(term_1022.right), body: this.expand(term_1022.body) }); + + expandForInStatement(term) { + return new _terms2.default('ForInStatement', { + left: this.expand(term.left), + right: this.expand(term.right), + body: this.expand(term.body) + }); } - expandTryCatchStatement(term_1023) { - return new _terms2.default("TryCatchStatement", { body: this.expand(term_1023.body), catchClause: this.expand(term_1023.catchClause) }); + + expandTryCatchStatement(term) { + return new _terms2.default('TryCatchStatement', { + body: this.expand(term.body), + catchClause: this.expand(term.catchClause) + }); } - expandTryFinallyStatement(term_1024) { - let catchClause_1025 = term_1024.catchClause == null ? null : this.expand(term_1024.catchClause); - return new _terms2.default("TryFinallyStatement", { body: this.expand(term_1024.body), catchClause: catchClause_1025, finalizer: this.expand(term_1024.finalizer) }); + + expandTryFinallyStatement(term) { + let catchClause = term.catchClause == null ? null : this.expand(term.catchClause); + return new _terms2.default('TryFinallyStatement', { + body: this.expand(term.body), + catchClause: catchClause, + finalizer: this.expand(term.finalizer) + }); } - expandCatchClause(term_1026) { - return new _terms2.default("CatchClause", { binding: this.expand(term_1026.binding), body: this.expand(term_1026.body) }); + + expandCatchClause(term) { + return new _terms2.default('CatchClause', { + binding: this.expand(term.binding), + body: this.expand(term.body) + }); } - expandThrowStatement(term_1027) { - return new _terms2.default("ThrowStatement", { expression: this.expand(term_1027.expression) }); + + expandThrowStatement(term) { + return new _terms2.default('ThrowStatement', { + expression: this.expand(term.expression) + }); } - expandForOfStatement(term_1028) { - return new _terms2.default("ForOfStatement", { left: this.expand(term_1028.left), right: this.expand(term_1028.right), body: this.expand(term_1028.body) }); + + expandForOfStatement(term) { + return new _terms2.default('ForOfStatement', { + left: this.expand(term.left), + right: this.expand(term.right), + body: this.expand(term.body) + }); } - expandBindingIdentifier(term_1029) { - return term_1029; + + expandBindingIdentifier(term) { + return term; } - expandBindingPropertyIdentifier(term_1030) { - return term_1030; + + expandBindingPropertyIdentifier(term) { + return term; } - expandBindingPropertyProperty(term_1031) { - return new _terms2.default("BindingPropertyProperty", { name: this.expand(term_1031.name), binding: this.expand(term_1031.binding) }); + expandBindingPropertyProperty(term) { + return new _terms2.default('BindingPropertyProperty', { + name: this.expand(term.name), + binding: this.expand(term.binding) + }); } - expandComputedPropertyName(term_1032) { - return new _terms2.default("ComputedPropertyName", { expression: this.expand(term_1032.expression) }); + + expandComputedPropertyName(term) { + return new _terms2.default('ComputedPropertyName', { + expression: this.expand(term.expression) + }); } - expandObjectBinding(term_1033) { - return new _terms2.default("ObjectBinding", { properties: term_1033.properties.map(t_1034 => this.expand(t_1034)).toArray() }); + + expandObjectBinding(term) { + return new _terms2.default('ObjectBinding', { + properties: term.properties.map(t => this.expand(t)).toArray() + }); } - expandArrayBinding(term_1035) { - let restElement_1036 = term_1035.restElement == null ? null : this.expand(term_1035.restElement); - return new _terms2.default("ArrayBinding", { elements: term_1035.elements.map(t_1037 => t_1037 == null ? null : this.expand(t_1037)).toArray(), restElement: restElement_1036 }); + + expandArrayBinding(term) { + let restElement = term.restElement == null ? null : this.expand(term.restElement); + return new _terms2.default('ArrayBinding', { + elements: term.elements.map(t => t == null ? null : this.expand(t)).toArray(), + restElement: restElement + }); } - expandBindingWithDefault(term_1038) { - return new _terms2.default("BindingWithDefault", { binding: this.expand(term_1038.binding), init: this.expand(term_1038.init) }); + + expandBindingWithDefault(term) { + return new _terms2.default('BindingWithDefault', { + binding: this.expand(term.binding), + init: this.expand(term.init) + }); } - expandShorthandProperty(term_1039) { - return new _terms2.default("DataProperty", { name: new _terms2.default("StaticPropertyName", { value: term_1039.name }), expression: new _terms2.default("IdentifierExpression", { name: term_1039.name }) }); + + expandShorthandProperty(term) { + // because hygiene, shorthand properties must turn into DataProperties + return new _terms2.default('DataProperty', { + name: new _terms2.default('StaticPropertyName', { + value: term.name + }), + expression: new _terms2.default('IdentifierExpression', { + name: term.name + }) + }); } - expandForStatement(term_1040) { - let init_1041 = term_1040.init == null ? null : this.expand(term_1040.init); - let test_1042 = term_1040.test == null ? null : this.expand(term_1040.test); - let update_1043 = term_1040.update == null ? null : this.expand(term_1040.update); - let body_1044 = this.expand(term_1040.body); - return new _terms2.default("ForStatement", { init: init_1041, test: test_1042, update: update_1043, body: body_1044 }); + + expandForStatement(term) { + let init = term.init == null ? null : this.expand(term.init); + let test = term.test == null ? null : this.expand(term.test); + let update = term.update == null ? null : this.expand(term.update); + let body = this.expand(term.body); + return new _terms2.default('ForStatement', { init: init, test: test, update: update, body: body }); } - expandYieldExpression(term_1045) { - let expr_1046 = term_1045.expression == null ? null : this.expand(term_1045.expression); - return new _terms2.default("YieldExpression", { expression: expr_1046 }); + + expandYieldExpression(term) { + let expr = term.expression == null ? null : this.expand(term.expression); + return new _terms2.default('YieldExpression', { + expression: expr + }); } - expandYieldGeneratorExpression(term_1047) { - let expr_1048 = term_1047.expression == null ? null : this.expand(term_1047.expression); - return new _terms2.default("YieldGeneratorExpression", { expression: expr_1048 }); + + expandYieldGeneratorExpression(term) { + let expr = term.expression == null ? null : this.expand(term.expression); + return new _terms2.default('YieldGeneratorExpression', { + expression: expr + }); } - expandWhileStatement(term_1049) { - return new _terms2.default("WhileStatement", { test: this.expand(term_1049.test), body: this.expand(term_1049.body) }); + + expandWhileStatement(term) { + return new _terms2.default('WhileStatement', { + test: this.expand(term.test), + body: this.expand(term.body) + }); } - expandIfStatement(term_1050) { - let consequent_1051 = term_1050.consequent == null ? null : this.expand(term_1050.consequent); - let alternate_1052 = term_1050.alternate == null ? null : this.expand(term_1050.alternate); - return new _terms2.default("IfStatement", { test: this.expand(term_1050.test), consequent: consequent_1051, alternate: alternate_1052 }); + + expandIfStatement(term) { + let consequent = term.consequent == null ? null : this.expand(term.consequent); + let alternate = term.alternate == null ? null : this.expand(term.alternate); + return new _terms2.default('IfStatement', { + test: this.expand(term.test), + consequent: consequent, + alternate: alternate + }); } - expandBlockStatement(term_1053) { - return new _terms2.default("BlockStatement", { block: this.expand(term_1053.block) }); + + expandBlockStatement(term) { + return new _terms2.default('BlockStatement', { + block: this.expand(term.block) + }); } - expandBlock(term_1054) { - let scope_1055 = (0, _scope.freshScope)("block"); - this.context.currentScope.push(scope_1055); - let compiler_1056 = new _compiler2.default(this.context.phase, this.context.env, this.context.store, this.context); - let markedBody_1057, bodyTerm_1058; - markedBody_1057 = term_1054.statements.map(b_1059 => b_1059.addScope(scope_1055, this.context.bindings, _syntax.ALL_PHASES)); - bodyTerm_1058 = new _terms2.default("Block", { statements: compiler_1056.compile(markedBody_1057) }); + + expandBlock(term) { + let scope = (0, _scope.freshScope)('block'); + this.context.currentScope.push(scope); + let compiler = new _compiler2.default(this.context.phase, this.context.env, this.context.store, this.context); + + let markedBody, bodyTerm; + markedBody = term.statements.map(b => b.addScope(scope, this.context.bindings, _syntax.ALL_PHASES)); + bodyTerm = new _terms2.default('Block', { + statements: compiler.compile(markedBody) + }); this.context.currentScope.pop(); - return bodyTerm_1058; + return bodyTerm; } - expandVariableDeclarationStatement(term_1060) { - return new _terms2.default("VariableDeclarationStatement", { declaration: this.expand(term_1060.declaration) }); + + expandVariableDeclarationStatement(term) { + return new _terms2.default('VariableDeclarationStatement', { + declaration: this.expand(term.declaration) + }); } - expandReturnStatement(term_1061) { - if (term_1061.expression == null) { - return term_1061; + expandReturnStatement(term) { + if (term.expression == null) { + return term; } - return new _terms2.default("ReturnStatement", { expression: this.expand(term_1061.expression) }); + return new _terms2.default("ReturnStatement", { + expression: this.expand(term.expression) + }); } - expandClassDeclaration(term_1062) { - return new _terms2.default("ClassDeclaration", { name: term_1062.name == null ? null : this.expand(term_1062.name), super: term_1062.super == null ? null : this.expand(term_1062.super), elements: term_1062.elements.map(el_1063 => this.expand(el_1063)).toArray() }); + + expandClassDeclaration(term) { + return new _terms2.default('ClassDeclaration', { + name: term.name == null ? null : this.expand(term.name), + super: term.super == null ? null : this.expand(term.super), + elements: term.elements.map(el => this.expand(el)).toArray() + }); } - expandClassExpression(term_1064) { - return new _terms2.default("ClassExpression", { name: term_1064.name == null ? null : this.expand(term_1064.name), super: term_1064.super == null ? null : this.expand(term_1064.super), elements: term_1064.elements.map(el_1065 => this.expand(el_1065)).toArray() }); + + expandClassExpression(term) { + return new _terms2.default('ClassExpression', { + name: term.name == null ? null : this.expand(term.name), + super: term.super == null ? null : this.expand(term.super), + elements: term.elements.map(el => this.expand(el)).toArray() + }); } - expandClassElement(term_1066) { - return new _terms2.default("ClassElement", { isStatic: term_1066.isStatic, method: this.expand(term_1066.method) }); + + expandClassElement(term) { + return new _terms2.default('ClassElement', { + isStatic: term.isStatic, + method: this.expand(term.method) + }); } - expandThisExpression(term_1067) { - return term_1067; + + expandThisExpression(term) { + return term; } - expandSyntaxTemplate(term_1068) { - let r_1069 = (0, _templateProcessor.processTemplate)(term_1068.template.inner()); - let str_1070 = _syntax2.default.from("string", _serializer.serializer.write(r_1069.template)); - let callee_1071 = new _terms2.default("IdentifierExpression", { name: _syntax2.default.from("identifier", "syntaxTemplate") }); - let expandedInterps_1072 = r_1069.interp.map(i_1074 => { - let enf_1075 = new _enforester.Enforester(i_1074, (0, _immutable.List)(), this.context); - return this.expand(enf_1075.enforest("expression")); + + expandSyntaxTemplate(term) { + let r = (0, _templateProcessor.processTemplate)(term.template.inner()); + let str = _syntax2.default.from("string", _serializer.serializer.write(r.template)); + let callee = new _terms2.default('IdentifierExpression', { name: _syntax2.default.from("identifier", 'syntaxTemplate') }); + + let expandedInterps = r.interp.map(i => { + let enf = new _enforester.Enforester(i, (0, _immutable.List)(), this.context); + return this.expand(enf.enforest('expression')); + }); + + let args = _immutable.List.of(new _terms2.default('LiteralStringExpression', { value: str })).concat(expandedInterps); + + return new _terms2.default('CallExpression', { + callee: callee, arguments: args }); - let args_1073 = _immutable.List.of(new _terms2.default("LiteralStringExpression", { value: str_1070 })).concat(expandedInterps_1072); - return new _terms2.default("CallExpression", { callee: callee_1071, arguments: args_1073 }); } - expandSyntaxQuote(term_1076) { - let str_1077 = new _terms2.default("LiteralStringExpression", { value: _syntax2.default.from("string", _serializer.serializer.write(term_1076.name)) }); - return new _terms2.default("TemplateExpression", { tag: term_1076.template.tag, elements: term_1076.template.elements.push(str_1077).push(new _terms2.default("TemplateElement", { rawValue: "" })).toArray() }); + + expandSyntaxQuote(term) { + let str = new _terms2.default("LiteralStringExpression", { + value: _syntax2.default.from("string", _serializer.serializer.write(term.name)) + }); + + return new _terms2.default("TemplateExpression", { + tag: term.template.tag, + elements: term.template.elements.push(str).push(new _terms2.default('TemplateElement', { + rawValue: '' + })).toArray() + }); } - expandStaticMemberExpression(term_1078) { - return new _terms2.default("StaticMemberExpression", { object: this.expand(term_1078.object), property: term_1078.property }); + + expandStaticMemberExpression(term) { + return new _terms2.default("StaticMemberExpression", { + object: this.expand(term.object), + property: term.property + }); } - expandArrayExpression(term_1079) { - return new _terms2.default("ArrayExpression", { elements: term_1079.elements.map(t_1080 => t_1080 == null ? t_1080 : this.expand(t_1080)) }); + + expandArrayExpression(term) { + return new _terms2.default("ArrayExpression", { + elements: term.elements.map(t => t == null ? t : this.expand(t)) + }); } - expandImport(term_1081) { - return term_1081; + + expandImport(term) { + return term; } - expandImportNamespace(term_1082) { - return term_1082; + + expandImportNamespace(term) { + return term; } - expandExport(term_1083) { - return new _terms2.default("Export", { declaration: this.expand(term_1083.declaration) }); + + expandExport(term) { + return new _terms2.default('Export', { + declaration: this.expand(term.declaration) + }); } - expandExportDefault(term_1084) { - return new _terms2.default("ExportDefault", { body: this.expand(term_1084.body) }); + + expandExportDefault(term) { + return new _terms2.default('ExportDefault', { + body: this.expand(term.body) + }); } - expandExportFrom(term_1085) { - return term_1085; + + expandExportFrom(term) { + return term; } - expandExportAllFrom(term_1086) { - return term_1086; + + expandExportAllFrom(term) { + return term; } - expandExportSpecifier(term_1087) { - return term_1087; + + expandExportSpecifier(term) { + return term; } - expandStaticPropertyName(term_1088) { - return term_1088; + + expandStaticPropertyName(term) { + return term; } - expandDataProperty(term_1089) { - return new _terms2.default("DataProperty", { name: this.expand(term_1089.name), expression: this.expand(term_1089.expression) }); + + expandDataProperty(term) { + return new _terms2.default("DataProperty", { + name: this.expand(term.name), + expression: this.expand(term.expression) + }); } - expandObjectExpression(term_1090) { - return new _terms2.default("ObjectExpression", { properties: term_1090.properties.map(t_1091 => this.expand(t_1091)) }); + + expandObjectExpression(term) { + return new _terms2.default("ObjectExpression", { + properties: term.properties.map(t => this.expand(t)) + }); } - expandVariableDeclarator(term_1092) { - let init_1093 = term_1092.init == null ? null : this.expand(term_1092.init); - return new _terms2.default("VariableDeclarator", { binding: this.expand(term_1092.binding), init: init_1093 }); + + expandVariableDeclarator(term) { + let init = term.init == null ? null : this.expand(term.init); + return new _terms2.default("VariableDeclarator", { + binding: this.expand(term.binding), + init: init + }); } - expandVariableDeclaration(term_1094) { - if (term_1094.kind === "syntax" || term_1094.kind === "syntaxrec") { - return term_1094; + + expandVariableDeclaration(term) { + if (term.kind === 'syntax' || term.kind === 'syntaxrec') { + return term; } - return new _terms2.default("VariableDeclaration", { kind: term_1094.kind, declarators: term_1094.declarators.map(d_1095 => this.expand(d_1095)) }); + return new _terms2.default("VariableDeclaration", { + kind: term.kind, + declarators: term.declarators.map(d => this.expand(d)) + }); } - expandParenthesizedExpression(term_1096) { - if (term_1096.inner.size === 0) { + + expandParenthesizedExpression(term) { + if (term.inner.size === 0) { throw new Error("unexpected end of input"); } - let enf_1097 = new _enforester.Enforester(term_1096.inner, (0, _immutable.List)(), this.context); - let lookahead_1098 = enf_1097.peek(); - let t_1099 = enf_1097.enforestExpression(); - if (t_1099 == null || enf_1097.rest.size > 0) { - throw enf_1097.createError(lookahead_1098, "unexpected syntax"); + let enf = new _enforester.Enforester(term.inner, (0, _immutable.List)(), this.context); + let lookahead = enf.peek(); + let t = enf.enforestExpression(); + if (t == null || enf.rest.size > 0) { + throw enf.createError(lookahead, "unexpected syntax"); } - return this.expand(t_1099); + return this.expand(t); } - expandUnaryExpression(term_1100) { - return new _terms2.default("UnaryExpression", { operator: term_1100.operator, operand: this.expand(term_1100.operand) }); + + expandUnaryExpression(term) { + return new _terms2.default('UnaryExpression', { + operator: term.operator, + operand: this.expand(term.operand) + }); } - expandUpdateExpression(term_1101) { - return new _terms2.default("UpdateExpression", { isPrefix: term_1101.isPrefix, operator: term_1101.operator, operand: this.expand(term_1101.operand) }); + + expandUpdateExpression(term) { + return new _terms2.default('UpdateExpression', { + isPrefix: term.isPrefix, + operator: term.operator, + operand: this.expand(term.operand) + }); } - expandBinaryExpression(term_1102) { - let left_1103 = this.expand(term_1102.left); - let right_1104 = this.expand(term_1102.right); - return new _terms2.default("BinaryExpression", { left: left_1103, operator: term_1102.operator, right: right_1104 }); + + expandBinaryExpression(term) { + let left = this.expand(term.left); + let right = this.expand(term.right); + return new _terms2.default("BinaryExpression", { + left: left, + operator: term.operator, + right: right + }); } - expandConditionalExpression(term_1105) { - return new _terms2.default("ConditionalExpression", { test: this.expand(term_1105.test), consequent: this.expand(term_1105.consequent), alternate: this.expand(term_1105.alternate) }); + + expandConditionalExpression(term) { + return new _terms2.default('ConditionalExpression', { + test: this.expand(term.test), + consequent: this.expand(term.consequent), + alternate: this.expand(term.alternate) + }); } - expandNewTargetExpression(term_1106) { - return term_1106; + + expandNewTargetExpression(term) { + return term; } - expandNewExpression(term_1107) { - let callee_1108 = this.expand(term_1107.callee); - let enf_1109 = new _enforester.Enforester(term_1107.arguments, (0, _immutable.List)(), this.context); - let args_1110 = enf_1109.enforestArgumentList().map(arg_1111 => this.expand(arg_1111)); - return new _terms2.default("NewExpression", { callee: callee_1108, arguments: args_1110.toArray() }); + + expandNewExpression(term) { + let callee = this.expand(term.callee); + let enf = new _enforester.Enforester(term.arguments, (0, _immutable.List)(), this.context); + let args = enf.enforestArgumentList().map(arg => this.expand(arg)); + return new _terms2.default('NewExpression', { + callee: callee, + arguments: args.toArray() + }); } - expandSuper(term_1112) { - return term_1112; + + expandSuper(term) { + return term; } - expandCallExpression(term_1113) { - let callee_1114 = this.expand(term_1113.callee); - let enf_1115 = new _enforester.Enforester(term_1113.arguments, (0, _immutable.List)(), this.context); - let args_1116 = enf_1115.enforestArgumentList().map(arg_1117 => this.expand(arg_1117)); - return new _terms2.default("CallExpression", { callee: callee_1114, arguments: args_1116 }); + + expandCallExpression(term) { + let callee = this.expand(term.callee); + let enf = new _enforester.Enforester(term.arguments, (0, _immutable.List)(), this.context); + let args = enf.enforestArgumentList().map(arg => this.expand(arg)); + return new _terms2.default("CallExpression", { + callee: callee, + arguments: args + }); } - expandSpreadElement(term_1118) { - return new _terms2.default("SpreadElement", { expression: this.expand(term_1118.expression) }); + + expandSpreadElement(term) { + return new _terms2.default('SpreadElement', { + expression: this.expand(term.expression) + }); } - expandExpressionStatement(term_1119) { - let child_1120 = this.expand(term_1119.expression); - return new _terms2.default("ExpressionStatement", { expression: child_1120 }); + + expandExpressionStatement(term) { + let child = this.expand(term.expression); + return new _terms2.default("ExpressionStatement", { + expression: child + }); } - expandLabeledStatement(term_1121) { - return new _terms2.default("LabeledStatement", { label: term_1121.label.val(), body: this.expand(term_1121.body) }); + + expandLabeledStatement(term) { + return new _terms2.default('LabeledStatement', { + label: term.label.val(), + body: this.expand(term.body) + }); } - doFunctionExpansion(term_1122, type_1123) { - let scope_1124 = (0, _scope.freshScope)("fun"); - let red_1125 = new _applyScopeInParamsReducer2.default(scope_1124, this.context); - let params_1126; - if (type_1123 !== "Getter" && type_1123 !== "Setter") { - params_1126 = red_1125.transform(term_1122.params); - params_1126 = this.expand(params_1126); + + doFunctionExpansion(term, type) { + let scope = (0, _scope.freshScope)("fun"); + let red = new _applyScopeInParamsReducer2.default(scope, this.context); + let params; + if (type !== 'Getter' && type !== 'Setter') { + params = red.transform(term.params); + params = this.expand(params); } - this.context.currentScope.push(scope_1124); - let compiler_1127 = new _compiler2.default(this.context.phase, this.context.env, this.context.store, this.context); - let markedBody_1128, bodyTerm_1129; - if (term_1122.body instanceof _terms2.default) { - bodyTerm_1129 = this.expand(term_1122.body.addScope(scope_1124, this.context.bindings, _syntax.ALL_PHASES)); + this.context.currentScope.push(scope); + let compiler = new _compiler2.default(this.context.phase, this.context.env, this.context.store, this.context); + + let markedBody, bodyTerm; + if (term.body instanceof _terms2.default) { + // Arrow functions have a single term as their body + bodyTerm = this.expand(term.body.addScope(scope, this.context.bindings, _syntax.ALL_PHASES)); } else { - markedBody_1128 = term_1122.body.map(b_1130 => b_1130.addScope(scope_1124, this.context.bindings, _syntax.ALL_PHASES)); - bodyTerm_1129 = new _terms2.default("FunctionBody", { directives: (0, _immutable.List)(), statements: compiler_1127.compile(markedBody_1128) }); + markedBody = term.body.map(b => b.addScope(scope, this.context.bindings, _syntax.ALL_PHASES)); + bodyTerm = new _terms2.default("FunctionBody", { + directives: (0, _immutable.List)(), + statements: compiler.compile(markedBody) + }); } this.context.currentScope.pop(); - if (type_1123 === "Getter") { - return new _terms2.default(type_1123, { name: this.expand(term_1122.name), body: bodyTerm_1129 }); - } else if (type_1123 === "Setter") { - return new _terms2.default(type_1123, { name: this.expand(term_1122.name), param: term_1122.param, body: bodyTerm_1129 }); + + if (type === 'Getter') { + return new _terms2.default(type, { + name: this.expand(term.name), + body: bodyTerm + }); + } else if (type === 'Setter') { + return new _terms2.default(type, { + name: this.expand(term.name), + param: term.param, + body: bodyTerm + }); + } else if (type === 'ArrowExpression') { + return new _terms2.default(type, { + params: params, + body: bodyTerm + }); } - return new _terms2.default(type_1123, { name: term_1122.name, isGenerator: term_1122.isGenerator, params: params_1126, body: bodyTerm_1129 }); + return new _terms2.default(type, { + name: term.name, + isGenerator: term.isGenerator, + params: params, + body: bodyTerm + }); } - expandMethod(term_1131) { - return this.doFunctionExpansion(term_1131, "Method"); + + expandMethod(term) { + return this.doFunctionExpansion(term, 'Method'); } - expandSetter(term_1132) { - return this.doFunctionExpansion(term_1132, "Setter"); + + expandSetter(term) { + return this.doFunctionExpansion(term, 'Setter'); } - expandGetter(term_1133) { - return this.doFunctionExpansion(term_1133, "Getter"); + + expandGetter(term) { + return this.doFunctionExpansion(term, 'Getter'); } - expandFunctionDeclaration(term_1134) { - return this.doFunctionExpansion(term_1134, "FunctionDeclaration"); + + expandFunctionDeclaration(term) { + return this.doFunctionExpansion(term, "FunctionDeclaration"); } - expandFunctionExpression(term_1135) { - return this.doFunctionExpansion(term_1135, "FunctionExpression"); + + expandFunctionExpression(term) { + return this.doFunctionExpansion(term, "FunctionExpression"); } - expandCompoundAssignmentExpression(term_1136) { - return new _terms2.default("CompoundAssignmentExpression", { binding: this.expand(term_1136.binding), operator: term_1136.operator, expression: this.expand(term_1136.expression) }); + + expandCompoundAssignmentExpression(term) { + return new _terms2.default("CompoundAssignmentExpression", { + binding: this.expand(term.binding), + operator: term.operator, + expression: this.expand(term.expression) + }); } - expandAssignmentExpression(term_1137) { - return new _terms2.default("AssignmentExpression", { binding: this.expand(term_1137.binding), expression: this.expand(term_1137.expression) }); + + expandAssignmentExpression(term) { + return new _terms2.default("AssignmentExpression", { + binding: this.expand(term.binding), + expression: this.expand(term.expression) + }); } - expandEmptyStatement(term_1138) { - return term_1138; + + expandEmptyStatement(term) { + return term; } - expandLiteralBooleanExpression(term_1139) { - return term_1139; + + expandLiteralBooleanExpression(term) { + return term; } - expandLiteralNumericExpression(term_1140) { - return term_1140; + + expandLiteralNumericExpression(term) { + return term; } - expandLiteralInfinityExpression(term_1141) { - return term_1141; + expandLiteralInfinityExpression(term) { + return term; } - expandIdentifierExpression(term_1142) { - let trans_1143 = this.context.env.get(term_1142.name.resolve(this.context.phase)); - if (trans_1143) { - return new _terms2.default("IdentifierExpression", { name: trans_1143.id }); + + expandIdentifierExpression(term) { + let trans = this.context.env.get(term.name.resolve(this.context.phase)); + if (trans) { + return new _terms2.default("IdentifierExpression", { + name: trans.id + }); } - return term_1142; + return term; } - expandLiteralNullExpression(term_1144) { - return term_1144; + + expandLiteralNullExpression(term) { + return term; } - expandLiteralStringExpression(term_1145) { - return term_1145; + + expandLiteralStringExpression(term) { + return term; } - expandLiteralRegExpExpression(term_1146) { - return term_1146; + + expandLiteralRegExpExpression(term) { + return term; } } exports.default = TermExpander; -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/term-expander.js"],"names":[],"mappings":"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","file":"term-expander.js","sourcesContent":["import {List} from \"immutable\";\nimport Term, {isEOF, isBindingIdentifier, isFunctionDeclaration, isFunctionExpression, isFunctionTerm, isFunctionWithName, isSyntaxDeclaration, isVariableDeclaration, isVariableDeclarationStatement, isImport, isExport} from \"./terms\";\nimport {Scope, freshScope} from \"./scope\";\nimport ApplyScopeInParamsReducer from \"./apply-scope-in-params-reducer\";\nimport reducer, {MonoidalReducer} from \"shift-reducer\";\nimport Compiler from \"./compiler\";\nimport Syntax, {ALL_PHASES} from \"./syntax\";\nimport {serializer, makeDeserializer} from \"./serializer\";\nimport {enforestExpr, Enforester} from \"./enforester\";\nimport {assert} from \"./errors\";\nimport {processTemplate} from \"./template-processor.js\";\nimport ASTDispatcher from \"./ast-dispatcher\";\nexport default class TermExpander extends ASTDispatcher {\n  constructor(context_999) {\n    super(\"expand\", true);\n    this.context = context_999;\n  }\n  expand(term_1000) {\n    return this.dispatch(term_1000);\n  }\n  expandPragma(term_1001) {\n    return term_1001;\n  }\n  expandTemplateExpression(term_1002) {\n    return new Term(\"TemplateExpression\", {tag: term_1002.tag == null ? null : this.expand(term_1002.tag), elements: term_1002.elements.toArray()});\n  }\n  expandBreakStatement(term_1003) {\n    return new Term(\"BreakStatement\", {label: term_1003.label ? term_1003.label.val() : null});\n  }\n  expandDoWhileStatement(term_1004) {\n    return new Term(\"DoWhileStatement\", {body: this.expand(term_1004.body), test: this.expand(term_1004.test)});\n  }\n  expandWithStatement(term_1005) {\n    return new Term(\"WithStatement\", {body: this.expand(term_1005.body), object: this.expand(term_1005.object)});\n  }\n  expandDebuggerStatement(term_1006) {\n    return term_1006;\n  }\n  expandContinueStatement(term_1007) {\n    return new Term(\"ContinueStatement\", {label: term_1007.label ? term_1007.label.val() : null});\n  }\n  expandSwitchStatementWithDefault(term_1008) {\n    return new Term(\"SwitchStatementWithDefault\", {discriminant: this.expand(term_1008.discriminant), preDefaultCases: term_1008.preDefaultCases.map(c_1009 => this.expand(c_1009)).toArray(), defaultCase: this.expand(term_1008.defaultCase), postDefaultCases: term_1008.postDefaultCases.map(c_1010 => this.expand(c_1010)).toArray()});\n  }\n  expandComputedMemberExpression(term_1011) {\n    return new Term(\"ComputedMemberExpression\", {object: this.expand(term_1011.object), expression: this.expand(term_1011.expression)});\n  }\n  expandSwitchStatement(term_1012) {\n    return new Term(\"SwitchStatement\", {discriminant: this.expand(term_1012.discriminant), cases: term_1012.cases.map(c_1013 => this.expand(c_1013)).toArray()});\n  }\n  expandFormalParameters(term_1014) {\n    let rest_1015 = term_1014.rest == null ? null : this.expand(term_1014.rest);\n    return new Term(\"FormalParameters\", {items: term_1014.items.map(i_1016 => this.expand(i_1016)), rest: rest_1015});\n  }\n  expandArrowExpression(term_1017) {\n    return this.doFunctionExpansion(term_1017, \"ArrowExpression\");\n  }\n  expandSwitchDefault(term_1018) {\n    return new Term(\"SwitchDefault\", {consequent: term_1018.consequent.map(c_1019 => this.expand(c_1019)).toArray()});\n  }\n  expandSwitchCase(term_1020) {\n    return new Term(\"SwitchCase\", {test: this.expand(term_1020.test), consequent: term_1020.consequent.map(c_1021 => this.expand(c_1021)).toArray()});\n  }\n  expandForInStatement(term_1022) {\n    return new Term(\"ForInStatement\", {left: this.expand(term_1022.left), right: this.expand(term_1022.right), body: this.expand(term_1022.body)});\n  }\n  expandTryCatchStatement(term_1023) {\n    return new Term(\"TryCatchStatement\", {body: this.expand(term_1023.body), catchClause: this.expand(term_1023.catchClause)});\n  }\n  expandTryFinallyStatement(term_1024) {\n    let catchClause_1025 = term_1024.catchClause == null ? null : this.expand(term_1024.catchClause);\n    return new Term(\"TryFinallyStatement\", {body: this.expand(term_1024.body), catchClause: catchClause_1025, finalizer: this.expand(term_1024.finalizer)});\n  }\n  expandCatchClause(term_1026) {\n    return new Term(\"CatchClause\", {binding: this.expand(term_1026.binding), body: this.expand(term_1026.body)});\n  }\n  expandThrowStatement(term_1027) {\n    return new Term(\"ThrowStatement\", {expression: this.expand(term_1027.expression)});\n  }\n  expandForOfStatement(term_1028) {\n    return new Term(\"ForOfStatement\", {left: this.expand(term_1028.left), right: this.expand(term_1028.right), body: this.expand(term_1028.body)});\n  }\n  expandBindingIdentifier(term_1029) {\n    return term_1029;\n  }\n  expandBindingPropertyIdentifier(term_1030) {\n    return term_1030;\n  }\n  expandBindingPropertyProperty(term_1031) {\n    return new Term(\"BindingPropertyProperty\", {name: this.expand(term_1031.name), binding: this.expand(term_1031.binding)});\n  }\n  expandComputedPropertyName(term_1032) {\n    return new Term(\"ComputedPropertyName\", {expression: this.expand(term_1032.expression)});\n  }\n  expandObjectBinding(term_1033) {\n    return new Term(\"ObjectBinding\", {properties: term_1033.properties.map(t_1034 => this.expand(t_1034)).toArray()});\n  }\n  expandArrayBinding(term_1035) {\n    let restElement_1036 = term_1035.restElement == null ? null : this.expand(term_1035.restElement);\n    return new Term(\"ArrayBinding\", {elements: term_1035.elements.map(t_1037 => t_1037 == null ? null : this.expand(t_1037)).toArray(), restElement: restElement_1036});\n  }\n  expandBindingWithDefault(term_1038) {\n    return new Term(\"BindingWithDefault\", {binding: this.expand(term_1038.binding), init: this.expand(term_1038.init)});\n  }\n  expandShorthandProperty(term_1039) {\n    return new Term(\"DataProperty\", {name: new Term(\"StaticPropertyName\", {value: term_1039.name}), expression: new Term(\"IdentifierExpression\", {name: term_1039.name})});\n  }\n  expandForStatement(term_1040) {\n    let init_1041 = term_1040.init == null ? null : this.expand(term_1040.init);\n    let test_1042 = term_1040.test == null ? null : this.expand(term_1040.test);\n    let update_1043 = term_1040.update == null ? null : this.expand(term_1040.update);\n    let body_1044 = this.expand(term_1040.body);\n    return new Term(\"ForStatement\", {init: init_1041, test: test_1042, update: update_1043, body: body_1044});\n  }\n  expandYieldExpression(term_1045) {\n    let expr_1046 = term_1045.expression == null ? null : this.expand(term_1045.expression);\n    return new Term(\"YieldExpression\", {expression: expr_1046});\n  }\n  expandYieldGeneratorExpression(term_1047) {\n    let expr_1048 = term_1047.expression == null ? null : this.expand(term_1047.expression);\n    return new Term(\"YieldGeneratorExpression\", {expression: expr_1048});\n  }\n  expandWhileStatement(term_1049) {\n    return new Term(\"WhileStatement\", {test: this.expand(term_1049.test), body: this.expand(term_1049.body)});\n  }\n  expandIfStatement(term_1050) {\n    let consequent_1051 = term_1050.consequent == null ? null : this.expand(term_1050.consequent);\n    let alternate_1052 = term_1050.alternate == null ? null : this.expand(term_1050.alternate);\n    return new Term(\"IfStatement\", {test: this.expand(term_1050.test), consequent: consequent_1051, alternate: alternate_1052});\n  }\n  expandBlockStatement(term_1053) {\n    return new Term(\"BlockStatement\", {block: this.expand(term_1053.block)});\n  }\n  expandBlock(term_1054) {\n    let scope_1055 = freshScope(\"block\");\n    this.context.currentScope.push(scope_1055);\n    let compiler_1056 = new Compiler(this.context.phase, this.context.env, this.context.store, this.context);\n    let markedBody_1057, bodyTerm_1058;\n    markedBody_1057 = term_1054.statements.map(b_1059 => b_1059.addScope(scope_1055, this.context.bindings, ALL_PHASES));\n    bodyTerm_1058 = new Term(\"Block\", {statements: compiler_1056.compile(markedBody_1057)});\n    this.context.currentScope.pop();\n    return bodyTerm_1058;\n  }\n  expandVariableDeclarationStatement(term_1060) {\n    return new Term(\"VariableDeclarationStatement\", {declaration: this.expand(term_1060.declaration)});\n  }\n  expandReturnStatement(term_1061) {\n    if (term_1061.expression == null) {\n      return term_1061;\n    }\n    return new Term(\"ReturnStatement\", {expression: this.expand(term_1061.expression)});\n  }\n  expandClassDeclaration(term_1062) {\n    return new Term(\"ClassDeclaration\", {name: term_1062.name == null ? null : this.expand(term_1062.name), super: term_1062.super == null ? null : this.expand(term_1062.super), elements: term_1062.elements.map(el_1063 => this.expand(el_1063)).toArray()});\n  }\n  expandClassExpression(term_1064) {\n    return new Term(\"ClassExpression\", {name: term_1064.name == null ? null : this.expand(term_1064.name), super: term_1064.super == null ? null : this.expand(term_1064.super), elements: term_1064.elements.map(el_1065 => this.expand(el_1065)).toArray()});\n  }\n  expandClassElement(term_1066) {\n    return new Term(\"ClassElement\", {isStatic: term_1066.isStatic, method: this.expand(term_1066.method)});\n  }\n  expandThisExpression(term_1067) {\n    return term_1067;\n  }\n  expandSyntaxTemplate(term_1068) {\n    let r_1069 = processTemplate(term_1068.template.inner());\n    let str_1070 = Syntax.from(\"string\", serializer.write(r_1069.template));\n    let callee_1071 = new Term(\"IdentifierExpression\", {name: Syntax.from(\"identifier\", \"syntaxTemplate\")});\n    let expandedInterps_1072 = r_1069.interp.map(i_1074 => {\n      let enf_1075 = new Enforester(i_1074, List(), this.context);\n      return this.expand(enf_1075.enforest(\"expression\"));\n    });\n    let args_1073 = List.of(new Term(\"LiteralStringExpression\", {value: str_1070})).concat(expandedInterps_1072);\n    return new Term(\"CallExpression\", {callee: callee_1071, arguments: args_1073});\n  }\n  expandSyntaxQuote(term_1076) {\n    let str_1077 = new Term(\"LiteralStringExpression\", {value: Syntax.from(\"string\", serializer.write(term_1076.name))});\n    return new Term(\"TemplateExpression\", {tag: term_1076.template.tag, elements: term_1076.template.elements.push(str_1077).push(new Term(\"TemplateElement\", {rawValue: \"\"})).toArray()});\n  }\n  expandStaticMemberExpression(term_1078) {\n    return new Term(\"StaticMemberExpression\", {object: this.expand(term_1078.object), property: term_1078.property});\n  }\n  expandArrayExpression(term_1079) {\n    return new Term(\"ArrayExpression\", {elements: term_1079.elements.map(t_1080 => t_1080 == null ? t_1080 : this.expand(t_1080))});\n  }\n  expandImport(term_1081) {\n    return term_1081;\n  }\n  expandImportNamespace(term_1082) {\n    return term_1082;\n  }\n  expandExport(term_1083) {\n    return new Term(\"Export\", {declaration: this.expand(term_1083.declaration)});\n  }\n  expandExportDefault(term_1084) {\n    return new Term(\"ExportDefault\", {body: this.expand(term_1084.body)});\n  }\n  expandExportFrom(term_1085) {\n    return term_1085;\n  }\n  expandExportAllFrom(term_1086) {\n    return term_1086;\n  }\n  expandExportSpecifier(term_1087) {\n    return term_1087;\n  }\n  expandStaticPropertyName(term_1088) {\n    return term_1088;\n  }\n  expandDataProperty(term_1089) {\n    return new Term(\"DataProperty\", {name: this.expand(term_1089.name), expression: this.expand(term_1089.expression)});\n  }\n  expandObjectExpression(term_1090) {\n    return new Term(\"ObjectExpression\", {properties: term_1090.properties.map(t_1091 => this.expand(t_1091))});\n  }\n  expandVariableDeclarator(term_1092) {\n    let init_1093 = term_1092.init == null ? null : this.expand(term_1092.init);\n    return new Term(\"VariableDeclarator\", {binding: this.expand(term_1092.binding), init: init_1093});\n  }\n  expandVariableDeclaration(term_1094) {\n    if (term_1094.kind === \"syntax\" || term_1094.kind === \"syntaxrec\") {\n      return term_1094;\n    }\n    return new Term(\"VariableDeclaration\", {kind: term_1094.kind, declarators: term_1094.declarators.map(d_1095 => this.expand(d_1095))});\n  }\n  expandParenthesizedExpression(term_1096) {\n    if (term_1096.inner.size === 0) {\n      throw new Error(\"unexpected end of input\");\n    }\n    let enf_1097 = new Enforester(term_1096.inner, List(), this.context);\n    let lookahead_1098 = enf_1097.peek();\n    let t_1099 = enf_1097.enforestExpression();\n    if (t_1099 == null || enf_1097.rest.size > 0) {\n      throw enf_1097.createError(lookahead_1098, \"unexpected syntax\");\n    }\n    return this.expand(t_1099);\n  }\n  expandUnaryExpression(term_1100) {\n    return new Term(\"UnaryExpression\", {operator: term_1100.operator, operand: this.expand(term_1100.operand)});\n  }\n  expandUpdateExpression(term_1101) {\n    return new Term(\"UpdateExpression\", {isPrefix: term_1101.isPrefix, operator: term_1101.operator, operand: this.expand(term_1101.operand)});\n  }\n  expandBinaryExpression(term_1102) {\n    let left_1103 = this.expand(term_1102.left);\n    let right_1104 = this.expand(term_1102.right);\n    return new Term(\"BinaryExpression\", {left: left_1103, operator: term_1102.operator, right: right_1104});\n  }\n  expandConditionalExpression(term_1105) {\n    return new Term(\"ConditionalExpression\", {test: this.expand(term_1105.test), consequent: this.expand(term_1105.consequent), alternate: this.expand(term_1105.alternate)});\n  }\n  expandNewTargetExpression(term_1106) {\n    return term_1106;\n  }\n  expandNewExpression(term_1107) {\n    let callee_1108 = this.expand(term_1107.callee);\n    let enf_1109 = new Enforester(term_1107.arguments, List(), this.context);\n    let args_1110 = enf_1109.enforestArgumentList().map(arg_1111 => this.expand(arg_1111));\n    return new Term(\"NewExpression\", {callee: callee_1108, arguments: args_1110.toArray()});\n  }\n  expandSuper(term_1112) {\n    return term_1112;\n  }\n  expandCallExpression(term_1113) {\n    let callee_1114 = this.expand(term_1113.callee);\n    let enf_1115 = new Enforester(term_1113.arguments, List(), this.context);\n    let args_1116 = enf_1115.enforestArgumentList().map(arg_1117 => this.expand(arg_1117));\n    return new Term(\"CallExpression\", {callee: callee_1114, arguments: args_1116});\n  }\n  expandSpreadElement(term_1118) {\n    return new Term(\"SpreadElement\", {expression: this.expand(term_1118.expression)});\n  }\n  expandExpressionStatement(term_1119) {\n    let child_1120 = this.expand(term_1119.expression);\n    return new Term(\"ExpressionStatement\", {expression: child_1120});\n  }\n  expandLabeledStatement(term_1121) {\n    return new Term(\"LabeledStatement\", {label: term_1121.label.val(), body: this.expand(term_1121.body)});\n  }\n  doFunctionExpansion(term_1122, type_1123) {\n    let scope_1124 = freshScope(\"fun\");\n    let red_1125 = new ApplyScopeInParamsReducer(scope_1124, this.context);\n    let params_1126;\n    if (type_1123 !== \"Getter\" && type_1123 !== \"Setter\") {\n      params_1126 = red_1125.transform(term_1122.params);\n      params_1126 = this.expand(params_1126);\n    }\n    this.context.currentScope.push(scope_1124);\n    let compiler_1127 = new Compiler(this.context.phase, this.context.env, this.context.store, this.context);\n    let markedBody_1128, bodyTerm_1129;\n    if (term_1122.body instanceof Term) {\n      bodyTerm_1129 = this.expand(term_1122.body.addScope(scope_1124, this.context.bindings, ALL_PHASES));\n    } else {\n      markedBody_1128 = term_1122.body.map(b_1130 => b_1130.addScope(scope_1124, this.context.bindings, ALL_PHASES));\n      bodyTerm_1129 = new Term(\"FunctionBody\", {directives: List(), statements: compiler_1127.compile(markedBody_1128)});\n    }\n    this.context.currentScope.pop();\n    if (type_1123 === \"Getter\") {\n      return new Term(type_1123, {name: this.expand(term_1122.name), body: bodyTerm_1129});\n    } else if (type_1123 === \"Setter\") {\n      return new Term(type_1123, {name: this.expand(term_1122.name), param: term_1122.param, body: bodyTerm_1129});\n    }\n    return new Term(type_1123, {name: term_1122.name, isGenerator: term_1122.isGenerator, params: params_1126, body: bodyTerm_1129});\n  }\n  expandMethod(term_1131) {\n    return this.doFunctionExpansion(term_1131, \"Method\");\n  }\n  expandSetter(term_1132) {\n    return this.doFunctionExpansion(term_1132, \"Setter\");\n  }\n  expandGetter(term_1133) {\n    return this.doFunctionExpansion(term_1133, \"Getter\");\n  }\n  expandFunctionDeclaration(term_1134) {\n    return this.doFunctionExpansion(term_1134, \"FunctionDeclaration\");\n  }\n  expandFunctionExpression(term_1135) {\n    return this.doFunctionExpansion(term_1135, \"FunctionExpression\");\n  }\n  expandCompoundAssignmentExpression(term_1136) {\n    return new Term(\"CompoundAssignmentExpression\", {binding: this.expand(term_1136.binding), operator: term_1136.operator, expression: this.expand(term_1136.expression)});\n  }\n  expandAssignmentExpression(term_1137) {\n    return new Term(\"AssignmentExpression\", {binding: this.expand(term_1137.binding), expression: this.expand(term_1137.expression)});\n  }\n  expandEmptyStatement(term_1138) {\n    return term_1138;\n  }\n  expandLiteralBooleanExpression(term_1139) {\n    return term_1139;\n  }\n  expandLiteralNumericExpression(term_1140) {\n    return term_1140;\n  }\n  expandLiteralInfinityExpression(term_1141) {\n    return term_1141;\n  }\n  expandIdentifierExpression(term_1142) {\n    let trans_1143 = this.context.env.get(term_1142.name.resolve(this.context.phase));\n    if (trans_1143) {\n      return new Term(\"IdentifierExpression\", {name: trans_1143.id});\n    }\n    return term_1142;\n  }\n  expandLiteralNullExpression(term_1144) {\n    return term_1144;\n  }\n  expandLiteralStringExpression(term_1145) {\n    return term_1145;\n  }\n  expandLiteralRegExpExpression(term_1146) {\n    return term_1146;\n  }\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/term-expander.js"],"names":[],"mappings":"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","file":"term-expander.js","sourcesContent":["import { List } from 'immutable';\nimport Term from \"./terms\";\nimport { freshScope } from \"./scope\";\nimport ApplyScopeInParamsReducer from \"./apply-scope-in-params-reducer\";\nimport Compiler from './compiler';\nimport Syntax, { ALL_PHASES } from \"./syntax\";\nimport { serializer } from \"./serializer\";\nimport { Enforester } from \"./enforester\";\nimport { processTemplate } from './template-processor.js';\nimport ASTDispatcher from './ast-dispatcher';\n\nexport default class TermExpander extends ASTDispatcher {\n  constructor(context) {\n    super('expand', true);\n    this.context = context;\n  }\n\n  expand(term) {\n    return this.dispatch(term);\n  }\n\n  expandPragma(term) {\n    return term;\n  }\n\n  expandTemplateExpression(term) {\n    return new Term('TemplateExpression', {\n      tag: term.tag == null ? null : this.expand(term.tag),\n      elements: term.elements.toArray()\n    });\n  }\n\n  expandBreakStatement(term) {\n    return new Term('BreakStatement', {\n      label: term.label ? term.label.val() : null\n    });\n  }\n\n  expandDoWhileStatement(term) {\n    return new Term('DoWhileStatement', {\n      body: this.expand(term.body),\n      test: this.expand(term.test)\n    });\n  }\n\n  expandWithStatement(term) {\n    return new Term('WithStatement', {\n      body: this.expand(term.body),\n      object: this.expand(term.object)\n    });\n  }\n\n  expandDebuggerStatement(term) { return term;}\n\n  expandContinueStatement(term) {\n    return new Term('ContinueStatement', {\n      label: term.label ? term.label.val() : null\n    });\n  }\n\n  expandSwitchStatementWithDefault(term) {\n    return new Term('SwitchStatementWithDefault', {\n      discriminant: this.expand(term.discriminant),\n      preDefaultCases: term.preDefaultCases.map(c => this.expand(c)).toArray(),\n      defaultCase: this.expand(term.defaultCase),\n      postDefaultCases: term.postDefaultCases.map(c => this.expand(c)).toArray()\n    });\n  }\n\n  expandComputedMemberExpression(term) {\n    return new Term('ComputedMemberExpression', {\n      object: this.expand(term.object),\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandSwitchStatement(term) {\n    return new Term('SwitchStatement', {\n      discriminant: this.expand(term.discriminant),\n      cases: term.cases.map(c => this.expand(c)).toArray()\n    });\n  }\n\n  expandFormalParameters(term) {\n    let rest = term.rest == null ? null : this.expand(term.rest);\n    return new Term('FormalParameters', {\n      items: term.items.map(i => this.expand(i)),\n      rest\n    });\n  }\n\n  expandArrowExpression(term) {\n    return this.doFunctionExpansion(term, 'ArrowExpression');\n  }\n\n  expandSwitchDefault(term) {\n    return new Term('SwitchDefault', {\n      consequent: term.consequent.map(c => this.expand(c)).toArray()\n    });\n  }\n\n  expandSwitchCase(term) {\n    return new Term('SwitchCase', {\n      test: this.expand(term.test),\n      consequent: term.consequent.map(c => this.expand(c)).toArray()\n    });\n  }\n\n  expandForInStatement(term) {\n    return new Term('ForInStatement', {\n      left: this.expand(term.left),\n      right: this.expand(term.right),\n      body: this.expand(term.body)\n    });\n  }\n\n  expandTryCatchStatement(term) {\n    return new Term('TryCatchStatement', {\n      body: this.expand(term.body),\n      catchClause: this.expand(term.catchClause)\n    });\n  }\n\n  expandTryFinallyStatement(term) {\n    let catchClause = term.catchClause == null ? null : this.expand(term.catchClause);\n    return new Term('TryFinallyStatement', {\n      body: this.expand(term.body),\n      catchClause,\n      finalizer: this.expand(term.finalizer)\n    });\n  }\n\n  expandCatchClause(term) {\n    return new Term('CatchClause', {\n      binding: this.expand(term.binding),\n      body: this.expand(term.body)\n    });\n  }\n\n  expandThrowStatement(term) {\n    return new Term('ThrowStatement', {\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandForOfStatement(term) {\n    return new Term('ForOfStatement', {\n      left: this.expand(term.left),\n      right: this.expand(term.right),\n      body: this.expand(term.body)\n    });\n  }\n\n  expandBindingIdentifier(term) {\n    return term;\n  }\n\n  expandBindingPropertyIdentifier(term) {\n    return term;\n  }\n  expandBindingPropertyProperty(term) {\n    return new Term('BindingPropertyProperty', {\n      name: this.expand(term.name),\n      binding: this.expand(term.binding)\n    });\n  }\n\n  expandComputedPropertyName(term) {\n    return new Term('ComputedPropertyName', {\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandObjectBinding(term) {\n    return new Term('ObjectBinding', {\n      properties: term.properties.map(t => this.expand(t)).toArray()\n    });\n  }\n\n  expandArrayBinding(term) {\n    let restElement = term.restElement == null ? null : this.expand(term.restElement);\n    return new Term('ArrayBinding', {\n      elements: term.elements.map(t => t == null ? null : this.expand(t)).toArray(),\n      restElement\n    });\n  }\n\n  expandBindingWithDefault(term) {\n    return new Term('BindingWithDefault', {\n      binding: this.expand(term.binding),\n      init: this.expand(term.init)\n    });\n  }\n\n  expandShorthandProperty(term) {\n    // because hygiene, shorthand properties must turn into DataProperties\n    return new Term('DataProperty', {\n      name: new Term('StaticPropertyName', {\n        value: term.name\n      }),\n      expression: new Term('IdentifierExpression', {\n        name: term.name\n      })\n    });\n  }\n\n\n  expandForStatement(term) {\n    let init = term.init == null ? null : this.expand(term.init);\n    let test = term.test == null ? null : this.expand(term.test);\n    let update = term.update == null ? null : this.expand(term.update);\n    let body = this.expand(term.body);\n    return new Term('ForStatement', { init, test, update, body });\n  }\n\n  expandYieldExpression(term) {\n    let expr = term.expression == null ? null : this.expand(term.expression);\n    return new Term('YieldExpression', {\n      expression: expr\n    });\n  }\n\n  expandYieldGeneratorExpression(term) {\n    let expr = term.expression == null ? null : this.expand(term.expression);\n    return new Term('YieldGeneratorExpression', {\n      expression: expr\n    });\n  }\n\n  expandWhileStatement(term) {\n    return new Term('WhileStatement', {\n      test: this.expand(term.test),\n      body: this.expand(term.body)\n    });\n  }\n\n  expandIfStatement(term) {\n    let consequent = term.consequent == null ? null : this.expand(term.consequent);\n    let alternate = term.alternate == null ? null : this.expand(term.alternate);\n    return new Term('IfStatement', {\n      test: this.expand(term.test),\n      consequent: consequent,\n      alternate: alternate\n    });\n  }\n\n  expandBlockStatement(term) {\n    return new Term('BlockStatement', {\n      block: this.expand(term.block)\n    });\n  }\n\n  expandBlock(term) {\n    let scope = freshScope('block');\n    this.context.currentScope.push(scope);\n    let compiler = new Compiler(this.context.phase, this.context.env, this.context.store, this.context);\n\n    let markedBody, bodyTerm;\n    markedBody = term.statements.map(b => b.addScope(scope, this.context.bindings, ALL_PHASES));\n    bodyTerm = new Term('Block', {\n      statements: compiler.compile(markedBody)\n    });\n    this.context.currentScope.pop();\n    return bodyTerm;\n  }\n\n  expandVariableDeclarationStatement(term) {\n    return new Term('VariableDeclarationStatement', {\n      declaration: this.expand(term.declaration)\n    });\n  }\n  expandReturnStatement(term) {\n    if (term.expression == null) {\n      return term;\n    }\n    return new Term(\"ReturnStatement\", {\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandClassDeclaration(term) {\n    return new Term('ClassDeclaration', {\n      name: term.name == null ? null : this.expand(term.name),\n      super: term.super == null ? null : this.expand(term.super),\n      elements: term.elements.map(el => this.expand(el)).toArray()\n    });\n  }\n\n  expandClassExpression(term) {\n    return new Term('ClassExpression', {\n      name: term.name == null ? null : this.expand(term.name),\n      super: term.super == null ? null : this.expand(term.super),\n      elements: term.elements.map(el => this.expand(el)).toArray()\n    });\n  }\n\n  expandClassElement(term) {\n    return new Term('ClassElement', {\n      isStatic: term.isStatic,\n      method: this.expand(term.method)\n    });\n  }\n\n  expandThisExpression(term) {\n    return term;\n  }\n\n  expandSyntaxTemplate(term) {\n    let r = processTemplate(term.template.inner());\n    let str = Syntax.from(\"string\", serializer.write(r.template));\n    let callee = new Term('IdentifierExpression', { name: Syntax.from(\"identifier\", 'syntaxTemplate') });\n\n    let expandedInterps = r.interp.map(i => {\n      let enf = new Enforester(i, List(), this.context);\n      return this.expand(enf.enforest('expression'));\n    });\n\n    let args = List.of(new Term('LiteralStringExpression', {value: str }))\n                   .concat(expandedInterps);\n\n    return new Term('CallExpression', {\n      callee, arguments: args\n    });\n  }\n\n  expandSyntaxQuote(term) {\n    let str = new Term(\"LiteralStringExpression\", {\n      value: Syntax.from(\"string\", serializer.write(term.name))\n    });\n\n    return new Term(\"TemplateExpression\", {\n      tag: term.template.tag,\n      elements: term.template.elements.push(str).push(new Term('TemplateElement', {\n        rawValue: ''\n      })).toArray()\n    });\n  }\n\n  expandStaticMemberExpression(term) {\n    return new Term(\"StaticMemberExpression\", {\n      object: this.expand(term.object),\n      property: term.property\n    });\n  }\n\n  expandArrayExpression(term) {\n    return new Term(\"ArrayExpression\", {\n      elements: term.elements.map(t => t == null ? t : this.expand(t))\n    });\n  }\n\n  expandImport(term) {\n    return term;\n  }\n\n  expandImportNamespace(term) {\n    return term;\n  }\n\n  expandExport(term) {\n    return new Term('Export', {\n      declaration: this.expand(term.declaration)\n    });\n  }\n\n  expandExportDefault(term) {\n    return new Term('ExportDefault', {\n      body: this.expand(term.body)\n    });\n  }\n\n\n  expandExportFrom(term) {\n    return term;\n  }\n\n  expandExportAllFrom(term) {\n    return term;\n  }\n\n  expandExportSpecifier(term) {\n    return term;\n  }\n\n  expandStaticPropertyName(term) {\n    return term;\n  }\n\n  expandDataProperty(term) {\n    return new Term(\"DataProperty\", {\n      name: this.expand(term.name),\n      expression: this.expand(term.expression)\n    });\n  }\n\n\n  expandObjectExpression(term) {\n    return new Term(\"ObjectExpression\", {\n      properties: term.properties.map(t => this.expand(t))\n    });\n  }\n\n  expandVariableDeclarator(term) {\n    let init = term.init == null ? null : this.expand(term.init);\n    return new Term(\"VariableDeclarator\", {\n      binding: this.expand(term.binding),\n      init: init\n    });\n  }\n\n  expandVariableDeclaration(term) {\n    if (term.kind === 'syntax' || term.kind === 'syntaxrec') {\n      return term;\n    }\n    return new Term(\"VariableDeclaration\", {\n      kind: term.kind,\n      declarators: term.declarators.map(d => this.expand(d))\n    });\n  }\n\n  expandParenthesizedExpression(term) {\n    if (term.inner.size === 0) {\n      throw new Error(\"unexpected end of input\");\n    }\n    let enf = new Enforester(term.inner, List(), this.context);\n    let lookahead = enf.peek();\n    let t = enf.enforestExpression();\n    if (t == null || enf.rest.size > 0) {\n      throw enf.createError(lookahead, \"unexpected syntax\");\n    }\n    return this.expand(t);\n  }\n\n  expandUnaryExpression(term) {\n    return new Term('UnaryExpression', {\n      operator: term.operator,\n      operand: this.expand(term.operand)\n    });\n  }\n\n  expandUpdateExpression(term) {\n    return new Term('UpdateExpression', {\n      isPrefix: term.isPrefix,\n      operator: term.operator,\n      operand: this.expand(term.operand)\n    });\n  }\n\n  expandBinaryExpression(term) {\n    let left = this.expand(term.left);\n    let right = this.expand(term.right);\n    return new Term(\"BinaryExpression\", {\n      left: left,\n      operator: term.operator,\n      right: right\n    });\n  }\n\n  expandConditionalExpression(term) {\n    return new Term('ConditionalExpression', {\n      test: this.expand(term.test),\n      consequent: this.expand(term.consequent),\n      alternate: this.expand(term.alternate)\n    });\n  }\n\n  expandNewTargetExpression(term) { return term; }\n\n  expandNewExpression(term) {\n    let callee = this.expand(term.callee);\n    let enf = new Enforester(term.arguments, List(), this.context);\n    let args = enf.enforestArgumentList().map(arg => this.expand(arg));\n    return new Term('NewExpression', {\n      callee,\n      arguments: args.toArray()\n    });\n  }\n\n  expandSuper(term) { return term; }\n\n  expandCallExpression(term) {\n    let callee = this.expand(term.callee);\n    let enf = new Enforester(term.arguments, List(), this.context);\n    let args = enf.enforestArgumentList().map(arg => this.expand(arg));\n    return new Term(\"CallExpression\", {\n      callee: callee,\n      arguments: args\n    });\n  }\n\n  expandSpreadElement(term) {\n    return new Term('SpreadElement', {\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandExpressionStatement(term) {\n    let child = this.expand(term.expression);\n    return new Term(\"ExpressionStatement\", {\n      expression: child\n    });\n  }\n\n  expandLabeledStatement(term) {\n    return new Term('LabeledStatement', {\n      label: term.label.val(),\n      body: this.expand(term.body)\n    });\n  }\n\n  doFunctionExpansion(term, type) {\n    let scope = freshScope(\"fun\");\n    let red = new ApplyScopeInParamsReducer(scope, this.context);\n    let params;\n    if (type !== 'Getter' && type !== 'Setter') {\n      params = red.transform(term.params);\n      params = this.expand(params);\n    }\n    this.context.currentScope.push(scope);\n    let compiler = new Compiler(this.context.phase, this.context.env, this.context.store, this.context);\n\n    let markedBody, bodyTerm;\n    if (term.body instanceof Term) {\n      // Arrow functions have a single term as their body\n      bodyTerm = this.expand(term.body.addScope(scope, this.context.bindings, ALL_PHASES));\n    } else {\n      markedBody = term.body.map(b => b.addScope(scope, this.context.bindings, ALL_PHASES));\n      bodyTerm = new Term(\"FunctionBody\", {\n        directives: List(),\n        statements: compiler.compile(markedBody)\n      });\n    }\n    this.context.currentScope.pop();\n\n    if (type === 'Getter') {\n      return new Term(type, {\n        name: this.expand(term.name),\n        body: bodyTerm\n      });\n    } else if (type === 'Setter') {\n      return new Term(type, {\n        name: this.expand(term.name),\n        param: term.param,\n        body: bodyTerm\n      });\n    } else if (type === 'ArrowExpression') {\n      return new Term(type, {\n        params: params,\n        body: bodyTerm\n      });\n    }\n    return new Term(type, {\n      name: term.name,\n      isGenerator: term.isGenerator,\n      params: params,\n      body: bodyTerm\n    });\n  }\n\n  expandMethod(term) {\n    return this.doFunctionExpansion(term, 'Method');\n  }\n\n  expandSetter(term) {\n    return this.doFunctionExpansion(term, 'Setter');\n  }\n\n  expandGetter(term) {\n    return this.doFunctionExpansion(term, 'Getter');\n  }\n\n  expandFunctionDeclaration(term) {\n    return this.doFunctionExpansion(term, \"FunctionDeclaration\");\n  }\n\n  expandFunctionExpression(term) {\n    return this.doFunctionExpansion(term, \"FunctionExpression\");\n  }\n\n  expandCompoundAssignmentExpression(term) {\n    return new Term(\"CompoundAssignmentExpression\", {\n      binding: this.expand(term.binding),\n      operator: term.operator,\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandAssignmentExpression(term) {\n    return new Term(\"AssignmentExpression\", {\n      binding: this.expand(term.binding),\n      expression: this.expand(term.expression)\n    });\n  }\n\n  expandEmptyStatement(term) {\n    return term;\n  }\n\n  expandLiteralBooleanExpression(term) {\n    return term;\n  }\n\n  expandLiteralNumericExpression(term) {\n    return term;\n  }\n  expandLiteralInfinityExpression(term) {\n    return term;\n  }\n\n  expandIdentifierExpression(term) {\n    let trans = this.context.env.get(term.name.resolve(this.context.phase));\n    if (trans) {\n      return new Term(\"IdentifierExpression\", {\n        name: trans.id\n      });\n    }\n    return term;\n  }\n\n  expandLiteralNullExpression(term) {\n    return term;\n  }\n\n  expandLiteralStringExpression(term) {\n    return term;\n  }\n\n  expandLiteralRegExpExpression(term) {\n    return term;\n  }\n}\n"]} \ No newline at end of file diff --git a/dist/terms.js b/dist/terms.js index 462427a9..18455262 100644 --- a/dist/terms.js +++ b/dist/terms.js @@ -7,418 +7,249 @@ exports.isImportDeclaration = exports.isCompiletimeStatement = exports.isCompile var _immutable = require("immutable"); -var _errors = require("./errors"); - -var _utils = require("./utils"); - -var _syntax = require("./syntax"); +var _ramda = require("ramda"); -var _syntax2 = _interopRequireDefault(_syntax); +var R = _interopRequireWildcard(_ramda); -var _termSpec = require("./term-spec"); +var _sweetSpec = require("sweet-spec"); -var _termSpec2 = _interopRequireDefault(_termSpec); +var _sweetSpec2 = _interopRequireDefault(_sweetSpec); -var _ramda = require("ramda"); - -var R = _interopRequireWildcard(_ramda); +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } +const attrName = a => a.attrName; class Term { - constructor(type_1349, props_1350) { - this.type = type_1349; + + constructor(type, props) { + let spec = _sweetSpec2.default.getDescendant(type); + if (spec == null) { + throw new Error(`Unknown term: ${ type }`); + } + this.type = type; this.loc = null; - for (let prop of Object.keys(props_1350)) { - this[prop] = props_1350[prop]; + this.spec = spec; + let propKeys = Object.keys(props); + let fieldNames = spec.getAttributes().map(attrName); + let diff = R.symmetricDifference(propKeys, fieldNames); + if (diff.length !== 0) { + throw new Error(`Unexpected properties for term ${ type }: ${ diff }`); } + Object.assign(this, props); } - extend(props_1351) { - let newProps_1352 = {}; - for (let field of _termSpec2.default.spec[this.type].fields) { - if (props_1351.hasOwnProperty(field)) { - newProps_1352[field] = props_1351[field]; - } else { - newProps_1352[field] = this[field]; - } + + extend(props) { + let specAttrNames = this.spec.getAttributes().map(attrName); + let newProps = R.pick(specAttrNames, this); + + let invalidAttrs = R.difference(Object.keys(props), specAttrNames); + if (invalidAttrs.length > 0) { + throw new Error(`Unexpected properties for term ${ this.type }: ${ invalidAttrs }`); } - return new Term(this.type, newProps_1352); + + return new Term(this.type, Object.assign(newProps, props)); } - gen() { - var _ref = arguments.length <= 0 || arguments[0] === undefined ? { includeImports: true } : arguments[0]; - let includeImports = _ref.includeImports; + // TODO: remove + gen() { + let includeImports = arguments.length <= 0 || arguments[0] === undefined ? true : arguments[0]; - let next_1353 = {}; - for (let field of _termSpec2.default.spec[this.type].fields) { - if (this[field] == null) { - next_1353[field] = null; - } else if (this[field] instanceof Term) { - next_1353[field] = this[field].gen(includeImports); - } else if (_immutable.List.isList(this[field])) { - let pred = includeImports ? R.complement(isCompiletimeStatement_1347) : R.both(R.complement(isImportDeclaration_1348), R.complement(isCompiletimeStatement_1347)); - next_1353[field] = this[field].filter(pred).map(term_1354 => term_1354 instanceof Term ? term_1354.gen(includeImports) : term_1354); + let next = {}; + for (let field of this.spec.getAttributes()) { + if (this[field.attrName] == null) { + next[field.attrName] = null; + } else if (this[field.attrName] instanceof Term) { + next[field.attrName] = this[field.attrName].gen(includeImports); + } else if (_immutable.List.isList(this[field.attrName])) { + let pred = includeImports ? R.complement(isCompiletimeStatement) : R.both(R.complement(isImportDeclaration), R.complement(isCompiletimeStatement)); + next[field.attrName] = this[field.attrName].filter(pred).map(term => term instanceof Term ? term.gen(includeImports) : term); } else { - next_1353[field] = this[field]; + next[field.attrName] = this[field.attrName]; } } - return new Term(this.type, next_1353); + return new Term(this.type, next); } - visit(f_1355) { - let next_1356 = {}; - for (let field of _termSpec2.default.spec[this.type].fields) { - if (this[field] == null) { - next_1356[field] = null; - } else if (_immutable.List.isList(this[field])) { - next_1356[field] = this[field].map(field_1357 => field_1357 != null ? f_1355(field_1357) : null); + + // TODO: remove + visit(f) { + let next = {}; + for (let field of _sweetSpec2.default.getDescendant(this.type).getAttributes()) { + if (this[field.attrName] == null) { + next[field.attrName] = null; + } else if (_immutable.List.isList(this[field.attrName])) { + next[field.attrName] = this[field.attrName].map(field => field != null ? f(field) : null); } else { - next_1356[field] = f_1355(this[field]); + next[field.attrName] = f(this[field.attrName]); } } - return this.extend(next_1356); + return this.extend(next); } - addScope(scope_1358, bindings_1359, phase_1360, options_1361) { - return this.visit(term_1362 => { - if (typeof term_1362.addScope === "function") { - return term_1362.addScope(scope_1358, bindings_1359, phase_1360, options_1361); + + // TODO: remove + addScope(scope, bindings, phase, options) { + return this.visit(term => { + if (typeof term.addScope === 'function') { + return term.addScope(scope, bindings, phase, options); } - return term_1362; + return term; }); } - removeScope(scope_1363, phase_1364) { - return this.visit(term_1365 => { - if (typeof term_1365.removeScope === "function") { - return term_1365.removeScope(scope_1363, phase_1364); + + // TODO: remove + removeScope(scope, phase) { + return this.visit(term => { + if (typeof term.removeScope === 'function') { + return term.removeScope(scope, phase); } - return term_1365; + return term; }); } + + // TODO: this is very wrong lineNumber() { - for (let field of _termSpec2.default.spec[this.type].fields) { - if (typeof this[field] && this[field].lineNumber === "function") { - return this[field].lineNumber(); + for (let field of _sweetSpec2.default.getDescendant(this.type).getAttributes()) { + if (typeof this[field.attrName] && this[field.attrName].lineNumber === 'function') { + return this[field.attrName].lineNumber(); } } } - setLineNumber(line_1366) { - let next_1367 = {}; - for (let field of _termSpec2.default.spec[this.type].fields) { - if (this[field] == null) { - next_1367[field] = null; - } else if (typeof this[field].setLineNumber === "function") { - next_1367[field] = this[field].setLineNumber(line_1366); - } else if (_immutable.List.isList(this[field])) { - next_1367[field] = this[field].map(f_1368 => f_1368.setLineNumber(line_1366)); + + setLineNumber(line) { + let next = {}; + for (let field of _sweetSpec2.default.getDescendant(this.type).getAttributes()) { + if (this[field.attrName] == null) { + next[field.attrName] = null; + } else if (typeof this[field.attrName].setLineNumber === 'function') { + next[field.attrName] = this[field.attrName].setLineNumber(line); + } else if (_immutable.List.isList(this[field.attrName])) { + next[field.attrName] = this[field.attrName].map(f => f.setLineNumber(line)); } else { - next_1367[field] = this[field]; + next[field.attrName] = this[field.attrName]; } } - return new Term(this.type, next_1367); + return new Term(this.type, next); } } -exports.default = Term; -const isBindingWithDefault_1249 = R.whereEq({ type: "BindingWithDefault" }); -; -const isBindingIdentifier_1250 = R.whereEq({ type: "BindingIdentifier" }); -; -const isArrayBinding_1251 = R.whereEq({ type: "ArrayBinding" }); -; -const isObjectBinding_1252 = R.whereEq({ type: "ObjectBinding" }); -; -const isBindingPropertyIdentifier_1253 = R.whereEq({ type: "BindingPropertyIdentifier" }); -; -const isBindingPropertyProperty_1254 = R.whereEq({ type: "BindingPropertyIdentifier" }); -; -const isClassExpression_1255 = R.whereEq({ type: "ClassExpression" }); -; -const isClassDeclaration_1256 = R.whereEq({ type: "ClassDeclaration" }); -; -const isClassElement_1257 = R.whereEq({ type: "ClassElement" }); -; -const isModule_1258 = R.whereEq({ type: "Module" }); -; -const isImport_1259 = R.whereEq({ type: "Import" }); -; -const isImportNamespace_1260 = R.whereEq({ type: "ImportNamespace" }); -; -const isImportSpecifier_1261 = R.whereEq({ type: "ImportSpecifier" }); -; -const isExportAllFrom_1262 = R.whereEq({ type: "ExportAllFrom" }); -; -const isExportFrom_1263 = R.whereEq({ type: "ExportFrom" }); -; -const isExport_1264 = R.whereEq({ type: "Export" }); -; -const isExportDefault_1265 = R.whereEq({ type: "ExportDefault" }); -; -const isExportSpecifier_1266 = R.whereEq({ type: "ExportSpecifier" }); -; -const isMethod_1267 = R.whereEq({ type: "Method" }); -; -const isGetter_1268 = R.whereEq({ type: "Getter" }); -; -const isSetter_1269 = R.whereEq({ type: "Setter" }); -; -const isDataProperty_1270 = R.whereEq({ type: "DataProperty" }); -; -const isShorthandProperty_1271 = R.whereEq({ type: "ShorthandProperty" }); -; -const isComputedPropertyName_1272 = R.whereEq({ type: "ComputedPropertyName" }); -; -const isStaticPropertyName_1273 = R.whereEq({ type: "StaticPropertyName" }); -; -const isLiteralBooleanExpression_1274 = R.whereEq({ type: "LiteralBooleanExpression" }); -; -const isLiteralInfinityExpression_1275 = R.whereEq({ type: "LiteralInfinityExpression" }); -; -const isLiteralNullExpression_1276 = R.whereEq({ type: "LiteralNullExpression" }); -; -const isLiteralNumericExpression_1277 = R.whereEq({ type: "LiteralNumericExpression" }); -; -const isLiteralRegExpExpression_1278 = R.whereEq({ type: "LiteralRegExpExpression" }); -; -const isLiteralStringExpression_1279 = R.whereEq({ type: "LiteralStringExpression" }); -; -const isArrayExpression_1280 = R.whereEq({ type: "ArrayExpression" }); -; -const isArrowExpression_1281 = R.whereEq({ type: "ArrowExpression" }); -; -const isAssignmentExpression_1282 = R.whereEq({ type: "AssignmentExpression" }); -; -const isBinaryExpression_1283 = R.whereEq({ type: "BinaryExpression" }); -; -const isCallExpression_1284 = R.whereEq({ type: "CallExpression" }); -; -const isComputedAssignmentExpression_1285 = R.whereEq({ type: "ComputedAssignmentExpression" }); -; -const isComputedMemberExpression_1286 = R.whereEq({ type: "ComputedMemberExpression" }); -; -const isConditionalExpression_1287 = R.whereEq({ type: "ConditionalExpression" }); -; -const isFunctionExpression_1288 = R.whereEq({ type: "FunctionExpression" }); -; -const isIdentifierExpression_1289 = R.whereEq({ type: "IdentifierExpression" }); -; -const isNewExpression_1290 = R.whereEq({ type: "NewExpression" }); -; -const isNewTargetExpression_1291 = R.whereEq({ type: "NewTargetExpression" }); -; -const isObjectExpression_1292 = R.whereEq({ type: "ObjectExpression" }); -; -const isUnaryExpression_1293 = R.whereEq({ type: "UnaryExpression" }); -; -const isStaticMemberExpression_1294 = R.whereEq({ type: "StaticMemberExpression" }); -; -const isTemplateExpression_1295 = R.whereEq({ type: "TemplateExpression" }); -; -const isThisExpression_1296 = R.whereEq({ type: "ThisExpression" }); -; -const isUpdateExpression_1297 = R.whereEq({ type: "UpdateExpression" }); -; -const isYieldExpression_1298 = R.whereEq({ type: "YieldExpression" }); -; -const isYieldGeneratorExpression_1299 = R.whereEq({ type: "YieldGeneratorExpression" }); -; -const isBlockStatement_1300 = R.whereEq({ type: "BlockStatement" }); -; -const isBreakStatement_1301 = R.whereEq({ type: "BreakStatement" }); -; -const isContinueStatement_1302 = R.whereEq({ type: "ContinueStatement" }); -; -const isCompoundAssignmentExpression_1303 = R.whereEq({ type: "CompoundAssignmentExpression" }); -; -const isDebuggerStatement_1304 = R.whereEq({ type: "DebuggerStatement" }); -; -const isDoWhileStatement_1305 = R.whereEq({ type: "DoWhileStatement" }); -; -const isEmptyStatement_1306 = R.whereEq({ type: "EmptyStatement" }); -; -const isExpressionStatement_1307 = R.whereEq({ type: "ExpressionStatement" }); -; -const isForInStatement_1308 = R.whereEq({ type: "ForInStatement" }); -; -const isForOfStatement_1309 = R.whereEq({ type: "ForOfStatement" }); -; -const isForStatement_1310 = R.whereEq({ type: "ForStatement" }); -; -const isIfStatement_1311 = R.whereEq({ type: "IfStatement" }); -; -const isLabeledStatement_1312 = R.whereEq({ type: "LabeledStatement" }); -; -const isReturnStatement_1313 = R.whereEq({ type: "ReturnStatement" }); -; -const isSwitchStatement_1314 = R.whereEq({ type: "SwitchStatement" }); -; -const isSwitchStatementWithDefault_1315 = R.whereEq({ type: "SwitchStatementWithDefault" }); -; -const isThrowStatement_1316 = R.whereEq({ type: "ThrowStatement" }); -; -const isTryCatchStatement_1317 = R.whereEq({ type: "TryCatchStatement" }); -; -const isTryFinallyStatement_1318 = R.whereEq({ type: "TryFinallyStatement" }); -; -const isVariableDeclarationStatement_1319 = R.whereEq({ type: "VariableDeclarationStatement" }); -; -const isWhileStatement_1320 = R.whereEq({ type: "WhileStatement" }); -; -const isWithStatement_1321 = R.whereEq({ type: "WithStatement" }); -; -const isPragma_1322 = R.whereEq({ type: "Pragma" }); -; -const isBlock_1323 = R.whereEq({ type: "Block" }); -; -const isCatchClause_1324 = R.whereEq({ type: "CatchClause" }); -; -const isDirective_1325 = R.whereEq({ type: "Directive" }); -; -const isFormalParameters_1326 = R.whereEq({ type: "FormalParameters" }); -; -const isFunctionBody_1327 = R.whereEq({ type: "FunctionBody" }); -; -const isFunctionDeclaration_1328 = R.whereEq({ type: "FunctionDeclaration" }); -; -const isScript_1329 = R.whereEq({ type: "Script" }); -; -const isSpreadElement_1330 = R.whereEq({ type: "SpreadElement" }); -; -const isSuper_1331 = R.whereEq({ type: "Super" }); -; -const isSwitchCase_1332 = R.whereEq({ type: "SwitchCase" }); -; -const isSwitchDefault_1333 = R.whereEq({ type: "SwitchDefault" }); -; -const isTemplateElement_1334 = R.whereEq({ type: "TemplateElement" }); -; -const isSyntaxTemplate_1335 = R.whereEq({ type: "SyntaxTemplate" }); -; -const isVariableDeclaration_1336 = R.whereEq({ type: "VariableDeclaration" }); -; -const isVariableDeclarator_1337 = R.whereEq({ type: "VariableDeclarator" }); -; -const isEOF_1338 = R.whereEq({ type: "EOF" }); -; -const isSyntaxDeclaration_1339 = R.both(isVariableDeclaration_1336, R.whereEq({ kind: "syntax" })); -; -const isSyntaxrecDeclaration_1340 = R.both(isVariableDeclaration_1336, R.whereEq({ kind: "syntaxrec" })); -; -const isFunctionTerm_1341 = R.either(isFunctionDeclaration_1328, isFunctionExpression_1288); -; -const isFunctionWithName_1342 = R.and(isFunctionTerm_1341, R.complement(R.where({ name: R.isNil }))); -; -const isParenthesizedExpression_1343 = R.whereEq({ type: "ParenthesizedExpression" }); -; -const isExportSyntax_1344 = R.both(isExport_1264, exp_1369 => R.or(isSyntaxDeclaration_1339(exp_1369.declaration), isSyntaxrecDeclaration_1340(exp_1369.declaration))); -; -const isSyntaxDeclarationStatement_1345 = R.both(isVariableDeclarationStatement_1319, decl_1370 => isCompiletimeDeclaration_1346(decl_1370.declaration)); -; -const isCompiletimeDeclaration_1346 = R.either(isSyntaxDeclaration_1339, isSyntaxrecDeclaration_1340); -; -const isCompiletimeStatement_1347 = term_1371 => { - return term_1371 instanceof Term && isVariableDeclarationStatement_1319(term_1371) && isCompiletimeDeclaration_1346(term_1371.declaration); + +exports.default = Term; // bindings + +const isBindingWithDefault = exports.isBindingWithDefault = R.whereEq({ type: "BindingWithDefault" }); +const isBindingIdentifier = exports.isBindingIdentifier = R.whereEq({ type: "BindingIdentifier" }); +const isArrayBinding = exports.isArrayBinding = R.whereEq({ type: "ArrayBinding" }); +const isObjectBinding = exports.isObjectBinding = R.whereEq({ type: "ObjectBinding" }); +const isBindingPropertyIdentifier = exports.isBindingPropertyIdentifier = R.whereEq({ type: "BindingPropertyIdentifier" }); +const isBindingPropertyProperty = exports.isBindingPropertyProperty = R.whereEq({ type: "BindingPropertyIdentifier" }); + +// class +const isClassExpression = exports.isClassExpression = R.whereEq({ type: "ClassExpression" }); +const isClassDeclaration = exports.isClassDeclaration = R.whereEq({ type: "ClassDeclaration" }); +const isClassElement = exports.isClassElement = R.whereEq({ type: "ClassElement" }); + +// modules +const isModule = exports.isModule = R.whereEq({ type: "Module" }); +const isImport = exports.isImport = R.whereEq({ type: "Import" }); +const isImportNamespace = exports.isImportNamespace = R.whereEq({ type: "ImportNamespace" }); +const isImportSpecifier = exports.isImportSpecifier = R.whereEq({ type: "ImportSpecifier" }); +const isExportAllFrom = exports.isExportAllFrom = R.whereEq({ type: "ExportAllFrom" }); +const isExportFrom = exports.isExportFrom = R.whereEq({ type: "ExportFrom" }); +const isExport = exports.isExport = R.whereEq({ type: "Export" }); +const isExportDefault = exports.isExportDefault = R.whereEq({ type: "ExportDefault" }); +const isExportSpecifier = exports.isExportSpecifier = R.whereEq({ type: "ExportSpecifier" }); + +// property definition +const isMethod = exports.isMethod = R.whereEq({ type: "Method" }); +const isGetter = exports.isGetter = R.whereEq({ type: "Getter" }); +const isSetter = exports.isSetter = R.whereEq({ type: "Setter" }); +const isDataProperty = exports.isDataProperty = R.whereEq({ type: "DataProperty" }); +const isShorthandProperty = exports.isShorthandProperty = R.whereEq({ type: "ShorthandProperty" }); +const isComputedPropertyName = exports.isComputedPropertyName = R.whereEq({ type: "ComputedPropertyName" }); +const isStaticPropertyName = exports.isStaticPropertyName = R.whereEq({ type: "StaticPropertyName" }); + +// literals +const isLiteralBooleanExpression = exports.isLiteralBooleanExpression = R.whereEq({ type: "LiteralBooleanExpression" }); +const isLiteralInfinityExpression = exports.isLiteralInfinityExpression = R.whereEq({ type: "LiteralInfinityExpression" }); +const isLiteralNullExpression = exports.isLiteralNullExpression = R.whereEq({ type: "LiteralNullExpression" }); +const isLiteralNumericExpression = exports.isLiteralNumericExpression = R.whereEq({ type: "LiteralNumericExpression" }); +const isLiteralRegExpExpression = exports.isLiteralRegExpExpression = R.whereEq({ type: "LiteralRegExpExpression" }); +const isLiteralStringExpression = exports.isLiteralStringExpression = R.whereEq({ type: "LiteralStringExpression" }); + +// expressions +const isArrayExpression = exports.isArrayExpression = R.whereEq({ type: "ArrayExpression" }); +const isArrowExpression = exports.isArrowExpression = R.whereEq({ type: "ArrowExpression" }); +const isAssignmentExpression = exports.isAssignmentExpression = R.whereEq({ type: "AssignmentExpression" }); +const isBinaryExpression = exports.isBinaryExpression = R.whereEq({ type: "BinaryExpression" }); +const isCallExpression = exports.isCallExpression = R.whereEq({ type: "CallExpression" }); +const isComputedAssignmentExpression = exports.isComputedAssignmentExpression = R.whereEq({ type: "ComputedAssignmentExpression" }); +const isComputedMemberExpression = exports.isComputedMemberExpression = R.whereEq({ type: "ComputedMemberExpression" }); +const isConditionalExpression = exports.isConditionalExpression = R.whereEq({ type: "ConditionalExpression" }); +const isFunctionExpression = exports.isFunctionExpression = R.whereEq({ type: "FunctionExpression" }); +const isIdentifierExpression = exports.isIdentifierExpression = R.whereEq({ type: "IdentifierExpression" }); +const isNewExpression = exports.isNewExpression = R.whereEq({ type: "NewExpression" }); +const isNewTargetExpression = exports.isNewTargetExpression = R.whereEq({ type: "NewTargetExpression" }); +const isObjectExpression = exports.isObjectExpression = R.whereEq({ type: "ObjectExpression" }); +const isUnaryExpression = exports.isUnaryExpression = R.whereEq({ type: "UnaryExpression" }); +const isStaticMemberExpression = exports.isStaticMemberExpression = R.whereEq({ type: "StaticMemberExpression" }); +const isTemplateExpression = exports.isTemplateExpression = R.whereEq({ type: "TemplateExpression" }); +const isThisExpression = exports.isThisExpression = R.whereEq({ type: "ThisExpression" }); +const isUpdateExpression = exports.isUpdateExpression = R.whereEq({ type: "UpdateExpression" }); +const isYieldExpression = exports.isYieldExpression = R.whereEq({ type: "YieldExpression" }); +const isYieldGeneratorExpression = exports.isYieldGeneratorExpression = R.whereEq({ type: "YieldGeneratorExpression" }); + +// statements +const isBlockStatement = exports.isBlockStatement = R.whereEq({ type: "BlockStatement" }); +const isBreakStatement = exports.isBreakStatement = R.whereEq({ type: "BreakStatement" }); +const isContinueStatement = exports.isContinueStatement = R.whereEq({ type: "ContinueStatement" }); +const isCompoundAssignmentExpression = exports.isCompoundAssignmentExpression = R.whereEq({ type: "CompoundAssignmentExpression" }); +const isDebuggerStatement = exports.isDebuggerStatement = R.whereEq({ type: "DebuggerStatement" }); +const isDoWhileStatement = exports.isDoWhileStatement = R.whereEq({ type: "DoWhileStatement" }); +const isEmptyStatement = exports.isEmptyStatement = R.whereEq({ type: "EmptyStatement" }); +const isExpressionStatement = exports.isExpressionStatement = R.whereEq({ type: "ExpressionStatement" }); +const isForInStatement = exports.isForInStatement = R.whereEq({ type: "ForInStatement" }); +const isForOfStatement = exports.isForOfStatement = R.whereEq({ type: "ForOfStatement" }); +const isForStatement = exports.isForStatement = R.whereEq({ type: "ForStatement" }); +const isIfStatement = exports.isIfStatement = R.whereEq({ type: "IfStatement" }); +const isLabeledStatement = exports.isLabeledStatement = R.whereEq({ type: "LabeledStatement" }); +const isReturnStatement = exports.isReturnStatement = R.whereEq({ type: "ReturnStatement" }); +const isSwitchStatement = exports.isSwitchStatement = R.whereEq({ type: "SwitchStatement" }); +const isSwitchStatementWithDefault = exports.isSwitchStatementWithDefault = R.whereEq({ type: "SwitchStatementWithDefault" }); +const isThrowStatement = exports.isThrowStatement = R.whereEq({ type: "ThrowStatement" }); +const isTryCatchStatement = exports.isTryCatchStatement = R.whereEq({ type: "TryCatchStatement" }); +const isTryFinallyStatement = exports.isTryFinallyStatement = R.whereEq({ type: "TryFinallyStatement" }); +const isVariableDeclarationStatement = exports.isVariableDeclarationStatement = R.whereEq({ type: "VariableDeclarationStatement" }); +const isWhileStatement = exports.isWhileStatement = R.whereEq({ type: "WhileStatement" }); +const isWithStatement = exports.isWithStatement = R.whereEq({ type: "WithStatement" }); + +// other +const isPragma = exports.isPragma = R.whereEq({ type: 'Pragma' }); +const isBlock = exports.isBlock = R.whereEq({ type: "Block" }); +const isCatchClause = exports.isCatchClause = R.whereEq({ type: "CatchClause" }); +const isDirective = exports.isDirective = R.whereEq({ type: "Directive" }); +const isFormalParameters = exports.isFormalParameters = R.whereEq({ type: "FormalParameters" }); +const isFunctionBody = exports.isFunctionBody = R.whereEq({ type: "FunctionBody" }); +const isFunctionDeclaration = exports.isFunctionDeclaration = R.whereEq({ type: "FunctionDeclaration" }); +const isScript = exports.isScript = R.whereEq({ type: "Script" }); +const isSpreadElement = exports.isSpreadElement = R.whereEq({ type: "SpreadElement" }); +const isSuper = exports.isSuper = R.whereEq({ type: "Super" }); +const isSwitchCase = exports.isSwitchCase = R.whereEq({ type: "SwitchCase" }); +const isSwitchDefault = exports.isSwitchDefault = R.whereEq({ type: "SwitchDefault" }); +const isTemplateElement = exports.isTemplateElement = R.whereEq({ type: "TemplateElement" }); +const isSyntaxTemplate = exports.isSyntaxTemplate = R.whereEq({ type: "SyntaxTemplate" }); +const isVariableDeclaration = exports.isVariableDeclaration = R.whereEq({ type: "VariableDeclaration" }); +const isVariableDeclarator = exports.isVariableDeclarator = R.whereEq({ type: "VariableDeclarator" }); +const isEOF = exports.isEOF = R.whereEq({ type: 'EOF' }); +const isSyntaxDeclaration = exports.isSyntaxDeclaration = R.both(isVariableDeclaration, R.whereEq({ kind: 'syntax' })); +const isSyntaxrecDeclaration = exports.isSyntaxrecDeclaration = R.both(isVariableDeclaration, R.whereEq({ kind: 'syntaxrec' })); +const isFunctionTerm = exports.isFunctionTerm = R.either(isFunctionDeclaration, isFunctionExpression); +const isFunctionWithName = exports.isFunctionWithName = R.and(isFunctionTerm, R.complement(R.where({ name: R.isNil }))); +const isParenthesizedExpression = exports.isParenthesizedExpression = R.whereEq({ type: 'ParenthesizedExpression' }); +const isExportSyntax = exports.isExportSyntax = R.both(isExport, exp => R.or(isSyntaxDeclaration(exp.declaration), isSyntaxrecDeclaration(exp.declaration))); +const isSyntaxDeclarationStatement = exports.isSyntaxDeclarationStatement = R.both(isVariableDeclarationStatement, decl => isCompiletimeDeclaration(decl.declaration)); + +const isCompiletimeDeclaration = exports.isCompiletimeDeclaration = R.either(isSyntaxDeclaration, isSyntaxrecDeclaration); +const isCompiletimeStatement = exports.isCompiletimeStatement = term => { + return term instanceof Term && isVariableDeclarationStatement(term) && isCompiletimeDeclaration(term.declaration); }; -; -const isImportDeclaration_1348 = R.either(isImport_1259, isImportNamespace_1260); -; -exports.isBindingWithDefault = isBindingWithDefault_1249; -exports.isBindingIdentifier = isBindingIdentifier_1250; -exports.isArrayBinding = isArrayBinding_1251; -exports.isObjectBinding = isObjectBinding_1252; -exports.isBindingPropertyIdentifier = isBindingPropertyIdentifier_1253; -exports.isBindingPropertyProperty = isBindingPropertyProperty_1254; -exports.isClassExpression = isClassExpression_1255; -exports.isClassDeclaration = isClassDeclaration_1256; -exports.isClassElement = isClassElement_1257; -exports.isModule = isModule_1258; -exports.isImport = isImport_1259; -exports.isImportNamespace = isImportNamespace_1260; -exports.isImportSpecifier = isImportSpecifier_1261; -exports.isExportAllFrom = isExportAllFrom_1262; -exports.isExportFrom = isExportFrom_1263; -exports.isExport = isExport_1264; -exports.isExportDefault = isExportDefault_1265; -exports.isExportSpecifier = isExportSpecifier_1266; -exports.isMethod = isMethod_1267; -exports.isGetter = isGetter_1268; -exports.isSetter = isSetter_1269; -exports.isDataProperty = isDataProperty_1270; -exports.isShorthandProperty = isShorthandProperty_1271; -exports.isComputedPropertyName = isComputedPropertyName_1272; -exports.isStaticPropertyName = isStaticPropertyName_1273; -exports.isLiteralBooleanExpression = isLiteralBooleanExpression_1274; -exports.isLiteralInfinityExpression = isLiteralInfinityExpression_1275; -exports.isLiteralNullExpression = isLiteralNullExpression_1276; -exports.isLiteralNumericExpression = isLiteralNumericExpression_1277; -exports.isLiteralRegExpExpression = isLiteralRegExpExpression_1278; -exports.isLiteralStringExpression = isLiteralStringExpression_1279; -exports.isArrayExpression = isArrayExpression_1280; -exports.isArrowExpression = isArrowExpression_1281; -exports.isAssignmentExpression = isAssignmentExpression_1282; -exports.isBinaryExpression = isBinaryExpression_1283; -exports.isCallExpression = isCallExpression_1284; -exports.isComputedAssignmentExpression = isComputedAssignmentExpression_1285; -exports.isComputedMemberExpression = isComputedMemberExpression_1286; -exports.isConditionalExpression = isConditionalExpression_1287; -exports.isFunctionExpression = isFunctionExpression_1288; -exports.isIdentifierExpression = isIdentifierExpression_1289; -exports.isNewExpression = isNewExpression_1290; -exports.isNewTargetExpression = isNewTargetExpression_1291; -exports.isObjectExpression = isObjectExpression_1292; -exports.isUnaryExpression = isUnaryExpression_1293; -exports.isStaticMemberExpression = isStaticMemberExpression_1294; -exports.isTemplateExpression = isTemplateExpression_1295; -exports.isThisExpression = isThisExpression_1296; -exports.isUpdateExpression = isUpdateExpression_1297; -exports.isYieldExpression = isYieldExpression_1298; -exports.isYieldGeneratorExpression = isYieldGeneratorExpression_1299; -exports.isBlockStatement = isBlockStatement_1300; -exports.isBreakStatement = isBreakStatement_1301; -exports.isContinueStatement = isContinueStatement_1302; -exports.isCompoundAssignmentExpression = isCompoundAssignmentExpression_1303; -exports.isDebuggerStatement = isDebuggerStatement_1304; -exports.isDoWhileStatement = isDoWhileStatement_1305; -exports.isEmptyStatement = isEmptyStatement_1306; -exports.isExpressionStatement = isExpressionStatement_1307; -exports.isForInStatement = isForInStatement_1308; -exports.isForOfStatement = isForOfStatement_1309; -exports.isForStatement = isForStatement_1310; -exports.isIfStatement = isIfStatement_1311; -exports.isLabeledStatement = isLabeledStatement_1312; -exports.isReturnStatement = isReturnStatement_1313; -exports.isSwitchStatement = isSwitchStatement_1314; -exports.isSwitchStatementWithDefault = isSwitchStatementWithDefault_1315; -exports.isThrowStatement = isThrowStatement_1316; -exports.isTryCatchStatement = isTryCatchStatement_1317; -exports.isTryFinallyStatement = isTryFinallyStatement_1318; -exports.isVariableDeclarationStatement = isVariableDeclarationStatement_1319; -exports.isWhileStatement = isWhileStatement_1320; -exports.isWithStatement = isWithStatement_1321; -exports.isPragma = isPragma_1322; -exports.isBlock = isBlock_1323; -exports.isCatchClause = isCatchClause_1324; -exports.isDirective = isDirective_1325; -exports.isFormalParameters = isFormalParameters_1326; -exports.isFunctionBody = isFunctionBody_1327; -exports.isFunctionDeclaration = isFunctionDeclaration_1328; -exports.isScript = isScript_1329; -exports.isSpreadElement = isSpreadElement_1330; -exports.isSuper = isSuper_1331; -exports.isSwitchCase = isSwitchCase_1332; -exports.isSwitchDefault = isSwitchDefault_1333; -exports.isTemplateElement = isTemplateElement_1334; -exports.isSyntaxTemplate = isSyntaxTemplate_1335; -exports.isVariableDeclaration = isVariableDeclaration_1336; -exports.isVariableDeclarator = isVariableDeclarator_1337; -exports.isEOF = isEOF_1338; -exports.isSyntaxDeclaration = isSyntaxDeclaration_1339; -exports.isSyntaxrecDeclaration = isSyntaxrecDeclaration_1340; -exports.isFunctionTerm = isFunctionTerm_1341; -exports.isFunctionWithName = isFunctionWithName_1342; -exports.isParenthesizedExpression = isParenthesizedExpression_1343; -exports.isExportSyntax = isExportSyntax_1344; -exports.isSyntaxDeclarationStatement = isSyntaxDeclarationStatement_1345; -exports.isCompiletimeDeclaration = isCompiletimeDeclaration_1346; -exports.isCompiletimeStatement = isCompiletimeStatement_1347; -exports.isImportDeclaration = isImportDeclaration_1348; -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/terms.js"],"names":[],"mappings":"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B,c,GAAvB,mB;QACsB,a,GAAtB,kB;QAC2B,kB,GAA3B,uB;QAC0B,iB,GAA1B,sB;QAC0B,iB,GAA1B,sB;QACqC,4B,GAArC,iC;QACyB,gB,GAAzB,qB;QAC4B,mB,GAA5B,wB;QAC8B,qB,GAA9B,0B;QACuC,8B,GAAvC,mC;QACyB,gB,GAAzB,qB;QACwB,e,GAAxB,oB;QACiB,Q,GAAjB,a;QACgB,O,GAAhB,Y;QACsB,a,GAAtB,kB;QACoB,W,GAApB,gB;QAC2B,kB,GAA3B,uB;QACuB,c,GAAvB,mB;QAC8B,qB,GAA9B,0B;QACiB,Q,GAAjB,a;QACwB,e,GAAxB,oB;QACgB,O,GAAhB,Y;QACqB,Y,GAArB,iB;QACwB,e,GAAxB,oB;QAC0B,iB,GAA1B,sB;QACyB,gB,GAAzB,qB;QAC8B,qB,GAA9B,0B;QAC6B,oB,GAA7B,yB;QACc,K,GAAd,U;QAC4B,mB,GAA5B,wB;QAC+B,sB,GAA/B,2B;QACuB,c,GAAvB,mB;QAC2B,kB,GAA3B,uB;QACkC,yB,GAAlC,8B;QACuB,c,GAAvB,mB;QACqC,4B,GAArC,iC;QACiC,wB,GAAjC,6B;QAC+B,sB,GAA/B,2B;QAC4B,mB,GAA5B,wB","file":"terms.js","sourcesContent":["import {List} from \"immutable\";\nimport {assert, expect} from \"./errors\";\nimport {mixin} from \"./utils\";\nimport Syntax from \"./syntax\";\nimport TermSpec from \"./term-spec\";\nimport  * as R from \"ramda\";\nexport default class Term {\n  constructor(type_1349, props_1350) {\n    this.type = type_1349;\n    this.loc = null;\n    for (let prop of Object.keys(props_1350)) {\n      this[prop] = props_1350[prop];\n    }\n  }\n  extend(props_1351) {\n    let newProps_1352 = {};\n    for (let field of TermSpec.spec[this.type].fields) {\n      if (props_1351.hasOwnProperty(field)) {\n        newProps_1352[field] = props_1351[field];\n      } else {\n        newProps_1352[field] = this[field];\n      }\n    }\n    return new Term(this.type, newProps_1352);\n  }\n  gen({includeImports} = {includeImports: true}) {\n    let next_1353 = {};\n    for (let field of TermSpec.spec[this.type].fields) {\n      if (this[field] == null) {\n        next_1353[field] = null;\n      } else if (this[field] instanceof Term) {\n        next_1353[field] = this[field].gen(includeImports);\n      } else if (List.isList(this[field])) {\n        let pred = includeImports ? R.complement(isCompiletimeStatement_1347) : R.both(R.complement(isImportDeclaration_1348), R.complement(isCompiletimeStatement_1347));\n        next_1353[field] = this[field].filter(pred).map(term_1354 => term_1354 instanceof Term ? term_1354.gen(includeImports) : term_1354);\n      } else {\n        next_1353[field] = this[field];\n      }\n    }\n    return new Term(this.type, next_1353);\n  }\n  visit(f_1355) {\n    let next_1356 = {};\n    for (let field of TermSpec.spec[this.type].fields) {\n      if (this[field] == null) {\n        next_1356[field] = null;\n      } else if (List.isList(this[field])) {\n        next_1356[field] = this[field].map(field_1357 => field_1357 != null ? f_1355(field_1357) : null);\n      } else {\n        next_1356[field] = f_1355(this[field]);\n      }\n    }\n    return this.extend(next_1356);\n  }\n  addScope(scope_1358, bindings_1359, phase_1360, options_1361) {\n    return this.visit(term_1362 => {\n      if (typeof term_1362.addScope === \"function\") {\n        return term_1362.addScope(scope_1358, bindings_1359, phase_1360, options_1361);\n      }\n      return term_1362;\n    });\n  }\n  removeScope(scope_1363, phase_1364) {\n    return this.visit(term_1365 => {\n      if (typeof term_1365.removeScope === \"function\") {\n        return term_1365.removeScope(scope_1363, phase_1364);\n      }\n      return term_1365;\n    });\n  }\n  lineNumber() {\n    for (let field of TermSpec.spec[this.type].fields) {\n      if (typeof this[field] && this[field].lineNumber === \"function\") {\n        return this[field].lineNumber();\n      }\n    }\n  }\n  setLineNumber(line_1366) {\n    let next_1367 = {};\n    for (let field of TermSpec.spec[this.type].fields) {\n      if (this[field] == null) {\n        next_1367[field] = null;\n      } else if (typeof this[field].setLineNumber === \"function\") {\n        next_1367[field] = this[field].setLineNumber(line_1366);\n      } else if (List.isList(this[field])) {\n        next_1367[field] = this[field].map(f_1368 => f_1368.setLineNumber(line_1366));\n      } else {\n        next_1367[field] = this[field];\n      }\n    }\n    return new Term(this.type, next_1367);\n  }\n}\nconst isBindingWithDefault_1249 = R.whereEq({type: \"BindingWithDefault\"});\n;\nconst isBindingIdentifier_1250 = R.whereEq({type: \"BindingIdentifier\"});\n;\nconst isArrayBinding_1251 = R.whereEq({type: \"ArrayBinding\"});\n;\nconst isObjectBinding_1252 = R.whereEq({type: \"ObjectBinding\"});\n;\nconst isBindingPropertyIdentifier_1253 = R.whereEq({type: \"BindingPropertyIdentifier\"});\n;\nconst isBindingPropertyProperty_1254 = R.whereEq({type: \"BindingPropertyIdentifier\"});\n;\nconst isClassExpression_1255 = R.whereEq({type: \"ClassExpression\"});\n;\nconst isClassDeclaration_1256 = R.whereEq({type: \"ClassDeclaration\"});\n;\nconst isClassElement_1257 = R.whereEq({type: \"ClassElement\"});\n;\nconst isModule_1258 = R.whereEq({type: \"Module\"});\n;\nconst isImport_1259 = R.whereEq({type: \"Import\"});\n;\nconst isImportNamespace_1260 = R.whereEq({type: \"ImportNamespace\"});\n;\nconst isImportSpecifier_1261 = R.whereEq({type: \"ImportSpecifier\"});\n;\nconst isExportAllFrom_1262 = R.whereEq({type: \"ExportAllFrom\"});\n;\nconst isExportFrom_1263 = R.whereEq({type: \"ExportFrom\"});\n;\nconst isExport_1264 = R.whereEq({type: \"Export\"});\n;\nconst isExportDefault_1265 = R.whereEq({type: \"ExportDefault\"});\n;\nconst isExportSpecifier_1266 = R.whereEq({type: \"ExportSpecifier\"});\n;\nconst isMethod_1267 = R.whereEq({type: \"Method\"});\n;\nconst isGetter_1268 = R.whereEq({type: \"Getter\"});\n;\nconst isSetter_1269 = R.whereEq({type: \"Setter\"});\n;\nconst isDataProperty_1270 = R.whereEq({type: \"DataProperty\"});\n;\nconst isShorthandProperty_1271 = R.whereEq({type: \"ShorthandProperty\"});\n;\nconst isComputedPropertyName_1272 = R.whereEq({type: \"ComputedPropertyName\"});\n;\nconst isStaticPropertyName_1273 = R.whereEq({type: \"StaticPropertyName\"});\n;\nconst isLiteralBooleanExpression_1274 = R.whereEq({type: \"LiteralBooleanExpression\"});\n;\nconst isLiteralInfinityExpression_1275 = R.whereEq({type: \"LiteralInfinityExpression\"});\n;\nconst isLiteralNullExpression_1276 = R.whereEq({type: \"LiteralNullExpression\"});\n;\nconst isLiteralNumericExpression_1277 = R.whereEq({type: \"LiteralNumericExpression\"});\n;\nconst isLiteralRegExpExpression_1278 = R.whereEq({type: \"LiteralRegExpExpression\"});\n;\nconst isLiteralStringExpression_1279 = R.whereEq({type: \"LiteralStringExpression\"});\n;\nconst isArrayExpression_1280 = R.whereEq({type: \"ArrayExpression\"});\n;\nconst isArrowExpression_1281 = R.whereEq({type: \"ArrowExpression\"});\n;\nconst isAssignmentExpression_1282 = R.whereEq({type: \"AssignmentExpression\"});\n;\nconst isBinaryExpression_1283 = R.whereEq({type: \"BinaryExpression\"});\n;\nconst isCallExpression_1284 = R.whereEq({type: \"CallExpression\"});\n;\nconst isComputedAssignmentExpression_1285 = R.whereEq({type: \"ComputedAssignmentExpression\"});\n;\nconst isComputedMemberExpression_1286 = R.whereEq({type: \"ComputedMemberExpression\"});\n;\nconst isConditionalExpression_1287 = R.whereEq({type: \"ConditionalExpression\"});\n;\nconst isFunctionExpression_1288 = R.whereEq({type: \"FunctionExpression\"});\n;\nconst isIdentifierExpression_1289 = R.whereEq({type: \"IdentifierExpression\"});\n;\nconst isNewExpression_1290 = R.whereEq({type: \"NewExpression\"});\n;\nconst isNewTargetExpression_1291 = R.whereEq({type: \"NewTargetExpression\"});\n;\nconst isObjectExpression_1292 = R.whereEq({type: \"ObjectExpression\"});\n;\nconst isUnaryExpression_1293 = R.whereEq({type: \"UnaryExpression\"});\n;\nconst isStaticMemberExpression_1294 = R.whereEq({type: \"StaticMemberExpression\"});\n;\nconst isTemplateExpression_1295 = R.whereEq({type: \"TemplateExpression\"});\n;\nconst isThisExpression_1296 = R.whereEq({type: \"ThisExpression\"});\n;\nconst isUpdateExpression_1297 = R.whereEq({type: \"UpdateExpression\"});\n;\nconst isYieldExpression_1298 = R.whereEq({type: \"YieldExpression\"});\n;\nconst isYieldGeneratorExpression_1299 = R.whereEq({type: \"YieldGeneratorExpression\"});\n;\nconst isBlockStatement_1300 = R.whereEq({type: \"BlockStatement\"});\n;\nconst isBreakStatement_1301 = R.whereEq({type: \"BreakStatement\"});\n;\nconst isContinueStatement_1302 = R.whereEq({type: \"ContinueStatement\"});\n;\nconst isCompoundAssignmentExpression_1303 = R.whereEq({type: \"CompoundAssignmentExpression\"});\n;\nconst isDebuggerStatement_1304 = R.whereEq({type: \"DebuggerStatement\"});\n;\nconst isDoWhileStatement_1305 = R.whereEq({type: \"DoWhileStatement\"});\n;\nconst isEmptyStatement_1306 = R.whereEq({type: \"EmptyStatement\"});\n;\nconst isExpressionStatement_1307 = R.whereEq({type: \"ExpressionStatement\"});\n;\nconst isForInStatement_1308 = R.whereEq({type: \"ForInStatement\"});\n;\nconst isForOfStatement_1309 = R.whereEq({type: \"ForOfStatement\"});\n;\nconst isForStatement_1310 = R.whereEq({type: \"ForStatement\"});\n;\nconst isIfStatement_1311 = R.whereEq({type: \"IfStatement\"});\n;\nconst isLabeledStatement_1312 = R.whereEq({type: \"LabeledStatement\"});\n;\nconst isReturnStatement_1313 = R.whereEq({type: \"ReturnStatement\"});\n;\nconst isSwitchStatement_1314 = R.whereEq({type: \"SwitchStatement\"});\n;\nconst isSwitchStatementWithDefault_1315 = R.whereEq({type: \"SwitchStatementWithDefault\"});\n;\nconst isThrowStatement_1316 = R.whereEq({type: \"ThrowStatement\"});\n;\nconst isTryCatchStatement_1317 = R.whereEq({type: \"TryCatchStatement\"});\n;\nconst isTryFinallyStatement_1318 = R.whereEq({type: \"TryFinallyStatement\"});\n;\nconst isVariableDeclarationStatement_1319 = R.whereEq({type: \"VariableDeclarationStatement\"});\n;\nconst isWhileStatement_1320 = R.whereEq({type: \"WhileStatement\"});\n;\nconst isWithStatement_1321 = R.whereEq({type: \"WithStatement\"});\n;\nconst isPragma_1322 = R.whereEq({type: \"Pragma\"});\n;\nconst isBlock_1323 = R.whereEq({type: \"Block\"});\n;\nconst isCatchClause_1324 = R.whereEq({type: \"CatchClause\"});\n;\nconst isDirective_1325 = R.whereEq({type: \"Directive\"});\n;\nconst isFormalParameters_1326 = R.whereEq({type: \"FormalParameters\"});\n;\nconst isFunctionBody_1327 = R.whereEq({type: \"FunctionBody\"});\n;\nconst isFunctionDeclaration_1328 = R.whereEq({type: \"FunctionDeclaration\"});\n;\nconst isScript_1329 = R.whereEq({type: \"Script\"});\n;\nconst isSpreadElement_1330 = R.whereEq({type: \"SpreadElement\"});\n;\nconst isSuper_1331 = R.whereEq({type: \"Super\"});\n;\nconst isSwitchCase_1332 = R.whereEq({type: \"SwitchCase\"});\n;\nconst isSwitchDefault_1333 = R.whereEq({type: \"SwitchDefault\"});\n;\nconst isTemplateElement_1334 = R.whereEq({type: \"TemplateElement\"});\n;\nconst isSyntaxTemplate_1335 = R.whereEq({type: \"SyntaxTemplate\"});\n;\nconst isVariableDeclaration_1336 = R.whereEq({type: \"VariableDeclaration\"});\n;\nconst isVariableDeclarator_1337 = R.whereEq({type: \"VariableDeclarator\"});\n;\nconst isEOF_1338 = R.whereEq({type: \"EOF\"});\n;\nconst isSyntaxDeclaration_1339 = R.both(isVariableDeclaration_1336, R.whereEq({kind: \"syntax\"}));\n;\nconst isSyntaxrecDeclaration_1340 = R.both(isVariableDeclaration_1336, R.whereEq({kind: \"syntaxrec\"}));\n;\nconst isFunctionTerm_1341 = R.either(isFunctionDeclaration_1328, isFunctionExpression_1288);\n;\nconst isFunctionWithName_1342 = R.and(isFunctionTerm_1341, R.complement(R.where({name: R.isNil})));\n;\nconst isParenthesizedExpression_1343 = R.whereEq({type: \"ParenthesizedExpression\"});\n;\nconst isExportSyntax_1344 = R.both(isExport_1264, exp_1369 => R.or(isSyntaxDeclaration_1339(exp_1369.declaration), isSyntaxrecDeclaration_1340(exp_1369.declaration)));\n;\nconst isSyntaxDeclarationStatement_1345 = R.both(isVariableDeclarationStatement_1319, decl_1370 => isCompiletimeDeclaration_1346(decl_1370.declaration));\n;\nconst isCompiletimeDeclaration_1346 = R.either(isSyntaxDeclaration_1339, isSyntaxrecDeclaration_1340);\n;\nconst isCompiletimeStatement_1347 = term_1371 => {\n  return term_1371 instanceof Term && isVariableDeclarationStatement_1319(term_1371) && isCompiletimeDeclaration_1346(term_1371.declaration);\n};\n;\nconst isImportDeclaration_1348 = R.either(isImport_1259, isImportNamespace_1260);\n;\nexport {isBindingWithDefault_1249 as isBindingWithDefault};\nexport {isBindingIdentifier_1250 as isBindingIdentifier};\nexport {isArrayBinding_1251 as isArrayBinding};\nexport {isObjectBinding_1252 as isObjectBinding};\nexport {isBindingPropertyIdentifier_1253 as isBindingPropertyIdentifier};\nexport {isBindingPropertyProperty_1254 as isBindingPropertyProperty};\nexport {isClassExpression_1255 as isClassExpression};\nexport {isClassDeclaration_1256 as isClassDeclaration};\nexport {isClassElement_1257 as isClassElement};\nexport {isModule_1258 as isModule};\nexport {isImport_1259 as isImport};\nexport {isImportNamespace_1260 as isImportNamespace};\nexport {isImportSpecifier_1261 as isImportSpecifier};\nexport {isExportAllFrom_1262 as isExportAllFrom};\nexport {isExportFrom_1263 as isExportFrom};\nexport {isExport_1264 as isExport};\nexport {isExportDefault_1265 as isExportDefault};\nexport {isExportSpecifier_1266 as isExportSpecifier};\nexport {isMethod_1267 as isMethod};\nexport {isGetter_1268 as isGetter};\nexport {isSetter_1269 as isSetter};\nexport {isDataProperty_1270 as isDataProperty};\nexport {isShorthandProperty_1271 as isShorthandProperty};\nexport {isComputedPropertyName_1272 as isComputedPropertyName};\nexport {isStaticPropertyName_1273 as isStaticPropertyName};\nexport {isLiteralBooleanExpression_1274 as isLiteralBooleanExpression};\nexport {isLiteralInfinityExpression_1275 as isLiteralInfinityExpression};\nexport {isLiteralNullExpression_1276 as isLiteralNullExpression};\nexport {isLiteralNumericExpression_1277 as isLiteralNumericExpression};\nexport {isLiteralRegExpExpression_1278 as isLiteralRegExpExpression};\nexport {isLiteralStringExpression_1279 as isLiteralStringExpression};\nexport {isArrayExpression_1280 as isArrayExpression};\nexport {isArrowExpression_1281 as isArrowExpression};\nexport {isAssignmentExpression_1282 as isAssignmentExpression};\nexport {isBinaryExpression_1283 as isBinaryExpression};\nexport {isCallExpression_1284 as isCallExpression};\nexport {isComputedAssignmentExpression_1285 as isComputedAssignmentExpression};\nexport {isComputedMemberExpression_1286 as isComputedMemberExpression};\nexport {isConditionalExpression_1287 as isConditionalExpression};\nexport {isFunctionExpression_1288 as isFunctionExpression};\nexport {isIdentifierExpression_1289 as isIdentifierExpression};\nexport {isNewExpression_1290 as isNewExpression};\nexport {isNewTargetExpression_1291 as isNewTargetExpression};\nexport {isObjectExpression_1292 as isObjectExpression};\nexport {isUnaryExpression_1293 as isUnaryExpression};\nexport {isStaticMemberExpression_1294 as isStaticMemberExpression};\nexport {isTemplateExpression_1295 as isTemplateExpression};\nexport {isThisExpression_1296 as isThisExpression};\nexport {isUpdateExpression_1297 as isUpdateExpression};\nexport {isYieldExpression_1298 as isYieldExpression};\nexport {isYieldGeneratorExpression_1299 as isYieldGeneratorExpression};\nexport {isBlockStatement_1300 as isBlockStatement};\nexport {isBreakStatement_1301 as isBreakStatement};\nexport {isContinueStatement_1302 as isContinueStatement};\nexport {isCompoundAssignmentExpression_1303 as isCompoundAssignmentExpression};\nexport {isDebuggerStatement_1304 as isDebuggerStatement};\nexport {isDoWhileStatement_1305 as isDoWhileStatement};\nexport {isEmptyStatement_1306 as isEmptyStatement};\nexport {isExpressionStatement_1307 as isExpressionStatement};\nexport {isForInStatement_1308 as isForInStatement};\nexport {isForOfStatement_1309 as isForOfStatement};\nexport {isForStatement_1310 as isForStatement};\nexport {isIfStatement_1311 as isIfStatement};\nexport {isLabeledStatement_1312 as isLabeledStatement};\nexport {isReturnStatement_1313 as isReturnStatement};\nexport {isSwitchStatement_1314 as isSwitchStatement};\nexport {isSwitchStatementWithDefault_1315 as isSwitchStatementWithDefault};\nexport {isThrowStatement_1316 as isThrowStatement};\nexport {isTryCatchStatement_1317 as isTryCatchStatement};\nexport {isTryFinallyStatement_1318 as isTryFinallyStatement};\nexport {isVariableDeclarationStatement_1319 as isVariableDeclarationStatement};\nexport {isWhileStatement_1320 as isWhileStatement};\nexport {isWithStatement_1321 as isWithStatement};\nexport {isPragma_1322 as isPragma};\nexport {isBlock_1323 as isBlock};\nexport {isCatchClause_1324 as isCatchClause};\nexport {isDirective_1325 as isDirective};\nexport {isFormalParameters_1326 as isFormalParameters};\nexport {isFunctionBody_1327 as isFunctionBody};\nexport {isFunctionDeclaration_1328 as isFunctionDeclaration};\nexport {isScript_1329 as isScript};\nexport {isSpreadElement_1330 as isSpreadElement};\nexport {isSuper_1331 as isSuper};\nexport {isSwitchCase_1332 as isSwitchCase};\nexport {isSwitchDefault_1333 as isSwitchDefault};\nexport {isTemplateElement_1334 as isTemplateElement};\nexport {isSyntaxTemplate_1335 as isSyntaxTemplate};\nexport {isVariableDeclaration_1336 as isVariableDeclaration};\nexport {isVariableDeclarator_1337 as isVariableDeclarator};\nexport {isEOF_1338 as isEOF};\nexport {isSyntaxDeclaration_1339 as isSyntaxDeclaration};\nexport {isSyntaxrecDeclaration_1340 as isSyntaxrecDeclaration};\nexport {isFunctionTerm_1341 as isFunctionTerm};\nexport {isFunctionWithName_1342 as isFunctionWithName};\nexport {isParenthesizedExpression_1343 as isParenthesizedExpression};\nexport {isExportSyntax_1344 as isExportSyntax};\nexport {isSyntaxDeclarationStatement_1345 as isSyntaxDeclarationStatement};\nexport {isCompiletimeDeclaration_1346 as isCompiletimeDeclaration};\nexport {isCompiletimeStatement_1347 as isCompiletimeStatement};\nexport {isImportDeclaration_1348 as isImportDeclaration}"]} \ No newline at end of file +const isImportDeclaration = exports.isImportDeclaration = R.either(isImport, isImportNamespace); +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/terms.js"],"names":[],"mappings":"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","file":"terms.js","sourcesContent":["import { List } from \"immutable\";\nimport * as R from \"ramda\";\nimport TermSpec from 'sweet-spec';\n\nconst attrName = a => a.attrName;\n\nexport default class Term {\n  type: string;\n  loc: null;\n  spec: typeof TermSpec;\n\n  constructor(type: string, props: {}) {\n    let spec = TermSpec.getDescendant(type);\n    if (spec == null) {\n      throw new Error(`Unknown term: ${type}`);\n    }\n    this.type = type;\n    this.loc = null;\n    this.spec = spec;\n    let propKeys = Object.keys(props);\n    let fieldNames = spec.getAttributes().map(attrName);\n    let diff = R.symmetricDifference(propKeys, fieldNames);\n    if (diff.length !== 0) {\n      throw new Error(`Unexpected properties for term ${type}: ${diff}`);\n    }\n    Object.assign(this, props);\n  }\n\n  extend(props: {}) {\n    let specAttrNames = this.spec.getAttributes().map(attrName);\n    let newProps = R.pick(specAttrNames, this);\n\n    let invalidAttrs = R.difference(Object.keys(props), specAttrNames);\n    if (invalidAttrs.length > 0) {\n      throw new Error(`Unexpected properties for term ${this.type}: ${invalidAttrs}`);\n    }\n\n    return new Term(this.type, Object.assign(newProps, props));\n  }\n\n  // TODO: remove\n  gen(includeImports: boolean = true) {\n    let next = {};\n    for (let field of this.spec.getAttributes()) {\n      if (this[field.attrName] == null) {\n        next[field.attrName] = null;\n      } else if (this[field.attrName] instanceof Term) {\n        next[field.attrName] = this[field.attrName].gen(includeImports);\n      } else if (List.isList(this[field.attrName])) {\n        let pred = includeImports ? R.complement(isCompiletimeStatement) : R.both(R.complement(isImportDeclaration), R.complement(isCompiletimeStatement));\n        next[field.attrName] = this[field.attrName].filter(pred)\n                                 .map(term => term instanceof Term ? term.gen(includeImports) : term);\n      } else {\n        next[field.attrName] = this[field.attrName];\n      }\n    }\n    return new Term(this.type, next);\n  }\n\n  // TODO: remove\n  visit(f) {\n    let next = {};\n    for (let field of TermSpec.getDescendant(this.type).getAttributes()) {\n      if (this[field.attrName] == null) {\n        next[field.attrName] = null;\n      } else if (List.isList(this[field.attrName])) {\n        next[field.attrName] = this[field.attrName].map(field => field != null ? f(field) : null);\n      } else {\n        next[field.attrName] = f(this[field.attrName]);\n      }\n    }\n    return this.extend(next);\n  }\n\n  // TODO: remove\n  addScope(scope, bindings, phase, options) {\n    return this.visit(term => {\n      if (typeof term.addScope === 'function') {\n        return term.addScope(scope, bindings, phase, options);\n      }\n      return term;\n    });\n  }\n\n  // TODO: remove\n  removeScope(scope, phase) {\n    return this.visit(term => {\n      if (typeof term.removeScope === 'function') {\n        return term.removeScope(scope, phase);\n      }\n      return term;\n    });\n  }\n\n  // TODO: this is very wrong\n  lineNumber() {\n    for (let field of TermSpec.getDescendant(this.type).getAttributes()) {\n      if (typeof this[field.attrName] && this[field.attrName].lineNumber === 'function') {\n        return this[field.attrName].lineNumber();\n      }\n    }\n  }\n\n  setLineNumber(line) {\n    let next = {};\n    for (let field of TermSpec.getDescendant(this.type).getAttributes()) {\n      if (this[field.attrName] == null) {\n        next[field.attrName] = null;\n      } else if (typeof this[field.attrName].setLineNumber === 'function') {\n        next[field.attrName] = this[field.attrName].setLineNumber(line);\n      } else if (List.isList(this[field.attrName])) {\n        next[field.attrName] = this[field.attrName].map(f => f.setLineNumber(line));\n      } else {\n        next[field.attrName] = this[field.attrName];\n      }\n    }\n    return new Term(this.type, next);\n  }\n}\n\n\n// bindings\nexport const isBindingWithDefault = R.whereEq({ type: \"BindingWithDefault\" });\nexport const isBindingIdentifier = R.whereEq({ type: \"BindingIdentifier\" });\nexport const isArrayBinding = R.whereEq({ type: \"ArrayBinding\" });\nexport const isObjectBinding = R.whereEq({ type: \"ObjectBinding\" });\nexport const isBindingPropertyIdentifier = R.whereEq({ type: \"BindingPropertyIdentifier\" });\nexport const isBindingPropertyProperty = R.whereEq({ type: \"BindingPropertyIdentifier\" });\n\n// class\nexport const isClassExpression = R.whereEq({ type: \"ClassExpression\" });\nexport const isClassDeclaration = R.whereEq({ type: \"ClassDeclaration\" });\nexport const isClassElement = R.whereEq({ type: \"ClassElement\" });\n\n// modules\nexport const isModule = R.whereEq({ type: \"Module\" });\nexport const isImport = R.whereEq({ type: \"Import\" });\nexport const isImportNamespace = R.whereEq({ type: \"ImportNamespace\" });\nexport const isImportSpecifier = R.whereEq({ type: \"ImportSpecifier\" });\nexport const isExportAllFrom = R.whereEq({ type: \"ExportAllFrom\" });\nexport const isExportFrom = R.whereEq({ type: \"ExportFrom\" });\nexport const isExport = R.whereEq({ type: \"Export\" });\nexport const isExportDefault = R.whereEq({ type: \"ExportDefault\" });\nexport const isExportSpecifier = R.whereEq({ type: \"ExportSpecifier\" });\n\n// property definition\nexport const isMethod = R.whereEq({ type: \"Method\" });\nexport const isGetter = R.whereEq({ type: \"Getter\" });\nexport const isSetter = R.whereEq({ type: \"Setter\" });\nexport const isDataProperty = R.whereEq({ type: \"DataProperty\" });\nexport const isShorthandProperty = R.whereEq({ type: \"ShorthandProperty\" });\nexport const isComputedPropertyName = R.whereEq({ type: \"ComputedPropertyName\" });\nexport const isStaticPropertyName = R.whereEq({ type: \"StaticPropertyName\" });\n\n// literals\nexport const isLiteralBooleanExpression = R.whereEq({ type: \"LiteralBooleanExpression\" });\nexport const isLiteralInfinityExpression = R.whereEq({ type: \"LiteralInfinityExpression\" });\nexport const isLiteralNullExpression = R.whereEq({ type: \"LiteralNullExpression\" });\nexport const isLiteralNumericExpression = R.whereEq({ type: \"LiteralNumericExpression\" });\nexport const isLiteralRegExpExpression = R.whereEq({ type: \"LiteralRegExpExpression\" });\nexport const isLiteralStringExpression = R.whereEq({ type: \"LiteralStringExpression\" });\n\n// expressions\nexport const isArrayExpression = R.whereEq({ type: \"ArrayExpression\" });\nexport const isArrowExpression = R.whereEq({ type: \"ArrowExpression\" });\nexport const isAssignmentExpression = R.whereEq({ type: \"AssignmentExpression\" });\nexport const isBinaryExpression = R.whereEq({ type: \"BinaryExpression\" });\nexport const isCallExpression = R.whereEq({ type: \"CallExpression\" });\nexport const isComputedAssignmentExpression = R.whereEq({ type: \"ComputedAssignmentExpression\" });\nexport const isComputedMemberExpression = R.whereEq({ type: \"ComputedMemberExpression\" });\nexport const isConditionalExpression = R.whereEq({ type: \"ConditionalExpression\" });\nexport const isFunctionExpression = R.whereEq({ type: \"FunctionExpression\" });\nexport const isIdentifierExpression = R.whereEq({ type: \"IdentifierExpression\" });\nexport const isNewExpression = R.whereEq({ type: \"NewExpression\" });\nexport const isNewTargetExpression = R.whereEq({ type: \"NewTargetExpression\" });\nexport const isObjectExpression = R.whereEq({ type: \"ObjectExpression\" });\nexport const isUnaryExpression = R.whereEq({ type: \"UnaryExpression\" });\nexport const isStaticMemberExpression = R.whereEq({ type: \"StaticMemberExpression\" });\nexport const isTemplateExpression = R.whereEq({ type: \"TemplateExpression\" });\nexport const isThisExpression = R.whereEq({ type: \"ThisExpression\" });\nexport const isUpdateExpression = R.whereEq({ type: \"UpdateExpression\" });\nexport const isYieldExpression = R.whereEq({ type: \"YieldExpression\" });\nexport const isYieldGeneratorExpression = R.whereEq({ type: \"YieldGeneratorExpression\" });\n\n// statements\nexport const isBlockStatement = R.whereEq({ type: \"BlockStatement\" });\nexport const isBreakStatement = R.whereEq({ type: \"BreakStatement\" });\nexport const isContinueStatement = R.whereEq({ type: \"ContinueStatement\" });\nexport const isCompoundAssignmentExpression = R.whereEq({ type: \"CompoundAssignmentExpression\" });\nexport const isDebuggerStatement = R.whereEq({ type: \"DebuggerStatement\" });\nexport const isDoWhileStatement = R.whereEq({ type: \"DoWhileStatement\" });\nexport const isEmptyStatement = R.whereEq({ type: \"EmptyStatement\" });\nexport const isExpressionStatement = R.whereEq({ type: \"ExpressionStatement\" });\nexport const isForInStatement = R.whereEq({ type: \"ForInStatement\" });\nexport const isForOfStatement = R.whereEq({ type: \"ForOfStatement\" });\nexport const isForStatement = R.whereEq({ type: \"ForStatement\" });\nexport const isIfStatement = R.whereEq({ type: \"IfStatement\" });\nexport const isLabeledStatement = R.whereEq({ type: \"LabeledStatement\" });\nexport const isReturnStatement = R.whereEq({ type: \"ReturnStatement\" });\nexport const isSwitchStatement = R.whereEq({ type: \"SwitchStatement\" });\nexport const isSwitchStatementWithDefault = R.whereEq({ type: \"SwitchStatementWithDefault\" });\nexport const isThrowStatement = R.whereEq({ type: \"ThrowStatement\" });\nexport const isTryCatchStatement = R.whereEq({ type: \"TryCatchStatement\" });\nexport const isTryFinallyStatement = R.whereEq({ type: \"TryFinallyStatement\" });\nexport const isVariableDeclarationStatement = R.whereEq({ type: \"VariableDeclarationStatement\" });\nexport const isWhileStatement = R.whereEq({ type: \"WhileStatement\" });\nexport const isWithStatement = R.whereEq({ type: \"WithStatement\" });\n\n// other\nexport const isPragma = R.whereEq({ type: 'Pragma' });\nexport const isBlock = R.whereEq({ type: \"Block\" });\nexport const isCatchClause = R.whereEq({ type: \"CatchClause\" });\nexport const isDirective = R.whereEq({ type: \"Directive\" });\nexport const isFormalParameters = R.whereEq({ type: \"FormalParameters\" });\nexport const isFunctionBody = R.whereEq({ type: \"FunctionBody\" });\nexport const isFunctionDeclaration = R.whereEq({ type: \"FunctionDeclaration\" });\nexport const isScript = R.whereEq({ type: \"Script\" });\nexport const isSpreadElement = R.whereEq({ type: \"SpreadElement\" });\nexport const isSuper = R.whereEq({ type: \"Super\" });\nexport const isSwitchCase = R.whereEq({ type: \"SwitchCase\" });\nexport const isSwitchDefault = R.whereEq({ type: \"SwitchDefault\" });\nexport const isTemplateElement = R.whereEq({ type: \"TemplateElement\" });\nexport const isSyntaxTemplate = R.whereEq({ type: \"SyntaxTemplate\" });\nexport const isVariableDeclaration = R.whereEq({ type: \"VariableDeclaration\" });\nexport const isVariableDeclarator = R.whereEq({ type: \"VariableDeclarator\" });\nexport const isEOF = R.whereEq({ type: 'EOF' });\nexport const isSyntaxDeclaration = R.both(isVariableDeclaration, R.whereEq({ kind: 'syntax' }));\nexport const isSyntaxrecDeclaration = R.both(isVariableDeclaration, R.whereEq({ kind: 'syntaxrec' }));\nexport const isFunctionTerm = R.either(isFunctionDeclaration, isFunctionExpression);\nexport const isFunctionWithName = R.and(isFunctionTerm, R.complement(R.where({ name: R.isNil })));\nexport const isParenthesizedExpression = R.whereEq({ type: 'ParenthesizedExpression'});\nexport const isExportSyntax = R.both(isExport, exp => R.or(isSyntaxDeclaration(exp.declaration), isSyntaxrecDeclaration(exp.declaration)));\nexport const isSyntaxDeclarationStatement = R.both(isVariableDeclarationStatement, decl => isCompiletimeDeclaration(decl.declaration));\n\n\nexport const isCompiletimeDeclaration = R.either(isSyntaxDeclaration, isSyntaxrecDeclaration);\nexport const isCompiletimeStatement = term => {\n  return (term instanceof Term) && isVariableDeclarationStatement(term) && isCompiletimeDeclaration(term.declaration);\n};\nexport const isImportDeclaration = R.either(isImport, isImportNamespace);\n"]} \ No newline at end of file diff --git a/dist/token-expander.js b/dist/token-expander.js index 7bc2c5b9..20222231 100644 --- a/dist/token-expander.js +++ b/dist/token-expander.js @@ -12,21 +12,17 @@ var _termExpander = require("./term-expander.js"); var _termExpander2 = _interopRequireDefault(_termExpander); -var _bindingMap = require("./binding-map.js"); - -var _bindingMap2 = _interopRequireDefault(_bindingMap); - var _env = require("./env"); var _env2 = _interopRequireDefault(_env); -var _shiftReader = require("./shift-reader"); +var _ramda = require("ramda"); -var _shiftReader2 = _interopRequireDefault(_shiftReader); +var _ = _interopRequireWildcard(_ramda); var _terms = require("./terms"); -var _terms2 = _interopRequireDefault(_terms); +var T = _interopRequireWildcard(_terms); var _symbol = require("./symbol"); @@ -40,160 +36,239 @@ var _scope = require("./scope"); var _syntax = require("./syntax"); -var _syntax2 = _interopRequireDefault(_syntax); - var _astDispatcher = require("./ast-dispatcher"); var _astDispatcher2 = _interopRequireDefault(_astDispatcher); var _hygieneUtils = require("./hygiene-utils"); -var _ramda = require("ramda"); - -var _ = _interopRequireWildcard(_ramda); - function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } -function bindImports_1372(impTerm_1375, exModule_1376, context_1377) { - let names_1378 = []; - let phase_1379 = impTerm_1375.forSyntax ? context_1377.phase + 1 : context_1377.phase; - impTerm_1375.namedImports.forEach(specifier_1380 => { - let name_1381 = specifier_1380.binding.name; - let exportName_1382 = findNameInExports_1373(name_1381, exModule_1376.exportEntries); - if (exportName_1382 != null) { - let newBinding = (0, _symbol.gensym)(name_1381.val()); - context_1377.store.set(newBinding.toString(), new _transforms.VarBindingTransform(name_1381)); - context_1377.bindings.addForward(name_1381, exportName_1382, newBinding, phase_1379); - names_1378.push(name_1381); +function bindImports(impTerm, exModule, context) { + let names = []; + let phase = impTerm.forSyntax ? context.phase + 1 : context.phase; + impTerm.namedImports.forEach(specifier => { + let name = specifier.binding.name; + let exportName = findNameInExports(name, exModule.exportEntries); + if (exportName != null) { + let newBinding = (0, _symbol.gensym)(name.val()); + context.store.set(newBinding.toString(), new _transforms.VarBindingTransform(name)); + context.bindings.addForward(name, exportName, newBinding, phase); + names.push(name); } }); - return (0, _immutable.List)(names_1378); + return (0, _immutable.List)(names); } -function findNameInExports_1373(name_1383, exp_1384) { - let foundNames_1385 = exp_1384.reduce((acc_1386, e_1387) => { - if ((0, _terms.isExportFrom)(e_1387)) { - return acc_1386.concat(e_1387.namedExports.reduce((acc_1388, specifier_1389) => { - if (specifier_1389.exportedName.val() === name_1383.val()) { - return acc_1388.concat(specifier_1389.exportedName); + +function findNameInExports(name, exp) { + let foundNames = exp.reduce((acc, e) => { + if (T.isExportFrom(e)) { + return acc.concat(e.namedExports.reduce((acc, specifier) => { + if (specifier.exportedName.val() === name.val()) { + return acc.concat(specifier.exportedName); } - return acc_1388; + return acc; }, (0, _immutable.List)())); - } else if ((0, _terms.isExport)(e_1387)) { - return acc_1386.concat(e_1387.declaration.declarators.reduce((acc_1390, decl_1391) => { - if (decl_1391.binding.name.val() === name_1383.val()) { - return acc_1390.concat(decl_1391.binding.name); + } else if (T.isExport(e)) { + return acc.concat(e.declaration.declarators.reduce((acc, decl) => { + if (decl.binding.name.val() === name.val()) { + return acc.concat(decl.binding.name); } - return acc_1390; + return acc; }, (0, _immutable.List)())); } - return acc_1386; + return acc; }, (0, _immutable.List)()); - (0, _errors.assert)(foundNames_1385.size <= 1, "expecting no more than 1 matching name in exports"); - return foundNames_1385.get(0); + (0, _errors.assert)(foundNames.size <= 1, 'expecting no more than 1 matching name in exports'); + return foundNames.get(0); } -function removeNames_1374(impTerm_1392, names_1393) { - let namedImports_1394 = impTerm_1392.namedImports.filter(specifier_1395 => !names_1393.contains(specifier_1395.binding.name)); - return impTerm_1392.extend({ namedImports: namedImports_1394 }); + +function removeNames(impTerm, names) { + let namedImports = impTerm.namedImports.filter(specifier => !names.contains(specifier.binding.name)); + return impTerm.extend({ namedImports: namedImports }); } + +// function bindAllSyntaxExports(exModule, toSynth, context) { +// let phase = context.phase; +// exModule.exportEntries.forEach(ex => { +// if (isExportSyntax(ex)) { +// ex.declaration.declarators.forEach(decl => { +// let name = decl.binding.name; +// let newBinding = gensym(name.val()); +// let storeName = exModule.moduleSpecifier + ":" + name.val() + ":" + phase; +// let synthStx = Syntax.fromIdentifier(name.val(), toSynth); +// let storeStx = Syntax.fromIdentifier(storeName, toSynth); +// context.bindings.addForward(synthStx, storeStx, newBinding, phase); +// }); +// } +// }); +// } + class TokenExpander extends _astDispatcher2.default { - constructor(context_1396) { - super("expand", false); - this.context = context_1396; + constructor(context) { + super('expand', false); + this.context = context; } - expand(stxl_1397) { - let result_1398 = []; - if (stxl_1397.size === 0) { - return (0, _immutable.List)(result_1398); + + expand(stxl) { + let result = []; + if (stxl.size === 0) { + return (0, _immutable.List)(result); } - let prev_1399 = (0, _immutable.List)(); - let enf_1400 = new _enforester.Enforester(stxl_1397, prev_1399, this.context); - while (!enf_1400.done) { - result_1398.push(this.dispatch(enf_1400.enforest())); + let prev = (0, _immutable.List)(); + let enf = new _enforester.Enforester(stxl, prev, this.context); + + while (!enf.done) { + result.push(this.dispatch(enf.enforest())); } - return (0, _immutable.List)(result_1398); + + return (0, _immutable.List)(result); } - expandVariableDeclarationStatement(term_1401) { - return term_1401.extend({ declaration: this.registerVariableDeclaration(term_1401.declaration) }); + + expandVariableDeclarationStatement(term) { + return term.extend({ + declaration: this.registerVariableDeclaration(term.declaration) + }); } - expandFunctionDeclaration(term_1402) { - let registeredTerm_1403 = this.registerFunctionOrClass(term_1402); - let stx_1404 = registeredTerm_1403.name.name; - this.context.env.set(stx_1404.resolve(this.context.phase), new _transforms.VarBindingTransform(stx_1404)); - return registeredTerm_1403; + + expandFunctionDeclaration(term) { + let registeredTerm = this.registerFunctionOrClass(term); + let stx = registeredTerm.name.name; + this.context.env.set(stx.resolve(this.context.phase), new _transforms.VarBindingTransform(stx)); + return registeredTerm; } - expandImport(term_1405) { - let path_1406 = term_1405.moduleSpecifier.val(); - let mod_1407; - if (term_1405.forSyntax) { - mod_1407 = this.context.modules.getAtPhase(path_1406, this.context.phase + 1, this.context.cwd); - this.context.store = this.context.modules.visit(mod_1407, this.context.phase + 1, this.context.store); - this.context.store = this.context.modules.invoke(mod_1407, this.context.phase + 1, this.context.store); + + // TODO: think about function expressions + + expandImport(term) { + let path = term.moduleSpecifier.val(); + let mod; + if (term.forSyntax) { + mod = this.context.modules.getAtPhase(path, this.context.phase + 1, this.context.cwd); + this.context.store = this.context.modules.visit(mod, this.context.phase + 1, this.context.store); + this.context.store = this.context.modules.invoke(mod, this.context.phase + 1, this.context.store); } else { - mod_1407 = this.context.modules.getAtPhase(path_1406, this.context.phase, this.context.cwd); - this.context.store = this.context.modules.visit(mod_1407, this.context.phase, this.context.store); + mod = this.context.modules.getAtPhase(path, this.context.phase, this.context.cwd); + this.context.store = this.context.modules.visit(mod, this.context.phase, this.context.store); } - let boundNames_1408 = bindImports_1372(term_1405, mod_1407, this.context); - return removeNames_1374(term_1405, boundNames_1408); + let boundNames = bindImports(term, mod, this.context); + return removeNames(term, boundNames); } - expandExport(term_1409) { - if ((0, _terms.isFunctionDeclaration)(term_1409.declaration) || (0, _terms.isClassDeclaration)(term_1409.declaration)) { - return term_1409.extend({ declaration: this.registerFunctionOrClass(term_1409.declaration) }); - } else if ((0, _terms.isVariableDeclaration)(term_1409.declaration)) { - return term_1409.extend({ declaration: this.registerVariableDeclaration(term_1409.declaration) }); + + expandExport(term) { + if (T.isFunctionDeclaration(term.declaration) || T.isClassDeclaration(term.declaration)) { + return term.extend({ + declaration: this.registerFunctionOrClass(term.declaration) + }); + } else if (T.isVariableDeclaration(term.declaration)) { + return term.extend({ + declaration: this.registerVariableDeclaration(term.declaration) + }); } - return term_1409; + return term; } - registerFunctionOrClass(term_1410) { - let name_1411 = term_1410.name.removeScope(this.context.useScope, this.context.phase); - (0, _hygieneUtils.collectBindings)(term_1410.name).forEach(stx_1412 => { - let newBinding_1413 = (0, _symbol.gensym)(stx_1412.val()); - this.context.bindings.add(stx_1412, { binding: newBinding_1413, phase: this.context.phase, skipDup: false }); - this.context.env.set(newBinding_1413.toString(), new _transforms.VarBindingTransform(stx_1412)); + + // [isPragma, term => { + // let pathStx = term.items.get(0); + // if (pathStx.val() === 'base') { + // return term; + // } + // let mod = this.context.modules.loadAndCompile(pathStx.val()); + // store = this.context.modules.visit(mod, phase, store); + // bindAllSyntaxExports(mod, pathStx, this.context); + // return term; + // }], + + registerFunctionOrClass(term) { + let name = term.name.removeScope(this.context.useScope, this.context.phase); + (0, _hygieneUtils.collectBindings)(term.name).forEach(stx => { + let newBinding = (0, _symbol.gensym)(stx.val()); + this.context.bindings.add(stx, { + binding: newBinding, + phase: this.context.phase, + skipDup: false + }); + // the meaning of a function declaration name is a runtime var binding + this.context.env.set(newBinding.toString(), new _transforms.VarBindingTransform(stx)); }); - return term_1410.extend({ name: name_1411 }); + return term.extend({ name: name }); } - registerVariableDeclaration(term_1414) { - if ((0, _terms.isSyntaxDeclaration)(term_1414) || (0, _terms.isSyntaxrecDeclaration)(term_1414)) { - return this.registerSyntaxDeclaration(term_1414); + + registerVariableDeclaration(term) { + if (T.isSyntaxDeclaration(term) || T.isSyntaxrecDeclaration(term)) { + return this.registerSyntaxDeclaration(term); } - return term_1414.extend({ declarators: term_1414.declarators.map(decl_1415 => { - let binding_1416 = decl_1415.binding.removeScope(this.context.useScope, this.context.phase); - (0, _hygieneUtils.collectBindings)(binding_1416).forEach(stx_1417 => { - let newBinding_1418 = (0, _symbol.gensym)(stx_1417.val()); - this.context.bindings.add(stx_1417, { binding: newBinding_1418, phase: this.context.phase, skipDup: term_1414.kind === "var" }); - this.context.env.set(newBinding_1418.toString(), new _transforms.VarBindingTransform(stx_1417)); + return term.extend({ + declarators: term.declarators.map(decl => { + let binding = decl.binding.removeScope(this.context.useScope, this.context.phase); + (0, _hygieneUtils.collectBindings)(binding).forEach(stx => { + let newBinding = (0, _symbol.gensym)(stx.val()); + this.context.bindings.add(stx, { + binding: newBinding, + phase: this.context.phase, + skipDup: term.kind === 'var' + }); + // the meaning of a var/let/const declaration is a var binding + this.context.env.set(newBinding.toString(), new _transforms.VarBindingTransform(stx)); }); - return decl_1415.extend({ binding: binding_1416 }); - }) }); + return decl.extend({ binding: binding }); + }) + }); } - registerSyntaxDeclaration(term_1419) { - if ((0, _terms.isSyntaxDeclaration)(term_1419)) { - let scope = (0, _scope.freshScope)("nonrec"); - term_1419 = term_1419.extend({ declarators: term_1419.declarators.map(decl_1420 => { - let name_1421 = decl_1420.binding.name; - let nameAdded_1422 = name_1421.addScope(scope, this.context.bindings, _syntax.ALL_PHASES); - let nameRemoved_1423 = name_1421.removeScope(this.context.currentScope[this.context.currentScope.length - 1], this.context.phase); - let newBinding_1424 = (0, _symbol.gensym)(name_1421.val()); - this.context.bindings.addForward(nameAdded_1422, nameRemoved_1423, newBinding_1424, this.context.phase); - return decl_1420.extend({ init: decl_1420.init.addScope(scope, this.context.bindings, _syntax.ALL_PHASES) }); - }) }); + + registerSyntaxDeclaration(term) { + // syntax id^{a, b} = ^{a, b} + // -> + // syntaxrec id^{a,b,c} = function() { return <> } + // syntaxrec id^{a,b} = ^{a,b,c} + if (T.isSyntaxDeclaration(term)) { + let scope = (0, _scope.freshScope)('nonrec'); + term = term.extend({ + declarators: term.declarators.map(decl => { + let name = decl.binding.name; + let nameAdded = name.addScope(scope, this.context.bindings, _syntax.ALL_PHASES); + let nameRemoved = name.removeScope(this.context.currentScope[this.context.currentScope.length - 1], this.context.phase); + let newBinding = (0, _symbol.gensym)(name.val()); + this.context.bindings.addForward(nameAdded, nameRemoved, newBinding, this.context.phase); + return decl.extend({ + init: decl.init.addScope(scope, this.context.bindings, _syntax.ALL_PHASES) + }); + }) + }); } - return term_1419.extend({ declarators: term_1419.declarators.map(decl_1425 => { - let binding_1426 = decl_1425.binding.removeScope(this.context.useScope, this.context.phase); - let syntaxExpander_1427 = new _termExpander2.default(_.merge(this.context, { phase: this.context.phase + 1, env: new _env2.default(), store: this.context.store })); - let init_1428 = syntaxExpander_1427.expand(decl_1425.init); - let val_1429 = (0, _loadSyntax.evalCompiletimeValue)(init_1428.gen(), _.merge(this.context, { phase: this.context.phase + 1 })); - (0, _hygieneUtils.collectBindings)(binding_1426).forEach(stx_1430 => { - let newBinding_1431 = (0, _symbol.gensym)(stx_1430.val()); - this.context.bindings.add(stx_1430, { binding: newBinding_1431, phase: this.context.phase, skipDup: false }); - let resolvedName_1432 = stx_1430.resolve(this.context.phase); - this.context.env.set(resolvedName_1432, new _transforms.CompiletimeTransform(val_1429)); + + // for syntax declarations we need to load the compiletime value + // into the environment + return term.extend({ + declarators: term.declarators.map(decl => { + let binding = decl.binding.removeScope(this.context.useScope, this.context.phase); + // each compiletime value needs to be expanded with a fresh + // environment and in the next higher phase + let syntaxExpander = new _termExpander2.default(_.merge(this.context, { + phase: this.context.phase + 1, + env: new _env2.default(), + store: this.context.store + })); + let init = syntaxExpander.expand(decl.init); + let val = (0, _loadSyntax.evalCompiletimeValue)(init.gen(), _.merge(this.context, { + phase: this.context.phase + 1 + })); + (0, _hygieneUtils.collectBindings)(binding).forEach(stx => { + let newBinding = (0, _symbol.gensym)(stx.val()); + this.context.bindings.add(stx, { + binding: newBinding, + phase: this.context.phase, + skipDup: false + }); + let resolvedName = stx.resolve(this.context.phase); + this.context.env.set(resolvedName, new _transforms.CompiletimeTransform(val)); }); - return decl_1425.extend({ binding: binding_1426, init: init_1428 }); - }) }); + return decl.extend({ binding: binding, init: init }); + }) + }); } } exports.default = TokenExpander; -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../sweet/token-expander.js"],"names":[],"mappings":"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","file":"token-expander.js","sourcesContent":["import {List} from \"immutable\";\nimport {enforestExpr, Enforester} from \"./enforester\";\nimport TermExpander from \"./term-expander.js\";\nimport BindingMap from \"./binding-map.js\";\nimport Env from \"./env\";\nimport Reader from \"./shift-reader\";\nimport Term, {isEOF, isBindingIdentifier, isBindingPropertyProperty, isBindingPropertyIdentifier, isObjectBinding, isArrayBinding, isFunctionDeclaration, isFunctionExpression, isFunctionTerm, isFunctionWithName, isSyntaxDeclaration, isSyntaxrecDeclaration, isVariableDeclaration, isVariableDeclarationStatement, isImport, isExport, isExportFrom, isPragma, isExportSyntax, isClassDeclaration} from \"./terms\";\nimport {gensym} from \"./symbol\";\nimport {VarBindingTransform, CompiletimeTransform} from \"./transforms\";\nimport {expect, assert} from \"./errors\";\nimport {evalCompiletimeValue} from \"./load-syntax\";\nimport {Scope, freshScope} from \"./scope\";\nimport Syntax, {ALL_PHASES} from \"./syntax\";\nimport ASTDispatcher from \"./ast-dispatcher\";\nimport {collectBindings} from \"./hygiene-utils\";\nimport  * as _ from \"ramda\";\nfunction bindImports_1372(impTerm_1375, exModule_1376, context_1377) {\n  let names_1378 = [];\n  let phase_1379 = impTerm_1375.forSyntax ? context_1377.phase + 1 : context_1377.phase;\n  impTerm_1375.namedImports.forEach(specifier_1380 => {\n    let name_1381 = specifier_1380.binding.name;\n    let exportName_1382 = findNameInExports_1373(name_1381, exModule_1376.exportEntries);\n    if (exportName_1382 != null) {\n      let newBinding = gensym(name_1381.val());\n      context_1377.store.set(newBinding.toString(), new VarBindingTransform(name_1381));\n      context_1377.bindings.addForward(name_1381, exportName_1382, newBinding, phase_1379);\n      names_1378.push(name_1381);\n    }\n  });\n  return List(names_1378);\n}\nfunction findNameInExports_1373(name_1383, exp_1384) {\n  let foundNames_1385 = exp_1384.reduce((acc_1386, e_1387) => {\n    if (isExportFrom(e_1387)) {\n      return acc_1386.concat(e_1387.namedExports.reduce((acc_1388, specifier_1389) => {\n        if (specifier_1389.exportedName.val() === name_1383.val()) {\n          return acc_1388.concat(specifier_1389.exportedName);\n        }\n        return acc_1388;\n      }, List()));\n    } else if (isExport(e_1387)) {\n      return acc_1386.concat(e_1387.declaration.declarators.reduce((acc_1390, decl_1391) => {\n        if (decl_1391.binding.name.val() === name_1383.val()) {\n          return acc_1390.concat(decl_1391.binding.name);\n        }\n        return acc_1390;\n      }, List()));\n    }\n    return acc_1386;\n  }, List());\n  assert(foundNames_1385.size <= 1, \"expecting no more than 1 matching name in exports\");\n  return foundNames_1385.get(0);\n}\nfunction removeNames_1374(impTerm_1392, names_1393) {\n  let namedImports_1394 = impTerm_1392.namedImports.filter(specifier_1395 => !names_1393.contains(specifier_1395.binding.name));\n  return impTerm_1392.extend({namedImports: namedImports_1394});\n}\nexport default class TokenExpander extends ASTDispatcher {\n  constructor(context_1396) {\n    super(\"expand\", false);\n    this.context = context_1396;\n  }\n  expand(stxl_1397) {\n    let result_1398 = [];\n    if (stxl_1397.size === 0) {\n      return List(result_1398);\n    }\n    let prev_1399 = List();\n    let enf_1400 = new Enforester(stxl_1397, prev_1399, this.context);\n    while (!enf_1400.done) {\n      result_1398.push(this.dispatch(enf_1400.enforest()));\n    }\n    return List(result_1398);\n  }\n  expandVariableDeclarationStatement(term_1401) {\n    return term_1401.extend({declaration: this.registerVariableDeclaration(term_1401.declaration)});\n  }\n  expandFunctionDeclaration(term_1402) {\n    let registeredTerm_1403 = this.registerFunctionOrClass(term_1402);\n    let stx_1404 = registeredTerm_1403.name.name;\n    this.context.env.set(stx_1404.resolve(this.context.phase), new VarBindingTransform(stx_1404));\n    return registeredTerm_1403;\n  }\n  expandImport(term_1405) {\n    let path_1406 = term_1405.moduleSpecifier.val();\n    let mod_1407;\n    if (term_1405.forSyntax) {\n      mod_1407 = this.context.modules.getAtPhase(path_1406, this.context.phase + 1, this.context.cwd);\n      this.context.store = this.context.modules.visit(mod_1407, this.context.phase + 1, this.context.store);\n      this.context.store = this.context.modules.invoke(mod_1407, this.context.phase + 1, this.context.store);\n    } else {\n      mod_1407 = this.context.modules.getAtPhase(path_1406, this.context.phase, this.context.cwd);\n      this.context.store = this.context.modules.visit(mod_1407, this.context.phase, this.context.store);\n    }\n    let boundNames_1408 = bindImports_1372(term_1405, mod_1407, this.context);\n    return removeNames_1374(term_1405, boundNames_1408);\n  }\n  expandExport(term_1409) {\n    if (isFunctionDeclaration(term_1409.declaration) || isClassDeclaration(term_1409.declaration)) {\n      return term_1409.extend({declaration: this.registerFunctionOrClass(term_1409.declaration)});\n    } else if (isVariableDeclaration(term_1409.declaration)) {\n      return term_1409.extend({declaration: this.registerVariableDeclaration(term_1409.declaration)});\n    }\n    return term_1409;\n  }\n  registerFunctionOrClass(term_1410) {\n    let name_1411 = term_1410.name.removeScope(this.context.useScope, this.context.phase);\n    collectBindings(term_1410.name).forEach(stx_1412 => {\n      let newBinding_1413 = gensym(stx_1412.val());\n      this.context.bindings.add(stx_1412, {binding: newBinding_1413, phase: this.context.phase, skipDup: false});\n      this.context.env.set(newBinding_1413.toString(), new VarBindingTransform(stx_1412));\n    });\n    return term_1410.extend({name: name_1411});\n  }\n  registerVariableDeclaration(term_1414) {\n    if (isSyntaxDeclaration(term_1414) || isSyntaxrecDeclaration(term_1414)) {\n      return this.registerSyntaxDeclaration(term_1414);\n    }\n    return term_1414.extend({declarators: term_1414.declarators.map(decl_1415 => {\n      let binding_1416 = decl_1415.binding.removeScope(this.context.useScope, this.context.phase);\n      collectBindings(binding_1416).forEach(stx_1417 => {\n        let newBinding_1418 = gensym(stx_1417.val());\n        this.context.bindings.add(stx_1417, {binding: newBinding_1418, phase: this.context.phase, skipDup: term_1414.kind === \"var\"});\n        this.context.env.set(newBinding_1418.toString(), new VarBindingTransform(stx_1417));\n      });\n      return decl_1415.extend({binding: binding_1416});\n    })});\n  }\n  registerSyntaxDeclaration(term_1419) {\n    if (isSyntaxDeclaration(term_1419)) {\n      let scope = freshScope(\"nonrec\");\n      term_1419 = term_1419.extend({declarators: term_1419.declarators.map(decl_1420 => {\n        let name_1421 = decl_1420.binding.name;\n        let nameAdded_1422 = name_1421.addScope(scope, this.context.bindings, ALL_PHASES);\n        let nameRemoved_1423 = name_1421.removeScope(this.context.currentScope[this.context.currentScope.length - 1], this.context.phase);\n        let newBinding_1424 = gensym(name_1421.val());\n        this.context.bindings.addForward(nameAdded_1422, nameRemoved_1423, newBinding_1424, this.context.phase);\n        return decl_1420.extend({init: decl_1420.init.addScope(scope, this.context.bindings, ALL_PHASES)});\n      })});\n    }\n    return term_1419.extend({declarators: term_1419.declarators.map(decl_1425 => {\n      let binding_1426 = decl_1425.binding.removeScope(this.context.useScope, this.context.phase);\n      let syntaxExpander_1427 = new TermExpander(_.merge(this.context, {phase: this.context.phase + 1, env: new Env, store: this.context.store}));\n      let init_1428 = syntaxExpander_1427.expand(decl_1425.init);\n      let val_1429 = evalCompiletimeValue(init_1428.gen(), _.merge(this.context, {phase: this.context.phase + 1}));\n      collectBindings(binding_1426).forEach(stx_1430 => {\n        let newBinding_1431 = gensym(stx_1430.val());\n        this.context.bindings.add(stx_1430, {binding: newBinding_1431, phase: this.context.phase, skipDup: false});\n        let resolvedName_1432 = stx_1430.resolve(this.context.phase);\n        this.context.env.set(resolvedName_1432, new CompiletimeTransform(val_1429));\n      });\n      return decl_1425.extend({binding: binding_1426, init: init_1428});\n    })});\n  }\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/token-expander.js"],"names":[],"mappings":"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","file":"token-expander.js","sourcesContent":["import { List } from 'immutable';\nimport {  Enforester } from \"./enforester\";\nimport TermExpander from \"./term-expander.js\";\nimport Env from \"./env\";\nimport * as _ from \"ramda\";\nimport * as T from \"./terms\";\nimport { gensym } from './symbol';\nimport { VarBindingTransform, CompiletimeTransform } from './transforms';\nimport {  assert } from \"./errors\";\nimport { evalCompiletimeValue } from './load-syntax';\nimport {  freshScope } from \"./scope\";\nimport { ALL_PHASES } from './syntax';\nimport ASTDispatcher from './ast-dispatcher';\nimport { collectBindings } from './hygiene-utils';\n\nfunction bindImports(impTerm, exModule, context) {\n  let names = [];\n  let phase = impTerm.forSyntax ? context.phase + 1 : context.phase;\n  impTerm.namedImports.forEach(specifier => {\n    let name = specifier.binding.name;\n    let exportName = findNameInExports(name, exModule.exportEntries);\n    if (exportName != null) {\n      let newBinding = gensym(name.val());\n      context.store.set(newBinding.toString(), new VarBindingTransform(name));\n      context.bindings.addForward(name, exportName, newBinding, phase);\n      names.push(name);\n    }\n  });\n  return List(names);\n}\n\n\nfunction findNameInExports(name, exp) {\n  let foundNames = exp.reduce((acc, e) => {\n    if (T.isExportFrom(e)) {\n      return acc.concat(e.namedExports.reduce((acc, specifier) => {\n        if (specifier.exportedName.val() === name.val()) {\n          return acc.concat(specifier.exportedName);\n        }\n        return acc;\n      }, List()));\n    } else if (T.isExport(e)) {\n      return acc.concat(e.declaration.declarators.reduce((acc, decl) => {\n        if (decl.binding.name.val() === name.val()) {\n          return acc.concat(decl.binding.name);\n        }\n        return acc;\n      }, List()));\n    }\n    return acc;\n  }, List());\n  assert(foundNames.size <= 1, 'expecting no more than 1 matching name in exports');\n  return foundNames.get(0);\n}\n\nfunction removeNames(impTerm, names) {\n  let namedImports = impTerm.namedImports.filter(specifier => !names.contains(specifier.binding.name));\n  return impTerm.extend({ namedImports });\n}\n\n// function bindAllSyntaxExports(exModule, toSynth, context) {\n//   let phase = context.phase;\n//   exModule.exportEntries.forEach(ex => {\n//     if (isExportSyntax(ex)) {\n//       ex.declaration.declarators.forEach(decl => {\n//         let name = decl.binding.name;\n//         let newBinding = gensym(name.val());\n//         let storeName = exModule.moduleSpecifier + \":\" + name.val() + \":\" + phase;\n//         let synthStx = Syntax.fromIdentifier(name.val(), toSynth);\n//         let storeStx = Syntax.fromIdentifier(storeName, toSynth);\n//         context.bindings.addForward(synthStx, storeStx, newBinding, phase);\n//       });\n//     }\n//   });\n// }\n\nexport default class TokenExpander extends ASTDispatcher {\n  constructor(context) {\n    super('expand', false);\n    this.context = context;\n  }\n\n  expand(stxl) {\n    let result = [];\n    if (stxl.size === 0) {\n      return List(result);\n    }\n    let prev = List();\n    let enf = new Enforester(stxl, prev, this.context);\n\n    while(!enf.done) {\n      result.push(this.dispatch(enf.enforest()));\n    }\n\n    return List(result);\n  }\n\n  expandVariableDeclarationStatement(term) {\n    return term.extend({\n      declaration: this.registerVariableDeclaration(term.declaration)\n    });\n  }\n\n  expandFunctionDeclaration(term) {\n    let registeredTerm = this.registerFunctionOrClass(term);\n    let stx = registeredTerm.name.name;\n    this.context.env.set(stx.resolve(this.context.phase),\n                         new VarBindingTransform(stx));\n    return registeredTerm;\n  }\n\n  // TODO: think about function expressions\n\n  expandImport(term) {\n    let path = term.moduleSpecifier.val();\n    let mod;\n    if (term.forSyntax) {\n      mod = this.context.modules.getAtPhase(path, this.context.phase + 1, this.context.cwd);\n      this.context.store = this.context.modules.visit(mod, this.context.phase + 1, this.context.store);\n      this.context.store = this.context.modules.invoke(mod, this.context.phase + 1, this.context.store);\n    } else {\n      mod = this.context.modules.getAtPhase(path, this.context.phase, this.context.cwd);\n      this.context.store = this.context.modules.visit(mod, this.context.phase, this.context.store);\n    }\n    let boundNames = bindImports(term, mod, this.context);\n    return removeNames(term, boundNames);\n  }\n\n  expandExport(term) {\n    if (T.isFunctionDeclaration(term.declaration) || T.isClassDeclaration(term.declaration)) {\n      return term.extend({\n        declaration: this.registerFunctionOrClass(term.declaration)\n      });\n    } else if (T.isVariableDeclaration(term.declaration)) {\n      return term.extend({\n        declaration: this.registerVariableDeclaration(term.declaration)\n      });\n    }\n    return term;\n  }\n\n  // [isPragma, term => {\n  //   let pathStx = term.items.get(0);\n  //   if (pathStx.val() === 'base') {\n  //     return term;\n  //   }\n  //   let mod = this.context.modules.loadAndCompile(pathStx.val());\n  //   store = this.context.modules.visit(mod, phase, store);\n  //   bindAllSyntaxExports(mod, pathStx, this.context);\n  //   return term;\n  // }],\n\n\n  registerFunctionOrClass(term) {\n    let name = term.name.removeScope(this.context.useScope, this.context.phase);\n    collectBindings(term.name).forEach(stx => {\n      let newBinding = gensym(stx.val());\n      this.context.bindings.add(stx, {\n        binding: newBinding,\n        phase: this.context.phase,\n        skipDup: false\n      });\n      // the meaning of a function declaration name is a runtime var binding\n      this.context.env.set(newBinding.toString(), new VarBindingTransform(stx));\n    });\n    return term.extend({ name });\n  }\n\n  registerVariableDeclaration(term) {\n    if (T.isSyntaxDeclaration(term) || T.isSyntaxrecDeclaration(term)) {\n      return this.registerSyntaxDeclaration(term);\n    }\n    return term.extend({\n      declarators: term.declarators.map(decl => {\n        let binding = decl.binding.removeScope(this.context.useScope, this.context.phase);\n        collectBindings(binding).forEach(stx => {\n          let newBinding = gensym(stx.val());\n          this.context.bindings.add(stx, {\n            binding: newBinding,\n            phase: this.context.phase,\n            skipDup: term.kind === 'var'\n          });\n          // the meaning of a var/let/const declaration is a var binding\n          this.context.env.set(newBinding.toString(), new VarBindingTransform(stx));\n        });\n        return decl.extend({ binding });\n      })\n    });\n  }\n\n  registerSyntaxDeclaration(term) {\n    // syntax id^{a, b} = <init>^{a, b}\n    // ->\n    // syntaxrec id^{a,b,c} = function() { return <<id^{a}>> }\n    // syntaxrec id^{a,b} = <init>^{a,b,c}\n    if (T.isSyntaxDeclaration(term)) {\n      let scope = freshScope('nonrec');\n      term = term.extend({\n        declarators: term.declarators.map(decl => {\n          let name = decl.binding.name;\n          let nameAdded = name.addScope(scope, this.context.bindings, ALL_PHASES);\n          let nameRemoved = name.removeScope(this.context.currentScope[this.context.currentScope.length - 1], this.context.phase);\n          let newBinding = gensym(name.val());\n          this.context.bindings.addForward(nameAdded, nameRemoved, newBinding, this.context.phase);\n          return decl.extend({\n            init: decl.init.addScope(scope, this.context.bindings, ALL_PHASES)\n          });\n        })\n      });\n    }\n\n    // for syntax declarations we need to load the compiletime value\n    // into the environment\n    return term.extend({\n      declarators: term.declarators.map(decl => {\n        let binding = decl.binding.removeScope(this.context.useScope, this.context.phase);\n        // each compiletime value needs to be expanded with a fresh\n        // environment and in the next higher phase\n        let syntaxExpander = new TermExpander(_.merge(this.context, {\n          phase: this.context.phase + 1,\n          env: new Env(),\n          store: this.context.store\n        }));\n        let init = syntaxExpander.expand(decl.init);\n        let val = evalCompiletimeValue(init.gen(), _.merge(this.context, {\n          phase: this.context.phase + 1\n        }));\n        collectBindings(binding).forEach(stx => {\n          let newBinding = gensym(stx.val());\n          this.context.bindings.add(stx, {\n            binding: newBinding,\n            phase: this.context.phase,\n            skipDup: false\n          });\n          let resolvedName = stx.resolve(this.context.phase);\n          this.context.env.set(resolvedName, new CompiletimeTransform(val));\n        });\n        return decl.extend({ binding, init });\n      })\n    });\n  }\n}\n"]} \ No newline at end of file diff --git a/dist/transforms.js b/dist/transforms.js index 99a0b5c2..96034d4a 100644 --- a/dist/transforms.js +++ b/dist/transforms.js @@ -3,56 +3,56 @@ Object.defineProperty(exports, "__esModule", { value: true }); -class FunctionDeclTransform_1433 {} -class VariableDeclTransform_1434 {} -class NewTransform_1435 {} -class ThrowTransform_1436 {} -class LetDeclTransform_1437 {} -class ConstDeclTransform_1438 {} -class TryTransform_1439 {} -class WhileTransform_1440 {} -class IfTransform_1441 {} -class ForTransform_1442 {} -class SwitchTransform_1443 {} -class BreakTransform_1444 {} -class ContinueTransform_1445 {} -class DoTransform_1446 {} -class WithTransform_1447 {} -class DebuggerTransform_1448 {} -class SyntaxrecDeclTransform_1449 {} -class SyntaxDeclTransform_1450 {} -class SyntaxQuoteTransform_1451 {} -class ReturnStatementTransform_1452 {} -class VarBindingTransform_1453 { - constructor(id_1455) { - this.id = id_1455; +class FunctionDeclTransform {} +exports.FunctionDeclTransform = FunctionDeclTransform; +class VariableDeclTransform {} +exports.VariableDeclTransform = VariableDeclTransform; +class NewTransform {} +exports.NewTransform = NewTransform; +class ThrowTransform {} +exports.ThrowTransform = ThrowTransform; +class LetDeclTransform {} +exports.LetDeclTransform = LetDeclTransform; +class ConstDeclTransform {} +exports.ConstDeclTransform = ConstDeclTransform; +class TryTransform {} +exports.TryTransform = TryTransform; +class WhileTransform {} +exports.WhileTransform = WhileTransform; +class IfTransform {} +exports.IfTransform = IfTransform; +class ForTransform {} +exports.ForTransform = ForTransform; +class SwitchTransform {} +exports.SwitchTransform = SwitchTransform; +class BreakTransform {} +exports.BreakTransform = BreakTransform; +class ContinueTransform {} +exports.ContinueTransform = ContinueTransform; +class DoTransform {} +exports.DoTransform = DoTransform; +class WithTransform {} +exports.WithTransform = WithTransform; +class DebuggerTransform {} +exports.DebuggerTransform = DebuggerTransform; +class SyntaxrecDeclTransform {} +exports.SyntaxrecDeclTransform = SyntaxrecDeclTransform; +class SyntaxDeclTransform {} +exports.SyntaxDeclTransform = SyntaxDeclTransform; +class SyntaxQuoteTransform {} +exports.SyntaxQuoteTransform = SyntaxQuoteTransform; +class ReturnStatementTransform {} +exports.ReturnStatementTransform = ReturnStatementTransform; +class VarBindingTransform { + constructor(id) { + this.id = id; } } -class CompiletimeTransform_1454 { - constructor(value_1456) { - this.value = value_1456; +exports.VarBindingTransform = VarBindingTransform; +class CompiletimeTransform { + constructor(value) { + this.value = value; } } -exports.FunctionDeclTransform = FunctionDeclTransform_1433; -exports.VariableDeclTransform = VariableDeclTransform_1434; -exports.NewTransform = NewTransform_1435; -exports.ThrowTransform = ThrowTransform_1436; -exports.LetDeclTransform = LetDeclTransform_1437; -exports.ConstDeclTransform = ConstDeclTransform_1438; -exports.TryTransform = TryTransform_1439; -exports.WhileTransform = WhileTransform_1440; -exports.IfTransform = IfTransform_1441; -exports.ForTransform = ForTransform_1442; -exports.SwitchTransform = SwitchTransform_1443; -exports.BreakTransform = BreakTransform_1444; -exports.ContinueTransform = ContinueTransform_1445; -exports.DoTransform = DoTransform_1446; -exports.WithTransform = WithTransform_1447; -exports.DebuggerTransform = DebuggerTransform_1448; -exports.SyntaxrecDeclTransform = SyntaxrecDeclTransform_1449; -exports.SyntaxDeclTransform = SyntaxDeclTransform_1450; -exports.SyntaxQuoteTransform = SyntaxQuoteTransform_1451; -exports.ReturnStatementTransform = ReturnStatementTransform_1452; -exports.VarBindingTransform = VarBindingTransform_1453; -exports.CompiletimeTransform = CompiletimeTransform_1454; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L3RyYW5zZm9ybXMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxNQUFNLDBCQUFOLENBQWlDO0FBQ2pDLE1BQU0sMEJBQU4sQ0FBaUM7QUFDakMsTUFBTSxpQkFBTixDQUF3QjtBQUN4QixNQUFNLG1CQUFOLENBQTBCO0FBQzFCLE1BQU0scUJBQU4sQ0FBNEI7QUFDNUIsTUFBTSx1QkFBTixDQUE4QjtBQUM5QixNQUFNLGlCQUFOLENBQXdCO0FBQ3hCLE1BQU0sbUJBQU4sQ0FBMEI7QUFDMUIsTUFBTSxnQkFBTixDQUF1QjtBQUN2QixNQUFNLGlCQUFOLENBQXdCO0FBQ3hCLE1BQU0sb0JBQU4sQ0FBMkI7QUFDM0IsTUFBTSxtQkFBTixDQUEwQjtBQUMxQixNQUFNLHNCQUFOLENBQTZCO0FBQzdCLE1BQU0sZ0JBQU4sQ0FBdUI7QUFDdkIsTUFBTSxrQkFBTixDQUF5QjtBQUN6QixNQUFNLHNCQUFOLENBQTZCO0FBQzdCLE1BQU0sMkJBQU4sQ0FBa0M7QUFDbEMsTUFBTSx3QkFBTixDQUErQjtBQUMvQixNQUFNLHlCQUFOLENBQWdDO0FBQ2hDLE1BQU0sNkJBQU4sQ0FBb0M7QUFDcEMsTUFBTSx3QkFBTixDQUErQjtBQUM3QixjQUFZLE9BQVosRUFBcUI7QUFDbkIsU0FBSyxFQUFMLEdBQVUsT0FBVjtBQUNEO0FBSDRCO0FBSy9CLE1BQU0seUJBQU4sQ0FBZ0M7QUFDOUIsY0FBWSxVQUFaLEVBQXdCO0FBQ3RCLFNBQUssS0FBTCxHQUFhLFVBQWI7QUFDRDtBQUg2QjtRQUtNLHFCLEdBQTlCLDBCO1FBQzhCLHFCLEdBQTlCLDBCO1FBQ3FCLFksR0FBckIsaUI7UUFDdUIsYyxHQUF2QixtQjtRQUN5QixnQixHQUF6QixxQjtRQUMyQixrQixHQUEzQix1QjtRQUNxQixZLEdBQXJCLGlCO1FBQ3VCLGMsR0FBdkIsbUI7UUFDb0IsVyxHQUFwQixnQjtRQUNxQixZLEdBQXJCLGlCO1FBQ3dCLGUsR0FBeEIsb0I7UUFDdUIsYyxHQUF2QixtQjtRQUMwQixpQixHQUExQixzQjtRQUNvQixXLEdBQXBCLGdCO1FBQ3NCLGEsR0FBdEIsa0I7UUFDMEIsaUIsR0FBMUIsc0I7UUFDK0Isc0IsR0FBL0IsMkI7UUFDNEIsbUIsR0FBNUIsd0I7UUFDNkIsb0IsR0FBN0IseUI7UUFDaUMsd0IsR0FBakMsNkI7UUFDNEIsbUIsR0FBNUIsd0I7UUFDNkIsb0IsR0FBN0IseUIiLCJmaWxlIjoidHJhbnNmb3Jtcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImNsYXNzIEZ1bmN0aW9uRGVjbFRyYW5zZm9ybV8xNDMzIHt9XG5jbGFzcyBWYXJpYWJsZURlY2xUcmFuc2Zvcm1fMTQzNCB7fVxuY2xhc3MgTmV3VHJhbnNmb3JtXzE0MzUge31cbmNsYXNzIFRocm93VHJhbnNmb3JtXzE0MzYge31cbmNsYXNzIExldERlY2xUcmFuc2Zvcm1fMTQzNyB7fVxuY2xhc3MgQ29uc3REZWNsVHJhbnNmb3JtXzE0Mzgge31cbmNsYXNzIFRyeVRyYW5zZm9ybV8xNDM5IHt9XG5jbGFzcyBXaGlsZVRyYW5zZm9ybV8xNDQwIHt9XG5jbGFzcyBJZlRyYW5zZm9ybV8xNDQxIHt9XG5jbGFzcyBGb3JUcmFuc2Zvcm1fMTQ0MiB7fVxuY2xhc3MgU3dpdGNoVHJhbnNmb3JtXzE0NDMge31cbmNsYXNzIEJyZWFrVHJhbnNmb3JtXzE0NDQge31cbmNsYXNzIENvbnRpbnVlVHJhbnNmb3JtXzE0NDUge31cbmNsYXNzIERvVHJhbnNmb3JtXzE0NDYge31cbmNsYXNzIFdpdGhUcmFuc2Zvcm1fMTQ0NyB7fVxuY2xhc3MgRGVidWdnZXJUcmFuc2Zvcm1fMTQ0OCB7fVxuY2xhc3MgU3ludGF4cmVjRGVjbFRyYW5zZm9ybV8xNDQ5IHt9XG5jbGFzcyBTeW50YXhEZWNsVHJhbnNmb3JtXzE0NTAge31cbmNsYXNzIFN5bnRheFF1b3RlVHJhbnNmb3JtXzE0NTEge31cbmNsYXNzIFJldHVyblN0YXRlbWVudFRyYW5zZm9ybV8xNDUyIHt9XG5jbGFzcyBWYXJCaW5kaW5nVHJhbnNmb3JtXzE0NTMge1xuICBjb25zdHJ1Y3RvcihpZF8xNDU1KSB7XG4gICAgdGhpcy5pZCA9IGlkXzE0NTU7XG4gIH1cbn1cbmNsYXNzIENvbXBpbGV0aW1lVHJhbnNmb3JtXzE0NTQge1xuICBjb25zdHJ1Y3Rvcih2YWx1ZV8xNDU2KSB7XG4gICAgdGhpcy52YWx1ZSA9IHZhbHVlXzE0NTY7XG4gIH1cbn1cbmV4cG9ydCB7RnVuY3Rpb25EZWNsVHJhbnNmb3JtXzE0MzMgYXMgRnVuY3Rpb25EZWNsVHJhbnNmb3JtfTtcbmV4cG9ydCB7VmFyaWFibGVEZWNsVHJhbnNmb3JtXzE0MzQgYXMgVmFyaWFibGVEZWNsVHJhbnNmb3JtfTtcbmV4cG9ydCB7TmV3VHJhbnNmb3JtXzE0MzUgYXMgTmV3VHJhbnNmb3JtfTtcbmV4cG9ydCB7VGhyb3dUcmFuc2Zvcm1fMTQzNiBhcyBUaHJvd1RyYW5zZm9ybX07XG5leHBvcnQge0xldERlY2xUcmFuc2Zvcm1fMTQzNyBhcyBMZXREZWNsVHJhbnNmb3JtfTtcbmV4cG9ydCB7Q29uc3REZWNsVHJhbnNmb3JtXzE0MzggYXMgQ29uc3REZWNsVHJhbnNmb3JtfTtcbmV4cG9ydCB7VHJ5VHJhbnNmb3JtXzE0MzkgYXMgVHJ5VHJhbnNmb3JtfTtcbmV4cG9ydCB7V2hpbGVUcmFuc2Zvcm1fMTQ0MCBhcyBXaGlsZVRyYW5zZm9ybX07XG5leHBvcnQge0lmVHJhbnNmb3JtXzE0NDEgYXMgSWZUcmFuc2Zvcm19O1xuZXhwb3J0IHtGb3JUcmFuc2Zvcm1fMTQ0MiBhcyBGb3JUcmFuc2Zvcm19O1xuZXhwb3J0IHtTd2l0Y2hUcmFuc2Zvcm1fMTQ0MyBhcyBTd2l0Y2hUcmFuc2Zvcm19O1xuZXhwb3J0IHtCcmVha1RyYW5zZm9ybV8xNDQ0IGFzIEJyZWFrVHJhbnNmb3JtfTtcbmV4cG9ydCB7Q29udGludWVUcmFuc2Zvcm1fMTQ0NSBhcyBDb250aW51ZVRyYW5zZm9ybX07XG5leHBvcnQge0RvVHJhbnNmb3JtXzE0NDYgYXMgRG9UcmFuc2Zvcm19O1xuZXhwb3J0IHtXaXRoVHJhbnNmb3JtXzE0NDcgYXMgV2l0aFRyYW5zZm9ybX07XG5leHBvcnQge0RlYnVnZ2VyVHJhbnNmb3JtXzE0NDggYXMgRGVidWdnZXJUcmFuc2Zvcm19O1xuZXhwb3J0IHtTeW50YXhyZWNEZWNsVHJhbnNmb3JtXzE0NDkgYXMgU3ludGF4cmVjRGVjbFRyYW5zZm9ybX07XG5leHBvcnQge1N5bnRheERlY2xUcmFuc2Zvcm1fMTQ1MCBhcyBTeW50YXhEZWNsVHJhbnNmb3JtfTtcbmV4cG9ydCB7U3ludGF4UXVvdGVUcmFuc2Zvcm1fMTQ1MSBhcyBTeW50YXhRdW90ZVRyYW5zZm9ybX07XG5leHBvcnQge1JldHVyblN0YXRlbWVudFRyYW5zZm9ybV8xNDUyIGFzIFJldHVyblN0YXRlbWVudFRyYW5zZm9ybX07XG5leHBvcnQge1ZhckJpbmRpbmdUcmFuc2Zvcm1fMTQ1MyBhcyBWYXJCaW5kaW5nVHJhbnNmb3JtfTtcbmV4cG9ydCB7Q29tcGlsZXRpbWVUcmFuc2Zvcm1fMTQ1NCBhcyBDb21waWxldGltZVRyYW5zZm9ybX0iXX0= \ No newline at end of file +exports.CompiletimeTransform = CompiletimeTransform; +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90cmFuc2Zvcm1zLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQU8sTUFBTSxxQkFBTixDQUE0QjtRQUF0QixxQixHQUFBLHFCO0FBQ04sTUFBTSxxQkFBTixDQUE0QjtRQUF0QixxQixHQUFBLHFCO0FBQ04sTUFBTSxZQUFOLENBQW1CO1FBQWIsWSxHQUFBLFk7QUFDTixNQUFNLGNBQU4sQ0FBcUI7UUFBZixjLEdBQUEsYztBQUNOLE1BQU0sZ0JBQU4sQ0FBdUI7UUFBakIsZ0IsR0FBQSxnQjtBQUNOLE1BQU0sa0JBQU4sQ0FBeUI7UUFBbkIsa0IsR0FBQSxrQjtBQUNOLE1BQU0sWUFBTixDQUFtQjtRQUFiLFksR0FBQSxZO0FBQ04sTUFBTSxjQUFOLENBQXFCO1FBQWYsYyxHQUFBLGM7QUFDTixNQUFNLFdBQU4sQ0FBa0I7UUFBWixXLEdBQUEsVztBQUNOLE1BQU0sWUFBTixDQUFtQjtRQUFiLFksR0FBQSxZO0FBQ04sTUFBTSxlQUFOLENBQXNCO1FBQWhCLGUsR0FBQSxlO0FBQ04sTUFBTSxjQUFOLENBQXFCO1FBQWYsYyxHQUFBLGM7QUFDTixNQUFNLGlCQUFOLENBQXdCO1FBQWxCLGlCLEdBQUEsaUI7QUFDTixNQUFNLFdBQU4sQ0FBa0I7UUFBWixXLEdBQUEsVztBQUNOLE1BQU0sYUFBTixDQUFvQjtRQUFkLGEsR0FBQSxhO0FBQ04sTUFBTSxpQkFBTixDQUF3QjtRQUFsQixpQixHQUFBLGlCO0FBQ04sTUFBTSxzQkFBTixDQUE2QjtRQUF2QixzQixHQUFBLHNCO0FBQ04sTUFBTSxtQkFBTixDQUEwQjtRQUFwQixtQixHQUFBLG1CO0FBQ04sTUFBTSxvQkFBTixDQUEyQjtRQUFyQixvQixHQUFBLG9CO0FBQ04sTUFBTSx3QkFBTixDQUErQjtRQUF6Qix3QixHQUFBLHdCO0FBQ04sTUFBTSxtQkFBTixDQUEwQjtBQUMvQixjQUFZLEVBQVosRUFBZ0I7QUFDZCxTQUFLLEVBQUwsR0FBVSxFQUFWO0FBQ0Q7QUFIOEI7UUFBcEIsbUIsR0FBQSxtQjtBQUtOLE1BQU0sb0JBQU4sQ0FBMkI7QUFDaEMsY0FBWSxLQUFaLEVBQW1CO0FBQ2pCLFNBQUssS0FBTCxHQUFhLEtBQWI7QUFDRDtBQUgrQjtRQUFyQixvQixHQUFBLG9CIiwiZmlsZSI6InRyYW5zZm9ybXMuanMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgRnVuY3Rpb25EZWNsVHJhbnNmb3JtIHsgfVxuZXhwb3J0IGNsYXNzIFZhcmlhYmxlRGVjbFRyYW5zZm9ybSB7IH1cbmV4cG9ydCBjbGFzcyBOZXdUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgVGhyb3dUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgTGV0RGVjbFRyYW5zZm9ybSB7IH1cbmV4cG9ydCBjbGFzcyBDb25zdERlY2xUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgVHJ5VHJhbnNmb3JtIHsgfVxuZXhwb3J0IGNsYXNzIFdoaWxlVHJhbnNmb3JtIHsgfVxuZXhwb3J0IGNsYXNzIElmVHJhbnNmb3JtIHsgfVxuZXhwb3J0IGNsYXNzIEZvclRyYW5zZm9ybSB7IH1cbmV4cG9ydCBjbGFzcyBTd2l0Y2hUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgQnJlYWtUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgQ29udGludWVUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgRG9UcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgV2l0aFRyYW5zZm9ybSB7IH1cbmV4cG9ydCBjbGFzcyBEZWJ1Z2dlclRyYW5zZm9ybSB7IH1cbmV4cG9ydCBjbGFzcyBTeW50YXhyZWNEZWNsVHJhbnNmb3JtIHsgfVxuZXhwb3J0IGNsYXNzIFN5bnRheERlY2xUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgU3ludGF4UXVvdGVUcmFuc2Zvcm0geyB9XG5leHBvcnQgY2xhc3MgUmV0dXJuU3RhdGVtZW50VHJhbnNmb3JtIHsgfVxuZXhwb3J0IGNsYXNzIFZhckJpbmRpbmdUcmFuc2Zvcm0ge1xuICBjb25zdHJ1Y3RvcihpZCkge1xuICAgIHRoaXMuaWQgPSBpZDtcbiAgfVxufVxuZXhwb3J0IGNsYXNzIENvbXBpbGV0aW1lVHJhbnNmb3JtIHtcbiAgY29uc3RydWN0b3IodmFsdWUpIHtcbiAgICB0aGlzLnZhbHVlID0gdmFsdWU7XG4gIH1cbn1cbiJdfQ== \ No newline at end of file diff --git a/dist/utils.js b/dist/utils.js index 19c170a1..3350a22f 100644 --- a/dist/utils.js +++ b/dist/utils.js @@ -3,15 +3,16 @@ Object.defineProperty(exports, "__esModule", { value: true }); -function mixin_1457(target_1458, source_1459) { - class F extends target_1458 {} - Object.getOwnPropertyNames(source_1459.prototype).forEach(name_1460 => { - if (name_1460 !== "constructor") { - let newProp = Object.getOwnPropertyDescriptor(source_1459.prototype, name_1460); - Object.defineProperty(F.prototype, name_1460, newProp); +exports.mixin = mixin; +function mixin(target, source) { + class F extends target {} + + Object.getOwnPropertyNames(source.prototype).forEach(name => { + if (name !== "constructor") { + let newProp = Object.getOwnPropertyDescriptor(source.prototype, name); + Object.defineProperty(F.prototype, name, newProp); } }); return F; } -exports.mixin = mixin_1457; -//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3N3ZWV0L3V0aWxzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsU0FBUyxVQUFULENBQW9CLFdBQXBCLEVBQWlDLFdBQWpDLEVBQThDO0FBQzVDLFFBQU0sQ0FBTixTQUFnQixXQUFoQixDQUE0QjtBQUM1QixTQUFPLG1CQUFQLENBQTJCLFlBQVksU0FBdkMsRUFBa0QsT0FBbEQsQ0FBMEQsYUFBYTtBQUNyRSxRQUFJLGNBQWMsYUFBbEIsRUFBaUM7QUFDL0IsVUFBSSxVQUFVLE9BQU8sd0JBQVAsQ0FBZ0MsWUFBWSxTQUE1QyxFQUF1RCxTQUF2RCxDQUFkO0FBQ0EsYUFBTyxjQUFQLENBQXNCLEVBQUUsU0FBeEIsRUFBbUMsU0FBbkMsRUFBOEMsT0FBOUM7QUFDRDtBQUNGLEdBTEQ7QUFNQSxTQUFPLENBQVA7QUFDRDtRQUNxQixLLEdBQWQsVSIsImZpbGUiOiJ1dGlscy5qcyIsInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIG1peGluXzE0NTcodGFyZ2V0XzE0NTgsIHNvdXJjZV8xNDU5KSB7XG4gIGNsYXNzIEYgZXh0ZW5kcyB0YXJnZXRfMTQ1OCB7fVxuICBPYmplY3QuZ2V0T3duUHJvcGVydHlOYW1lcyhzb3VyY2VfMTQ1OS5wcm90b3R5cGUpLmZvckVhY2gobmFtZV8xNDYwID0+IHtcbiAgICBpZiAobmFtZV8xNDYwICE9PSBcImNvbnN0cnVjdG9yXCIpIHtcbiAgICAgIGxldCBuZXdQcm9wID0gT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcihzb3VyY2VfMTQ1OS5wcm90b3R5cGUsIG5hbWVfMTQ2MCk7XG4gICAgICBPYmplY3QuZGVmaW5lUHJvcGVydHkoRi5wcm90b3R5cGUsIG5hbWVfMTQ2MCwgbmV3UHJvcCk7XG4gICAgfVxuICB9KTtcbiAgcmV0dXJuIEY7XG59XG5leHBvcnQge21peGluXzE0NTcgYXMgbWl4aW59Il19 \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztRQUFnQixLLEdBQUEsSztBQUFULFNBQVMsS0FBVCxDQUFlLE1BQWYsRUFBdUIsTUFBdkIsRUFBK0I7QUFDcEMsUUFBTSxDQUFOLFNBQWdCLE1BQWhCLENBQXVCOztBQUd2QixTQUFPLG1CQUFQLENBQTJCLE9BQU8sU0FBbEMsRUFBNkMsT0FBN0MsQ0FBcUQsUUFBUTtBQUMzRCxRQUFJLFNBQVMsYUFBYixFQUE0QjtBQUMxQixVQUFJLFVBQVUsT0FBTyx3QkFBUCxDQUFnQyxPQUFPLFNBQXZDLEVBQWtELElBQWxELENBQWQ7QUFDQSxhQUFPLGNBQVAsQ0FBc0IsRUFBRSxTQUF4QixFQUFtQyxJQUFuQyxFQUF5QyxPQUF6QztBQUNEO0FBQ0YsR0FMRDtBQU1BLFNBQU8sQ0FBUDtBQUNEIiwiZmlsZSI6InV0aWxzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIG1peGluKHRhcmdldCwgc291cmNlKSB7XG4gIGNsYXNzIEYgZXh0ZW5kcyB0YXJnZXQge1xuICB9XG5cbiAgT2JqZWN0LmdldE93blByb3BlcnR5TmFtZXMoc291cmNlLnByb3RvdHlwZSkuZm9yRWFjaChuYW1lID0+IHtcbiAgICBpZiAobmFtZSAhPT0gXCJjb25zdHJ1Y3RvclwiKSB7XG4gICAgICBsZXQgbmV3UHJvcCA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Ioc291cmNlLnByb3RvdHlwZSwgbmFtZSk7XG4gICAgICBPYmplY3QuZGVmaW5lUHJvcGVydHkoRi5wcm90b3R5cGUsIG5hbWUsIG5ld1Byb3ApO1xuICAgIH1cbiAgfSk7XG4gIHJldHVybiBGO1xufVxuIl19 \ No newline at end of file diff --git a/package.json b/package.json index ab5df4eb..c9dae427 100644 --- a/package.json +++ b/package.json @@ -5,7 +5,7 @@ "bin": { "sjs": "bin/sjs" }, - "version": "2.2.0", + "version": "2.2.1", "engines": { "node": ">5.0.0" },