gemi 0.4.93 → 0.4.95

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (131) hide show
  1. package/dist/app/App.d.ts +2 -11
  2. package/dist/app/App.d.ts.map +1 -1
  3. package/dist/app/index.js +3 -1
  4. package/dist/app/index.js.map +13 -0
  5. package/dist/auth/AuthenticationServiceContainer.d.ts +3 -1
  6. package/dist/auth/AuthenticationServiceContainer.d.ts.map +1 -1
  7. package/dist/auth/AuthenticationServiceProvider.d.ts +3 -5
  8. package/dist/auth/AuthenticationServiceProvider.d.ts.map +1 -1
  9. package/dist/bin/index.js +3 -0
  10. package/dist/broadcasting/index.js +3 -1
  11. package/dist/broadcasting/index.js.map +10 -0
  12. package/dist/{chunk-d09948245f5b426d.js → chunk-07f44e411ae4ea5e.js} +3 -1
  13. package/dist/chunk-07f44e411ae4ea5e.js.map +11 -0
  14. package/dist/{chunk-7ce930fe69575c87.js → chunk-0d97333b6af9fc45.js} +3 -1
  15. package/dist/chunk-0d97333b6af9fc45.js.map +9 -0
  16. package/dist/{chunk-e76c7e3bf2d698af.js → chunk-11de5b0adccef35c.js} +3 -1
  17. package/dist/chunk-11de5b0adccef35c.js.map +17 -0
  18. package/dist/{chunk-1770e9abf10029e0.js → chunk-18a59fffad60f059.js} +3 -1
  19. package/dist/chunk-18a59fffad60f059.js.map +12 -0
  20. package/dist/{chunk-8fec55214eb03a61.js → chunk-201c5005a90452fa.js} +4 -2
  21. package/dist/chunk-201c5005a90452fa.js.map +11 -0
  22. package/dist/{chunk-cfb8c5b12b0e5378.js → chunk-23d3df5f8342ecc6.js} +4 -2
  23. package/dist/chunk-23d3df5f8342ecc6.js.map +54 -0
  24. package/dist/chunk-278677330e53423b.js +4 -0
  25. package/dist/chunk-278677330e53423b.js.map +26 -0
  26. package/dist/{chunk-e1929f0f7003fbdf.js → chunk-28ec4c2b20e69deb.js} +4 -2
  27. package/dist/chunk-28ec4c2b20e69deb.js.map +10 -0
  28. package/dist/chunk-2f8cf8372320b622.js +4 -0
  29. package/dist/chunk-2f8cf8372320b622.js.map +11 -0
  30. package/dist/{chunk-ef791082443c0cbd.js → chunk-53b0fab00d83f47e.js} +3 -1
  31. package/dist/chunk-53b0fab00d83f47e.js.map +13 -0
  32. package/dist/chunk-57ba59dd008d6e0e.js +4 -0
  33. package/dist/chunk-57ba59dd008d6e0e.js.map +32 -0
  34. package/dist/chunk-642b04056dab5d64.js +4 -0
  35. package/dist/chunk-642b04056dab5d64.js.map +11 -0
  36. package/dist/{chunk-dfb863d471bf3b18.js → chunk-643529c2ad120db7.js} +4 -2
  37. package/dist/chunk-643529c2ad120db7.js.map +50 -0
  38. package/dist/{chunk-b6fb088270ea6584.js → chunk-683905a55f8da1ad.js} +4 -2
  39. package/dist/chunk-683905a55f8da1ad.js.map +64 -0
  40. package/dist/{chunk-035e233acf299392.js → chunk-90436b32a64fc784.js} +4 -2
  41. package/dist/chunk-90436b32a64fc784.js.map +53 -0
  42. package/dist/chunk-99c32e4d937131e0.js +4 -0
  43. package/dist/chunk-99c32e4d937131e0.js.map +10 -0
  44. package/dist/{chunk-d7525516b1305ba3.js → chunk-9be25fac5f76b2f7.js} +3 -1
  45. package/dist/chunk-9be25fac5f76b2f7.js.map +13 -0
  46. package/dist/{chunk-f10ba402aaacfc12.js → chunk-9f9e21f9fd0d6af1.js} +4 -2
  47. package/dist/chunk-9f9e21f9fd0d6af1.js.map +10 -0
  48. package/dist/chunk-9ff3d7096b6de8eb.js +4 -0
  49. package/dist/chunk-9ff3d7096b6de8eb.js.map +22 -0
  50. package/dist/{chunk-cfbe2cbcadcb1ac1.js → chunk-a7d87b5d6d789781.js} +3 -1
  51. package/dist/chunk-a7d87b5d6d789781.js.map +23 -0
  52. package/dist/chunk-b84d011a2972c7d1.js +4 -0
  53. package/dist/chunk-b84d011a2972c7d1.js.map +10 -0
  54. package/dist/{chunk-2f8839f406606d63.js → chunk-bace428bfab523c4.js} +3 -1
  55. package/dist/chunk-bace428bfab523c4.js.map +23 -0
  56. package/dist/{chunk-494de321e3423d54.js → chunk-bd708d3c982948aa.js} +4 -2
  57. package/dist/chunk-bd708d3c982948aa.js.map +16 -0
  58. package/dist/{chunk-496c32676431beab.js → chunk-c8c4a1285a266c51.js} +4 -2
  59. package/dist/chunk-c8c4a1285a266c51.js.map +169 -0
  60. package/dist/{chunk-eabfa03c809e14df.js → chunk-cd4bfdd46ec4cbb8.js} +4 -2
  61. package/dist/chunk-cd4bfdd46ec4cbb8.js.map +10 -0
  62. package/dist/{chunk-0f0add364d3ea615.js → chunk-cd9c5e8a6c80384f.js} +3 -1
  63. package/dist/chunk-cd9c5e8a6c80384f.js.map +20 -0
  64. package/dist/{chunk-04f04986e53516f0.js → chunk-d5b8023c223e3a60.js} +3 -1
  65. package/dist/chunk-d5b8023c223e3a60.js.map +10 -0
  66. package/dist/chunk-e4961d79807acd3d.js +4 -0
  67. package/dist/chunk-e4961d79807acd3d.js.map +33 -0
  68. package/dist/client/ClientRouterContext.d.ts.map +1 -1
  69. package/dist/client/HttpReload.d.ts.map +1 -1
  70. package/dist/email/index.js +3 -1
  71. package/dist/email/index.js.map +11 -0
  72. package/dist/facades/Auth.d.ts.map +1 -1
  73. package/dist/facades/Broadcast.d.ts.map +1 -1
  74. package/dist/facades/FileStorage.d.ts.map +1 -1
  75. package/dist/facades/I18n.d.ts.map +1 -1
  76. package/dist/facades/Prefetch.d.ts.map +1 -1
  77. package/dist/facades/index.js +3 -1
  78. package/dist/facades/index.js.map +28 -0
  79. package/dist/http/AuthenticationMiddlware.d.ts.map +1 -1
  80. package/dist/http/I18nServiceContainer.d.ts +6 -9
  81. package/dist/http/I18nServiceContainer.d.ts.map +1 -1
  82. package/dist/http/I18nServiceProvider.d.ts +3 -1
  83. package/dist/http/I18nServiceProvider.d.ts.map +1 -1
  84. package/dist/http/MiddlewareServiceProvider.d.ts +3 -1
  85. package/dist/http/MiddlewareServiceProvider.d.ts.map +1 -1
  86. package/dist/http/RateLimitMiddleware.d.ts.map +1 -1
  87. package/dist/http/index.js +3 -1
  88. package/dist/http/index.js.map +29 -0
  89. package/dist/kernel/Kernel.d.ts +4 -32
  90. package/dist/kernel/Kernel.d.ts.map +1 -1
  91. package/dist/kernel/KernelContext.d.ts +1 -1
  92. package/dist/kernel/KernelContext.d.ts.map +1 -1
  93. package/dist/kernel/context.d.ts +1 -21
  94. package/dist/kernel/context.d.ts.map +1 -1
  95. package/dist/kernel/index.js +3 -1
  96. package/dist/kernel/index.js.map +11 -0
  97. package/dist/server/index.js +6 -4
  98. package/dist/server/index.js.map +17 -0
  99. package/dist/services/ServiceContainer.d.ts +2 -2
  100. package/dist/services/ServiceContainer.d.ts.map +1 -1
  101. package/dist/services/email/EmailServiceContainer.d.ts +1 -1
  102. package/dist/services/email/EmailServiceContainer.d.ts.map +1 -1
  103. package/dist/services/file-storage/FileStorageServiceContainer.d.ts +3 -1
  104. package/dist/services/file-storage/FileStorageServiceContainer.d.ts.map +1 -1
  105. package/dist/services/file-storage/FileStorageServiceProvider.d.ts +3 -1
  106. package/dist/services/file-storage/FileStorageServiceProvider.d.ts.map +1 -1
  107. package/dist/services/index.d.ts +2 -0
  108. package/dist/services/index.d.ts.map +1 -1
  109. package/dist/services/index.js +12 -1
  110. package/dist/services/index.js.map +121 -0
  111. package/dist/services/middleware/MiddlewareServiceContainer.d.ts +3 -1
  112. package/dist/services/middleware/MiddlewareServiceContainer.d.ts.map +1 -1
  113. package/dist/services/rate-limiter/RateLimiterServiceContainer.d.ts +3 -1
  114. package/dist/services/rate-limiter/RateLimiterServiceContainer.d.ts.map +1 -1
  115. package/dist/services/rate-limiter/RateLimiterServiceProvider.d.ts +3 -1
  116. package/dist/services/rate-limiter/RateLimiterServiceProvider.d.ts.map +1 -1
  117. package/dist/services/router/ApiRouterServiceContainer.d.ts +5 -1
  118. package/dist/services/router/ApiRouterServiceContainer.d.ts.map +1 -1
  119. package/dist/services/router/ApiRouterServiceProvider.d.ts +3 -4
  120. package/dist/services/router/ApiRouterServiceProvider.d.ts.map +1 -1
  121. package/dist/services/router/ViewRouterServiceContainer.d.ts +11 -1
  122. package/dist/services/router/ViewRouterServiceContainer.d.ts.map +1 -1
  123. package/dist/services/router/ViewRouterServiceProvider.d.ts +4 -9
  124. package/dist/services/router/ViewRouterServiceProvider.d.ts.map +1 -1
  125. package/package.json +2 -2
  126. package/dist/chunk-0fd23409fff0376b.js +0 -2
  127. package/dist/chunk-2573b2361de4a370.js +0 -2
  128. package/dist/chunk-33abc8f4f7df6791.js +0 -2
  129. package/dist/chunk-6286081da32e2feb.js +0 -2
  130. package/dist/chunk-9a9d43e4b919c267.js +0 -2
  131. package/dist/chunk-c459f3e37965c22f.js +0 -2
@@ -0,0 +1,53 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../node_modules/tiny-invariant/dist/tiny-invariant.cjs.js", "../../../node_modules/recast/node_modules/ast-types/lib/shared.js", "../../../node_modules/recast/node_modules/ast-types/lib/types.js", "../../../node_modules/recast/node_modules/ast-types/lib/path.js", "../../../node_modules/recast/node_modules/ast-types/lib/scope.js", "../../../node_modules/recast/node_modules/ast-types/lib/node-path.js", "../../../node_modules/recast/node_modules/ast-types/lib/path-visitor.js", "../../../node_modules/recast/node_modules/ast-types/lib/equiv.js", "../../../node_modules/recast/node_modules/ast-types/lib/fork.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/operators/core.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/operators/es2016.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/operators/es2020.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/operators/es2021.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/core.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/es6.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/es2016.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/es2017.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/es2018.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/es2019.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/es2020.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/es2021.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/es2022.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/es-proposals.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/jsx.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/type-annotations.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/flow.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/esprima.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/babel-core.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/babel.js", "../../../node_modules/recast/node_modules/ast-types/lib/def/typescript.js", "../../../node_modules/recast/node_modules/ast-types/lib/gen/namedTypes.js", "../../../node_modules/recast/node_modules/ast-types/lib/main.js", "../../../node_modules/source-map/lib/base64.js", "../../../node_modules/source-map/lib/base64-vlq.js", "../../../node_modules/source-map/lib/util.js", "../../../node_modules/source-map/lib/array-set.js", "../../../node_modules/source-map/lib/mapping-list.js", "../../../node_modules/source-map/lib/source-map-generator.js", "../../../node_modules/source-map/lib/binary-search.js", "../../../node_modules/source-map/lib/quick-sort.js", "../../../node_modules/source-map/lib/source-map-consumer.js", "../../../node_modules/source-map/lib/source-node.js", "../../../node_modules/source-map/source-map.js", "../../../node_modules/recast/lib/util.js"],
4
+ "sourcesContent": [
5
+ "'use strict';\n\nvar isProduction = process.env.NODE_ENV === 'production';\nvar prefix = 'Invariant failed';\nfunction invariant(condition, message) {\n if (condition) {\n return;\n }\n if (isProduction) {\n throw new Error(prefix);\n }\n var provided = typeof message === 'function' ? message() : message;\n var value = provided ? \"\".concat(prefix, \": \").concat(provided) : prefix;\n throw new Error(value);\n}\n\nmodule.exports = invariant;\n",
6
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.maybeSetModuleExports = void 0;\nvar tslib_1 = require(\"tslib\");\nvar types_1 = tslib_1.__importDefault(require(\"./types\"));\nfunction default_1(fork) {\n var types = fork.use(types_1.default);\n var Type = types.Type;\n var builtin = types.builtInTypes;\n var isNumber = builtin.number;\n // An example of constructing a new type with arbitrary constraints from\n // an existing type.\n function geq(than) {\n return Type.from(function (value) { return isNumber.check(value) && value >= than; }, isNumber + \" >= \" + than);\n }\n ;\n // Default value-returning functions that may optionally be passed as a\n // third argument to Def.prototype.field.\n var defaults = {\n // Functions were used because (among other reasons) that's the most\n // elegant way to allow for the emptyArray one always to give a new\n // array instance.\n \"null\": function () { return null; },\n \"emptyArray\": function () { return []; },\n \"false\": function () { return false; },\n \"true\": function () { return true; },\n \"undefined\": function () { },\n \"use strict\": function () { return \"use strict\"; }\n };\n var naiveIsPrimitive = Type.or(builtin.string, builtin.number, builtin.boolean, builtin.null, builtin.undefined);\n var isPrimitive = Type.from(function (value) {\n if (value === null)\n return true;\n var type = typeof value;\n if (type === \"object\" ||\n type === \"function\") {\n return false;\n }\n return true;\n }, naiveIsPrimitive.toString());\n return {\n geq: geq,\n defaults: defaults,\n isPrimitive: isPrimitive,\n };\n}\nexports.default = default_1;\n;\n// This function accepts a getter function that should return an object\n// conforming to the NodeModule interface above. Typically, this means calling\n// maybeSetModuleExports(() => module) at the very end of any module that has a\n// default export, so the default export value can replace module.exports and\n// thus CommonJS consumers can continue to rely on require(\"./that/module\")\n// returning the default-exported value, rather than always returning an exports\n// object with a default property equal to that value. This function should help\n// preserve backwards compatibility for CommonJS consumers, as a replacement for\n// the ts-add-module-exports package.\nfunction maybeSetModuleExports(moduleGetter) {\n try {\n var nodeModule = moduleGetter();\n var originalExports = nodeModule.exports;\n var defaultExport = originalExports[\"default\"];\n }\n catch (_a) {\n // It's normal/acceptable for this code to throw a ReferenceError due to\n // the moduleGetter function attempting to access a non-existent global\n // `module` variable. That's the reason we use a getter function here:\n // so the calling code doesn't have to do its own typeof module ===\n // \"object\" checking (because it's always safe to pass `() => module` as\n // an argument, even when `module` is not defined in the calling scope).\n return;\n }\n if (defaultExport &&\n defaultExport !== originalExports &&\n typeof originalExports === \"object\") {\n // Make all properties found in originalExports properties of the\n // default export, including the default property itself, so that\n // require(nodeModule.id).default === require(nodeModule.id).\n Object.assign(defaultExport, originalExports, { \"default\": defaultExport });\n // Object.assign only transfers enumerable properties, and\n // __esModule is (and should remain) non-enumerable.\n if (originalExports.__esModule) {\n Object.defineProperty(defaultExport, \"__esModule\", { value: true });\n }\n // This line allows require(nodeModule.id) === defaultExport, rather\n // than (only) require(nodeModule.id).default === defaultExport.\n nodeModule.exports = defaultExport;\n }\n}\nexports.maybeSetModuleExports = maybeSetModuleExports;\n//# sourceMappingURL=shared.js.map",
7
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Def = void 0;\nvar tslib_1 = require(\"tslib\");\nvar shared_1 = require(\"./shared\");\nvar Op = Object.prototype;\nvar objToStr = Op.toString;\nvar hasOwn = Op.hasOwnProperty;\nvar BaseType = /** @class */ (function () {\n function BaseType() {\n }\n BaseType.prototype.assert = function (value, deep) {\n if (!this.check(value, deep)) {\n var str = shallowStringify(value);\n throw new Error(str + \" does not match type \" + this);\n }\n return true;\n };\n BaseType.prototype.arrayOf = function () {\n var elemType = this;\n return new ArrayType(elemType);\n };\n return BaseType;\n}());\nvar ArrayType = /** @class */ (function (_super) {\n tslib_1.__extends(ArrayType, _super);\n function ArrayType(elemType) {\n var _this = _super.call(this) || this;\n _this.elemType = elemType;\n _this.kind = \"ArrayType\";\n return _this;\n }\n ArrayType.prototype.toString = function () {\n return \"[\" + this.elemType + \"]\";\n };\n ArrayType.prototype.check = function (value, deep) {\n var _this = this;\n return Array.isArray(value) && value.every(function (elem) { return _this.elemType.check(elem, deep); });\n };\n return ArrayType;\n}(BaseType));\nvar IdentityType = /** @class */ (function (_super) {\n tslib_1.__extends(IdentityType, _super);\n function IdentityType(value) {\n var _this = _super.call(this) || this;\n _this.value = value;\n _this.kind = \"IdentityType\";\n return _this;\n }\n IdentityType.prototype.toString = function () {\n return String(this.value);\n };\n IdentityType.prototype.check = function (value, deep) {\n var result = value === this.value;\n if (!result && typeof deep === \"function\") {\n deep(this, value);\n }\n return result;\n };\n return IdentityType;\n}(BaseType));\nvar ObjectType = /** @class */ (function (_super) {\n tslib_1.__extends(ObjectType, _super);\n function ObjectType(fields) {\n var _this = _super.call(this) || this;\n _this.fields = fields;\n _this.kind = \"ObjectType\";\n return _this;\n }\n ObjectType.prototype.toString = function () {\n return \"{ \" + this.fields.join(\", \") + \" }\";\n };\n ObjectType.prototype.check = function (value, deep) {\n return (objToStr.call(value) === objToStr.call({}) &&\n this.fields.every(function (field) {\n return field.type.check(value[field.name], deep);\n }));\n };\n return ObjectType;\n}(BaseType));\nvar OrType = /** @class */ (function (_super) {\n tslib_1.__extends(OrType, _super);\n function OrType(types) {\n var _this = _super.call(this) || this;\n _this.types = types;\n _this.kind = \"OrType\";\n return _this;\n }\n OrType.prototype.toString = function () {\n return this.types.join(\" | \");\n };\n OrType.prototype.check = function (value, deep) {\n if (this.types.some(function (type) { return type.check(value, !!deep); })) {\n return true;\n }\n if (typeof deep === \"function\") {\n deep(this, value);\n }\n return false;\n };\n return OrType;\n}(BaseType));\nvar PredicateType = /** @class */ (function (_super) {\n tslib_1.__extends(PredicateType, _super);\n function PredicateType(name, predicate) {\n var _this = _super.call(this) || this;\n _this.name = name;\n _this.predicate = predicate;\n _this.kind = \"PredicateType\";\n return _this;\n }\n PredicateType.prototype.toString = function () {\n return this.name;\n };\n PredicateType.prototype.check = function (value, deep) {\n var result = this.predicate(value, deep);\n if (!result && typeof deep === \"function\") {\n deep(this, value);\n }\n return result;\n };\n return PredicateType;\n}(BaseType));\nvar Def = /** @class */ (function () {\n function Def(type, typeName) {\n this.type = type;\n this.typeName = typeName;\n this.baseNames = [];\n this.ownFields = Object.create(null);\n // Includes own typeName. Populated during finalization.\n this.allSupertypes = Object.create(null);\n // Linear inheritance hierarchy. Populated during finalization.\n this.supertypeList = [];\n // Includes inherited fields.\n this.allFields = Object.create(null);\n // Non-hidden keys of allFields.\n this.fieldNames = [];\n // This property will be overridden as true by individual Def instances\n // when they are finalized.\n this.finalized = false;\n // False by default until .build(...) is called on an instance.\n this.buildable = false;\n this.buildParams = [];\n }\n Def.prototype.isSupertypeOf = function (that) {\n if (that instanceof Def) {\n if (this.finalized !== true ||\n that.finalized !== true) {\n throw new Error(\"\");\n }\n return hasOwn.call(that.allSupertypes, this.typeName);\n }\n else {\n throw new Error(that + \" is not a Def\");\n }\n };\n Def.prototype.checkAllFields = function (value, deep) {\n var allFields = this.allFields;\n if (this.finalized !== true) {\n throw new Error(\"\" + this.typeName);\n }\n function checkFieldByName(name) {\n var field = allFields[name];\n var type = field.type;\n var child = field.getValue(value);\n return type.check(child, deep);\n }\n return value !== null &&\n typeof value === \"object\" &&\n Object.keys(allFields).every(checkFieldByName);\n };\n Def.prototype.bases = function () {\n var supertypeNames = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n supertypeNames[_i] = arguments[_i];\n }\n var bases = this.baseNames;\n if (this.finalized) {\n if (supertypeNames.length !== bases.length) {\n throw new Error(\"\");\n }\n for (var i = 0; i < supertypeNames.length; i++) {\n if (supertypeNames[i] !== bases[i]) {\n throw new Error(\"\");\n }\n }\n return this;\n }\n supertypeNames.forEach(function (baseName) {\n // This indexOf lookup may be O(n), but the typical number of base\n // names is very small, and indexOf is a native Array method.\n if (bases.indexOf(baseName) < 0) {\n bases.push(baseName);\n }\n });\n return this; // For chaining.\n };\n return Def;\n}());\nexports.Def = Def;\nvar Field = /** @class */ (function () {\n function Field(name, type, defaultFn, hidden) {\n this.name = name;\n this.type = type;\n this.defaultFn = defaultFn;\n this.hidden = !!hidden;\n }\n Field.prototype.toString = function () {\n return JSON.stringify(this.name) + \": \" + this.type;\n };\n Field.prototype.getValue = function (obj) {\n var value = obj[this.name];\n if (typeof value !== \"undefined\") {\n return value;\n }\n if (typeof this.defaultFn === \"function\") {\n value = this.defaultFn.call(obj);\n }\n return value;\n };\n return Field;\n}());\nfunction shallowStringify(value) {\n if (Array.isArray(value)) {\n return \"[\" + value.map(shallowStringify).join(\", \") + \"]\";\n }\n if (value && typeof value === \"object\") {\n return \"{ \" + Object.keys(value).map(function (key) {\n return key + \": \" + value[key];\n }).join(\", \") + \" }\";\n }\n return JSON.stringify(value);\n}\nfunction typesPlugin(_fork) {\n var Type = {\n or: function () {\n var types = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n types[_i] = arguments[_i];\n }\n return new OrType(types.map(function (type) { return Type.from(type); }));\n },\n from: function (value, name) {\n if (value instanceof ArrayType ||\n value instanceof IdentityType ||\n value instanceof ObjectType ||\n value instanceof OrType ||\n value instanceof PredicateType) {\n return value;\n }\n // The Def type is used as a helper for constructing compound\n // interface types for AST nodes.\n if (value instanceof Def) {\n return value.type;\n }\n // Support [ElemType] syntax.\n if (isArray.check(value)) {\n if (value.length !== 1) {\n throw new Error(\"only one element type is permitted for typed arrays\");\n }\n return new ArrayType(Type.from(value[0]));\n }\n // Support { someField: FieldType, ... } syntax.\n if (isObject.check(value)) {\n return new ObjectType(Object.keys(value).map(function (name) {\n return new Field(name, Type.from(value[name], name));\n }));\n }\n if (typeof value === \"function\") {\n var bicfIndex = builtInCtorFns.indexOf(value);\n if (bicfIndex >= 0) {\n return builtInCtorTypes[bicfIndex];\n }\n if (typeof name !== \"string\") {\n throw new Error(\"missing name\");\n }\n return new PredicateType(name, value);\n }\n // As a last resort, toType returns a type that matches any value that\n // is === from. This is primarily useful for literal values like\n // toType(null), but it has the additional advantage of allowing\n // toType to be a total function.\n return new IdentityType(value);\n },\n // Define a type whose name is registered in a namespace (the defCache) so\n // that future definitions will return the same type given the same name.\n // In particular, this system allows for circular and forward definitions.\n // The Def object d returned from Type.def may be used to configure the\n // type d.type by calling methods such as d.bases, d.build, and d.field.\n def: function (typeName) {\n return hasOwn.call(defCache, typeName)\n ? defCache[typeName]\n : defCache[typeName] = new DefImpl(typeName);\n },\n hasDef: function (typeName) {\n return hasOwn.call(defCache, typeName);\n }\n };\n var builtInCtorFns = [];\n var builtInCtorTypes = [];\n function defBuiltInType(name, example) {\n var objStr = objToStr.call(example);\n var type = new PredicateType(name, function (value) { return objToStr.call(value) === objStr; });\n if (example && typeof example.constructor === \"function\") {\n builtInCtorFns.push(example.constructor);\n builtInCtorTypes.push(type);\n }\n return type;\n }\n // These types check the underlying [[Class]] attribute of the given\n // value, rather than using the problematic typeof operator. Note however\n // that no subtyping is considered; so, for instance, isObject.check\n // returns false for [], /./, new Date, and null.\n var isString = defBuiltInType(\"string\", \"truthy\");\n var isFunction = defBuiltInType(\"function\", function () { });\n var isArray = defBuiltInType(\"array\", []);\n var isObject = defBuiltInType(\"object\", {});\n var isRegExp = defBuiltInType(\"RegExp\", /./);\n var isDate = defBuiltInType(\"Date\", new Date());\n var isNumber = defBuiltInType(\"number\", 3);\n var isBoolean = defBuiltInType(\"boolean\", true);\n var isNull = defBuiltInType(\"null\", null);\n var isUndefined = defBuiltInType(\"undefined\", undefined);\n var isBigInt = typeof BigInt === \"function\"\n ? defBuiltInType(\"BigInt\", BigInt(1234))\n : new PredicateType(\"BigInt\", function () { return false; });\n var builtInTypes = {\n string: isString,\n function: isFunction,\n array: isArray,\n object: isObject,\n RegExp: isRegExp,\n Date: isDate,\n number: isNumber,\n boolean: isBoolean,\n null: isNull,\n undefined: isUndefined,\n BigInt: isBigInt,\n };\n // In order to return the same Def instance every time Type.def is called\n // with a particular name, those instances need to be stored in a cache.\n var defCache = Object.create(null);\n function defFromValue(value) {\n if (value && typeof value === \"object\") {\n var type = value.type;\n if (typeof type === \"string\" &&\n hasOwn.call(defCache, type)) {\n var d = defCache[type];\n if (d.finalized) {\n return d;\n }\n }\n }\n return null;\n }\n var DefImpl = /** @class */ (function (_super) {\n tslib_1.__extends(DefImpl, _super);\n function DefImpl(typeName) {\n var _this = _super.call(this, new PredicateType(typeName, function (value, deep) { return _this.check(value, deep); }), typeName) || this;\n return _this;\n }\n DefImpl.prototype.check = function (value, deep) {\n if (this.finalized !== true) {\n throw new Error(\"prematurely checking unfinalized type \" + this.typeName);\n }\n // A Def type can only match an object value.\n if (value === null || typeof value !== \"object\") {\n return false;\n }\n var vDef = defFromValue(value);\n if (!vDef) {\n // If we couldn't infer the Def associated with the given value,\n // and we expected it to be a SourceLocation or a Position, it was\n // probably just missing a \"type\" field (because Esprima does not\n // assign a type property to such nodes). Be optimistic and let\n // this.checkAllFields make the final decision.\n if (this.typeName === \"SourceLocation\" ||\n this.typeName === \"Position\") {\n return this.checkAllFields(value, deep);\n }\n // Calling this.checkAllFields for any other type of node is both\n // bad for performance and way too forgiving.\n return false;\n }\n // If checking deeply and vDef === this, then we only need to call\n // checkAllFields once. Calling checkAllFields is too strict when deep\n // is false, because then we only care about this.isSupertypeOf(vDef).\n if (deep && vDef === this) {\n return this.checkAllFields(value, deep);\n }\n // In most cases we rely exclusively on isSupertypeOf to make O(1)\n // subtyping determinations. This suffices in most situations outside\n // of unit tests, since interface conformance is checked whenever new\n // instances are created using builder functions.\n if (!this.isSupertypeOf(vDef)) {\n return false;\n }\n // The exception is when deep is true; then, we recursively check all\n // fields.\n if (!deep) {\n return true;\n }\n // Use the more specific Def (vDef) to perform the deep check, but\n // shallow-check fields defined by the less specific Def (this).\n return vDef.checkAllFields(value, deep)\n && this.checkAllFields(value, false);\n };\n DefImpl.prototype.build = function () {\n var _this = this;\n var buildParams = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n buildParams[_i] = arguments[_i];\n }\n // Calling Def.prototype.build multiple times has the effect of merely\n // redefining this property.\n this.buildParams = buildParams;\n if (this.buildable) {\n // If this Def is already buildable, update self.buildParams and\n // continue using the old builder function.\n return this;\n }\n // Every buildable type will have its \"type\" field filled in\n // automatically. This includes types that are not subtypes of Node,\n // like SourceLocation, but that seems harmless (TODO?).\n this.field(\"type\", String, function () { return _this.typeName; });\n // Override Dp.buildable for this Def instance.\n this.buildable = true;\n var addParam = function (built, param, arg, isArgAvailable) {\n if (hasOwn.call(built, param))\n return;\n var all = _this.allFields;\n if (!hasOwn.call(all, param)) {\n throw new Error(\"\" + param);\n }\n var field = all[param];\n var type = field.type;\n var value;\n if (isArgAvailable) {\n value = arg;\n }\n else if (field.defaultFn) {\n // Expose the partially-built object to the default\n // function as its `this` object.\n value = field.defaultFn.call(built);\n }\n else {\n var message = \"no value or default function given for field \" +\n JSON.stringify(param) + \" of \" + _this.typeName + \"(\" +\n _this.buildParams.map(function (name) {\n return all[name];\n }).join(\", \") + \")\";\n throw new Error(message);\n }\n if (!type.check(value)) {\n throw new Error(shallowStringify(value) +\n \" does not match field \" + field +\n \" of type \" + _this.typeName);\n }\n built[param] = value;\n };\n // Calling the builder function will construct an instance of the Def,\n // with positional arguments mapped to the fields original passed to .build.\n // If not enough arguments are provided, the default value for the remaining fields\n // will be used.\n var builder = function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var argc = args.length;\n if (!_this.finalized) {\n throw new Error(\"attempting to instantiate unfinalized type \" +\n _this.typeName);\n }\n var built = Object.create(nodePrototype);\n _this.buildParams.forEach(function (param, i) {\n if (i < argc) {\n addParam(built, param, args[i], true);\n }\n else {\n addParam(built, param, null, false);\n }\n });\n Object.keys(_this.allFields).forEach(function (param) {\n // Use the default value.\n addParam(built, param, null, false);\n });\n // Make sure that the \"type\" field was filled automatically.\n if (built.type !== _this.typeName) {\n throw new Error(\"\");\n }\n return built;\n };\n // Calling .from on the builder function will construct an instance of the Def,\n // using field values from the passed object. For fields missing from the passed object,\n // their default value will be used.\n builder.from = function (obj) {\n if (!_this.finalized) {\n throw new Error(\"attempting to instantiate unfinalized type \" +\n _this.typeName);\n }\n var built = Object.create(nodePrototype);\n Object.keys(_this.allFields).forEach(function (param) {\n if (hasOwn.call(obj, param)) {\n addParam(built, param, obj[param], true);\n }\n else {\n addParam(built, param, null, false);\n }\n });\n // Make sure that the \"type\" field was filled automatically.\n if (built.type !== _this.typeName) {\n throw new Error(\"\");\n }\n return built;\n };\n Object.defineProperty(builders, getBuilderName(this.typeName), {\n enumerable: true,\n value: builder\n });\n return this;\n };\n // The reason fields are specified using .field(...) instead of an object\n // literal syntax is somewhat subtle: the object literal syntax would\n // support only one key and one value, but with .field(...) we can pass\n // any number of arguments to specify the field.\n DefImpl.prototype.field = function (name, type, defaultFn, hidden) {\n if (this.finalized) {\n console.error(\"Ignoring attempt to redefine field \" +\n JSON.stringify(name) + \" of finalized type \" +\n JSON.stringify(this.typeName));\n return this;\n }\n this.ownFields[name] = new Field(name, Type.from(type), defaultFn, hidden);\n return this; // For chaining.\n };\n DefImpl.prototype.finalize = function () {\n var _this = this;\n // It's not an error to finalize a type more than once, but only the\n // first call to .finalize does anything.\n if (!this.finalized) {\n var allFields = this.allFields;\n var allSupertypes = this.allSupertypes;\n this.baseNames.forEach(function (name) {\n var def = defCache[name];\n if (def instanceof Def) {\n def.finalize();\n extend(allFields, def.allFields);\n extend(allSupertypes, def.allSupertypes);\n }\n else {\n var message = \"unknown supertype name \" +\n JSON.stringify(name) +\n \" for subtype \" +\n JSON.stringify(_this.typeName);\n throw new Error(message);\n }\n });\n // TODO Warn if fields are overridden with incompatible types.\n extend(allFields, this.ownFields);\n allSupertypes[this.typeName] = this;\n this.fieldNames.length = 0;\n for (var fieldName in allFields) {\n if (hasOwn.call(allFields, fieldName) &&\n !allFields[fieldName].hidden) {\n this.fieldNames.push(fieldName);\n }\n }\n // Types are exported only once they have been finalized.\n Object.defineProperty(namedTypes, this.typeName, {\n enumerable: true,\n value: this.type\n });\n this.finalized = true;\n // A linearization of the inheritance hierarchy.\n populateSupertypeList(this.typeName, this.supertypeList);\n if (this.buildable &&\n this.supertypeList.lastIndexOf(\"Expression\") >= 0) {\n wrapExpressionBuilderWithStatement(this.typeName);\n }\n }\n };\n return DefImpl;\n }(Def));\n // Note that the list returned by this function is a copy of the internal\n // supertypeList, *without* the typeName itself as the first element.\n function getSupertypeNames(typeName) {\n if (!hasOwn.call(defCache, typeName)) {\n throw new Error(\"\");\n }\n var d = defCache[typeName];\n if (d.finalized !== true) {\n throw new Error(\"\");\n }\n return d.supertypeList.slice(1);\n }\n // Returns an object mapping from every known type in the defCache to the\n // most specific supertype whose name is an own property of the candidates\n // object.\n function computeSupertypeLookupTable(candidates) {\n var table = {};\n var typeNames = Object.keys(defCache);\n var typeNameCount = typeNames.length;\n for (var i = 0; i < typeNameCount; ++i) {\n var typeName = typeNames[i];\n var d = defCache[typeName];\n if (d.finalized !== true) {\n throw new Error(\"\" + typeName);\n }\n for (var j = 0; j < d.supertypeList.length; ++j) {\n var superTypeName = d.supertypeList[j];\n if (hasOwn.call(candidates, superTypeName)) {\n table[typeName] = superTypeName;\n break;\n }\n }\n }\n return table;\n }\n var builders = Object.create(null);\n // This object is used as prototype for any node created by a builder.\n var nodePrototype = {};\n // Call this function to define a new method to be shared by all AST\n // nodes. The replaced method (if any) is returned for easy wrapping.\n function defineMethod(name, func) {\n var old = nodePrototype[name];\n // Pass undefined as func to delete nodePrototype[name].\n if (isUndefined.check(func)) {\n delete nodePrototype[name];\n }\n else {\n isFunction.assert(func);\n Object.defineProperty(nodePrototype, name, {\n enumerable: true,\n configurable: true,\n value: func\n });\n }\n return old;\n }\n function getBuilderName(typeName) {\n return typeName.replace(/^[A-Z]+/, function (upperCasePrefix) {\n var len = upperCasePrefix.length;\n switch (len) {\n case 0: return \"\";\n // If there's only one initial capital letter, just lower-case it.\n case 1: return upperCasePrefix.toLowerCase();\n default:\n // If there's more than one initial capital letter, lower-case\n // all but the last one, so that XMLDefaultDeclaration (for\n // example) becomes xmlDefaultDeclaration.\n return upperCasePrefix.slice(0, len - 1).toLowerCase() +\n upperCasePrefix.charAt(len - 1);\n }\n });\n }\n function getStatementBuilderName(typeName) {\n typeName = getBuilderName(typeName);\n return typeName.replace(/(Expression)?$/, \"Statement\");\n }\n var namedTypes = {};\n // Like Object.keys, but aware of what fields each AST type should have.\n function getFieldNames(object) {\n var d = defFromValue(object);\n if (d) {\n return d.fieldNames.slice(0);\n }\n if (\"type\" in object) {\n throw new Error(\"did not recognize object of type \" +\n JSON.stringify(object.type));\n }\n return Object.keys(object);\n }\n // Get the value of an object property, taking object.type and default\n // functions into account.\n function getFieldValue(object, fieldName) {\n var d = defFromValue(object);\n if (d) {\n var field = d.allFields[fieldName];\n if (field) {\n return field.getValue(object);\n }\n }\n return object && object[fieldName];\n }\n // Iterate over all defined fields of an object, including those missing\n // or undefined, passing each field name and effective value (as returned\n // by getFieldValue) to the callback. If the object has no corresponding\n // Def, the callback will never be called.\n function eachField(object, callback, context) {\n getFieldNames(object).forEach(function (name) {\n callback.call(this, name, getFieldValue(object, name));\n }, context);\n }\n // Similar to eachField, except that iteration stops as soon as the\n // callback returns a truthy value. Like Array.prototype.some, the final\n // result is either true or false to indicates whether the callback\n // returned true for any element or not.\n function someField(object, callback, context) {\n return getFieldNames(object).some(function (name) {\n return callback.call(this, name, getFieldValue(object, name));\n }, context);\n }\n // Adds an additional builder for Expression subtypes\n // that wraps the built Expression in an ExpressionStatements.\n function wrapExpressionBuilderWithStatement(typeName) {\n var wrapperName = getStatementBuilderName(typeName);\n // skip if the builder already exists\n if (builders[wrapperName])\n return;\n // the builder function to wrap with builders.ExpressionStatement\n var wrapped = builders[getBuilderName(typeName)];\n // skip if there is nothing to wrap\n if (!wrapped)\n return;\n var builder = function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n return builders.expressionStatement(wrapped.apply(builders, args));\n };\n builder.from = function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n return builders.expressionStatement(wrapped.from.apply(builders, args));\n };\n builders[wrapperName] = builder;\n }\n function populateSupertypeList(typeName, list) {\n list.length = 0;\n list.push(typeName);\n var lastSeen = Object.create(null);\n for (var pos = 0; pos < list.length; ++pos) {\n typeName = list[pos];\n var d = defCache[typeName];\n if (d.finalized !== true) {\n throw new Error(\"\");\n }\n // If we saw typeName earlier in the breadth-first traversal,\n // delete the last-seen occurrence.\n if (hasOwn.call(lastSeen, typeName)) {\n delete list[lastSeen[typeName]];\n }\n // Record the new index of the last-seen occurrence of typeName.\n lastSeen[typeName] = pos;\n // Enqueue the base names of this type.\n list.push.apply(list, d.baseNames);\n }\n // Compaction loop to remove array holes.\n for (var to = 0, from = to, len = list.length; from < len; ++from) {\n if (hasOwn.call(list, from)) {\n list[to++] = list[from];\n }\n }\n list.length = to;\n }\n function extend(into, from) {\n Object.keys(from).forEach(function (name) {\n into[name] = from[name];\n });\n return into;\n }\n function finalize() {\n Object.keys(defCache).forEach(function (name) {\n defCache[name].finalize();\n });\n }\n return {\n Type: Type,\n builtInTypes: builtInTypes,\n getSupertypeNames: getSupertypeNames,\n computeSupertypeLookupTable: computeSupertypeLookupTable,\n builders: builders,\n defineMethod: defineMethod,\n getBuilderName: getBuilderName,\n getStatementBuilderName: getStatementBuilderName,\n namedTypes: namedTypes,\n getFieldNames: getFieldNames,\n getFieldValue: getFieldValue,\n eachField: eachField,\n someField: someField,\n finalize: finalize,\n };\n}\nexports.default = typesPlugin;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=types.js.map",
8
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar shared_1 = require(\"./shared\");\nvar types_1 = tslib_1.__importDefault(require(\"./types\"));\nvar Op = Object.prototype;\nvar hasOwn = Op.hasOwnProperty;\nfunction pathPlugin(fork) {\n var types = fork.use(types_1.default);\n var isArray = types.builtInTypes.array;\n var isNumber = types.builtInTypes.number;\n var Path = function Path(value, parentPath, name) {\n if (!(this instanceof Path)) {\n throw new Error(\"Path constructor cannot be invoked without 'new'\");\n }\n if (parentPath) {\n if (!(parentPath instanceof Path)) {\n throw new Error(\"\");\n }\n }\n else {\n parentPath = null;\n name = null;\n }\n // The value encapsulated by this Path, generally equal to\n // parentPath.value[name] if we have a parentPath.\n this.value = value;\n // The immediate parent Path of this Path.\n this.parentPath = parentPath;\n // The name of the property of parentPath.value through which this\n // Path's value was reached.\n this.name = name;\n // Calling path.get(\"child\") multiple times always returns the same\n // child Path object, for both performance and consistency reasons.\n this.__childCache = null;\n };\n var Pp = Path.prototype;\n function getChildCache(path) {\n // Lazily create the child cache. This also cheapens cache\n // invalidation, since you can just reset path.__childCache to null.\n return path.__childCache || (path.__childCache = Object.create(null));\n }\n function getChildPath(path, name) {\n var cache = getChildCache(path);\n var actualChildValue = path.getValueProperty(name);\n var childPath = cache[name];\n if (!hasOwn.call(cache, name) ||\n // Ensure consistency between cache and reality.\n childPath.value !== actualChildValue) {\n childPath = cache[name] = new path.constructor(actualChildValue, path, name);\n }\n return childPath;\n }\n // This method is designed to be overridden by subclasses that need to\n // handle missing properties, etc.\n Pp.getValueProperty = function getValueProperty(name) {\n return this.value[name];\n };\n Pp.get = function get() {\n var names = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n names[_i] = arguments[_i];\n }\n var path = this;\n var count = names.length;\n for (var i = 0; i < count; ++i) {\n path = getChildPath(path, names[i]);\n }\n return path;\n };\n Pp.each = function each(callback, context) {\n var childPaths = [];\n var len = this.value.length;\n var i = 0;\n // Collect all the original child paths before invoking the callback.\n for (var i = 0; i < len; ++i) {\n if (hasOwn.call(this.value, i)) {\n childPaths[i] = this.get(i);\n }\n }\n // Invoke the callback on just the original child paths, regardless of\n // any modifications made to the array by the callback. I chose these\n // semantics over cleverly invoking the callback on new elements because\n // this way is much easier to reason about.\n context = context || this;\n for (i = 0; i < len; ++i) {\n if (hasOwn.call(childPaths, i)) {\n callback.call(context, childPaths[i]);\n }\n }\n };\n Pp.map = function map(callback, context) {\n var result = [];\n this.each(function (childPath) {\n result.push(callback.call(this, childPath));\n }, context);\n return result;\n };\n Pp.filter = function filter(callback, context) {\n var result = [];\n this.each(function (childPath) {\n if (callback.call(this, childPath)) {\n result.push(childPath);\n }\n }, context);\n return result;\n };\n function emptyMoves() { }\n function getMoves(path, offset, start, end) {\n isArray.assert(path.value);\n if (offset === 0) {\n return emptyMoves;\n }\n var length = path.value.length;\n if (length < 1) {\n return emptyMoves;\n }\n var argc = arguments.length;\n if (argc === 2) {\n start = 0;\n end = length;\n }\n else if (argc === 3) {\n start = Math.max(start, 0);\n end = length;\n }\n else {\n start = Math.max(start, 0);\n end = Math.min(end, length);\n }\n isNumber.assert(start);\n isNumber.assert(end);\n var moves = Object.create(null);\n var cache = getChildCache(path);\n for (var i = start; i < end; ++i) {\n if (hasOwn.call(path.value, i)) {\n var childPath = path.get(i);\n if (childPath.name !== i) {\n throw new Error(\"\");\n }\n var newIndex = i + offset;\n childPath.name = newIndex;\n moves[newIndex] = childPath;\n delete cache[i];\n }\n }\n delete cache.length;\n return function () {\n for (var newIndex in moves) {\n var childPath = moves[newIndex];\n if (childPath.name !== +newIndex) {\n throw new Error(\"\");\n }\n cache[newIndex] = childPath;\n path.value[newIndex] = childPath.value;\n }\n };\n }\n Pp.shift = function shift() {\n var move = getMoves(this, -1);\n var result = this.value.shift();\n move();\n return result;\n };\n Pp.unshift = function unshift() {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var move = getMoves(this, args.length);\n var result = this.value.unshift.apply(this.value, args);\n move();\n return result;\n };\n Pp.push = function push() {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n isArray.assert(this.value);\n delete getChildCache(this).length;\n return this.value.push.apply(this.value, args);\n };\n Pp.pop = function pop() {\n isArray.assert(this.value);\n var cache = getChildCache(this);\n delete cache[this.value.length - 1];\n delete cache.length;\n return this.value.pop();\n };\n Pp.insertAt = function insertAt(index) {\n var argc = arguments.length;\n var move = getMoves(this, argc - 1, index);\n if (move === emptyMoves && argc <= 1) {\n return this;\n }\n index = Math.max(index, 0);\n for (var i = 1; i < argc; ++i) {\n this.value[index + i - 1] = arguments[i];\n }\n move();\n return this;\n };\n Pp.insertBefore = function insertBefore() {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var pp = this.parentPath;\n var argc = args.length;\n var insertAtArgs = [this.name];\n for (var i = 0; i < argc; ++i) {\n insertAtArgs.push(args[i]);\n }\n return pp.insertAt.apply(pp, insertAtArgs);\n };\n Pp.insertAfter = function insertAfter() {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var pp = this.parentPath;\n var argc = args.length;\n var insertAtArgs = [this.name + 1];\n for (var i = 0; i < argc; ++i) {\n insertAtArgs.push(args[i]);\n }\n return pp.insertAt.apply(pp, insertAtArgs);\n };\n function repairRelationshipWithParent(path) {\n if (!(path instanceof Path)) {\n throw new Error(\"\");\n }\n var pp = path.parentPath;\n if (!pp) {\n // Orphan paths have no relationship to repair.\n return path;\n }\n var parentValue = pp.value;\n var parentCache = getChildCache(pp);\n // Make sure parentCache[path.name] is populated.\n if (parentValue[path.name] === path.value) {\n parentCache[path.name] = path;\n }\n else if (isArray.check(parentValue)) {\n // Something caused path.name to become out of date, so attempt to\n // recover by searching for path.value in parentValue.\n var i = parentValue.indexOf(path.value);\n if (i >= 0) {\n parentCache[path.name = i] = path;\n }\n }\n else {\n // If path.value disagrees with parentValue[path.name], and\n // path.name is not an array index, let path.value become the new\n // parentValue[path.name] and update parentCache accordingly.\n parentValue[path.name] = path.value;\n parentCache[path.name] = path;\n }\n if (parentValue[path.name] !== path.value) {\n throw new Error(\"\");\n }\n if (path.parentPath.get(path.name) !== path) {\n throw new Error(\"\");\n }\n return path;\n }\n Pp.replace = function replace(replacement) {\n var results = [];\n var parentValue = this.parentPath.value;\n var parentCache = getChildCache(this.parentPath);\n var count = arguments.length;\n repairRelationshipWithParent(this);\n if (isArray.check(parentValue)) {\n var originalLength = parentValue.length;\n var move = getMoves(this.parentPath, count - 1, this.name + 1);\n var spliceArgs = [this.name, 1];\n for (var i = 0; i < count; ++i) {\n spliceArgs.push(arguments[i]);\n }\n var splicedOut = parentValue.splice.apply(parentValue, spliceArgs);\n if (splicedOut[0] !== this.value) {\n throw new Error(\"\");\n }\n if (parentValue.length !== (originalLength - 1 + count)) {\n throw new Error(\"\");\n }\n move();\n if (count === 0) {\n delete this.value;\n delete parentCache[this.name];\n this.__childCache = null;\n }\n else {\n if (parentValue[this.name] !== replacement) {\n throw new Error(\"\");\n }\n if (this.value !== replacement) {\n this.value = replacement;\n this.__childCache = null;\n }\n for (i = 0; i < count; ++i) {\n results.push(this.parentPath.get(this.name + i));\n }\n if (results[0] !== this) {\n throw new Error(\"\");\n }\n }\n }\n else if (count === 1) {\n if (this.value !== replacement) {\n this.__childCache = null;\n }\n this.value = parentValue[this.name] = replacement;\n results.push(this);\n }\n else if (count === 0) {\n delete parentValue[this.name];\n delete this.value;\n this.__childCache = null;\n // Leave this path cached as parentCache[this.name], even though\n // it no longer has a value defined.\n }\n else {\n throw new Error(\"Could not replace path\");\n }\n return results;\n };\n return Path;\n}\nexports.default = pathPlugin;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=path.js.map",
9
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar shared_1 = require(\"./shared\");\nvar types_1 = tslib_1.__importDefault(require(\"./types\"));\nvar hasOwn = Object.prototype.hasOwnProperty;\nfunction scopePlugin(fork) {\n var types = fork.use(types_1.default);\n var Type = types.Type;\n var namedTypes = types.namedTypes;\n var Node = namedTypes.Node;\n var Expression = namedTypes.Expression;\n var isArray = types.builtInTypes.array;\n var b = types.builders;\n var Scope = function Scope(path, parentScope) {\n if (!(this instanceof Scope)) {\n throw new Error(\"Scope constructor cannot be invoked without 'new'\");\n }\n if (!TypeParameterScopeType.check(path.value)) {\n ScopeType.assert(path.value);\n }\n var depth;\n if (parentScope) {\n if (!(parentScope instanceof Scope)) {\n throw new Error(\"\");\n }\n depth = parentScope.depth + 1;\n }\n else {\n parentScope = null;\n depth = 0;\n }\n Object.defineProperties(this, {\n path: { value: path },\n node: { value: path.value },\n isGlobal: { value: !parentScope, enumerable: true },\n depth: { value: depth },\n parent: { value: parentScope },\n bindings: { value: {} },\n types: { value: {} },\n });\n };\n var ScopeType = Type.or(\n // Program nodes introduce global scopes.\n namedTypes.Program, \n // Function is the supertype of FunctionExpression,\n // FunctionDeclaration, ArrowExpression, etc.\n namedTypes.Function, \n // In case you didn't know, the caught parameter shadows any variable\n // of the same name in an outer scope.\n namedTypes.CatchClause);\n // These types introduce scopes that are restricted to type parameters in\n // Flow (this doesn't apply to ECMAScript).\n var TypeParameterScopeType = Type.or(namedTypes.Function, namedTypes.ClassDeclaration, namedTypes.ClassExpression, namedTypes.InterfaceDeclaration, namedTypes.TSInterfaceDeclaration, namedTypes.TypeAlias, namedTypes.TSTypeAliasDeclaration);\n var FlowOrTSTypeParameterType = Type.or(namedTypes.TypeParameter, namedTypes.TSTypeParameter);\n Scope.isEstablishedBy = function (node) {\n return ScopeType.check(node) || TypeParameterScopeType.check(node);\n };\n var Sp = Scope.prototype;\n // Will be overridden after an instance lazily calls scanScope.\n Sp.didScan = false;\n Sp.declares = function (name) {\n this.scan();\n return hasOwn.call(this.bindings, name);\n };\n Sp.declaresType = function (name) {\n this.scan();\n return hasOwn.call(this.types, name);\n };\n Sp.declareTemporary = function (prefix) {\n if (prefix) {\n if (!/^[a-z$_]/i.test(prefix)) {\n throw new Error(\"\");\n }\n }\n else {\n prefix = \"t$\";\n }\n // Include this.depth in the name to make sure the name does not\n // collide with any variables in nested/enclosing scopes.\n prefix += this.depth.toString(36) + \"$\";\n this.scan();\n var index = 0;\n while (this.declares(prefix + index)) {\n ++index;\n }\n var name = prefix + index;\n return this.bindings[name] = types.builders.identifier(name);\n };\n Sp.injectTemporary = function (identifier, init) {\n identifier || (identifier = this.declareTemporary());\n var bodyPath = this.path.get(\"body\");\n if (namedTypes.BlockStatement.check(bodyPath.value)) {\n bodyPath = bodyPath.get(\"body\");\n }\n bodyPath.unshift(b.variableDeclaration(\"var\", [b.variableDeclarator(identifier, init || null)]));\n return identifier;\n };\n Sp.scan = function (force) {\n if (force || !this.didScan) {\n for (var name in this.bindings) {\n // Empty out this.bindings, just in cases.\n delete this.bindings[name];\n }\n for (var name in this.types) {\n // Empty out this.types, just in cases.\n delete this.types[name];\n }\n scanScope(this.path, this.bindings, this.types);\n this.didScan = true;\n }\n };\n Sp.getBindings = function () {\n this.scan();\n return this.bindings;\n };\n Sp.getTypes = function () {\n this.scan();\n return this.types;\n };\n function scanScope(path, bindings, scopeTypes) {\n var node = path.value;\n if (TypeParameterScopeType.check(node)) {\n var params = path.get('typeParameters', 'params');\n if (isArray.check(params.value)) {\n params.each(function (childPath) {\n addTypeParameter(childPath, scopeTypes);\n });\n }\n }\n if (ScopeType.check(node)) {\n if (namedTypes.CatchClause.check(node)) {\n // A catch clause establishes a new scope but the only variable\n // bound in that scope is the catch parameter. Any other\n // declarations create bindings in the outer scope.\n addPattern(path.get(\"param\"), bindings);\n }\n else {\n recursiveScanScope(path, bindings, scopeTypes);\n }\n }\n }\n function recursiveScanScope(path, bindings, scopeTypes) {\n var node = path.value;\n if (path.parent &&\n namedTypes.FunctionExpression.check(path.parent.node) &&\n path.parent.node.id) {\n addPattern(path.parent.get(\"id\"), bindings);\n }\n if (!node) {\n // None of the remaining cases matter if node is falsy.\n }\n else if (isArray.check(node)) {\n path.each(function (childPath) {\n recursiveScanChild(childPath, bindings, scopeTypes);\n });\n }\n else if (namedTypes.Function.check(node)) {\n path.get(\"params\").each(function (paramPath) {\n addPattern(paramPath, bindings);\n });\n recursiveScanChild(path.get(\"body\"), bindings, scopeTypes);\n recursiveScanScope(path.get(\"typeParameters\"), bindings, scopeTypes);\n }\n else if ((namedTypes.TypeAlias && namedTypes.TypeAlias.check(node)) ||\n (namedTypes.InterfaceDeclaration && namedTypes.InterfaceDeclaration.check(node)) ||\n (namedTypes.TSTypeAliasDeclaration && namedTypes.TSTypeAliasDeclaration.check(node)) ||\n (namedTypes.TSInterfaceDeclaration && namedTypes.TSInterfaceDeclaration.check(node))) {\n addTypePattern(path.get(\"id\"), scopeTypes);\n }\n else if (namedTypes.VariableDeclarator.check(node)) {\n addPattern(path.get(\"id\"), bindings);\n recursiveScanChild(path.get(\"init\"), bindings, scopeTypes);\n }\n else if (node.type === \"ImportSpecifier\" ||\n node.type === \"ImportNamespaceSpecifier\" ||\n node.type === \"ImportDefaultSpecifier\") {\n addPattern(\n // Esprima used to use the .name field to refer to the local\n // binding identifier for ImportSpecifier nodes, but .id for\n // ImportNamespaceSpecifier and ImportDefaultSpecifier nodes.\n // ESTree/Acorn/ESpree use .local for all three node types.\n path.get(node.local ? \"local\" :\n node.name ? \"name\" : \"id\"), bindings);\n }\n else if (Node.check(node) && !Expression.check(node)) {\n types.eachField(node, function (name, child) {\n var childPath = path.get(name);\n if (!pathHasValue(childPath, child)) {\n throw new Error(\"\");\n }\n recursiveScanChild(childPath, bindings, scopeTypes);\n });\n }\n }\n function pathHasValue(path, value) {\n if (path.value === value) {\n return true;\n }\n // Empty arrays are probably produced by defaults.emptyArray, in which\n // case is makes sense to regard them as equivalent, if not ===.\n if (Array.isArray(path.value) &&\n path.value.length === 0 &&\n Array.isArray(value) &&\n value.length === 0) {\n return true;\n }\n return false;\n }\n function recursiveScanChild(path, bindings, scopeTypes) {\n var node = path.value;\n if (!node || Expression.check(node)) {\n // Ignore falsy values and Expressions.\n }\n else if (namedTypes.FunctionDeclaration.check(node) &&\n node.id !== null) {\n addPattern(path.get(\"id\"), bindings);\n }\n else if (namedTypes.ClassDeclaration &&\n namedTypes.ClassDeclaration.check(node) &&\n node.id !== null) {\n addPattern(path.get(\"id\"), bindings);\n recursiveScanScope(path.get(\"typeParameters\"), bindings, scopeTypes);\n }\n else if ((namedTypes.InterfaceDeclaration &&\n namedTypes.InterfaceDeclaration.check(node)) ||\n (namedTypes.TSInterfaceDeclaration &&\n namedTypes.TSInterfaceDeclaration.check(node))) {\n addTypePattern(path.get(\"id\"), scopeTypes);\n }\n else if (ScopeType.check(node)) {\n if (namedTypes.CatchClause.check(node) &&\n // TODO Broaden this to accept any pattern.\n namedTypes.Identifier.check(node.param)) {\n var catchParamName = node.param.name;\n var hadBinding = hasOwn.call(bindings, catchParamName);\n // Any declarations that occur inside the catch body that do\n // not have the same name as the catch parameter should count\n // as bindings in the outer scope.\n recursiveScanScope(path.get(\"body\"), bindings, scopeTypes);\n // If a new binding matching the catch parameter name was\n // created while scanning the catch body, ignore it because it\n // actually refers to the catch parameter and not the outer\n // scope that we're currently scanning.\n if (!hadBinding) {\n delete bindings[catchParamName];\n }\n }\n }\n else {\n recursiveScanScope(path, bindings, scopeTypes);\n }\n }\n function addPattern(patternPath, bindings) {\n var pattern = patternPath.value;\n namedTypes.Pattern.assert(pattern);\n if (namedTypes.Identifier.check(pattern)) {\n if (hasOwn.call(bindings, pattern.name)) {\n bindings[pattern.name].push(patternPath);\n }\n else {\n bindings[pattern.name] = [patternPath];\n }\n }\n else if (namedTypes.AssignmentPattern &&\n namedTypes.AssignmentPattern.check(pattern)) {\n addPattern(patternPath.get('left'), bindings);\n }\n else if (namedTypes.ObjectPattern &&\n namedTypes.ObjectPattern.check(pattern)) {\n patternPath.get('properties').each(function (propertyPath) {\n var property = propertyPath.value;\n if (namedTypes.Pattern.check(property)) {\n addPattern(propertyPath, bindings);\n }\n else if (namedTypes.Property.check(property) ||\n (namedTypes.ObjectProperty &&\n namedTypes.ObjectProperty.check(property))) {\n addPattern(propertyPath.get('value'), bindings);\n }\n else if (namedTypes.SpreadProperty &&\n namedTypes.SpreadProperty.check(property)) {\n addPattern(propertyPath.get('argument'), bindings);\n }\n });\n }\n else if (namedTypes.ArrayPattern &&\n namedTypes.ArrayPattern.check(pattern)) {\n patternPath.get('elements').each(function (elementPath) {\n var element = elementPath.value;\n if (namedTypes.Pattern.check(element)) {\n addPattern(elementPath, bindings);\n }\n else if (namedTypes.SpreadElement &&\n namedTypes.SpreadElement.check(element)) {\n addPattern(elementPath.get(\"argument\"), bindings);\n }\n });\n }\n else if (namedTypes.PropertyPattern &&\n namedTypes.PropertyPattern.check(pattern)) {\n addPattern(patternPath.get('pattern'), bindings);\n }\n else if ((namedTypes.SpreadElementPattern &&\n namedTypes.SpreadElementPattern.check(pattern)) ||\n (namedTypes.RestElement &&\n namedTypes.RestElement.check(pattern)) ||\n (namedTypes.SpreadPropertyPattern &&\n namedTypes.SpreadPropertyPattern.check(pattern))) {\n addPattern(patternPath.get('argument'), bindings);\n }\n }\n function addTypePattern(patternPath, types) {\n var pattern = patternPath.value;\n namedTypes.Pattern.assert(pattern);\n if (namedTypes.Identifier.check(pattern)) {\n if (hasOwn.call(types, pattern.name)) {\n types[pattern.name].push(patternPath);\n }\n else {\n types[pattern.name] = [patternPath];\n }\n }\n }\n function addTypeParameter(parameterPath, types) {\n var parameter = parameterPath.value;\n FlowOrTSTypeParameterType.assert(parameter);\n if (hasOwn.call(types, parameter.name)) {\n types[parameter.name].push(parameterPath);\n }\n else {\n types[parameter.name] = [parameterPath];\n }\n }\n Sp.lookup = function (name) {\n for (var scope = this; scope; scope = scope.parent)\n if (scope.declares(name))\n break;\n return scope;\n };\n Sp.lookupType = function (name) {\n for (var scope = this; scope; scope = scope.parent)\n if (scope.declaresType(name))\n break;\n return scope;\n };\n Sp.getGlobalScope = function () {\n var scope = this;\n while (!scope.isGlobal)\n scope = scope.parent;\n return scope;\n };\n return Scope;\n}\nexports.default = scopePlugin;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=scope.js.map",
10
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar types_1 = tslib_1.__importDefault(require(\"./types\"));\nvar path_1 = tslib_1.__importDefault(require(\"./path\"));\nvar scope_1 = tslib_1.__importDefault(require(\"./scope\"));\nvar shared_1 = require(\"./shared\");\nfunction nodePathPlugin(fork) {\n var types = fork.use(types_1.default);\n var n = types.namedTypes;\n var b = types.builders;\n var isNumber = types.builtInTypes.number;\n var isArray = types.builtInTypes.array;\n var Path = fork.use(path_1.default);\n var Scope = fork.use(scope_1.default);\n var NodePath = function NodePath(value, parentPath, name) {\n if (!(this instanceof NodePath)) {\n throw new Error(\"NodePath constructor cannot be invoked without 'new'\");\n }\n Path.call(this, value, parentPath, name);\n };\n var NPp = NodePath.prototype = Object.create(Path.prototype, {\n constructor: {\n value: NodePath,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperties(NPp, {\n node: {\n get: function () {\n Object.defineProperty(this, \"node\", {\n configurable: true,\n value: this._computeNode()\n });\n return this.node;\n }\n },\n parent: {\n get: function () {\n Object.defineProperty(this, \"parent\", {\n configurable: true,\n value: this._computeParent()\n });\n return this.parent;\n }\n },\n scope: {\n get: function () {\n Object.defineProperty(this, \"scope\", {\n configurable: true,\n value: this._computeScope()\n });\n return this.scope;\n }\n }\n });\n NPp.replace = function () {\n delete this.node;\n delete this.parent;\n delete this.scope;\n return Path.prototype.replace.apply(this, arguments);\n };\n NPp.prune = function () {\n var remainingNodePath = this.parent;\n this.replace();\n return cleanUpNodesAfterPrune(remainingNodePath);\n };\n // The value of the first ancestor Path whose value is a Node.\n NPp._computeNode = function () {\n var value = this.value;\n if (n.Node.check(value)) {\n return value;\n }\n var pp = this.parentPath;\n return pp && pp.node || null;\n };\n // The first ancestor Path whose value is a Node distinct from this.node.\n NPp._computeParent = function () {\n var value = this.value;\n var pp = this.parentPath;\n if (!n.Node.check(value)) {\n while (pp && !n.Node.check(pp.value)) {\n pp = pp.parentPath;\n }\n if (pp) {\n pp = pp.parentPath;\n }\n }\n while (pp && !n.Node.check(pp.value)) {\n pp = pp.parentPath;\n }\n return pp || null;\n };\n // The closest enclosing scope that governs this node.\n NPp._computeScope = function () {\n var value = this.value;\n var pp = this.parentPath;\n var scope = pp && pp.scope;\n if (n.Node.check(value) &&\n Scope.isEstablishedBy(value)) {\n scope = new Scope(this, scope);\n }\n return scope || null;\n };\n NPp.getValueProperty = function (name) {\n return types.getFieldValue(this.value, name);\n };\n /**\n * Determine whether this.node needs to be wrapped in parentheses in order\n * for a parser to reproduce the same local AST structure.\n *\n * For instance, in the expression `(1 + 2) * 3`, the BinaryExpression\n * whose operator is \"+\" needs parentheses, because `1 + 2 * 3` would\n * parse differently.\n *\n * If assumeExpressionContext === true, we don't worry about edge cases\n * like an anonymous FunctionExpression appearing lexically first in its\n * enclosing statement and thus needing parentheses to avoid being parsed\n * as a FunctionDeclaration with a missing name.\n */\n NPp.needsParens = function (assumeExpressionContext) {\n var pp = this.parentPath;\n if (!pp) {\n return false;\n }\n var node = this.value;\n // Only expressions need parentheses.\n if (!n.Expression.check(node)) {\n return false;\n }\n // Identifiers never need parentheses.\n if (node.type === \"Identifier\") {\n return false;\n }\n while (!n.Node.check(pp.value)) {\n pp = pp.parentPath;\n if (!pp) {\n return false;\n }\n }\n var parent = pp.value;\n switch (node.type) {\n case \"UnaryExpression\":\n case \"SpreadElement\":\n case \"SpreadProperty\":\n return parent.type === \"MemberExpression\"\n && this.name === \"object\"\n && parent.object === node;\n case \"BinaryExpression\":\n case \"LogicalExpression\":\n switch (parent.type) {\n case \"CallExpression\":\n return this.name === \"callee\"\n && parent.callee === node;\n case \"UnaryExpression\":\n case \"SpreadElement\":\n case \"SpreadProperty\":\n return true;\n case \"MemberExpression\":\n return this.name === \"object\"\n && parent.object === node;\n case \"BinaryExpression\":\n case \"LogicalExpression\": {\n var n_1 = node;\n var po = parent.operator;\n var pp_1 = PRECEDENCE[po];\n var no = n_1.operator;\n var np = PRECEDENCE[no];\n if (pp_1 > np) {\n return true;\n }\n if (pp_1 === np && this.name === \"right\") {\n if (parent.right !== n_1) {\n throw new Error(\"Nodes must be equal\");\n }\n return true;\n }\n }\n default:\n return false;\n }\n case \"SequenceExpression\":\n switch (parent.type) {\n case \"ForStatement\":\n // Although parentheses wouldn't hurt around sequence\n // expressions in the head of for loops, traditional style\n // dictates that e.g. i++, j++ should not be wrapped with\n // parentheses.\n return false;\n case \"ExpressionStatement\":\n return this.name !== \"expression\";\n default:\n // Otherwise err on the side of overparenthesization, adding\n // explicit exceptions above if this proves overzealous.\n return true;\n }\n case \"YieldExpression\":\n switch (parent.type) {\n case \"BinaryExpression\":\n case \"LogicalExpression\":\n case \"UnaryExpression\":\n case \"SpreadElement\":\n case \"SpreadProperty\":\n case \"CallExpression\":\n case \"MemberExpression\":\n case \"NewExpression\":\n case \"ConditionalExpression\":\n case \"YieldExpression\":\n return true;\n default:\n return false;\n }\n case \"Literal\":\n return parent.type === \"MemberExpression\"\n && isNumber.check(node.value)\n && this.name === \"object\"\n && parent.object === node;\n case \"AssignmentExpression\":\n case \"ConditionalExpression\":\n switch (parent.type) {\n case \"UnaryExpression\":\n case \"SpreadElement\":\n case \"SpreadProperty\":\n case \"BinaryExpression\":\n case \"LogicalExpression\":\n return true;\n case \"CallExpression\":\n return this.name === \"callee\"\n && parent.callee === node;\n case \"ConditionalExpression\":\n return this.name === \"test\"\n && parent.test === node;\n case \"MemberExpression\":\n return this.name === \"object\"\n && parent.object === node;\n default:\n return false;\n }\n default:\n if (parent.type === \"NewExpression\" &&\n this.name === \"callee\" &&\n parent.callee === node) {\n return containsCallExpression(node);\n }\n }\n if (assumeExpressionContext !== true &&\n !this.canBeFirstInStatement() &&\n this.firstInStatement())\n return true;\n return false;\n };\n function isBinary(node) {\n return n.BinaryExpression.check(node)\n || n.LogicalExpression.check(node);\n }\n // @ts-ignore 'isUnaryLike' is declared but its value is never read. [6133]\n function isUnaryLike(node) {\n return n.UnaryExpression.check(node)\n // I considered making SpreadElement and SpreadProperty subtypes\n // of UnaryExpression, but they're not really Expression nodes.\n || (n.SpreadElement && n.SpreadElement.check(node))\n || (n.SpreadProperty && n.SpreadProperty.check(node));\n }\n var PRECEDENCE = {};\n [[\"||\"],\n [\"&&\"],\n [\"|\"],\n [\"^\"],\n [\"&\"],\n [\"==\", \"===\", \"!=\", \"!==\"],\n [\"<\", \">\", \"<=\", \">=\", \"in\", \"instanceof\"],\n [\">>\", \"<<\", \">>>\"],\n [\"+\", \"-\"],\n [\"*\", \"/\", \"%\"]\n ].forEach(function (tier, i) {\n tier.forEach(function (op) {\n PRECEDENCE[op] = i;\n });\n });\n function containsCallExpression(node) {\n if (n.CallExpression.check(node)) {\n return true;\n }\n if (isArray.check(node)) {\n return node.some(containsCallExpression);\n }\n if (n.Node.check(node)) {\n return types.someField(node, function (_name, child) {\n return containsCallExpression(child);\n });\n }\n return false;\n }\n NPp.canBeFirstInStatement = function () {\n var node = this.node;\n return !n.FunctionExpression.check(node)\n && !n.ObjectExpression.check(node);\n };\n NPp.firstInStatement = function () {\n return firstInStatement(this);\n };\n function firstInStatement(path) {\n for (var node, parent; path.parent; path = path.parent) {\n node = path.node;\n parent = path.parent.node;\n if (n.BlockStatement.check(parent) &&\n path.parent.name === \"body\" &&\n path.name === 0) {\n if (parent.body[0] !== node) {\n throw new Error(\"Nodes must be equal\");\n }\n return true;\n }\n if (n.ExpressionStatement.check(parent) &&\n path.name === \"expression\") {\n if (parent.expression !== node) {\n throw new Error(\"Nodes must be equal\");\n }\n return true;\n }\n if (n.SequenceExpression.check(parent) &&\n path.parent.name === \"expressions\" &&\n path.name === 0) {\n if (parent.expressions[0] !== node) {\n throw new Error(\"Nodes must be equal\");\n }\n continue;\n }\n if (n.CallExpression.check(parent) &&\n path.name === \"callee\") {\n if (parent.callee !== node) {\n throw new Error(\"Nodes must be equal\");\n }\n continue;\n }\n if (n.MemberExpression.check(parent) &&\n path.name === \"object\") {\n if (parent.object !== node) {\n throw new Error(\"Nodes must be equal\");\n }\n continue;\n }\n if (n.ConditionalExpression.check(parent) &&\n path.name === \"test\") {\n if (parent.test !== node) {\n throw new Error(\"Nodes must be equal\");\n }\n continue;\n }\n if (isBinary(parent) &&\n path.name === \"left\") {\n if (parent.left !== node) {\n throw new Error(\"Nodes must be equal\");\n }\n continue;\n }\n if (n.UnaryExpression.check(parent) &&\n !parent.prefix &&\n path.name === \"argument\") {\n if (parent.argument !== node) {\n throw new Error(\"Nodes must be equal\");\n }\n continue;\n }\n return false;\n }\n return true;\n }\n /**\n * Pruning certain nodes will result in empty or incomplete nodes, here we clean those nodes up.\n */\n function cleanUpNodesAfterPrune(remainingNodePath) {\n if (n.VariableDeclaration.check(remainingNodePath.node)) {\n var declarations = remainingNodePath.get('declarations').value;\n if (!declarations || declarations.length === 0) {\n return remainingNodePath.prune();\n }\n }\n else if (n.ExpressionStatement.check(remainingNodePath.node)) {\n if (!remainingNodePath.get('expression').value) {\n return remainingNodePath.prune();\n }\n }\n else if (n.IfStatement.check(remainingNodePath.node)) {\n cleanUpIfStatementAfterPrune(remainingNodePath);\n }\n return remainingNodePath;\n }\n function cleanUpIfStatementAfterPrune(ifStatement) {\n var testExpression = ifStatement.get('test').value;\n var alternate = ifStatement.get('alternate').value;\n var consequent = ifStatement.get('consequent').value;\n if (!consequent && !alternate) {\n var testExpressionStatement = b.expressionStatement(testExpression);\n ifStatement.replace(testExpressionStatement);\n }\n else if (!consequent && alternate) {\n var negatedTestExpression = b.unaryExpression('!', testExpression, true);\n if (n.UnaryExpression.check(testExpression) && testExpression.operator === '!') {\n negatedTestExpression = testExpression.argument;\n }\n ifStatement.get(\"test\").replace(negatedTestExpression);\n ifStatement.get(\"consequent\").replace(alternate);\n ifStatement.get(\"alternate\").replace();\n }\n }\n return NodePath;\n}\nexports.default = nodePathPlugin;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=node-path.js.map",
11
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar types_1 = tslib_1.__importDefault(require(\"./types\"));\nvar node_path_1 = tslib_1.__importDefault(require(\"./node-path\"));\nvar shared_1 = require(\"./shared\");\nvar hasOwn = Object.prototype.hasOwnProperty;\nfunction pathVisitorPlugin(fork) {\n var types = fork.use(types_1.default);\n var NodePath = fork.use(node_path_1.default);\n var isArray = types.builtInTypes.array;\n var isObject = types.builtInTypes.object;\n var isFunction = types.builtInTypes.function;\n var undefined;\n var PathVisitor = function PathVisitor() {\n if (!(this instanceof PathVisitor)) {\n throw new Error(\"PathVisitor constructor cannot be invoked without 'new'\");\n }\n // Permanent state.\n this._reusableContextStack = [];\n this._methodNameTable = computeMethodNameTable(this);\n this._shouldVisitComments =\n hasOwn.call(this._methodNameTable, \"Block\") ||\n hasOwn.call(this._methodNameTable, \"Line\");\n this.Context = makeContextConstructor(this);\n // State reset every time PathVisitor.prototype.visit is called.\n this._visiting = false;\n this._changeReported = false;\n };\n function computeMethodNameTable(visitor) {\n var typeNames = Object.create(null);\n for (var methodName in visitor) {\n if (/^visit[A-Z]/.test(methodName)) {\n typeNames[methodName.slice(\"visit\".length)] = true;\n }\n }\n var supertypeTable = types.computeSupertypeLookupTable(typeNames);\n var methodNameTable = Object.create(null);\n var typeNameKeys = Object.keys(supertypeTable);\n var typeNameCount = typeNameKeys.length;\n for (var i = 0; i < typeNameCount; ++i) {\n var typeName = typeNameKeys[i];\n methodName = \"visit\" + supertypeTable[typeName];\n if (isFunction.check(visitor[methodName])) {\n methodNameTable[typeName] = methodName;\n }\n }\n return methodNameTable;\n }\n PathVisitor.fromMethodsObject = function fromMethodsObject(methods) {\n if (methods instanceof PathVisitor) {\n return methods;\n }\n if (!isObject.check(methods)) {\n // An empty visitor?\n return new PathVisitor;\n }\n var Visitor = function Visitor() {\n if (!(this instanceof Visitor)) {\n throw new Error(\"Visitor constructor cannot be invoked without 'new'\");\n }\n PathVisitor.call(this);\n };\n var Vp = Visitor.prototype = Object.create(PVp);\n Vp.constructor = Visitor;\n extend(Vp, methods);\n extend(Visitor, PathVisitor);\n isFunction.assert(Visitor.fromMethodsObject);\n isFunction.assert(Visitor.visit);\n return new Visitor;\n };\n function extend(target, source) {\n for (var property in source) {\n if (hasOwn.call(source, property)) {\n target[property] = source[property];\n }\n }\n return target;\n }\n PathVisitor.visit = function visit(node, methods) {\n return PathVisitor.fromMethodsObject(methods).visit(node);\n };\n var PVp = PathVisitor.prototype;\n PVp.visit = function () {\n if (this._visiting) {\n throw new Error(\"Recursively calling visitor.visit(path) resets visitor state. \" +\n \"Try this.visit(path) or this.traverse(path) instead.\");\n }\n // Private state that needs to be reset before every traversal.\n this._visiting = true;\n this._changeReported = false;\n this._abortRequested = false;\n var argc = arguments.length;\n var args = new Array(argc);\n for (var i = 0; i < argc; ++i) {\n args[i] = arguments[i];\n }\n if (!(args[0] instanceof NodePath)) {\n args[0] = new NodePath({ root: args[0] }).get(\"root\");\n }\n // Called with the same arguments as .visit.\n this.reset.apply(this, args);\n var didNotThrow;\n try {\n var root = this.visitWithoutReset(args[0]);\n didNotThrow = true;\n }\n finally {\n this._visiting = false;\n if (!didNotThrow && this._abortRequested) {\n // If this.visitWithoutReset threw an exception and\n // this._abortRequested was set to true, return the root of\n // the AST instead of letting the exception propagate, so that\n // client code does not have to provide a try-catch block to\n // intercept the AbortRequest exception. Other kinds of\n // exceptions will propagate without being intercepted and\n // rethrown by a catch block, so their stacks will accurately\n // reflect the original throwing context.\n return args[0].value;\n }\n }\n return root;\n };\n PVp.AbortRequest = function AbortRequest() { };\n PVp.abort = function () {\n var visitor = this;\n visitor._abortRequested = true;\n var request = new visitor.AbortRequest();\n // If you decide to catch this exception and stop it from propagating,\n // make sure to call its cancel method to avoid silencing other\n // exceptions that might be thrown later in the traversal.\n request.cancel = function () {\n visitor._abortRequested = false;\n };\n throw request;\n };\n PVp.reset = function (_path /*, additional arguments */) {\n // Empty stub; may be reassigned or overridden by subclasses.\n };\n PVp.visitWithoutReset = function (path) {\n if (this instanceof this.Context) {\n // Since this.Context.prototype === this, there's a chance we\n // might accidentally call context.visitWithoutReset. If that\n // happens, re-invoke the method against context.visitor.\n return this.visitor.visitWithoutReset(path);\n }\n if (!(path instanceof NodePath)) {\n throw new Error(\"\");\n }\n var value = path.value;\n var methodName = value &&\n typeof value === \"object\" &&\n typeof value.type === \"string\" &&\n this._methodNameTable[value.type];\n if (methodName) {\n var context = this.acquireContext(path);\n try {\n return context.invokeVisitorMethod(methodName);\n }\n finally {\n this.releaseContext(context);\n }\n }\n else {\n // If there was no visitor method to call, visit the children of\n // this node generically.\n return visitChildren(path, this);\n }\n };\n function visitChildren(path, visitor) {\n if (!(path instanceof NodePath)) {\n throw new Error(\"\");\n }\n if (!(visitor instanceof PathVisitor)) {\n throw new Error(\"\");\n }\n var value = path.value;\n if (isArray.check(value)) {\n path.each(visitor.visitWithoutReset, visitor);\n }\n else if (!isObject.check(value)) {\n // No children to visit.\n }\n else {\n var childNames = types.getFieldNames(value);\n // The .comments field of the Node type is hidden, so we only\n // visit it if the visitor defines visitBlock or visitLine, and\n // value.comments is defined.\n if (visitor._shouldVisitComments &&\n value.comments &&\n childNames.indexOf(\"comments\") < 0) {\n childNames.push(\"comments\");\n }\n var childCount = childNames.length;\n var childPaths = [];\n for (var i = 0; i < childCount; ++i) {\n var childName = childNames[i];\n if (!hasOwn.call(value, childName)) {\n value[childName] = types.getFieldValue(value, childName);\n }\n childPaths.push(path.get(childName));\n }\n for (var i = 0; i < childCount; ++i) {\n visitor.visitWithoutReset(childPaths[i]);\n }\n }\n return path.value;\n }\n PVp.acquireContext = function (path) {\n if (this._reusableContextStack.length === 0) {\n return new this.Context(path);\n }\n return this._reusableContextStack.pop().reset(path);\n };\n PVp.releaseContext = function (context) {\n if (!(context instanceof this.Context)) {\n throw new Error(\"\");\n }\n this._reusableContextStack.push(context);\n context.currentPath = null;\n };\n PVp.reportChanged = function () {\n this._changeReported = true;\n };\n PVp.wasChangeReported = function () {\n return this._changeReported;\n };\n function makeContextConstructor(visitor) {\n function Context(path) {\n if (!(this instanceof Context)) {\n throw new Error(\"\");\n }\n if (!(this instanceof PathVisitor)) {\n throw new Error(\"\");\n }\n if (!(path instanceof NodePath)) {\n throw new Error(\"\");\n }\n Object.defineProperty(this, \"visitor\", {\n value: visitor,\n writable: false,\n enumerable: true,\n configurable: false\n });\n this.currentPath = path;\n this.needToCallTraverse = true;\n Object.seal(this);\n }\n if (!(visitor instanceof PathVisitor)) {\n throw new Error(\"\");\n }\n // Note that the visitor object is the prototype of Context.prototype,\n // so all visitor methods are inherited by context objects.\n var Cp = Context.prototype = Object.create(visitor);\n Cp.constructor = Context;\n extend(Cp, sharedContextProtoMethods);\n return Context;\n }\n // Every PathVisitor has a different this.Context constructor and\n // this.Context.prototype object, but those prototypes can all use the\n // same reset, invokeVisitorMethod, and traverse function objects.\n var sharedContextProtoMethods = Object.create(null);\n sharedContextProtoMethods.reset =\n function reset(path) {\n if (!(this instanceof this.Context)) {\n throw new Error(\"\");\n }\n if (!(path instanceof NodePath)) {\n throw new Error(\"\");\n }\n this.currentPath = path;\n this.needToCallTraverse = true;\n return this;\n };\n sharedContextProtoMethods.invokeVisitorMethod =\n function invokeVisitorMethod(methodName) {\n if (!(this instanceof this.Context)) {\n throw new Error(\"\");\n }\n if (!(this.currentPath instanceof NodePath)) {\n throw new Error(\"\");\n }\n var result = this.visitor[methodName].call(this, this.currentPath);\n if (result === false) {\n // Visitor methods return false to indicate that they have handled\n // their own traversal needs, and we should not complain if\n // this.needToCallTraverse is still true.\n this.needToCallTraverse = false;\n }\n else if (result !== undefined) {\n // Any other non-undefined value returned from the visitor method\n // is interpreted as a replacement value.\n this.currentPath = this.currentPath.replace(result)[0];\n if (this.needToCallTraverse) {\n // If this.traverse still hasn't been called, visit the\n // children of the replacement node.\n this.traverse(this.currentPath);\n }\n }\n if (this.needToCallTraverse !== false) {\n throw new Error(\"Must either call this.traverse or return false in \" + methodName);\n }\n var path = this.currentPath;\n return path && path.value;\n };\n sharedContextProtoMethods.traverse =\n function traverse(path, newVisitor) {\n if (!(this instanceof this.Context)) {\n throw new Error(\"\");\n }\n if (!(path instanceof NodePath)) {\n throw new Error(\"\");\n }\n if (!(this.currentPath instanceof NodePath)) {\n throw new Error(\"\");\n }\n this.needToCallTraverse = false;\n return visitChildren(path, PathVisitor.fromMethodsObject(newVisitor || this.visitor));\n };\n sharedContextProtoMethods.visit =\n function visit(path, newVisitor) {\n if (!(this instanceof this.Context)) {\n throw new Error(\"\");\n }\n if (!(path instanceof NodePath)) {\n throw new Error(\"\");\n }\n if (!(this.currentPath instanceof NodePath)) {\n throw new Error(\"\");\n }\n this.needToCallTraverse = false;\n return PathVisitor.fromMethodsObject(newVisitor || this.visitor).visitWithoutReset(path);\n };\n sharedContextProtoMethods.reportChanged = function reportChanged() {\n this.visitor.reportChanged();\n };\n sharedContextProtoMethods.abort = function abort() {\n this.needToCallTraverse = false;\n this.visitor.abort();\n };\n return PathVisitor;\n}\nexports.default = pathVisitorPlugin;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=path-visitor.js.map",
12
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar shared_1 = require(\"./shared\");\nvar types_1 = tslib_1.__importDefault(require(\"./types\"));\nfunction default_1(fork) {\n var types = fork.use(types_1.default);\n var getFieldNames = types.getFieldNames;\n var getFieldValue = types.getFieldValue;\n var isArray = types.builtInTypes.array;\n var isObject = types.builtInTypes.object;\n var isDate = types.builtInTypes.Date;\n var isRegExp = types.builtInTypes.RegExp;\n var hasOwn = Object.prototype.hasOwnProperty;\n function astNodesAreEquivalent(a, b, problemPath) {\n if (isArray.check(problemPath)) {\n problemPath.length = 0;\n }\n else {\n problemPath = null;\n }\n return areEquivalent(a, b, problemPath);\n }\n astNodesAreEquivalent.assert = function (a, b) {\n var problemPath = [];\n if (!astNodesAreEquivalent(a, b, problemPath)) {\n if (problemPath.length === 0) {\n if (a !== b) {\n throw new Error(\"Nodes must be equal\");\n }\n }\n else {\n throw new Error(\"Nodes differ in the following path: \" +\n problemPath.map(subscriptForProperty).join(\"\"));\n }\n }\n };\n function subscriptForProperty(property) {\n if (/[_$a-z][_$a-z0-9]*/i.test(property)) {\n return \".\" + property;\n }\n return \"[\" + JSON.stringify(property) + \"]\";\n }\n function areEquivalent(a, b, problemPath) {\n if (a === b) {\n return true;\n }\n if (isArray.check(a)) {\n return arraysAreEquivalent(a, b, problemPath);\n }\n if (isObject.check(a)) {\n return objectsAreEquivalent(a, b, problemPath);\n }\n if (isDate.check(a)) {\n return isDate.check(b) && (+a === +b);\n }\n if (isRegExp.check(a)) {\n return isRegExp.check(b) && (a.source === b.source &&\n a.global === b.global &&\n a.multiline === b.multiline &&\n a.ignoreCase === b.ignoreCase);\n }\n return a == b;\n }\n function arraysAreEquivalent(a, b, problemPath) {\n isArray.assert(a);\n var aLength = a.length;\n if (!isArray.check(b) || b.length !== aLength) {\n if (problemPath) {\n problemPath.push(\"length\");\n }\n return false;\n }\n for (var i = 0; i < aLength; ++i) {\n if (problemPath) {\n problemPath.push(i);\n }\n if (i in a !== i in b) {\n return false;\n }\n if (!areEquivalent(a[i], b[i], problemPath)) {\n return false;\n }\n if (problemPath) {\n var problemPathTail = problemPath.pop();\n if (problemPathTail !== i) {\n throw new Error(\"\" + problemPathTail);\n }\n }\n }\n return true;\n }\n function objectsAreEquivalent(a, b, problemPath) {\n isObject.assert(a);\n if (!isObject.check(b)) {\n return false;\n }\n // Fast path for a common property of AST nodes.\n if (a.type !== b.type) {\n if (problemPath) {\n problemPath.push(\"type\");\n }\n return false;\n }\n var aNames = getFieldNames(a);\n var aNameCount = aNames.length;\n var bNames = getFieldNames(b);\n var bNameCount = bNames.length;\n if (aNameCount === bNameCount) {\n for (var i = 0; i < aNameCount; ++i) {\n var name = aNames[i];\n var aChild = getFieldValue(a, name);\n var bChild = getFieldValue(b, name);\n if (problemPath) {\n problemPath.push(name);\n }\n if (!areEquivalent(aChild, bChild, problemPath)) {\n return false;\n }\n if (problemPath) {\n var problemPathTail = problemPath.pop();\n if (problemPathTail !== name) {\n throw new Error(\"\" + problemPathTail);\n }\n }\n }\n return true;\n }\n if (!problemPath) {\n return false;\n }\n // Since aNameCount !== bNameCount, we need to find some name that's\n // missing in aNames but present in bNames, or vice-versa.\n var seenNames = Object.create(null);\n for (i = 0; i < aNameCount; ++i) {\n seenNames[aNames[i]] = true;\n }\n for (i = 0; i < bNameCount; ++i) {\n name = bNames[i];\n if (!hasOwn.call(seenNames, name)) {\n problemPath.push(name);\n return false;\n }\n delete seenNames[name];\n }\n for (name in seenNames) {\n problemPath.push(name);\n break;\n }\n return false;\n }\n return astNodesAreEquivalent;\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=equiv.js.map",
13
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar types_1 = tslib_1.__importDefault(require(\"./types\"));\nvar path_visitor_1 = tslib_1.__importDefault(require(\"./path-visitor\"));\nvar equiv_1 = tslib_1.__importDefault(require(\"./equiv\"));\nvar path_1 = tslib_1.__importDefault(require(\"./path\"));\nvar node_path_1 = tslib_1.__importDefault(require(\"./node-path\"));\nvar shared_1 = require(\"./shared\");\nfunction default_1(plugins) {\n var fork = createFork();\n var types = fork.use(types_1.default);\n plugins.forEach(fork.use);\n types.finalize();\n var PathVisitor = fork.use(path_visitor_1.default);\n return {\n Type: types.Type,\n builtInTypes: types.builtInTypes,\n namedTypes: types.namedTypes,\n builders: types.builders,\n defineMethod: types.defineMethod,\n getFieldNames: types.getFieldNames,\n getFieldValue: types.getFieldValue,\n eachField: types.eachField,\n someField: types.someField,\n getSupertypeNames: types.getSupertypeNames,\n getBuilderName: types.getBuilderName,\n astNodesAreEquivalent: fork.use(equiv_1.default),\n finalize: types.finalize,\n Path: fork.use(path_1.default),\n NodePath: fork.use(node_path_1.default),\n PathVisitor: PathVisitor,\n use: fork.use,\n visit: PathVisitor.visit,\n };\n}\nexports.default = default_1;\n;\nfunction createFork() {\n var used = [];\n var usedResult = [];\n function use(plugin) {\n var idx = used.indexOf(plugin);\n if (idx === -1) {\n idx = used.length;\n used.push(plugin);\n usedResult[idx] = plugin(fork);\n }\n return usedResult[idx];\n }\n var fork = { use: use };\n return fork;\n}\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=fork.js.map",
14
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar shared_1 = require(\"../../shared\");\nfunction default_1() {\n return {\n BinaryOperators: [\n \"==\", \"!=\", \"===\", \"!==\",\n \"<\", \"<=\", \">\", \">=\",\n \"<<\", \">>\", \">>>\",\n \"+\", \"-\", \"*\", \"/\", \"%\",\n \"&\",\n \"|\", \"^\", \"in\",\n \"instanceof\",\n ],\n AssignmentOperators: [\n \"=\", \"+=\", \"-=\", \"*=\", \"/=\", \"%=\",\n \"<<=\", \">>=\", \">>>=\",\n \"|=\", \"^=\", \"&=\",\n ],\n LogicalOperators: [\n \"||\", \"&&\",\n ],\n };\n}\nexports.default = default_1;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=core.js.map",
15
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar shared_1 = require(\"../../shared\");\nvar core_1 = tslib_1.__importDefault(require(\"./core\"));\nfunction default_1(fork) {\n var result = fork.use(core_1.default);\n // Exponentiation operators. Must run before BinaryOperators or\n // AssignmentOperators are used (hence before fork.use(es6Def)).\n // https://github.com/tc39/proposal-exponentiation-operator\n if (result.BinaryOperators.indexOf(\"**\") < 0) {\n result.BinaryOperators.push(\"**\");\n }\n if (result.AssignmentOperators.indexOf(\"**=\") < 0) {\n result.AssignmentOperators.push(\"**=\");\n }\n return result;\n}\nexports.default = default_1;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=es2016.js.map",
16
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar shared_1 = require(\"../../shared\");\nvar es2016_1 = tslib_1.__importDefault(require(\"./es2016\"));\nfunction default_1(fork) {\n var result = fork.use(es2016_1.default);\n // Nullish coalescing. Must run before LogicalOperators is used.\n // https://github.com/tc39/proposal-nullish-coalescing\n if (result.LogicalOperators.indexOf(\"??\") < 0) {\n result.LogicalOperators.push(\"??\");\n }\n return result;\n}\nexports.default = default_1;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=es2020.js.map",
17
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar shared_1 = require(\"../../shared\");\nvar es2020_1 = tslib_1.__importDefault(require(\"./es2020\"));\nfunction default_1(fork) {\n var result = fork.use(es2020_1.default);\n // Logical assignment operators. Must run before AssignmentOperators is used.\n // https://github.com/tc39/proposal-logical-assignment\n result.LogicalOperators.forEach(function (op) {\n var assignOp = op + \"=\";\n if (result.AssignmentOperators.indexOf(assignOp) < 0) {\n result.AssignmentOperators.push(assignOp);\n }\n });\n return result;\n}\nexports.default = default_1;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=es2021.js.map",
18
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar core_1 = tslib_1.__importDefault(require(\"./operators/core\"));\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = tslib_1.__importStar(require(\"../shared\"));\nfunction default_1(fork) {\n var types = fork.use(types_1.default);\n var Type = types.Type;\n var def = Type.def;\n var or = Type.or;\n var shared = fork.use(shared_1.default);\n var defaults = shared.defaults;\n var geq = shared.geq;\n var _a = fork.use(core_1.default), BinaryOperators = _a.BinaryOperators, AssignmentOperators = _a.AssignmentOperators, LogicalOperators = _a.LogicalOperators;\n // Abstract supertype of all syntactic entities that are allowed to have a\n // .loc field.\n def(\"Printable\")\n .field(\"loc\", or(def(\"SourceLocation\"), null), defaults[\"null\"], true);\n def(\"Node\")\n .bases(\"Printable\")\n .field(\"type\", String)\n .field(\"comments\", or([def(\"Comment\")], null), defaults[\"null\"], true);\n def(\"SourceLocation\")\n .field(\"start\", def(\"Position\"))\n .field(\"end\", def(\"Position\"))\n .field(\"source\", or(String, null), defaults[\"null\"]);\n def(\"Position\")\n .field(\"line\", geq(1))\n .field(\"column\", geq(0));\n def(\"File\")\n .bases(\"Node\")\n .build(\"program\", \"name\")\n .field(\"program\", def(\"Program\"))\n .field(\"name\", or(String, null), defaults[\"null\"]);\n def(\"Program\")\n .bases(\"Node\")\n .build(\"body\")\n .field(\"body\", [def(\"Statement\")]);\n def(\"Function\")\n .bases(\"Node\")\n .field(\"id\", or(def(\"Identifier\"), null), defaults[\"null\"])\n .field(\"params\", [def(\"Pattern\")])\n .field(\"body\", def(\"BlockStatement\"))\n .field(\"generator\", Boolean, defaults[\"false\"])\n .field(\"async\", Boolean, defaults[\"false\"]);\n def(\"Statement\").bases(\"Node\");\n // The empty .build() here means that an EmptyStatement can be constructed\n // (i.e. it's not abstract) but that it needs no arguments.\n def(\"EmptyStatement\").bases(\"Statement\").build();\n def(\"BlockStatement\")\n .bases(\"Statement\")\n .build(\"body\")\n .field(\"body\", [def(\"Statement\")]);\n // TODO Figure out how to silently coerce Expressions to\n // ExpressionStatements where a Statement was expected.\n def(\"ExpressionStatement\")\n .bases(\"Statement\")\n .build(\"expression\")\n .field(\"expression\", def(\"Expression\"));\n def(\"IfStatement\")\n .bases(\"Statement\")\n .build(\"test\", \"consequent\", \"alternate\")\n .field(\"test\", def(\"Expression\"))\n .field(\"consequent\", def(\"Statement\"))\n .field(\"alternate\", or(def(\"Statement\"), null), defaults[\"null\"]);\n def(\"LabeledStatement\")\n .bases(\"Statement\")\n .build(\"label\", \"body\")\n .field(\"label\", def(\"Identifier\"))\n .field(\"body\", def(\"Statement\"));\n def(\"BreakStatement\")\n .bases(\"Statement\")\n .build(\"label\")\n .field(\"label\", or(def(\"Identifier\"), null), defaults[\"null\"]);\n def(\"ContinueStatement\")\n .bases(\"Statement\")\n .build(\"label\")\n .field(\"label\", or(def(\"Identifier\"), null), defaults[\"null\"]);\n def(\"WithStatement\")\n .bases(\"Statement\")\n .build(\"object\", \"body\")\n .field(\"object\", def(\"Expression\"))\n .field(\"body\", def(\"Statement\"));\n def(\"SwitchStatement\")\n .bases(\"Statement\")\n .build(\"discriminant\", \"cases\", \"lexical\")\n .field(\"discriminant\", def(\"Expression\"))\n .field(\"cases\", [def(\"SwitchCase\")])\n .field(\"lexical\", Boolean, defaults[\"false\"]);\n def(\"ReturnStatement\")\n .bases(\"Statement\")\n .build(\"argument\")\n .field(\"argument\", or(def(\"Expression\"), null));\n def(\"ThrowStatement\")\n .bases(\"Statement\")\n .build(\"argument\")\n .field(\"argument\", def(\"Expression\"));\n def(\"TryStatement\")\n .bases(\"Statement\")\n .build(\"block\", \"handler\", \"finalizer\")\n .field(\"block\", def(\"BlockStatement\"))\n .field(\"handler\", or(def(\"CatchClause\"), null), function () {\n return this.handlers && this.handlers[0] || null;\n })\n .field(\"handlers\", [def(\"CatchClause\")], function () {\n return this.handler ? [this.handler] : [];\n }, true) // Indicates this field is hidden from eachField iteration.\n .field(\"guardedHandlers\", [def(\"CatchClause\")], defaults.emptyArray)\n .field(\"finalizer\", or(def(\"BlockStatement\"), null), defaults[\"null\"]);\n def(\"CatchClause\")\n .bases(\"Node\")\n .build(\"param\", \"guard\", \"body\")\n .field(\"param\", def(\"Pattern\"))\n .field(\"guard\", or(def(\"Expression\"), null), defaults[\"null\"])\n .field(\"body\", def(\"BlockStatement\"));\n def(\"WhileStatement\")\n .bases(\"Statement\")\n .build(\"test\", \"body\")\n .field(\"test\", def(\"Expression\"))\n .field(\"body\", def(\"Statement\"));\n def(\"DoWhileStatement\")\n .bases(\"Statement\")\n .build(\"body\", \"test\")\n .field(\"body\", def(\"Statement\"))\n .field(\"test\", def(\"Expression\"));\n def(\"ForStatement\")\n .bases(\"Statement\")\n .build(\"init\", \"test\", \"update\", \"body\")\n .field(\"init\", or(def(\"VariableDeclaration\"), def(\"Expression\"), null))\n .field(\"test\", or(def(\"Expression\"), null))\n .field(\"update\", or(def(\"Expression\"), null))\n .field(\"body\", def(\"Statement\"));\n def(\"ForInStatement\")\n .bases(\"Statement\")\n .build(\"left\", \"right\", \"body\")\n .field(\"left\", or(def(\"VariableDeclaration\"), def(\"Expression\")))\n .field(\"right\", def(\"Expression\"))\n .field(\"body\", def(\"Statement\"));\n def(\"DebuggerStatement\").bases(\"Statement\").build();\n def(\"Declaration\").bases(\"Statement\");\n def(\"FunctionDeclaration\")\n .bases(\"Function\", \"Declaration\")\n .build(\"id\", \"params\", \"body\")\n .field(\"id\", def(\"Identifier\"));\n def(\"FunctionExpression\")\n .bases(\"Function\", \"Expression\")\n .build(\"id\", \"params\", \"body\");\n def(\"VariableDeclaration\")\n .bases(\"Declaration\")\n .build(\"kind\", \"declarations\")\n .field(\"kind\", or(\"var\", \"let\", \"const\"))\n .field(\"declarations\", [def(\"VariableDeclarator\")]);\n def(\"VariableDeclarator\")\n .bases(\"Node\")\n .build(\"id\", \"init\")\n .field(\"id\", def(\"Pattern\"))\n .field(\"init\", or(def(\"Expression\"), null), defaults[\"null\"]);\n def(\"Expression\").bases(\"Node\");\n def(\"ThisExpression\").bases(\"Expression\").build();\n def(\"ArrayExpression\")\n .bases(\"Expression\")\n .build(\"elements\")\n .field(\"elements\", [or(def(\"Expression\"), null)]);\n def(\"ObjectExpression\")\n .bases(\"Expression\")\n .build(\"properties\")\n .field(\"properties\", [def(\"Property\")]);\n // TODO Not in the Mozilla Parser API, but used by Esprima.\n def(\"Property\")\n .bases(\"Node\") // Want to be able to visit Property Nodes.\n .build(\"kind\", \"key\", \"value\")\n .field(\"kind\", or(\"init\", \"get\", \"set\"))\n .field(\"key\", or(def(\"Literal\"), def(\"Identifier\")))\n .field(\"value\", def(\"Expression\"));\n def(\"SequenceExpression\")\n .bases(\"Expression\")\n .build(\"expressions\")\n .field(\"expressions\", [def(\"Expression\")]);\n var UnaryOperator = or(\"-\", \"+\", \"!\", \"~\", \"typeof\", \"void\", \"delete\");\n def(\"UnaryExpression\")\n .bases(\"Expression\")\n .build(\"operator\", \"argument\", \"prefix\")\n .field(\"operator\", UnaryOperator)\n .field(\"argument\", def(\"Expression\"))\n // Esprima doesn't bother with this field, presumably because it's\n // always true for unary operators.\n .field(\"prefix\", Boolean, defaults[\"true\"]);\n var BinaryOperator = or.apply(void 0, BinaryOperators);\n def(\"BinaryExpression\")\n .bases(\"Expression\")\n .build(\"operator\", \"left\", \"right\")\n .field(\"operator\", BinaryOperator)\n .field(\"left\", def(\"Expression\"))\n .field(\"right\", def(\"Expression\"));\n var AssignmentOperator = or.apply(void 0, AssignmentOperators);\n def(\"AssignmentExpression\")\n .bases(\"Expression\")\n .build(\"operator\", \"left\", \"right\")\n .field(\"operator\", AssignmentOperator)\n .field(\"left\", or(def(\"Pattern\"), def(\"MemberExpression\")))\n .field(\"right\", def(\"Expression\"));\n var UpdateOperator = or(\"++\", \"--\");\n def(\"UpdateExpression\")\n .bases(\"Expression\")\n .build(\"operator\", \"argument\", \"prefix\")\n .field(\"operator\", UpdateOperator)\n .field(\"argument\", def(\"Expression\"))\n .field(\"prefix\", Boolean);\n var LogicalOperator = or.apply(void 0, LogicalOperators);\n def(\"LogicalExpression\")\n .bases(\"Expression\")\n .build(\"operator\", \"left\", \"right\")\n .field(\"operator\", LogicalOperator)\n .field(\"left\", def(\"Expression\"))\n .field(\"right\", def(\"Expression\"));\n def(\"ConditionalExpression\")\n .bases(\"Expression\")\n .build(\"test\", \"consequent\", \"alternate\")\n .field(\"test\", def(\"Expression\"))\n .field(\"consequent\", def(\"Expression\"))\n .field(\"alternate\", def(\"Expression\"));\n def(\"NewExpression\")\n .bases(\"Expression\")\n .build(\"callee\", \"arguments\")\n .field(\"callee\", def(\"Expression\"))\n // The Mozilla Parser API gives this type as [or(def(\"Expression\"),\n // null)], but null values don't really make sense at the call site.\n // TODO Report this nonsense.\n .field(\"arguments\", [def(\"Expression\")]);\n def(\"CallExpression\")\n .bases(\"Expression\")\n .build(\"callee\", \"arguments\")\n .field(\"callee\", def(\"Expression\"))\n // See comment for NewExpression above.\n .field(\"arguments\", [def(\"Expression\")]);\n def(\"MemberExpression\")\n .bases(\"Expression\")\n .build(\"object\", \"property\", \"computed\")\n .field(\"object\", def(\"Expression\"))\n .field(\"property\", or(def(\"Identifier\"), def(\"Expression\")))\n .field(\"computed\", Boolean, function () {\n var type = this.property.type;\n if (type === 'Literal' ||\n type === 'MemberExpression' ||\n type === 'BinaryExpression') {\n return true;\n }\n return false;\n });\n def(\"Pattern\").bases(\"Node\");\n def(\"SwitchCase\")\n .bases(\"Node\")\n .build(\"test\", \"consequent\")\n .field(\"test\", or(def(\"Expression\"), null))\n .field(\"consequent\", [def(\"Statement\")]);\n def(\"Identifier\")\n .bases(\"Expression\", \"Pattern\")\n .build(\"name\")\n .field(\"name\", String)\n .field(\"optional\", Boolean, defaults[\"false\"]);\n def(\"Literal\")\n .bases(\"Expression\")\n .build(\"value\")\n .field(\"value\", or(String, Boolean, null, Number, RegExp, BigInt));\n // Abstract (non-buildable) comment supertype. Not a Node.\n def(\"Comment\")\n .bases(\"Printable\")\n .field(\"value\", String)\n // A .leading comment comes before the node, whereas a .trailing\n // comment comes after it. These two fields should not both be true,\n // but they might both be false when the comment falls inside a node\n // and the node has no children for the comment to lead or trail,\n // e.g. { /*dangling*/ }.\n .field(\"leading\", Boolean, defaults[\"true\"])\n .field(\"trailing\", Boolean, defaults[\"false\"]);\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=core.js.map",
19
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar core_1 = tslib_1.__importDefault(require(\"./core\"));\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = tslib_1.__importStar(require(\"../shared\"));\nfunction default_1(fork) {\n fork.use(core_1.default);\n var types = fork.use(types_1.default);\n var def = types.Type.def;\n var or = types.Type.or;\n var defaults = fork.use(shared_1.default).defaults;\n def(\"Function\")\n .field(\"generator\", Boolean, defaults[\"false\"])\n .field(\"expression\", Boolean, defaults[\"false\"])\n .field(\"defaults\", [or(def(\"Expression\"), null)], defaults.emptyArray)\n // Legacy\n .field(\"rest\", or(def(\"Identifier\"), null), defaults[\"null\"]);\n // The ESTree way of representing a ...rest parameter.\n def(\"RestElement\")\n .bases(\"Pattern\")\n .build(\"argument\")\n .field(\"argument\", def(\"Pattern\"))\n .field(\"typeAnnotation\", // for Babylon. Flow parser puts it on the identifier\n or(def(\"TypeAnnotation\"), def(\"TSTypeAnnotation\"), null), defaults[\"null\"]);\n def(\"SpreadElementPattern\")\n .bases(\"Pattern\")\n .build(\"argument\")\n .field(\"argument\", def(\"Pattern\"));\n def(\"FunctionDeclaration\")\n .build(\"id\", \"params\", \"body\", \"generator\", \"expression\")\n // May be `null` in the context of `export default function () {}`\n .field(\"id\", or(def(\"Identifier\"), null));\n def(\"FunctionExpression\")\n .build(\"id\", \"params\", \"body\", \"generator\", \"expression\");\n def(\"ArrowFunctionExpression\")\n .bases(\"Function\", \"Expression\")\n .build(\"params\", \"body\", \"expression\")\n // The forced null value here is compatible with the overridden\n // definition of the \"id\" field in the Function interface.\n .field(\"id\", null, defaults[\"null\"])\n // Arrow function bodies are allowed to be expressions.\n .field(\"body\", or(def(\"BlockStatement\"), def(\"Expression\")))\n // The current spec forbids arrow generators, so I have taken the\n // liberty of enforcing that. TODO Report this.\n .field(\"generator\", false, defaults[\"false\"]);\n def(\"ForOfStatement\")\n .bases(\"Statement\")\n .build(\"left\", \"right\", \"body\")\n .field(\"left\", or(def(\"VariableDeclaration\"), def(\"Pattern\")))\n .field(\"right\", def(\"Expression\"))\n .field(\"body\", def(\"Statement\"));\n def(\"YieldExpression\")\n .bases(\"Expression\")\n .build(\"argument\", \"delegate\")\n .field(\"argument\", or(def(\"Expression\"), null))\n .field(\"delegate\", Boolean, defaults[\"false\"]);\n def(\"GeneratorExpression\")\n .bases(\"Expression\")\n .build(\"body\", \"blocks\", \"filter\")\n .field(\"body\", def(\"Expression\"))\n .field(\"blocks\", [def(\"ComprehensionBlock\")])\n .field(\"filter\", or(def(\"Expression\"), null));\n def(\"ComprehensionExpression\")\n .bases(\"Expression\")\n .build(\"body\", \"blocks\", \"filter\")\n .field(\"body\", def(\"Expression\"))\n .field(\"blocks\", [def(\"ComprehensionBlock\")])\n .field(\"filter\", or(def(\"Expression\"), null));\n def(\"ComprehensionBlock\")\n .bases(\"Node\")\n .build(\"left\", \"right\", \"each\")\n .field(\"left\", def(\"Pattern\"))\n .field(\"right\", def(\"Expression\"))\n .field(\"each\", Boolean);\n def(\"Property\")\n .field(\"key\", or(def(\"Literal\"), def(\"Identifier\"), def(\"Expression\")))\n .field(\"value\", or(def(\"Expression\"), def(\"Pattern\")))\n .field(\"method\", Boolean, defaults[\"false\"])\n .field(\"shorthand\", Boolean, defaults[\"false\"])\n .field(\"computed\", Boolean, defaults[\"false\"]);\n def(\"ObjectProperty\")\n .field(\"shorthand\", Boolean, defaults[\"false\"]);\n def(\"PropertyPattern\")\n .bases(\"Pattern\")\n .build(\"key\", \"pattern\")\n .field(\"key\", or(def(\"Literal\"), def(\"Identifier\"), def(\"Expression\")))\n .field(\"pattern\", def(\"Pattern\"))\n .field(\"computed\", Boolean, defaults[\"false\"]);\n def(\"ObjectPattern\")\n .bases(\"Pattern\")\n .build(\"properties\")\n .field(\"properties\", [or(def(\"PropertyPattern\"), def(\"Property\"))]);\n def(\"ArrayPattern\")\n .bases(\"Pattern\")\n .build(\"elements\")\n .field(\"elements\", [or(def(\"Pattern\"), null)]);\n def(\"SpreadElement\")\n .bases(\"Node\")\n .build(\"argument\")\n .field(\"argument\", def(\"Expression\"));\n def(\"ArrayExpression\")\n .field(\"elements\", [or(def(\"Expression\"), def(\"SpreadElement\"), def(\"RestElement\"), null)]);\n def(\"NewExpression\")\n .field(\"arguments\", [or(def(\"Expression\"), def(\"SpreadElement\"))]);\n def(\"CallExpression\")\n .field(\"arguments\", [or(def(\"Expression\"), def(\"SpreadElement\"))]);\n // Note: this node type is *not* an AssignmentExpression with a Pattern on\n // the left-hand side! The existing AssignmentExpression type already\n // supports destructuring assignments. AssignmentPattern nodes may appear\n // wherever a Pattern is allowed, and the right-hand side represents a\n // default value to be destructured against the left-hand side, if no\n // value is otherwise provided. For example: default parameter values.\n def(\"AssignmentPattern\")\n .bases(\"Pattern\")\n .build(\"left\", \"right\")\n .field(\"left\", def(\"Pattern\"))\n .field(\"right\", def(\"Expression\"));\n def(\"MethodDefinition\")\n .bases(\"Declaration\")\n .build(\"kind\", \"key\", \"value\", \"static\")\n .field(\"kind\", or(\"constructor\", \"method\", \"get\", \"set\"))\n .field(\"key\", def(\"Expression\"))\n .field(\"value\", def(\"Function\"))\n .field(\"computed\", Boolean, defaults[\"false\"])\n .field(\"static\", Boolean, defaults[\"false\"]);\n var ClassBodyElement = or(def(\"MethodDefinition\"), def(\"VariableDeclarator\"), def(\"ClassPropertyDefinition\"), def(\"ClassProperty\"), def(\"StaticBlock\"));\n def(\"ClassProperty\")\n .bases(\"Declaration\")\n .build(\"key\")\n .field(\"key\", or(def(\"Literal\"), def(\"Identifier\"), def(\"Expression\")))\n .field(\"computed\", Boolean, defaults[\"false\"]);\n def(\"ClassPropertyDefinition\") // static property\n .bases(\"Declaration\")\n .build(\"definition\")\n // Yes, Virginia, circular definitions are permitted.\n .field(\"definition\", ClassBodyElement);\n def(\"ClassBody\")\n .bases(\"Declaration\")\n .build(\"body\")\n .field(\"body\", [ClassBodyElement]);\n def(\"ClassDeclaration\")\n .bases(\"Declaration\")\n .build(\"id\", \"body\", \"superClass\")\n .field(\"id\", or(def(\"Identifier\"), null))\n .field(\"body\", def(\"ClassBody\"))\n .field(\"superClass\", or(def(\"Expression\"), null), defaults[\"null\"]);\n def(\"ClassExpression\")\n .bases(\"Expression\")\n .build(\"id\", \"body\", \"superClass\")\n .field(\"id\", or(def(\"Identifier\"), null), defaults[\"null\"])\n .field(\"body\", def(\"ClassBody\"))\n .field(\"superClass\", or(def(\"Expression\"), null), defaults[\"null\"]);\n def(\"Super\")\n .bases(\"Expression\")\n .build();\n // Specifier and ModuleSpecifier are abstract non-standard types\n // introduced for definitional convenience.\n def(\"Specifier\").bases(\"Node\");\n // This supertype is shared/abused by both def/babel.js and\n // def/esprima.js. In the future, it will be possible to load only one set\n // of definitions appropriate for a given parser, but until then we must\n // rely on default functions to reconcile the conflicting AST formats.\n def(\"ModuleSpecifier\")\n .bases(\"Specifier\")\n // This local field is used by Babel/Acorn. It should not technically\n // be optional in the Babel/Acorn AST format, but it must be optional\n // in the Esprima AST format.\n .field(\"local\", or(def(\"Identifier\"), null), defaults[\"null\"])\n // The id and name fields are used by Esprima. The id field should not\n // technically be optional in the Esprima AST format, but it must be\n // optional in the Babel/Acorn AST format.\n .field(\"id\", or(def(\"Identifier\"), null), defaults[\"null\"])\n .field(\"name\", or(def(\"Identifier\"), null), defaults[\"null\"]);\n // import {<id [as name]>} from ...;\n def(\"ImportSpecifier\")\n .bases(\"ModuleSpecifier\")\n .build(\"imported\", \"local\")\n .field(\"imported\", def(\"Identifier\"));\n // import <id> from ...;\n def(\"ImportDefaultSpecifier\")\n .bases(\"ModuleSpecifier\")\n .build(\"local\");\n // import <* as id> from ...;\n def(\"ImportNamespaceSpecifier\")\n .bases(\"ModuleSpecifier\")\n .build(\"local\");\n def(\"ImportDeclaration\")\n .bases(\"Declaration\")\n .build(\"specifiers\", \"source\", \"importKind\")\n .field(\"specifiers\", [or(def(\"ImportSpecifier\"), def(\"ImportNamespaceSpecifier\"), def(\"ImportDefaultSpecifier\"))], defaults.emptyArray)\n .field(\"source\", def(\"Literal\"))\n .field(\"importKind\", or(\"value\", \"type\"), function () {\n return \"value\";\n });\n def(\"ExportNamedDeclaration\")\n .bases(\"Declaration\")\n .build(\"declaration\", \"specifiers\", \"source\")\n .field(\"declaration\", or(def(\"Declaration\"), null))\n .field(\"specifiers\", [def(\"ExportSpecifier\")], defaults.emptyArray)\n .field(\"source\", or(def(\"Literal\"), null), defaults[\"null\"]);\n def(\"ExportSpecifier\")\n .bases(\"ModuleSpecifier\")\n .build(\"local\", \"exported\")\n .field(\"exported\", def(\"Identifier\"));\n def(\"ExportDefaultDeclaration\")\n .bases(\"Declaration\")\n .build(\"declaration\")\n .field(\"declaration\", or(def(\"Declaration\"), def(\"Expression\")));\n def(\"ExportAllDeclaration\")\n .bases(\"Declaration\")\n .build(\"source\")\n .field(\"source\", def(\"Literal\"));\n def(\"TaggedTemplateExpression\")\n .bases(\"Expression\")\n .build(\"tag\", \"quasi\")\n .field(\"tag\", def(\"Expression\"))\n .field(\"quasi\", def(\"TemplateLiteral\"));\n def(\"TemplateLiteral\")\n .bases(\"Expression\")\n .build(\"quasis\", \"expressions\")\n .field(\"quasis\", [def(\"TemplateElement\")])\n .field(\"expressions\", [def(\"Expression\")]);\n def(\"TemplateElement\")\n .bases(\"Node\")\n .build(\"value\", \"tail\")\n .field(\"value\", { \"cooked\": String, \"raw\": String })\n .field(\"tail\", Boolean);\n def(\"MetaProperty\")\n .bases(\"Expression\")\n .build(\"meta\", \"property\")\n .field(\"meta\", def(\"Identifier\"))\n .field(\"property\", def(\"Identifier\"));\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=es6.js.map",
20
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar es2016_1 = tslib_1.__importDefault(require(\"./operators/es2016\"));\nvar es6_1 = tslib_1.__importDefault(require(\"./es6\"));\nvar shared_1 = require(\"../shared\");\nfunction default_1(fork) {\n // The es2016OpsDef plugin comes before es6Def so BinaryOperators and\n // AssignmentOperators will be appropriately augmented before they are first\n // used in the core definitions for this fork.\n fork.use(es2016_1.default);\n fork.use(es6_1.default);\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=es2016.js.map",
21
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar es2016_1 = tslib_1.__importDefault(require(\"./es2016\"));\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = tslib_1.__importStar(require(\"../shared\"));\nfunction default_1(fork) {\n fork.use(es2016_1.default);\n var types = fork.use(types_1.default);\n var def = types.Type.def;\n var defaults = fork.use(shared_1.default).defaults;\n def(\"Function\")\n .field(\"async\", Boolean, defaults[\"false\"]);\n def(\"AwaitExpression\")\n .bases(\"Expression\")\n .build(\"argument\")\n .field(\"argument\", def(\"Expression\"));\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=es2017.js.map",
22
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar es2017_1 = tslib_1.__importDefault(require(\"./es2017\"));\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = tslib_1.__importStar(require(\"../shared\"));\nfunction default_1(fork) {\n fork.use(es2017_1.default);\n var types = fork.use(types_1.default);\n var def = types.Type.def;\n var or = types.Type.or;\n var defaults = fork.use(shared_1.default).defaults;\n def(\"ForOfStatement\")\n .field(\"await\", Boolean, defaults[\"false\"]);\n // Legacy\n def(\"SpreadProperty\")\n .bases(\"Node\")\n .build(\"argument\")\n .field(\"argument\", def(\"Expression\"));\n def(\"ObjectExpression\")\n .field(\"properties\", [or(def(\"Property\"), def(\"SpreadProperty\"), // Legacy\n def(\"SpreadElement\"))]);\n def(\"TemplateElement\")\n .field(\"value\", { \"cooked\": or(String, null), \"raw\": String });\n // Legacy\n def(\"SpreadPropertyPattern\")\n .bases(\"Pattern\")\n .build(\"argument\")\n .field(\"argument\", def(\"Pattern\"));\n def(\"ObjectPattern\")\n .field(\"properties\", [or(def(\"PropertyPattern\"), def(\"Property\"), def(\"RestElement\"), def(\"SpreadPropertyPattern\"))]);\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=es2018.js.map",
23
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar es2018_1 = tslib_1.__importDefault(require(\"./es2018\"));\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = tslib_1.__importStar(require(\"../shared\"));\nfunction default_1(fork) {\n fork.use(es2018_1.default);\n var types = fork.use(types_1.default);\n var def = types.Type.def;\n var or = types.Type.or;\n var defaults = fork.use(shared_1.default).defaults;\n def(\"CatchClause\")\n .field(\"param\", or(def(\"Pattern\"), null), defaults[\"null\"]);\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=es2019.js.map",
24
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar es2020_1 = tslib_1.__importDefault(require(\"./operators/es2020\"));\nvar es2019_1 = tslib_1.__importDefault(require(\"./es2019\"));\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = tslib_1.__importStar(require(\"../shared\"));\nfunction default_1(fork) {\n // The es2020OpsDef plugin comes before es2019Def so LogicalOperators will be\n // appropriately augmented before first used.\n fork.use(es2020_1.default);\n fork.use(es2019_1.default);\n var types = fork.use(types_1.default);\n var def = types.Type.def;\n var or = types.Type.or;\n var shared = fork.use(shared_1.default);\n var defaults = shared.defaults;\n def(\"ImportExpression\")\n .bases(\"Expression\")\n .build(\"source\")\n .field(\"source\", def(\"Expression\"));\n def(\"ExportAllDeclaration\")\n .bases(\"Declaration\")\n .build(\"source\", \"exported\")\n .field(\"source\", def(\"Literal\"))\n .field(\"exported\", or(def(\"Identifier\"), null, void 0), defaults[\"null\"]);\n // Optional chaining\n def(\"ChainElement\")\n .bases(\"Node\")\n .field(\"optional\", Boolean, defaults[\"false\"]);\n def(\"CallExpression\")\n .bases(\"Expression\", \"ChainElement\");\n def(\"MemberExpression\")\n .bases(\"Expression\", \"ChainElement\");\n def(\"ChainExpression\")\n .bases(\"Expression\")\n .build(\"expression\")\n .field(\"expression\", def(\"ChainElement\"));\n def(\"OptionalCallExpression\")\n .bases(\"CallExpression\")\n .build(\"callee\", \"arguments\", \"optional\")\n .field(\"optional\", Boolean, defaults[\"true\"]);\n // Deprecated optional chaining type, doesn't work with babelParser@7.11.0 or newer\n def(\"OptionalMemberExpression\")\n .bases(\"MemberExpression\")\n .build(\"object\", \"property\", \"computed\", \"optional\")\n .field(\"optional\", Boolean, defaults[\"true\"]);\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=es2020.js.map",
25
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar es2021_1 = tslib_1.__importDefault(require(\"./operators/es2021\"));\nvar es2020_1 = tslib_1.__importDefault(require(\"./es2020\"));\nvar shared_1 = require(\"../shared\");\nfunction default_1(fork) {\n // The es2021OpsDef plugin comes before es2020Def so AssignmentOperators will\n // be appropriately augmented before first used.\n fork.use(es2021_1.default);\n fork.use(es2020_1.default);\n}\nexports.default = default_1;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=es2021.js.map",
26
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar es2021_1 = tslib_1.__importDefault(require(\"./es2021\"));\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = require(\"../shared\");\nfunction default_1(fork) {\n fork.use(es2021_1.default);\n var types = fork.use(types_1.default);\n var def = types.Type.def;\n def(\"StaticBlock\")\n .bases(\"Declaration\")\n .build(\"body\")\n .field(\"body\", [def(\"Statement\")]);\n}\nexports.default = default_1;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=es2022.js.map",
27
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = tslib_1.__importStar(require(\"../shared\"));\nvar es2022_1 = tslib_1.__importDefault(require(\"./es2022\"));\nfunction default_1(fork) {\n fork.use(es2022_1.default);\n var types = fork.use(types_1.default);\n var Type = types.Type;\n var def = types.Type.def;\n var or = Type.or;\n var shared = fork.use(shared_1.default);\n var defaults = shared.defaults;\n def(\"AwaitExpression\")\n .build(\"argument\", \"all\")\n .field(\"argument\", or(def(\"Expression\"), null))\n .field(\"all\", Boolean, defaults[\"false\"]);\n // Decorators\n def(\"Decorator\")\n .bases(\"Node\")\n .build(\"expression\")\n .field(\"expression\", def(\"Expression\"));\n def(\"Property\")\n .field(\"decorators\", or([def(\"Decorator\")], null), defaults[\"null\"]);\n def(\"MethodDefinition\")\n .field(\"decorators\", or([def(\"Decorator\")], null), defaults[\"null\"]);\n // Private names\n def(\"PrivateName\")\n .bases(\"Expression\", \"Pattern\")\n .build(\"id\")\n .field(\"id\", def(\"Identifier\"));\n def(\"ClassPrivateProperty\")\n .bases(\"ClassProperty\")\n .build(\"key\", \"value\")\n .field(\"key\", def(\"PrivateName\"))\n .field(\"value\", or(def(\"Expression\"), null), defaults[\"null\"]);\n // https://github.com/tc39/proposal-import-assertions\n def(\"ImportAttribute\")\n .bases(\"Node\")\n .build(\"key\", \"value\")\n .field(\"key\", or(def(\"Identifier\"), def(\"Literal\")))\n .field(\"value\", def(\"Expression\"));\n [\"ImportDeclaration\",\n \"ExportAllDeclaration\",\n \"ExportNamedDeclaration\",\n ].forEach(function (decl) {\n def(decl).field(\"assertions\", [def(\"ImportAttribute\")], defaults.emptyArray);\n });\n // https://github.com/tc39/proposal-record-tuple\n // https://github.com/babel/babel/pull/10865\n def(\"RecordExpression\")\n .bases(\"Expression\")\n .build(\"properties\")\n .field(\"properties\", [or(def(\"ObjectProperty\"), def(\"ObjectMethod\"), def(\"SpreadElement\"))]);\n def(\"TupleExpression\")\n .bases(\"Expression\")\n .build(\"elements\")\n .field(\"elements\", [or(def(\"Expression\"), def(\"SpreadElement\"), null)]);\n // https://github.com/tc39/proposal-js-module-blocks\n // https://github.com/babel/babel/pull/12469\n def(\"ModuleExpression\")\n .bases(\"Node\")\n .build(\"body\")\n .field(\"body\", def(\"Program\"));\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=es-proposals.js.map",
28
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar es_proposals_1 = tslib_1.__importDefault(require(\"./es-proposals\"));\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = tslib_1.__importStar(require(\"../shared\"));\nfunction default_1(fork) {\n fork.use(es_proposals_1.default);\n var types = fork.use(types_1.default);\n var def = types.Type.def;\n var or = types.Type.or;\n var defaults = fork.use(shared_1.default).defaults;\n def(\"JSXAttribute\")\n .bases(\"Node\")\n .build(\"name\", \"value\")\n .field(\"name\", or(def(\"JSXIdentifier\"), def(\"JSXNamespacedName\")))\n .field(\"value\", or(def(\"Literal\"), // attr=\"value\"\n def(\"JSXExpressionContainer\"), // attr={value}\n def(\"JSXElement\"), // attr=<div />\n def(\"JSXFragment\"), // attr=<></>\n null // attr= or just attr\n ), defaults[\"null\"]);\n def(\"JSXIdentifier\")\n .bases(\"Identifier\")\n .build(\"name\")\n .field(\"name\", String);\n def(\"JSXNamespacedName\")\n .bases(\"Node\")\n .build(\"namespace\", \"name\")\n .field(\"namespace\", def(\"JSXIdentifier\"))\n .field(\"name\", def(\"JSXIdentifier\"));\n def(\"JSXMemberExpression\")\n .bases(\"MemberExpression\")\n .build(\"object\", \"property\")\n .field(\"object\", or(def(\"JSXIdentifier\"), def(\"JSXMemberExpression\")))\n .field(\"property\", def(\"JSXIdentifier\"))\n .field(\"computed\", Boolean, defaults.false);\n var JSXElementName = or(def(\"JSXIdentifier\"), def(\"JSXNamespacedName\"), def(\"JSXMemberExpression\"));\n def(\"JSXSpreadAttribute\")\n .bases(\"Node\")\n .build(\"argument\")\n .field(\"argument\", def(\"Expression\"));\n var JSXAttributes = [or(def(\"JSXAttribute\"), def(\"JSXSpreadAttribute\"))];\n def(\"JSXExpressionContainer\")\n .bases(\"Expression\")\n .build(\"expression\")\n .field(\"expression\", or(def(\"Expression\"), def(\"JSXEmptyExpression\")));\n var JSXChildren = [or(def(\"JSXText\"), def(\"JSXExpressionContainer\"), def(\"JSXSpreadChild\"), def(\"JSXElement\"), def(\"JSXFragment\"), def(\"Literal\") // Legacy: Esprima should return JSXText instead.\n )];\n def(\"JSXElement\")\n .bases(\"Expression\")\n .build(\"openingElement\", \"closingElement\", \"children\")\n .field(\"openingElement\", def(\"JSXOpeningElement\"))\n .field(\"closingElement\", or(def(\"JSXClosingElement\"), null), defaults[\"null\"])\n .field(\"children\", JSXChildren, defaults.emptyArray)\n .field(\"name\", JSXElementName, function () {\n // Little-known fact: the `this` object inside a default function\n // is none other than the partially-built object itself, and any\n // fields initialized directly from builder function arguments\n // (like openingElement, closingElement, and children) are\n // guaranteed to be available.\n return this.openingElement.name;\n }, true) // hidden from traversal\n .field(\"selfClosing\", Boolean, function () {\n return this.openingElement.selfClosing;\n }, true) // hidden from traversal\n .field(\"attributes\", JSXAttributes, function () {\n return this.openingElement.attributes;\n }, true); // hidden from traversal\n def(\"JSXOpeningElement\")\n .bases(\"Node\")\n .build(\"name\", \"attributes\", \"selfClosing\")\n .field(\"name\", JSXElementName)\n .field(\"attributes\", JSXAttributes, defaults.emptyArray)\n .field(\"selfClosing\", Boolean, defaults[\"false\"]);\n def(\"JSXClosingElement\")\n .bases(\"Node\")\n .build(\"name\")\n .field(\"name\", JSXElementName);\n def(\"JSXFragment\")\n .bases(\"Expression\")\n .build(\"openingFragment\", \"closingFragment\", \"children\")\n .field(\"openingFragment\", def(\"JSXOpeningFragment\"))\n .field(\"closingFragment\", def(\"JSXClosingFragment\"))\n .field(\"children\", JSXChildren, defaults.emptyArray);\n def(\"JSXOpeningFragment\")\n .bases(\"Node\")\n .build();\n def(\"JSXClosingFragment\")\n .bases(\"Node\")\n .build();\n def(\"JSXText\")\n .bases(\"Literal\")\n .build(\"value\", \"raw\")\n .field(\"value\", String)\n .field(\"raw\", String, function () {\n return this.value;\n });\n def(\"JSXEmptyExpression\")\n .bases(\"Node\")\n .build();\n def(\"JSXSpreadChild\")\n .bases(\"Node\")\n .build(\"expression\")\n .field(\"expression\", def(\"Expression\"));\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=jsx.js.map",
29
+ "\"use strict\";\n/**\n * Type annotation defs shared between Flow and TypeScript.\n * These defs could not be defined in ./flow.ts or ./typescript.ts directly\n * because they use the same name.\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = tslib_1.__importStar(require(\"../shared\"));\nfunction default_1(fork) {\n var types = fork.use(types_1.default);\n var def = types.Type.def;\n var or = types.Type.or;\n var defaults = fork.use(shared_1.default).defaults;\n var TypeAnnotation = or(def(\"TypeAnnotation\"), def(\"TSTypeAnnotation\"), null);\n var TypeParamDecl = or(def(\"TypeParameterDeclaration\"), def(\"TSTypeParameterDeclaration\"), null);\n def(\"Identifier\")\n .field(\"typeAnnotation\", TypeAnnotation, defaults[\"null\"]);\n def(\"ObjectPattern\")\n .field(\"typeAnnotation\", TypeAnnotation, defaults[\"null\"]);\n def(\"Function\")\n .field(\"returnType\", TypeAnnotation, defaults[\"null\"])\n .field(\"typeParameters\", TypeParamDecl, defaults[\"null\"]);\n def(\"ClassProperty\")\n .build(\"key\", \"value\", \"typeAnnotation\", \"static\")\n .field(\"value\", or(def(\"Expression\"), null))\n .field(\"static\", Boolean, defaults[\"false\"])\n .field(\"typeAnnotation\", TypeAnnotation, defaults[\"null\"]);\n [\"ClassDeclaration\",\n \"ClassExpression\",\n ].forEach(function (typeName) {\n def(typeName)\n .field(\"typeParameters\", TypeParamDecl, defaults[\"null\"])\n .field(\"superTypeParameters\", or(def(\"TypeParameterInstantiation\"), def(\"TSTypeParameterInstantiation\"), null), defaults[\"null\"])\n .field(\"implements\", or([def(\"ClassImplements\")], [def(\"TSExpressionWithTypeArguments\")]), defaults.emptyArray);\n });\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=type-annotations.js.map",
30
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar es_proposals_1 = tslib_1.__importDefault(require(\"./es-proposals\"));\nvar type_annotations_1 = tslib_1.__importDefault(require(\"./type-annotations\"));\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = tslib_1.__importStar(require(\"../shared\"));\nfunction default_1(fork) {\n fork.use(es_proposals_1.default);\n fork.use(type_annotations_1.default);\n var types = fork.use(types_1.default);\n var def = types.Type.def;\n var or = types.Type.or;\n var defaults = fork.use(shared_1.default).defaults;\n // Base types\n def(\"Flow\").bases(\"Node\");\n def(\"FlowType\").bases(\"Flow\");\n // Type annotations\n def(\"AnyTypeAnnotation\")\n .bases(\"FlowType\")\n .build();\n def(\"EmptyTypeAnnotation\")\n .bases(\"FlowType\")\n .build();\n def(\"MixedTypeAnnotation\")\n .bases(\"FlowType\")\n .build();\n def(\"VoidTypeAnnotation\")\n .bases(\"FlowType\")\n .build();\n def(\"SymbolTypeAnnotation\")\n .bases(\"FlowType\")\n .build();\n def(\"NumberTypeAnnotation\")\n .bases(\"FlowType\")\n .build();\n def(\"BigIntTypeAnnotation\")\n .bases(\"FlowType\")\n .build();\n def(\"NumberLiteralTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"value\", \"raw\")\n .field(\"value\", Number)\n .field(\"raw\", String);\n // Babylon 6 differs in AST from Flow\n // same as NumberLiteralTypeAnnotation\n def(\"NumericLiteralTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"value\", \"raw\")\n .field(\"value\", Number)\n .field(\"raw\", String);\n def(\"BigIntLiteralTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"value\", \"raw\")\n .field(\"value\", null)\n .field(\"raw\", String);\n def(\"StringTypeAnnotation\")\n .bases(\"FlowType\")\n .build();\n def(\"StringLiteralTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"value\", \"raw\")\n .field(\"value\", String)\n .field(\"raw\", String);\n def(\"BooleanTypeAnnotation\")\n .bases(\"FlowType\")\n .build();\n def(\"BooleanLiteralTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"value\", \"raw\")\n .field(\"value\", Boolean)\n .field(\"raw\", String);\n def(\"TypeAnnotation\")\n .bases(\"Node\")\n .build(\"typeAnnotation\")\n .field(\"typeAnnotation\", def(\"FlowType\"));\n def(\"NullableTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"typeAnnotation\")\n .field(\"typeAnnotation\", def(\"FlowType\"));\n def(\"NullLiteralTypeAnnotation\")\n .bases(\"FlowType\")\n .build();\n def(\"NullTypeAnnotation\")\n .bases(\"FlowType\")\n .build();\n def(\"ThisTypeAnnotation\")\n .bases(\"FlowType\")\n .build();\n def(\"ExistsTypeAnnotation\")\n .bases(\"FlowType\")\n .build();\n def(\"ExistentialTypeParam\")\n .bases(\"FlowType\")\n .build();\n def(\"FunctionTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"params\", \"returnType\", \"rest\", \"typeParameters\")\n .field(\"params\", [def(\"FunctionTypeParam\")])\n .field(\"returnType\", def(\"FlowType\"))\n .field(\"rest\", or(def(\"FunctionTypeParam\"), null))\n .field(\"typeParameters\", or(def(\"TypeParameterDeclaration\"), null));\n def(\"FunctionTypeParam\")\n .bases(\"Node\")\n .build(\"name\", \"typeAnnotation\", \"optional\")\n .field(\"name\", or(def(\"Identifier\"), null))\n .field(\"typeAnnotation\", def(\"FlowType\"))\n .field(\"optional\", Boolean);\n def(\"ArrayTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"elementType\")\n .field(\"elementType\", def(\"FlowType\"));\n def(\"ObjectTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"properties\", \"indexers\", \"callProperties\")\n .field(\"properties\", [\n or(def(\"ObjectTypeProperty\"), def(\"ObjectTypeSpreadProperty\"))\n ])\n .field(\"indexers\", [def(\"ObjectTypeIndexer\")], defaults.emptyArray)\n .field(\"callProperties\", [def(\"ObjectTypeCallProperty\")], defaults.emptyArray)\n .field(\"inexact\", or(Boolean, void 0), defaults[\"undefined\"])\n .field(\"exact\", Boolean, defaults[\"false\"])\n .field(\"internalSlots\", [def(\"ObjectTypeInternalSlot\")], defaults.emptyArray);\n def(\"Variance\")\n .bases(\"Node\")\n .build(\"kind\")\n .field(\"kind\", or(\"plus\", \"minus\"));\n var LegacyVariance = or(def(\"Variance\"), \"plus\", \"minus\", null);\n def(\"ObjectTypeProperty\")\n .bases(\"Node\")\n .build(\"key\", \"value\", \"optional\")\n .field(\"key\", or(def(\"Literal\"), def(\"Identifier\")))\n .field(\"value\", def(\"FlowType\"))\n .field(\"optional\", Boolean)\n .field(\"variance\", LegacyVariance, defaults[\"null\"]);\n def(\"ObjectTypeIndexer\")\n .bases(\"Node\")\n .build(\"id\", \"key\", \"value\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"key\", def(\"FlowType\"))\n .field(\"value\", def(\"FlowType\"))\n .field(\"variance\", LegacyVariance, defaults[\"null\"])\n .field(\"static\", Boolean, defaults[\"false\"]);\n def(\"ObjectTypeCallProperty\")\n .bases(\"Node\")\n .build(\"value\")\n .field(\"value\", def(\"FunctionTypeAnnotation\"))\n .field(\"static\", Boolean, defaults[\"false\"]);\n def(\"QualifiedTypeIdentifier\")\n .bases(\"Node\")\n .build(\"qualification\", \"id\")\n .field(\"qualification\", or(def(\"Identifier\"), def(\"QualifiedTypeIdentifier\")))\n .field(\"id\", def(\"Identifier\"));\n def(\"GenericTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"id\", \"typeParameters\")\n .field(\"id\", or(def(\"Identifier\"), def(\"QualifiedTypeIdentifier\")))\n .field(\"typeParameters\", or(def(\"TypeParameterInstantiation\"), null));\n def(\"MemberTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"object\", \"property\")\n .field(\"object\", def(\"Identifier\"))\n .field(\"property\", or(def(\"MemberTypeAnnotation\"), def(\"GenericTypeAnnotation\")));\n def(\"IndexedAccessType\")\n .bases(\"FlowType\")\n .build(\"objectType\", \"indexType\")\n .field(\"objectType\", def(\"FlowType\"))\n .field(\"indexType\", def(\"FlowType\"));\n def(\"OptionalIndexedAccessType\")\n .bases(\"FlowType\")\n .build(\"objectType\", \"indexType\", \"optional\")\n .field(\"objectType\", def(\"FlowType\"))\n .field(\"indexType\", def(\"FlowType\"))\n .field('optional', Boolean);\n def(\"UnionTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"types\")\n .field(\"types\", [def(\"FlowType\")]);\n def(\"IntersectionTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"types\")\n .field(\"types\", [def(\"FlowType\")]);\n def(\"TypeofTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"argument\")\n .field(\"argument\", def(\"FlowType\"));\n def(\"ObjectTypeSpreadProperty\")\n .bases(\"Node\")\n .build(\"argument\")\n .field(\"argument\", def(\"FlowType\"));\n def(\"ObjectTypeInternalSlot\")\n .bases(\"Node\")\n .build(\"id\", \"value\", \"optional\", \"static\", \"method\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"value\", def(\"FlowType\"))\n .field(\"optional\", Boolean)\n .field(\"static\", Boolean)\n .field(\"method\", Boolean);\n def(\"TypeParameterDeclaration\")\n .bases(\"Node\")\n .build(\"params\")\n .field(\"params\", [def(\"TypeParameter\")]);\n def(\"TypeParameterInstantiation\")\n .bases(\"Node\")\n .build(\"params\")\n .field(\"params\", [def(\"FlowType\")]);\n def(\"TypeParameter\")\n .bases(\"FlowType\")\n .build(\"name\", \"variance\", \"bound\", \"default\")\n .field(\"name\", String)\n .field(\"variance\", LegacyVariance, defaults[\"null\"])\n .field(\"bound\", or(def(\"TypeAnnotation\"), null), defaults[\"null\"])\n .field(\"default\", or(def(\"FlowType\"), null), defaults[\"null\"]);\n def(\"ClassProperty\")\n .field(\"variance\", LegacyVariance, defaults[\"null\"]);\n def(\"ClassImplements\")\n .bases(\"Node\")\n .build(\"id\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"superClass\", or(def(\"Expression\"), null), defaults[\"null\"])\n .field(\"typeParameters\", or(def(\"TypeParameterInstantiation\"), null), defaults[\"null\"]);\n def(\"InterfaceTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"body\", \"extends\")\n .field(\"body\", def(\"ObjectTypeAnnotation\"))\n .field(\"extends\", or([def(\"InterfaceExtends\")], null), defaults[\"null\"]);\n def(\"InterfaceDeclaration\")\n .bases(\"Declaration\")\n .build(\"id\", \"body\", \"extends\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"typeParameters\", or(def(\"TypeParameterDeclaration\"), null), defaults[\"null\"])\n .field(\"body\", def(\"ObjectTypeAnnotation\"))\n .field(\"extends\", [def(\"InterfaceExtends\")]);\n def(\"DeclareInterface\")\n .bases(\"InterfaceDeclaration\")\n .build(\"id\", \"body\", \"extends\");\n def(\"InterfaceExtends\")\n .bases(\"Node\")\n .build(\"id\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"typeParameters\", or(def(\"TypeParameterInstantiation\"), null), defaults[\"null\"]);\n def(\"TypeAlias\")\n .bases(\"Declaration\")\n .build(\"id\", \"typeParameters\", \"right\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"typeParameters\", or(def(\"TypeParameterDeclaration\"), null))\n .field(\"right\", def(\"FlowType\"));\n def(\"DeclareTypeAlias\")\n .bases(\"TypeAlias\")\n .build(\"id\", \"typeParameters\", \"right\");\n def(\"OpaqueType\")\n .bases(\"Declaration\")\n .build(\"id\", \"typeParameters\", \"impltype\", \"supertype\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"typeParameters\", or(def(\"TypeParameterDeclaration\"), null))\n .field(\"impltype\", def(\"FlowType\"))\n .field(\"supertype\", or(def(\"FlowType\"), null));\n def(\"DeclareOpaqueType\")\n .bases(\"OpaqueType\")\n .build(\"id\", \"typeParameters\", \"supertype\")\n .field(\"impltype\", or(def(\"FlowType\"), null));\n def(\"TypeCastExpression\")\n .bases(\"Expression\")\n .build(\"expression\", \"typeAnnotation\")\n .field(\"expression\", def(\"Expression\"))\n .field(\"typeAnnotation\", def(\"TypeAnnotation\"));\n def(\"TupleTypeAnnotation\")\n .bases(\"FlowType\")\n .build(\"types\")\n .field(\"types\", [def(\"FlowType\")]);\n def(\"DeclareVariable\")\n .bases(\"Statement\")\n .build(\"id\")\n .field(\"id\", def(\"Identifier\"));\n def(\"DeclareFunction\")\n .bases(\"Statement\")\n .build(\"id\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"predicate\", or(def(\"FlowPredicate\"), null), defaults[\"null\"]);\n def(\"DeclareClass\")\n .bases(\"InterfaceDeclaration\")\n .build(\"id\");\n def(\"DeclareModule\")\n .bases(\"Statement\")\n .build(\"id\", \"body\")\n .field(\"id\", or(def(\"Identifier\"), def(\"Literal\")))\n .field(\"body\", def(\"BlockStatement\"));\n def(\"DeclareModuleExports\")\n .bases(\"Statement\")\n .build(\"typeAnnotation\")\n .field(\"typeAnnotation\", def(\"TypeAnnotation\"));\n def(\"DeclareExportDeclaration\")\n .bases(\"Declaration\")\n .build(\"default\", \"declaration\", \"specifiers\", \"source\")\n .field(\"default\", Boolean)\n .field(\"declaration\", or(def(\"DeclareVariable\"), def(\"DeclareFunction\"), def(\"DeclareClass\"), def(\"FlowType\"), // Implies default.\n def(\"TypeAlias\"), // Implies named type\n def(\"DeclareOpaqueType\"), // Implies named opaque type\n def(\"InterfaceDeclaration\"), null))\n .field(\"specifiers\", [or(def(\"ExportSpecifier\"), def(\"ExportBatchSpecifier\"))], defaults.emptyArray)\n .field(\"source\", or(def(\"Literal\"), null), defaults[\"null\"]);\n def(\"DeclareExportAllDeclaration\")\n .bases(\"Declaration\")\n .build(\"source\")\n .field(\"source\", or(def(\"Literal\"), null), defaults[\"null\"]);\n def(\"ImportDeclaration\")\n .field(\"importKind\", or(\"value\", \"type\", \"typeof\"), function () { return \"value\"; });\n def(\"FlowPredicate\").bases(\"Flow\");\n def(\"InferredPredicate\")\n .bases(\"FlowPredicate\")\n .build();\n def(\"DeclaredPredicate\")\n .bases(\"FlowPredicate\")\n .build(\"value\")\n .field(\"value\", def(\"Expression\"));\n def(\"Function\")\n .field(\"predicate\", or(def(\"FlowPredicate\"), null), defaults[\"null\"]);\n def(\"CallExpression\")\n .field(\"typeArguments\", or(null, def(\"TypeParameterInstantiation\")), defaults[\"null\"]);\n def(\"NewExpression\")\n .field(\"typeArguments\", or(null, def(\"TypeParameterInstantiation\")), defaults[\"null\"]);\n // Enums\n def(\"EnumDeclaration\")\n .bases(\"Declaration\")\n .build(\"id\", \"body\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"body\", or(def(\"EnumBooleanBody\"), def(\"EnumNumberBody\"), def(\"EnumStringBody\"), def(\"EnumSymbolBody\")));\n def(\"EnumBooleanBody\")\n .build(\"members\", \"explicitType\")\n .field(\"members\", [def(\"EnumBooleanMember\")])\n .field(\"explicitType\", Boolean);\n def(\"EnumNumberBody\")\n .build(\"members\", \"explicitType\")\n .field(\"members\", [def(\"EnumNumberMember\")])\n .field(\"explicitType\", Boolean);\n def(\"EnumStringBody\")\n .build(\"members\", \"explicitType\")\n .field(\"members\", or([def(\"EnumStringMember\")], [def(\"EnumDefaultedMember\")]))\n .field(\"explicitType\", Boolean);\n def(\"EnumSymbolBody\")\n .build(\"members\")\n .field(\"members\", [def(\"EnumDefaultedMember\")]);\n def(\"EnumBooleanMember\")\n .build(\"id\", \"init\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"init\", or(def(\"Literal\"), Boolean));\n def(\"EnumNumberMember\")\n .build(\"id\", \"init\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"init\", def(\"Literal\"));\n def(\"EnumStringMember\")\n .build(\"id\", \"init\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"init\", def(\"Literal\"));\n def(\"EnumDefaultedMember\")\n .build(\"id\")\n .field(\"id\", def(\"Identifier\"));\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=flow.js.map",
31
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar es_proposals_1 = tslib_1.__importDefault(require(\"./es-proposals\"));\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = tslib_1.__importStar(require(\"../shared\"));\nfunction default_1(fork) {\n fork.use(es_proposals_1.default);\n var types = fork.use(types_1.default);\n var defaults = fork.use(shared_1.default).defaults;\n var def = types.Type.def;\n var or = types.Type.or;\n def(\"VariableDeclaration\")\n .field(\"declarations\", [or(def(\"VariableDeclarator\"), def(\"Identifier\") // Esprima deviation.\n )]);\n def(\"Property\")\n .field(\"value\", or(def(\"Expression\"), def(\"Pattern\") // Esprima deviation.\n ));\n def(\"ArrayPattern\")\n .field(\"elements\", [or(def(\"Pattern\"), def(\"SpreadElement\"), null)]);\n def(\"ObjectPattern\")\n .field(\"properties\", [or(def(\"Property\"), def(\"PropertyPattern\"), def(\"SpreadPropertyPattern\"), def(\"SpreadProperty\") // Used by Esprima.\n )]);\n // Like ModuleSpecifier, except type:\"ExportSpecifier\" and buildable.\n // export {<id [as name]>} [from ...];\n def(\"ExportSpecifier\")\n .bases(\"ModuleSpecifier\")\n .build(\"id\", \"name\");\n // export <*> from ...;\n def(\"ExportBatchSpecifier\")\n .bases(\"Specifier\")\n .build();\n def(\"ExportDeclaration\")\n .bases(\"Declaration\")\n .build(\"default\", \"declaration\", \"specifiers\", \"source\")\n .field(\"default\", Boolean)\n .field(\"declaration\", or(def(\"Declaration\"), def(\"Expression\"), // Implies default.\n null))\n .field(\"specifiers\", [or(def(\"ExportSpecifier\"), def(\"ExportBatchSpecifier\"))], defaults.emptyArray)\n .field(\"source\", or(def(\"Literal\"), null), defaults[\"null\"]);\n def(\"Block\")\n .bases(\"Comment\")\n .build(\"value\", /*optional:*/ \"leading\", \"trailing\");\n def(\"Line\")\n .bases(\"Comment\")\n .build(\"value\", /*optional:*/ \"leading\", \"trailing\");\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=esprima.js.map",
32
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar es_proposals_1 = tslib_1.__importDefault(require(\"./es-proposals\"));\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = tslib_1.__importStar(require(\"../shared\"));\nfunction default_1(fork) {\n var _a, _b, _c, _d, _e;\n fork.use(es_proposals_1.default);\n var types = fork.use(types_1.default);\n var defaults = fork.use(shared_1.default).defaults;\n var def = types.Type.def;\n var or = types.Type.or;\n var isUndefined = types.builtInTypes.undefined;\n def(\"Noop\")\n .bases(\"Statement\")\n .build();\n def(\"DoExpression\")\n .bases(\"Expression\")\n .build(\"body\")\n .field(\"body\", [def(\"Statement\")]);\n def(\"BindExpression\")\n .bases(\"Expression\")\n .build(\"object\", \"callee\")\n .field(\"object\", or(def(\"Expression\"), null))\n .field(\"callee\", def(\"Expression\"));\n def(\"ParenthesizedExpression\")\n .bases(\"Expression\")\n .build(\"expression\")\n .field(\"expression\", def(\"Expression\"));\n def(\"ExportNamespaceSpecifier\")\n .bases(\"Specifier\")\n .build(\"exported\")\n .field(\"exported\", def(\"Identifier\"));\n def(\"ExportDefaultSpecifier\")\n .bases(\"Specifier\")\n .build(\"exported\")\n .field(\"exported\", def(\"Identifier\"));\n def(\"CommentBlock\")\n .bases(\"Comment\")\n .build(\"value\", /*optional:*/ \"leading\", \"trailing\");\n def(\"CommentLine\")\n .bases(\"Comment\")\n .build(\"value\", /*optional:*/ \"leading\", \"trailing\");\n def(\"Directive\")\n .bases(\"Node\")\n .build(\"value\")\n .field(\"value\", def(\"DirectiveLiteral\"));\n def(\"DirectiveLiteral\")\n .bases(\"Node\", \"Expression\")\n .build(\"value\")\n .field(\"value\", String, defaults[\"use strict\"]);\n def(\"InterpreterDirective\")\n .bases(\"Node\")\n .build(\"value\")\n .field(\"value\", String);\n def(\"BlockStatement\")\n .bases(\"Statement\")\n .build(\"body\")\n .field(\"body\", [def(\"Statement\")])\n .field(\"directives\", [def(\"Directive\")], defaults.emptyArray);\n def(\"Program\")\n .bases(\"Node\")\n .build(\"body\")\n .field(\"body\", [def(\"Statement\")])\n .field(\"directives\", [def(\"Directive\")], defaults.emptyArray)\n .field(\"interpreter\", or(def(\"InterpreterDirective\"), null), defaults[\"null\"]);\n function makeLiteralExtra(rawValueType, toRaw) {\n if (rawValueType === void 0) { rawValueType = String; }\n return [\n \"extra\",\n {\n rawValue: rawValueType,\n raw: String,\n },\n function getDefault() {\n var value = types.getFieldValue(this, \"value\");\n return {\n rawValue: value,\n raw: toRaw ? toRaw(value) : String(value),\n };\n },\n ];\n }\n // Split Literal\n (_a = def(\"StringLiteral\")\n .bases(\"Literal\")\n .build(\"value\")\n .field(\"value\", String))\n .field.apply(_a, makeLiteralExtra(String, function (val) { return JSON.stringify(val); }));\n (_b = def(\"NumericLiteral\")\n .bases(\"Literal\")\n .build(\"value\")\n .field(\"value\", Number)\n .field(\"raw\", or(String, null), defaults[\"null\"]))\n .field.apply(_b, makeLiteralExtra(Number));\n (_c = def(\"BigIntLiteral\")\n .bases(\"Literal\")\n .build(\"value\")\n // Only String really seems appropriate here, since BigInt values\n // often exceed the limits of JS numbers.\n .field(\"value\", or(String, Number)))\n .field.apply(_c, makeLiteralExtra(String, function (val) { return val + \"n\"; }));\n // https://github.com/tc39/proposal-decimal\n // https://github.com/babel/babel/pull/11640\n (_d = def(\"DecimalLiteral\")\n .bases(\"Literal\")\n .build(\"value\")\n .field(\"value\", String))\n .field.apply(_d, makeLiteralExtra(String, function (val) { return val + \"m\"; }));\n def(\"NullLiteral\")\n .bases(\"Literal\")\n .build()\n .field(\"value\", null, defaults[\"null\"]);\n def(\"BooleanLiteral\")\n .bases(\"Literal\")\n .build(\"value\")\n .field(\"value\", Boolean);\n (_e = def(\"RegExpLiteral\")\n .bases(\"Literal\")\n .build(\"pattern\", \"flags\")\n .field(\"pattern\", String)\n .field(\"flags\", String)\n .field(\"value\", RegExp, function () {\n return new RegExp(this.pattern, this.flags);\n }))\n .field.apply(_e, makeLiteralExtra(or(RegExp, isUndefined), function (exp) { return \"/\".concat(exp.pattern, \"/\").concat(exp.flags || \"\"); })).field(\"regex\", {\n pattern: String,\n flags: String\n }, function () {\n return {\n pattern: this.pattern,\n flags: this.flags,\n };\n });\n var ObjectExpressionProperty = or(def(\"Property\"), def(\"ObjectMethod\"), def(\"ObjectProperty\"), def(\"SpreadProperty\"), def(\"SpreadElement\"));\n // Split Property -> ObjectProperty and ObjectMethod\n def(\"ObjectExpression\")\n .bases(\"Expression\")\n .build(\"properties\")\n .field(\"properties\", [ObjectExpressionProperty]);\n // ObjectMethod hoist .value properties to own properties\n def(\"ObjectMethod\")\n .bases(\"Node\", \"Function\")\n .build(\"kind\", \"key\", \"params\", \"body\", \"computed\")\n .field(\"kind\", or(\"method\", \"get\", \"set\"))\n .field(\"key\", or(def(\"Literal\"), def(\"Identifier\"), def(\"Expression\")))\n .field(\"params\", [def(\"Pattern\")])\n .field(\"body\", def(\"BlockStatement\"))\n .field(\"computed\", Boolean, defaults[\"false\"])\n .field(\"generator\", Boolean, defaults[\"false\"])\n .field(\"async\", Boolean, defaults[\"false\"])\n .field(\"accessibility\", // TypeScript\n or(def(\"Literal\"), null), defaults[\"null\"])\n .field(\"decorators\", or([def(\"Decorator\")], null), defaults[\"null\"]);\n def(\"ObjectProperty\")\n .bases(\"Node\")\n .build(\"key\", \"value\")\n .field(\"key\", or(def(\"Literal\"), def(\"Identifier\"), def(\"Expression\")))\n .field(\"value\", or(def(\"Expression\"), def(\"Pattern\")))\n .field(\"accessibility\", // TypeScript\n or(def(\"Literal\"), null), defaults[\"null\"])\n .field(\"computed\", Boolean, defaults[\"false\"]);\n var ClassBodyElement = or(def(\"MethodDefinition\"), def(\"VariableDeclarator\"), def(\"ClassPropertyDefinition\"), def(\"ClassProperty\"), def(\"ClassPrivateProperty\"), def(\"ClassMethod\"), def(\"ClassPrivateMethod\"), def(\"ClassAccessorProperty\"), def(\"StaticBlock\"));\n // MethodDefinition -> ClassMethod\n def(\"ClassBody\")\n .bases(\"Declaration\")\n .build(\"body\")\n .field(\"body\", [ClassBodyElement]);\n def(\"ClassMethod\")\n .bases(\"Declaration\", \"Function\")\n .build(\"kind\", \"key\", \"params\", \"body\", \"computed\", \"static\")\n .field(\"key\", or(def(\"Literal\"), def(\"Identifier\"), def(\"Expression\")));\n def(\"ClassPrivateMethod\")\n .bases(\"Declaration\", \"Function\")\n .build(\"key\", \"params\", \"body\", \"kind\", \"computed\", \"static\")\n .field(\"key\", def(\"PrivateName\"));\n def(\"ClassAccessorProperty\")\n .bases(\"Declaration\")\n .build(\"key\", \"value\", \"decorators\", \"computed\", \"static\")\n .field(\"key\", or(def(\"Literal\"), def(\"Identifier\"), def(\"PrivateName\"), \n // Only when .computed is true (TODO enforce this)\n def(\"Expression\")))\n .field(\"value\", or(def(\"Expression\"), null), defaults[\"null\"]);\n [\"ClassMethod\",\n \"ClassPrivateMethod\",\n ].forEach(function (typeName) {\n def(typeName)\n .field(\"kind\", or(\"get\", \"set\", \"method\", \"constructor\"), function () { return \"method\"; })\n .field(\"body\", def(\"BlockStatement\"))\n // For backwards compatibility only. Expect accessibility instead (see below).\n .field(\"access\", or(\"public\", \"private\", \"protected\", null), defaults[\"null\"]);\n });\n [\"ClassMethod\",\n \"ClassPrivateMethod\",\n \"ClassAccessorProperty\",\n ].forEach(function (typeName) {\n def(typeName)\n .field(\"computed\", Boolean, defaults[\"false\"])\n .field(\"static\", Boolean, defaults[\"false\"])\n .field(\"abstract\", Boolean, defaults[\"false\"])\n .field(\"accessibility\", or(\"public\", \"private\", \"protected\", null), defaults[\"null\"])\n .field(\"decorators\", or([def(\"Decorator\")], null), defaults[\"null\"])\n .field(\"definite\", Boolean, defaults[\"false\"])\n .field(\"optional\", Boolean, defaults[\"false\"])\n .field(\"override\", Boolean, defaults[\"false\"])\n .field(\"readonly\", Boolean, defaults[\"false\"]);\n });\n var ObjectPatternProperty = or(def(\"Property\"), def(\"PropertyPattern\"), def(\"SpreadPropertyPattern\"), def(\"SpreadProperty\"), // Used by Esprima\n def(\"ObjectProperty\"), // Babel 6\n def(\"RestProperty\"), // Babel 6\n def(\"RestElement\"));\n // Split into RestProperty and SpreadProperty\n def(\"ObjectPattern\")\n .bases(\"Pattern\")\n .build(\"properties\")\n .field(\"properties\", [ObjectPatternProperty])\n .field(\"decorators\", or([def(\"Decorator\")], null), defaults[\"null\"]);\n def(\"SpreadProperty\")\n .bases(\"Node\")\n .build(\"argument\")\n .field(\"argument\", def(\"Expression\"));\n def(\"RestProperty\")\n .bases(\"Node\")\n .build(\"argument\")\n .field(\"argument\", def(\"Expression\"));\n def(\"ForAwaitStatement\")\n .bases(\"Statement\")\n .build(\"left\", \"right\", \"body\")\n .field(\"left\", or(def(\"VariableDeclaration\"), def(\"Expression\")))\n .field(\"right\", def(\"Expression\"))\n .field(\"body\", def(\"Statement\"));\n // The callee node of a dynamic import(...) expression.\n def(\"Import\")\n .bases(\"Expression\")\n .build();\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=babel-core.js.map",
33
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar babel_core_1 = tslib_1.__importDefault(require(\"./babel-core\"));\nvar flow_1 = tslib_1.__importDefault(require(\"./flow\"));\nvar shared_1 = require(\"../shared\");\nfunction default_1(fork) {\n var types = fork.use(types_1.default);\n var def = types.Type.def;\n fork.use(babel_core_1.default);\n fork.use(flow_1.default);\n // https://github.com/babel/babel/pull/10148\n def(\"V8IntrinsicIdentifier\")\n .bases(\"Expression\")\n .build(\"name\")\n .field(\"name\", String);\n // https://github.com/babel/babel/pull/13191\n // https://github.com/babel/website/pull/2541\n def(\"TopicReference\")\n .bases(\"Expression\")\n .build();\n}\nexports.default = default_1;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=babel.js.map",
34
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar babel_core_1 = tslib_1.__importDefault(require(\"./babel-core\"));\nvar type_annotations_1 = tslib_1.__importDefault(require(\"./type-annotations\"));\nvar types_1 = tslib_1.__importDefault(require(\"../types\"));\nvar shared_1 = tslib_1.__importStar(require(\"../shared\"));\nfunction default_1(fork) {\n // Since TypeScript is parsed by Babylon, include the core Babylon types\n // but omit the Flow-related types.\n fork.use(babel_core_1.default);\n fork.use(type_annotations_1.default);\n var types = fork.use(types_1.default);\n var n = types.namedTypes;\n var def = types.Type.def;\n var or = types.Type.or;\n var defaults = fork.use(shared_1.default).defaults;\n var StringLiteral = types.Type.from(function (value, deep) {\n if (n.StringLiteral &&\n n.StringLiteral.check(value, deep)) {\n return true;\n }\n if (n.Literal &&\n n.Literal.check(value, deep) &&\n typeof value.value === \"string\") {\n return true;\n }\n return false;\n }, \"StringLiteral\");\n def(\"TSType\")\n .bases(\"Node\");\n var TSEntityName = or(def(\"Identifier\"), def(\"TSQualifiedName\"));\n def(\"TSTypeReference\")\n .bases(\"TSType\", \"TSHasOptionalTypeParameterInstantiation\")\n .build(\"typeName\", \"typeParameters\")\n .field(\"typeName\", TSEntityName);\n // An abstract (non-buildable) base type that provide a commonly-needed\n // optional .typeParameters field.\n def(\"TSHasOptionalTypeParameterInstantiation\")\n .field(\"typeParameters\", or(def(\"TSTypeParameterInstantiation\"), null), defaults[\"null\"]);\n // An abstract (non-buildable) base type that provide a commonly-needed\n // optional .typeParameters field.\n def(\"TSHasOptionalTypeParameters\")\n .field(\"typeParameters\", or(def(\"TSTypeParameterDeclaration\"), null, void 0), defaults[\"null\"]);\n // An abstract (non-buildable) base type that provide a commonly-needed\n // optional .typeAnnotation field.\n def(\"TSHasOptionalTypeAnnotation\")\n .field(\"typeAnnotation\", or(def(\"TSTypeAnnotation\"), null), defaults[\"null\"]);\n def(\"TSQualifiedName\")\n .bases(\"Node\")\n .build(\"left\", \"right\")\n .field(\"left\", TSEntityName)\n .field(\"right\", TSEntityName);\n def(\"TSAsExpression\")\n .bases(\"Expression\", \"Pattern\")\n .build(\"expression\", \"typeAnnotation\")\n .field(\"expression\", def(\"Expression\"))\n .field(\"typeAnnotation\", def(\"TSType\"))\n .field(\"extra\", or({ parenthesized: Boolean }, null), defaults[\"null\"]);\n def(\"TSTypeCastExpression\")\n .bases(\"Expression\")\n .build(\"expression\", \"typeAnnotation\")\n .field(\"expression\", def(\"Expression\"))\n .field(\"typeAnnotation\", def(\"TSType\"));\n def(\"TSSatisfiesExpression\")\n .bases(\"Expression\", \"Pattern\")\n .build(\"expression\", \"typeAnnotation\")\n .field(\"expression\", def(\"Expression\"))\n .field(\"typeAnnotation\", def(\"TSType\"));\n def(\"TSNonNullExpression\")\n .bases(\"Expression\", \"Pattern\")\n .build(\"expression\")\n .field(\"expression\", def(\"Expression\"));\n [\n \"TSAnyKeyword\",\n \"TSBigIntKeyword\",\n \"TSBooleanKeyword\",\n \"TSNeverKeyword\",\n \"TSNullKeyword\",\n \"TSNumberKeyword\",\n \"TSObjectKeyword\",\n \"TSStringKeyword\",\n \"TSSymbolKeyword\",\n \"TSUndefinedKeyword\",\n \"TSUnknownKeyword\",\n \"TSVoidKeyword\",\n \"TSIntrinsicKeyword\",\n \"TSThisType\",\n ].forEach(function (keywordType) {\n def(keywordType)\n .bases(\"TSType\")\n .build();\n });\n def(\"TSArrayType\")\n .bases(\"TSType\")\n .build(\"elementType\")\n .field(\"elementType\", def(\"TSType\"));\n def(\"TSLiteralType\")\n .bases(\"TSType\")\n .build(\"literal\")\n .field(\"literal\", or(def(\"NumericLiteral\"), def(\"StringLiteral\"), def(\"BooleanLiteral\"), def(\"TemplateLiteral\"), def(\"UnaryExpression\"), def(\"BigIntLiteral\")));\n def(\"TemplateLiteral\")\n // The TemplateLiteral type appears to be reused for TypeScript template\n // literal types (instead of introducing a new TSTemplateLiteralType type),\n // so we allow the templateLiteral.expressions array to be either all\n // expressions or all TypeScript types.\n .field(\"expressions\", or([def(\"Expression\")], [def(\"TSType\")]));\n [\"TSUnionType\",\n \"TSIntersectionType\",\n ].forEach(function (typeName) {\n def(typeName)\n .bases(\"TSType\")\n .build(\"types\")\n .field(\"types\", [def(\"TSType\")]);\n });\n def(\"TSConditionalType\")\n .bases(\"TSType\")\n .build(\"checkType\", \"extendsType\", \"trueType\", \"falseType\")\n .field(\"checkType\", def(\"TSType\"))\n .field(\"extendsType\", def(\"TSType\"))\n .field(\"trueType\", def(\"TSType\"))\n .field(\"falseType\", def(\"TSType\"));\n def(\"TSInferType\")\n .bases(\"TSType\")\n .build(\"typeParameter\")\n .field(\"typeParameter\", def(\"TSTypeParameter\"));\n def(\"TSParenthesizedType\")\n .bases(\"TSType\")\n .build(\"typeAnnotation\")\n .field(\"typeAnnotation\", def(\"TSType\"));\n var ParametersType = [or(def(\"Identifier\"), def(\"RestElement\"), def(\"ArrayPattern\"), def(\"ObjectPattern\"))];\n [\"TSFunctionType\",\n \"TSConstructorType\",\n ].forEach(function (typeName) {\n def(typeName)\n .bases(\"TSType\", \"TSHasOptionalTypeParameters\", \"TSHasOptionalTypeAnnotation\")\n .build(\"parameters\")\n .field(\"parameters\", ParametersType);\n });\n def(\"TSDeclareFunction\")\n .bases(\"Declaration\", \"TSHasOptionalTypeParameters\")\n .build(\"id\", \"params\", \"returnType\")\n .field(\"declare\", Boolean, defaults[\"false\"])\n .field(\"async\", Boolean, defaults[\"false\"])\n .field(\"generator\", Boolean, defaults[\"false\"])\n .field(\"id\", or(def(\"Identifier\"), null), defaults[\"null\"])\n .field(\"params\", [def(\"Pattern\")])\n // tSFunctionTypeAnnotationCommon\n .field(\"returnType\", or(def(\"TSTypeAnnotation\"), def(\"Noop\"), // Still used?\n null), defaults[\"null\"]);\n def(\"TSDeclareMethod\")\n .bases(\"Declaration\", \"TSHasOptionalTypeParameters\")\n .build(\"key\", \"params\", \"returnType\")\n .field(\"async\", Boolean, defaults[\"false\"])\n .field(\"generator\", Boolean, defaults[\"false\"])\n .field(\"params\", [def(\"Pattern\")])\n // classMethodOrPropertyCommon\n .field(\"abstract\", Boolean, defaults[\"false\"])\n .field(\"accessibility\", or(\"public\", \"private\", \"protected\", void 0), defaults[\"undefined\"])\n .field(\"static\", Boolean, defaults[\"false\"])\n .field(\"computed\", Boolean, defaults[\"false\"])\n .field(\"optional\", Boolean, defaults[\"false\"])\n .field(\"key\", or(def(\"Identifier\"), def(\"StringLiteral\"), def(\"NumericLiteral\"), \n // Only allowed if .computed is true.\n def(\"Expression\")))\n // classMethodOrDeclareMethodCommon\n .field(\"kind\", or(\"get\", \"set\", \"method\", \"constructor\"), function getDefault() { return \"method\"; })\n .field(\"access\", // Not \"accessibility\"?\n or(\"public\", \"private\", \"protected\", void 0), defaults[\"undefined\"])\n .field(\"decorators\", or([def(\"Decorator\")], null), defaults[\"null\"])\n // tSFunctionTypeAnnotationCommon\n .field(\"returnType\", or(def(\"TSTypeAnnotation\"), def(\"Noop\"), // Still used?\n null), defaults[\"null\"]);\n def(\"TSMappedType\")\n .bases(\"TSType\")\n .build(\"typeParameter\", \"typeAnnotation\")\n .field(\"readonly\", or(Boolean, \"+\", \"-\"), defaults[\"false\"])\n .field(\"typeParameter\", def(\"TSTypeParameter\"))\n .field(\"optional\", or(Boolean, \"+\", \"-\"), defaults[\"false\"])\n .field(\"typeAnnotation\", or(def(\"TSType\"), null), defaults[\"null\"]);\n def(\"TSTupleType\")\n .bases(\"TSType\")\n .build(\"elementTypes\")\n .field(\"elementTypes\", [or(def(\"TSType\"), def(\"TSNamedTupleMember\"))]);\n def(\"TSNamedTupleMember\")\n .bases(\"TSType\")\n .build(\"label\", \"elementType\", \"optional\")\n .field(\"label\", def(\"Identifier\"))\n .field(\"optional\", Boolean, defaults[\"false\"])\n .field(\"elementType\", def(\"TSType\"));\n def(\"TSRestType\")\n .bases(\"TSType\")\n .build(\"typeAnnotation\")\n .field(\"typeAnnotation\", def(\"TSType\"));\n def(\"TSOptionalType\")\n .bases(\"TSType\")\n .build(\"typeAnnotation\")\n .field(\"typeAnnotation\", def(\"TSType\"));\n def(\"TSIndexedAccessType\")\n .bases(\"TSType\")\n .build(\"objectType\", \"indexType\")\n .field(\"objectType\", def(\"TSType\"))\n .field(\"indexType\", def(\"TSType\"));\n def(\"TSTypeOperator\")\n .bases(\"TSType\")\n .build(\"operator\")\n .field(\"operator\", String)\n .field(\"typeAnnotation\", def(\"TSType\"));\n def(\"TSTypeAnnotation\")\n .bases(\"Node\")\n .build(\"typeAnnotation\")\n .field(\"typeAnnotation\", or(def(\"TSType\"), def(\"TSTypeAnnotation\")));\n def(\"TSIndexSignature\")\n .bases(\"Declaration\", \"TSHasOptionalTypeAnnotation\")\n .build(\"parameters\", \"typeAnnotation\")\n .field(\"parameters\", [def(\"Identifier\")]) // Length === 1\n .field(\"readonly\", Boolean, defaults[\"false\"]);\n def(\"TSPropertySignature\")\n .bases(\"Declaration\", \"TSHasOptionalTypeAnnotation\")\n .build(\"key\", \"typeAnnotation\", \"optional\")\n .field(\"key\", def(\"Expression\"))\n .field(\"computed\", Boolean, defaults[\"false\"])\n .field(\"readonly\", Boolean, defaults[\"false\"])\n .field(\"optional\", Boolean, defaults[\"false\"])\n .field(\"initializer\", or(def(\"Expression\"), null), defaults[\"null\"]);\n def(\"TSMethodSignature\")\n .bases(\"Declaration\", \"TSHasOptionalTypeParameters\", \"TSHasOptionalTypeAnnotation\")\n .build(\"key\", \"parameters\", \"typeAnnotation\")\n .field(\"key\", def(\"Expression\"))\n .field(\"computed\", Boolean, defaults[\"false\"])\n .field(\"optional\", Boolean, defaults[\"false\"])\n .field(\"parameters\", ParametersType);\n def(\"TSTypePredicate\")\n .bases(\"TSTypeAnnotation\", \"TSType\")\n .build(\"parameterName\", \"typeAnnotation\", \"asserts\")\n .field(\"parameterName\", or(def(\"Identifier\"), def(\"TSThisType\")))\n .field(\"typeAnnotation\", or(def(\"TSTypeAnnotation\"), null), defaults[\"null\"])\n .field(\"asserts\", Boolean, defaults[\"false\"]);\n [\"TSCallSignatureDeclaration\",\n \"TSConstructSignatureDeclaration\",\n ].forEach(function (typeName) {\n def(typeName)\n .bases(\"Declaration\", \"TSHasOptionalTypeParameters\", \"TSHasOptionalTypeAnnotation\")\n .build(\"parameters\", \"typeAnnotation\")\n .field(\"parameters\", ParametersType);\n });\n def(\"TSEnumMember\")\n .bases(\"Node\")\n .build(\"id\", \"initializer\")\n .field(\"id\", or(def(\"Identifier\"), StringLiteral))\n .field(\"initializer\", or(def(\"Expression\"), null), defaults[\"null\"]);\n def(\"TSTypeQuery\")\n .bases(\"TSType\")\n .build(\"exprName\")\n .field(\"exprName\", or(TSEntityName, def(\"TSImportType\")));\n // Inferred from Babylon's tsParseTypeMember method.\n var TSTypeMember = or(def(\"TSCallSignatureDeclaration\"), def(\"TSConstructSignatureDeclaration\"), def(\"TSIndexSignature\"), def(\"TSMethodSignature\"), def(\"TSPropertySignature\"));\n def(\"TSTypeLiteral\")\n .bases(\"TSType\")\n .build(\"members\")\n .field(\"members\", [TSTypeMember]);\n def(\"TSTypeParameter\")\n .bases(\"Identifier\")\n .build(\"name\", \"constraint\", \"default\")\n .field(\"name\", or(def(\"Identifier\"), String))\n .field(\"constraint\", or(def(\"TSType\"), void 0), defaults[\"undefined\"])\n .field(\"default\", or(def(\"TSType\"), void 0), defaults[\"undefined\"]);\n def(\"TSTypeAssertion\")\n .bases(\"Expression\", \"Pattern\")\n .build(\"typeAnnotation\", \"expression\")\n .field(\"typeAnnotation\", def(\"TSType\"))\n .field(\"expression\", def(\"Expression\"))\n .field(\"extra\", or({ parenthesized: Boolean }, null), defaults[\"null\"]);\n def(\"TSTypeParameterDeclaration\")\n .bases(\"Declaration\")\n .build(\"params\")\n .field(\"params\", [def(\"TSTypeParameter\")]);\n def(\"TSInstantiationExpression\")\n .bases(\"Expression\", \"TSHasOptionalTypeParameterInstantiation\")\n .build(\"expression\", \"typeParameters\")\n .field(\"expression\", def(\"Expression\"));\n def(\"TSTypeParameterInstantiation\")\n .bases(\"Node\")\n .build(\"params\")\n .field(\"params\", [def(\"TSType\")]);\n def(\"TSEnumDeclaration\")\n .bases(\"Declaration\")\n .build(\"id\", \"members\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"const\", Boolean, defaults[\"false\"])\n .field(\"declare\", Boolean, defaults[\"false\"])\n .field(\"members\", [def(\"TSEnumMember\")])\n .field(\"initializer\", or(def(\"Expression\"), null), defaults[\"null\"]);\n def(\"TSTypeAliasDeclaration\")\n .bases(\"Declaration\", \"TSHasOptionalTypeParameters\")\n .build(\"id\", \"typeAnnotation\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"declare\", Boolean, defaults[\"false\"])\n .field(\"typeAnnotation\", def(\"TSType\"));\n def(\"TSModuleBlock\")\n .bases(\"Node\")\n .build(\"body\")\n .field(\"body\", [def(\"Statement\")]);\n def(\"TSModuleDeclaration\")\n .bases(\"Declaration\")\n .build(\"id\", \"body\")\n .field(\"id\", or(StringLiteral, TSEntityName))\n .field(\"declare\", Boolean, defaults[\"false\"])\n .field(\"global\", Boolean, defaults[\"false\"])\n .field(\"body\", or(def(\"TSModuleBlock\"), def(\"TSModuleDeclaration\"), null), defaults[\"null\"]);\n def(\"TSImportType\")\n .bases(\"TSType\", \"TSHasOptionalTypeParameterInstantiation\")\n .build(\"argument\", \"qualifier\", \"typeParameters\")\n .field(\"argument\", StringLiteral)\n .field(\"qualifier\", or(TSEntityName, void 0), defaults[\"undefined\"]);\n def(\"TSImportEqualsDeclaration\")\n .bases(\"Declaration\")\n .build(\"id\", \"moduleReference\")\n .field(\"id\", def(\"Identifier\"))\n .field(\"isExport\", Boolean, defaults[\"false\"])\n .field(\"moduleReference\", or(TSEntityName, def(\"TSExternalModuleReference\")));\n def(\"TSExternalModuleReference\")\n .bases(\"Declaration\")\n .build(\"expression\")\n .field(\"expression\", StringLiteral);\n def(\"TSExportAssignment\")\n .bases(\"Statement\")\n .build(\"expression\")\n .field(\"expression\", def(\"Expression\"));\n def(\"TSNamespaceExportDeclaration\")\n .bases(\"Declaration\")\n .build(\"id\")\n .field(\"id\", def(\"Identifier\"));\n def(\"TSInterfaceBody\")\n .bases(\"Node\")\n .build(\"body\")\n .field(\"body\", [TSTypeMember]);\n def(\"TSExpressionWithTypeArguments\")\n .bases(\"TSType\", \"TSHasOptionalTypeParameterInstantiation\")\n .build(\"expression\", \"typeParameters\")\n .field(\"expression\", TSEntityName);\n def(\"TSInterfaceDeclaration\")\n .bases(\"Declaration\", \"TSHasOptionalTypeParameters\")\n .build(\"id\", \"body\")\n .field(\"id\", TSEntityName)\n .field(\"declare\", Boolean, defaults[\"false\"])\n .field(\"extends\", or([def(\"TSExpressionWithTypeArguments\")], null), defaults[\"null\"])\n .field(\"body\", def(\"TSInterfaceBody\"));\n def(\"TSParameterProperty\")\n .bases(\"Pattern\")\n .build(\"parameter\")\n .field(\"accessibility\", or(\"public\", \"private\", \"protected\", void 0), defaults[\"undefined\"])\n .field(\"readonly\", Boolean, defaults[\"false\"])\n .field(\"parameter\", or(def(\"Identifier\"), def(\"AssignmentPattern\")));\n def(\"ClassProperty\")\n .field(\"access\", // Not \"accessibility\"?\n or(\"public\", \"private\", \"protected\", void 0), defaults[\"undefined\"]);\n def(\"ClassAccessorProperty\")\n .bases(\"Declaration\", \"TSHasOptionalTypeAnnotation\");\n // Defined already in es6 and babel-core.\n def(\"ClassBody\")\n .field(\"body\", [or(def(\"MethodDefinition\"), def(\"VariableDeclarator\"), def(\"ClassPropertyDefinition\"), def(\"ClassProperty\"), def(\"ClassPrivateProperty\"), def(\"ClassAccessorProperty\"), def(\"ClassMethod\"), def(\"ClassPrivateMethod\"), def(\"StaticBlock\"), \n // Just need to add these types:\n def(\"TSDeclareMethod\"), TSTypeMember)]);\n}\nexports.default = default_1;\n;\n(0, shared_1.maybeSetModuleExports)(function () { return module; });\n//# sourceMappingURL=typescript.js.map",
35
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.namedTypes = void 0;\nvar namedTypes;\n(function (namedTypes) {\n})(namedTypes = exports.namedTypes || (exports.namedTypes = {}));\n//# sourceMappingURL=namedTypes.js.map",
36
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.visit = exports.use = exports.Type = exports.someField = exports.PathVisitor = exports.Path = exports.NodePath = exports.namedTypes = exports.getSupertypeNames = exports.getFieldValue = exports.getFieldNames = exports.getBuilderName = exports.finalize = exports.eachField = exports.defineMethod = exports.builtInTypes = exports.builders = exports.astNodesAreEquivalent = void 0;\nvar tslib_1 = require(\"tslib\");\nvar fork_1 = tslib_1.__importDefault(require(\"./fork\"));\nvar es_proposals_1 = tslib_1.__importDefault(require(\"./def/es-proposals\"));\nvar jsx_1 = tslib_1.__importDefault(require(\"./def/jsx\"));\nvar flow_1 = tslib_1.__importDefault(require(\"./def/flow\"));\nvar esprima_1 = tslib_1.__importDefault(require(\"./def/esprima\"));\nvar babel_1 = tslib_1.__importDefault(require(\"./def/babel\"));\nvar typescript_1 = tslib_1.__importDefault(require(\"./def/typescript\"));\nvar namedTypes_1 = require(\"./gen/namedTypes\");\nObject.defineProperty(exports, \"namedTypes\", { enumerable: true, get: function () { return namedTypes_1.namedTypes; } });\nvar _a = (0, fork_1.default)([\n // Feel free to add to or remove from this list of extension modules to\n // configure the precise type hierarchy that you need.\n es_proposals_1.default,\n jsx_1.default,\n flow_1.default,\n esprima_1.default,\n babel_1.default,\n typescript_1.default,\n]), astNodesAreEquivalent = _a.astNodesAreEquivalent, builders = _a.builders, builtInTypes = _a.builtInTypes, defineMethod = _a.defineMethod, eachField = _a.eachField, finalize = _a.finalize, getBuilderName = _a.getBuilderName, getFieldNames = _a.getFieldNames, getFieldValue = _a.getFieldValue, getSupertypeNames = _a.getSupertypeNames, n = _a.namedTypes, NodePath = _a.NodePath, Path = _a.Path, PathVisitor = _a.PathVisitor, someField = _a.someField, Type = _a.Type, use = _a.use, visit = _a.visit;\nexports.astNodesAreEquivalent = astNodesAreEquivalent;\nexports.builders = builders;\nexports.builtInTypes = builtInTypes;\nexports.defineMethod = defineMethod;\nexports.eachField = eachField;\nexports.finalize = finalize;\nexports.getBuilderName = getBuilderName;\nexports.getFieldNames = getFieldNames;\nexports.getFieldValue = getFieldValue;\nexports.getSupertypeNames = getSupertypeNames;\nexports.NodePath = NodePath;\nexports.Path = Path;\nexports.PathVisitor = PathVisitor;\nexports.someField = someField;\nexports.Type = Type;\nexports.use = use;\nexports.visit = visit;\n// Populate the exported fields of the namedTypes namespace, while still\n// retaining its member types.\nObject.assign(namedTypes_1.namedTypes, n);\n//# sourceMappingURL=main.js.map",
37
+ "/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\nvar intToCharMap = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'.split('');\n\n/**\n * Encode an integer in the range of 0 to 63 to a single base 64 digit.\n */\nexports.encode = function (number) {\n if (0 <= number && number < intToCharMap.length) {\n return intToCharMap[number];\n }\n throw new TypeError(\"Must be between 0 and 63: \" + number);\n};\n\n/**\n * Decode a single base 64 character code digit to an integer. Returns -1 on\n * failure.\n */\nexports.decode = function (charCode) {\n var bigA = 65; // 'A'\n var bigZ = 90; // 'Z'\n\n var littleA = 97; // 'a'\n var littleZ = 122; // 'z'\n\n var zero = 48; // '0'\n var nine = 57; // '9'\n\n var plus = 43; // '+'\n var slash = 47; // '/'\n\n var littleOffset = 26;\n var numberOffset = 52;\n\n // 0 - 25: ABCDEFGHIJKLMNOPQRSTUVWXYZ\n if (bigA <= charCode && charCode <= bigZ) {\n return (charCode - bigA);\n }\n\n // 26 - 51: abcdefghijklmnopqrstuvwxyz\n if (littleA <= charCode && charCode <= littleZ) {\n return (charCode - littleA + littleOffset);\n }\n\n // 52 - 61: 0123456789\n if (zero <= charCode && charCode <= nine) {\n return (charCode - zero + numberOffset);\n }\n\n // 62: +\n if (charCode == plus) {\n return 62;\n }\n\n // 63: /\n if (charCode == slash) {\n return 63;\n }\n\n // Invalid base64 digit.\n return -1;\n};\n",
38
+ "/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n *\n * Based on the Base 64 VLQ implementation in Closure Compiler:\n * https://code.google.com/p/closure-compiler/source/browse/trunk/src/com/google/debugging/sourcemap/Base64VLQ.java\n *\n * Copyright 2011 The Closure Compiler Authors. All rights reserved.\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are\n * met:\n *\n * * Redistributions of source code must retain the above copyright\n * notice, this list of conditions and the following disclaimer.\n * * Redistributions in binary form must reproduce the above\n * copyright notice, this list of conditions and the following\n * disclaimer in the documentation and/or other materials provided\n * with the distribution.\n * * Neither the name of Google Inc. nor the names of its\n * contributors may be used to endorse or promote products derived\n * from this software without specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS\n * \"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT\n * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR\n * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT\n * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,\n * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,\n * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY\n * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nvar base64 = require('./base64');\n\n// A single base 64 digit can contain 6 bits of data. For the base 64 variable\n// length quantities we use in the source map spec, the first bit is the sign,\n// the next four bits are the actual value, and the 6th bit is the\n// continuation bit. The continuation bit tells us whether there are more\n// digits in this value following this digit.\n//\n// Continuation\n// | Sign\n// | |\n// V V\n// 101011\n\nvar VLQ_BASE_SHIFT = 5;\n\n// binary: 100000\nvar VLQ_BASE = 1 << VLQ_BASE_SHIFT;\n\n// binary: 011111\nvar VLQ_BASE_MASK = VLQ_BASE - 1;\n\n// binary: 100000\nvar VLQ_CONTINUATION_BIT = VLQ_BASE;\n\n/**\n * Converts from a two-complement value to a value where the sign bit is\n * placed in the least significant bit. For example, as decimals:\n * 1 becomes 2 (10 binary), -1 becomes 3 (11 binary)\n * 2 becomes 4 (100 binary), -2 becomes 5 (101 binary)\n */\nfunction toVLQSigned(aValue) {\n return aValue < 0\n ? ((-aValue) << 1) + 1\n : (aValue << 1) + 0;\n}\n\n/**\n * Converts to a two-complement value from a value where the sign bit is\n * placed in the least significant bit. For example, as decimals:\n * 2 (10 binary) becomes 1, 3 (11 binary) becomes -1\n * 4 (100 binary) becomes 2, 5 (101 binary) becomes -2\n */\nfunction fromVLQSigned(aValue) {\n var isNegative = (aValue & 1) === 1;\n var shifted = aValue >> 1;\n return isNegative\n ? -shifted\n : shifted;\n}\n\n/**\n * Returns the base 64 VLQ encoded value.\n */\nexports.encode = function base64VLQ_encode(aValue) {\n var encoded = \"\";\n var digit;\n\n var vlq = toVLQSigned(aValue);\n\n do {\n digit = vlq & VLQ_BASE_MASK;\n vlq >>>= VLQ_BASE_SHIFT;\n if (vlq > 0) {\n // There are still more digits in this value, so we must make sure the\n // continuation bit is marked.\n digit |= VLQ_CONTINUATION_BIT;\n }\n encoded += base64.encode(digit);\n } while (vlq > 0);\n\n return encoded;\n};\n\n/**\n * Decodes the next base 64 VLQ value from the given string and returns the\n * value and the rest of the string via the out parameter.\n */\nexports.decode = function base64VLQ_decode(aStr, aIndex, aOutParam) {\n var strLen = aStr.length;\n var result = 0;\n var shift = 0;\n var continuation, digit;\n\n do {\n if (aIndex >= strLen) {\n throw new Error(\"Expected more digits in base 64 VLQ value.\");\n }\n\n digit = base64.decode(aStr.charCodeAt(aIndex++));\n if (digit === -1) {\n throw new Error(\"Invalid base64 digit: \" + aStr.charAt(aIndex - 1));\n }\n\n continuation = !!(digit & VLQ_CONTINUATION_BIT);\n digit &= VLQ_BASE_MASK;\n result = result + (digit << shift);\n shift += VLQ_BASE_SHIFT;\n } while (continuation);\n\n aOutParam.value = fromVLQSigned(result);\n aOutParam.rest = aIndex;\n};\n",
39
+ "/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\n/**\n * This is a helper function for getting values from parameter/options\n * objects.\n *\n * @param args The object we are extracting values from\n * @param name The name of the property we are getting.\n * @param defaultValue An optional value to return if the property is missing\n * from the object. If this is not specified and the property is missing, an\n * error will be thrown.\n */\nfunction getArg(aArgs, aName, aDefaultValue) {\n if (aName in aArgs) {\n return aArgs[aName];\n } else if (arguments.length === 3) {\n return aDefaultValue;\n } else {\n throw new Error('\"' + aName + '\" is a required argument.');\n }\n}\nexports.getArg = getArg;\n\nvar urlRegexp = /^(?:([\\w+\\-.]+):)?\\/\\/(?:(\\w+:\\w+)@)?([\\w.-]*)(?::(\\d+))?(.*)$/;\nvar dataUrlRegexp = /^data:.+\\,.+$/;\n\nfunction urlParse(aUrl) {\n var match = aUrl.match(urlRegexp);\n if (!match) {\n return null;\n }\n return {\n scheme: match[1],\n auth: match[2],\n host: match[3],\n port: match[4],\n path: match[5]\n };\n}\nexports.urlParse = urlParse;\n\nfunction urlGenerate(aParsedUrl) {\n var url = '';\n if (aParsedUrl.scheme) {\n url += aParsedUrl.scheme + ':';\n }\n url += '//';\n if (aParsedUrl.auth) {\n url += aParsedUrl.auth + '@';\n }\n if (aParsedUrl.host) {\n url += aParsedUrl.host;\n }\n if (aParsedUrl.port) {\n url += \":\" + aParsedUrl.port\n }\n if (aParsedUrl.path) {\n url += aParsedUrl.path;\n }\n return url;\n}\nexports.urlGenerate = urlGenerate;\n\n/**\n * Normalizes a path, or the path portion of a URL:\n *\n * - Replaces consecutive slashes with one slash.\n * - Removes unnecessary '.' parts.\n * - Removes unnecessary '<dir>/..' parts.\n *\n * Based on code in the Node.js 'path' core module.\n *\n * @param aPath The path or url to normalize.\n */\nfunction normalize(aPath) {\n var path = aPath;\n var url = urlParse(aPath);\n if (url) {\n if (!url.path) {\n return aPath;\n }\n path = url.path;\n }\n var isAbsolute = exports.isAbsolute(path);\n\n var parts = path.split(/\\/+/);\n for (var part, up = 0, i = parts.length - 1; i >= 0; i--) {\n part = parts[i];\n if (part === '.') {\n parts.splice(i, 1);\n } else if (part === '..') {\n up++;\n } else if (up > 0) {\n if (part === '') {\n // The first part is blank if the path is absolute. Trying to go\n // above the root is a no-op. Therefore we can remove all '..' parts\n // directly after the root.\n parts.splice(i + 1, up);\n up = 0;\n } else {\n parts.splice(i, 2);\n up--;\n }\n }\n }\n path = parts.join('/');\n\n if (path === '') {\n path = isAbsolute ? '/' : '.';\n }\n\n if (url) {\n url.path = path;\n return urlGenerate(url);\n }\n return path;\n}\nexports.normalize = normalize;\n\n/**\n * Joins two paths/URLs.\n *\n * @param aRoot The root path or URL.\n * @param aPath The path or URL to be joined with the root.\n *\n * - If aPath is a URL or a data URI, aPath is returned, unless aPath is a\n * scheme-relative URL: Then the scheme of aRoot, if any, is prepended\n * first.\n * - Otherwise aPath is a path. If aRoot is a URL, then its path portion\n * is updated with the result and aRoot is returned. Otherwise the result\n * is returned.\n * - If aPath is absolute, the result is aPath.\n * - Otherwise the two paths are joined with a slash.\n * - Joining for example 'http://' and 'www.example.com' is also supported.\n */\nfunction join(aRoot, aPath) {\n if (aRoot === \"\") {\n aRoot = \".\";\n }\n if (aPath === \"\") {\n aPath = \".\";\n }\n var aPathUrl = urlParse(aPath);\n var aRootUrl = urlParse(aRoot);\n if (aRootUrl) {\n aRoot = aRootUrl.path || '/';\n }\n\n // `join(foo, '//www.example.org')`\n if (aPathUrl && !aPathUrl.scheme) {\n if (aRootUrl) {\n aPathUrl.scheme = aRootUrl.scheme;\n }\n return urlGenerate(aPathUrl);\n }\n\n if (aPathUrl || aPath.match(dataUrlRegexp)) {\n return aPath;\n }\n\n // `join('http://', 'www.example.com')`\n if (aRootUrl && !aRootUrl.host && !aRootUrl.path) {\n aRootUrl.host = aPath;\n return urlGenerate(aRootUrl);\n }\n\n var joined = aPath.charAt(0) === '/'\n ? aPath\n : normalize(aRoot.replace(/\\/+$/, '') + '/' + aPath);\n\n if (aRootUrl) {\n aRootUrl.path = joined;\n return urlGenerate(aRootUrl);\n }\n return joined;\n}\nexports.join = join;\n\nexports.isAbsolute = function (aPath) {\n return aPath.charAt(0) === '/' || urlRegexp.test(aPath);\n};\n\n/**\n * Make a path relative to a URL or another path.\n *\n * @param aRoot The root path or URL.\n * @param aPath The path or URL to be made relative to aRoot.\n */\nfunction relative(aRoot, aPath) {\n if (aRoot === \"\") {\n aRoot = \".\";\n }\n\n aRoot = aRoot.replace(/\\/$/, '');\n\n // It is possible for the path to be above the root. In this case, simply\n // checking whether the root is a prefix of the path won't work. Instead, we\n // need to remove components from the root one by one, until either we find\n // a prefix that fits, or we run out of components to remove.\n var level = 0;\n while (aPath.indexOf(aRoot + '/') !== 0) {\n var index = aRoot.lastIndexOf(\"/\");\n if (index < 0) {\n return aPath;\n }\n\n // If the only part of the root that is left is the scheme (i.e. http://,\n // file:///, etc.), one or more slashes (/), or simply nothing at all, we\n // have exhausted all components, so the path is not relative to the root.\n aRoot = aRoot.slice(0, index);\n if (aRoot.match(/^([^\\/]+:\\/)?\\/*$/)) {\n return aPath;\n }\n\n ++level;\n }\n\n // Make sure we add a \"../\" for each component we removed from the root.\n return Array(level + 1).join(\"../\") + aPath.substr(aRoot.length + 1);\n}\nexports.relative = relative;\n\nvar supportsNullProto = (function () {\n var obj = Object.create(null);\n return !('__proto__' in obj);\n}());\n\nfunction identity (s) {\n return s;\n}\n\n/**\n * Because behavior goes wacky when you set `__proto__` on objects, we\n * have to prefix all the strings in our set with an arbitrary character.\n *\n * See https://github.com/mozilla/source-map/pull/31 and\n * https://github.com/mozilla/source-map/issues/30\n *\n * @param String aStr\n */\nfunction toSetString(aStr) {\n if (isProtoString(aStr)) {\n return '$' + aStr;\n }\n\n return aStr;\n}\nexports.toSetString = supportsNullProto ? identity : toSetString;\n\nfunction fromSetString(aStr) {\n if (isProtoString(aStr)) {\n return aStr.slice(1);\n }\n\n return aStr;\n}\nexports.fromSetString = supportsNullProto ? identity : fromSetString;\n\nfunction isProtoString(s) {\n if (!s) {\n return false;\n }\n\n var length = s.length;\n\n if (length < 9 /* \"__proto__\".length */) {\n return false;\n }\n\n if (s.charCodeAt(length - 1) !== 95 /* '_' */ ||\n s.charCodeAt(length - 2) !== 95 /* '_' */ ||\n s.charCodeAt(length - 3) !== 111 /* 'o' */ ||\n s.charCodeAt(length - 4) !== 116 /* 't' */ ||\n s.charCodeAt(length - 5) !== 111 /* 'o' */ ||\n s.charCodeAt(length - 6) !== 114 /* 'r' */ ||\n s.charCodeAt(length - 7) !== 112 /* 'p' */ ||\n s.charCodeAt(length - 8) !== 95 /* '_' */ ||\n s.charCodeAt(length - 9) !== 95 /* '_' */) {\n return false;\n }\n\n for (var i = length - 10; i >= 0; i--) {\n if (s.charCodeAt(i) !== 36 /* '$' */) {\n return false;\n }\n }\n\n return true;\n}\n\n/**\n * Comparator between two mappings where the original positions are compared.\n *\n * Optionally pass in `true` as `onlyCompareGenerated` to consider two\n * mappings with the same original source/line/column, but different generated\n * line and column the same. Useful when searching for a mapping with a\n * stubbed out mapping.\n */\nfunction compareByOriginalPositions(mappingA, mappingB, onlyCompareOriginal) {\n var cmp = strcmp(mappingA.source, mappingB.source);\n if (cmp !== 0) {\n return cmp;\n }\n\n cmp = mappingA.originalLine - mappingB.originalLine;\n if (cmp !== 0) {\n return cmp;\n }\n\n cmp = mappingA.originalColumn - mappingB.originalColumn;\n if (cmp !== 0 || onlyCompareOriginal) {\n return cmp;\n }\n\n cmp = mappingA.generatedColumn - mappingB.generatedColumn;\n if (cmp !== 0) {\n return cmp;\n }\n\n cmp = mappingA.generatedLine - mappingB.generatedLine;\n if (cmp !== 0) {\n return cmp;\n }\n\n return strcmp(mappingA.name, mappingB.name);\n}\nexports.compareByOriginalPositions = compareByOriginalPositions;\n\n/**\n * Comparator between two mappings with deflated source and name indices where\n * the generated positions are compared.\n *\n * Optionally pass in `true` as `onlyCompareGenerated` to consider two\n * mappings with the same generated line and column, but different\n * source/name/original line and column the same. Useful when searching for a\n * mapping with a stubbed out mapping.\n */\nfunction compareByGeneratedPositionsDeflated(mappingA, mappingB, onlyCompareGenerated) {\n var cmp = mappingA.generatedLine - mappingB.generatedLine;\n if (cmp !== 0) {\n return cmp;\n }\n\n cmp = mappingA.generatedColumn - mappingB.generatedColumn;\n if (cmp !== 0 || onlyCompareGenerated) {\n return cmp;\n }\n\n cmp = strcmp(mappingA.source, mappingB.source);\n if (cmp !== 0) {\n return cmp;\n }\n\n cmp = mappingA.originalLine - mappingB.originalLine;\n if (cmp !== 0) {\n return cmp;\n }\n\n cmp = mappingA.originalColumn - mappingB.originalColumn;\n if (cmp !== 0) {\n return cmp;\n }\n\n return strcmp(mappingA.name, mappingB.name);\n}\nexports.compareByGeneratedPositionsDeflated = compareByGeneratedPositionsDeflated;\n\nfunction strcmp(aStr1, aStr2) {\n if (aStr1 === aStr2) {\n return 0;\n }\n\n if (aStr1 === null) {\n return 1; // aStr2 !== null\n }\n\n if (aStr2 === null) {\n return -1; // aStr1 !== null\n }\n\n if (aStr1 > aStr2) {\n return 1;\n }\n\n return -1;\n}\n\n/**\n * Comparator between two mappings with inflated source and name strings where\n * the generated positions are compared.\n */\nfunction compareByGeneratedPositionsInflated(mappingA, mappingB) {\n var cmp = mappingA.generatedLine - mappingB.generatedLine;\n if (cmp !== 0) {\n return cmp;\n }\n\n cmp = mappingA.generatedColumn - mappingB.generatedColumn;\n if (cmp !== 0) {\n return cmp;\n }\n\n cmp = strcmp(mappingA.source, mappingB.source);\n if (cmp !== 0) {\n return cmp;\n }\n\n cmp = mappingA.originalLine - mappingB.originalLine;\n if (cmp !== 0) {\n return cmp;\n }\n\n cmp = mappingA.originalColumn - mappingB.originalColumn;\n if (cmp !== 0) {\n return cmp;\n }\n\n return strcmp(mappingA.name, mappingB.name);\n}\nexports.compareByGeneratedPositionsInflated = compareByGeneratedPositionsInflated;\n\n/**\n * Strip any JSON XSSI avoidance prefix from the string (as documented\n * in the source maps specification), and then parse the string as\n * JSON.\n */\nfunction parseSourceMapInput(str) {\n return JSON.parse(str.replace(/^\\)]}'[^\\n]*\\n/, ''));\n}\nexports.parseSourceMapInput = parseSourceMapInput;\n\n/**\n * Compute the URL of a source given the the source root, the source's\n * URL, and the source map's URL.\n */\nfunction computeSourceURL(sourceRoot, sourceURL, sourceMapURL) {\n sourceURL = sourceURL || '';\n\n if (sourceRoot) {\n // This follows what Chrome does.\n if (sourceRoot[sourceRoot.length - 1] !== '/' && sourceURL[0] !== '/') {\n sourceRoot += '/';\n }\n // The spec says:\n // Line 4: An optional source root, useful for relocating source\n // files on a server or removing repeated values in the\n // “sources” entry. This value is prepended to the individual\n // entries in the “source” field.\n sourceURL = sourceRoot + sourceURL;\n }\n\n // Historically, SourceMapConsumer did not take the sourceMapURL as\n // a parameter. This mode is still somewhat supported, which is why\n // this code block is conditional. However, it's preferable to pass\n // the source map URL to SourceMapConsumer, so that this function\n // can implement the source URL resolution algorithm as outlined in\n // the spec. This block is basically the equivalent of:\n // new URL(sourceURL, sourceMapURL).toString()\n // ... except it avoids using URL, which wasn't available in the\n // older releases of node still supported by this library.\n //\n // The spec says:\n // If the sources are not absolute URLs after prepending of the\n // “sourceRoot”, the sources are resolved relative to the\n // SourceMap (like resolving script src in a html document).\n if (sourceMapURL) {\n var parsed = urlParse(sourceMapURL);\n if (!parsed) {\n throw new Error(\"sourceMapURL could not be parsed\");\n }\n if (parsed.path) {\n // Strip the last path component, but keep the \"/\".\n var index = parsed.path.lastIndexOf('/');\n if (index >= 0) {\n parsed.path = parsed.path.substring(0, index + 1);\n }\n }\n sourceURL = join(urlGenerate(parsed), sourceURL);\n }\n\n return normalize(sourceURL);\n}\nexports.computeSourceURL = computeSourceURL;\n",
40
+ "/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\nvar util = require('./util');\nvar has = Object.prototype.hasOwnProperty;\nvar hasNativeMap = typeof Map !== \"undefined\";\n\n/**\n * A data structure which is a combination of an array and a set. Adding a new\n * member is O(1), testing for membership is O(1), and finding the index of an\n * element is O(1). Removing elements from the set is not supported. Only\n * strings are supported for membership.\n */\nfunction ArraySet() {\n this._array = [];\n this._set = hasNativeMap ? new Map() : Object.create(null);\n}\n\n/**\n * Static method for creating ArraySet instances from an existing array.\n */\nArraySet.fromArray = function ArraySet_fromArray(aArray, aAllowDuplicates) {\n var set = new ArraySet();\n for (var i = 0, len = aArray.length; i < len; i++) {\n set.add(aArray[i], aAllowDuplicates);\n }\n return set;\n};\n\n/**\n * Return how many unique items are in this ArraySet. If duplicates have been\n * added, than those do not count towards the size.\n *\n * @returns Number\n */\nArraySet.prototype.size = function ArraySet_size() {\n return hasNativeMap ? this._set.size : Object.getOwnPropertyNames(this._set).length;\n};\n\n/**\n * Add the given string to this set.\n *\n * @param String aStr\n */\nArraySet.prototype.add = function ArraySet_add(aStr, aAllowDuplicates) {\n var sStr = hasNativeMap ? aStr : util.toSetString(aStr);\n var isDuplicate = hasNativeMap ? this.has(aStr) : has.call(this._set, sStr);\n var idx = this._array.length;\n if (!isDuplicate || aAllowDuplicates) {\n this._array.push(aStr);\n }\n if (!isDuplicate) {\n if (hasNativeMap) {\n this._set.set(aStr, idx);\n } else {\n this._set[sStr] = idx;\n }\n }\n};\n\n/**\n * Is the given string a member of this set?\n *\n * @param String aStr\n */\nArraySet.prototype.has = function ArraySet_has(aStr) {\n if (hasNativeMap) {\n return this._set.has(aStr);\n } else {\n var sStr = util.toSetString(aStr);\n return has.call(this._set, sStr);\n }\n};\n\n/**\n * What is the index of the given string in the array?\n *\n * @param String aStr\n */\nArraySet.prototype.indexOf = function ArraySet_indexOf(aStr) {\n if (hasNativeMap) {\n var idx = this._set.get(aStr);\n if (idx >= 0) {\n return idx;\n }\n } else {\n var sStr = util.toSetString(aStr);\n if (has.call(this._set, sStr)) {\n return this._set[sStr];\n }\n }\n\n throw new Error('\"' + aStr + '\" is not in the set.');\n};\n\n/**\n * What is the element at the given index?\n *\n * @param Number aIdx\n */\nArraySet.prototype.at = function ArraySet_at(aIdx) {\n if (aIdx >= 0 && aIdx < this._array.length) {\n return this._array[aIdx];\n }\n throw new Error('No element indexed by ' + aIdx);\n};\n\n/**\n * Returns the array representation of this set (which has the proper indices\n * indicated by indexOf). Note that this is a copy of the internal array used\n * for storing the members so that no one can mess with internal state.\n */\nArraySet.prototype.toArray = function ArraySet_toArray() {\n return this._array.slice();\n};\n\nexports.ArraySet = ArraySet;\n",
41
+ "/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2014 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\nvar util = require('./util');\n\n/**\n * Determine whether mappingB is after mappingA with respect to generated\n * position.\n */\nfunction generatedPositionAfter(mappingA, mappingB) {\n // Optimized for most common case\n var lineA = mappingA.generatedLine;\n var lineB = mappingB.generatedLine;\n var columnA = mappingA.generatedColumn;\n var columnB = mappingB.generatedColumn;\n return lineB > lineA || lineB == lineA && columnB >= columnA ||\n util.compareByGeneratedPositionsInflated(mappingA, mappingB) <= 0;\n}\n\n/**\n * A data structure to provide a sorted view of accumulated mappings in a\n * performance conscious manner. It trades a neglibable overhead in general\n * case for a large speedup in case of mappings being added in order.\n */\nfunction MappingList() {\n this._array = [];\n this._sorted = true;\n // Serves as infimum\n this._last = {generatedLine: -1, generatedColumn: 0};\n}\n\n/**\n * Iterate through internal items. This method takes the same arguments that\n * `Array.prototype.forEach` takes.\n *\n * NOTE: The order of the mappings is NOT guaranteed.\n */\nMappingList.prototype.unsortedForEach =\n function MappingList_forEach(aCallback, aThisArg) {\n this._array.forEach(aCallback, aThisArg);\n };\n\n/**\n * Add the given source mapping.\n *\n * @param Object aMapping\n */\nMappingList.prototype.add = function MappingList_add(aMapping) {\n if (generatedPositionAfter(this._last, aMapping)) {\n this._last = aMapping;\n this._array.push(aMapping);\n } else {\n this._sorted = false;\n this._array.push(aMapping);\n }\n};\n\n/**\n * Returns the flat, sorted array of mappings. The mappings are sorted by\n * generated position.\n *\n * WARNING: This method returns internal data without copying, for\n * performance. The return value must NOT be mutated, and should be treated as\n * an immutable borrow. If you want to take ownership, you must make your own\n * copy.\n */\nMappingList.prototype.toArray = function MappingList_toArray() {\n if (!this._sorted) {\n this._array.sort(util.compareByGeneratedPositionsInflated);\n this._sorted = true;\n }\n return this._array;\n};\n\nexports.MappingList = MappingList;\n",
42
+ "/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\nvar base64VLQ = require('./base64-vlq');\nvar util = require('./util');\nvar ArraySet = require('./array-set').ArraySet;\nvar MappingList = require('./mapping-list').MappingList;\n\n/**\n * An instance of the SourceMapGenerator represents a source map which is\n * being built incrementally. You may pass an object with the following\n * properties:\n *\n * - file: The filename of the generated source.\n * - sourceRoot: A root for all relative URLs in this source map.\n */\nfunction SourceMapGenerator(aArgs) {\n if (!aArgs) {\n aArgs = {};\n }\n this._file = util.getArg(aArgs, 'file', null);\n this._sourceRoot = util.getArg(aArgs, 'sourceRoot', null);\n this._skipValidation = util.getArg(aArgs, 'skipValidation', false);\n this._sources = new ArraySet();\n this._names = new ArraySet();\n this._mappings = new MappingList();\n this._sourcesContents = null;\n}\n\nSourceMapGenerator.prototype._version = 3;\n\n/**\n * Creates a new SourceMapGenerator based on a SourceMapConsumer\n *\n * @param aSourceMapConsumer The SourceMap.\n */\nSourceMapGenerator.fromSourceMap =\n function SourceMapGenerator_fromSourceMap(aSourceMapConsumer) {\n var sourceRoot = aSourceMapConsumer.sourceRoot;\n var generator = new SourceMapGenerator({\n file: aSourceMapConsumer.file,\n sourceRoot: sourceRoot\n });\n aSourceMapConsumer.eachMapping(function (mapping) {\n var newMapping = {\n generated: {\n line: mapping.generatedLine,\n column: mapping.generatedColumn\n }\n };\n\n if (mapping.source != null) {\n newMapping.source = mapping.source;\n if (sourceRoot != null) {\n newMapping.source = util.relative(sourceRoot, newMapping.source);\n }\n\n newMapping.original = {\n line: mapping.originalLine,\n column: mapping.originalColumn\n };\n\n if (mapping.name != null) {\n newMapping.name = mapping.name;\n }\n }\n\n generator.addMapping(newMapping);\n });\n aSourceMapConsumer.sources.forEach(function (sourceFile) {\n var sourceRelative = sourceFile;\n if (sourceRoot !== null) {\n sourceRelative = util.relative(sourceRoot, sourceFile);\n }\n\n if (!generator._sources.has(sourceRelative)) {\n generator._sources.add(sourceRelative);\n }\n\n var content = aSourceMapConsumer.sourceContentFor(sourceFile);\n if (content != null) {\n generator.setSourceContent(sourceFile, content);\n }\n });\n return generator;\n };\n\n/**\n * Add a single mapping from original source line and column to the generated\n * source's line and column for this source map being created. The mapping\n * object should have the following properties:\n *\n * - generated: An object with the generated line and column positions.\n * - original: An object with the original line and column positions.\n * - source: The original source file (relative to the sourceRoot).\n * - name: An optional original token name for this mapping.\n */\nSourceMapGenerator.prototype.addMapping =\n function SourceMapGenerator_addMapping(aArgs) {\n var generated = util.getArg(aArgs, 'generated');\n var original = util.getArg(aArgs, 'original', null);\n var source = util.getArg(aArgs, 'source', null);\n var name = util.getArg(aArgs, 'name', null);\n\n if (!this._skipValidation) {\n this._validateMapping(generated, original, source, name);\n }\n\n if (source != null) {\n source = String(source);\n if (!this._sources.has(source)) {\n this._sources.add(source);\n }\n }\n\n if (name != null) {\n name = String(name);\n if (!this._names.has(name)) {\n this._names.add(name);\n }\n }\n\n this._mappings.add({\n generatedLine: generated.line,\n generatedColumn: generated.column,\n originalLine: original != null && original.line,\n originalColumn: original != null && original.column,\n source: source,\n name: name\n });\n };\n\n/**\n * Set the source content for a source file.\n */\nSourceMapGenerator.prototype.setSourceContent =\n function SourceMapGenerator_setSourceContent(aSourceFile, aSourceContent) {\n var source = aSourceFile;\n if (this._sourceRoot != null) {\n source = util.relative(this._sourceRoot, source);\n }\n\n if (aSourceContent != null) {\n // Add the source content to the _sourcesContents map.\n // Create a new _sourcesContents map if the property is null.\n if (!this._sourcesContents) {\n this._sourcesContents = Object.create(null);\n }\n this._sourcesContents[util.toSetString(source)] = aSourceContent;\n } else if (this._sourcesContents) {\n // Remove the source file from the _sourcesContents map.\n // If the _sourcesContents map is empty, set the property to null.\n delete this._sourcesContents[util.toSetString(source)];\n if (Object.keys(this._sourcesContents).length === 0) {\n this._sourcesContents = null;\n }\n }\n };\n\n/**\n * Applies the mappings of a sub-source-map for a specific source file to the\n * source map being generated. Each mapping to the supplied source file is\n * rewritten using the supplied source map. Note: The resolution for the\n * resulting mappings is the minimium of this map and the supplied map.\n *\n * @param aSourceMapConsumer The source map to be applied.\n * @param aSourceFile Optional. The filename of the source file.\n * If omitted, SourceMapConsumer's file property will be used.\n * @param aSourceMapPath Optional. The dirname of the path to the source map\n * to be applied. If relative, it is relative to the SourceMapConsumer.\n * This parameter is needed when the two source maps aren't in the same\n * directory, and the source map to be applied contains relative source\n * paths. If so, those relative source paths need to be rewritten\n * relative to the SourceMapGenerator.\n */\nSourceMapGenerator.prototype.applySourceMap =\n function SourceMapGenerator_applySourceMap(aSourceMapConsumer, aSourceFile, aSourceMapPath) {\n var sourceFile = aSourceFile;\n // If aSourceFile is omitted, we will use the file property of the SourceMap\n if (aSourceFile == null) {\n if (aSourceMapConsumer.file == null) {\n throw new Error(\n 'SourceMapGenerator.prototype.applySourceMap requires either an explicit source file, ' +\n 'or the source map\\'s \"file\" property. Both were omitted.'\n );\n }\n sourceFile = aSourceMapConsumer.file;\n }\n var sourceRoot = this._sourceRoot;\n // Make \"sourceFile\" relative if an absolute Url is passed.\n if (sourceRoot != null) {\n sourceFile = util.relative(sourceRoot, sourceFile);\n }\n // Applying the SourceMap can add and remove items from the sources and\n // the names array.\n var newSources = new ArraySet();\n var newNames = new ArraySet();\n\n // Find mappings for the \"sourceFile\"\n this._mappings.unsortedForEach(function (mapping) {\n if (mapping.source === sourceFile && mapping.originalLine != null) {\n // Check if it can be mapped by the source map, then update the mapping.\n var original = aSourceMapConsumer.originalPositionFor({\n line: mapping.originalLine,\n column: mapping.originalColumn\n });\n if (original.source != null) {\n // Copy mapping\n mapping.source = original.source;\n if (aSourceMapPath != null) {\n mapping.source = util.join(aSourceMapPath, mapping.source)\n }\n if (sourceRoot != null) {\n mapping.source = util.relative(sourceRoot, mapping.source);\n }\n mapping.originalLine = original.line;\n mapping.originalColumn = original.column;\n if (original.name != null) {\n mapping.name = original.name;\n }\n }\n }\n\n var source = mapping.source;\n if (source != null && !newSources.has(source)) {\n newSources.add(source);\n }\n\n var name = mapping.name;\n if (name != null && !newNames.has(name)) {\n newNames.add(name);\n }\n\n }, this);\n this._sources = newSources;\n this._names = newNames;\n\n // Copy sourcesContents of applied map.\n aSourceMapConsumer.sources.forEach(function (sourceFile) {\n var content = aSourceMapConsumer.sourceContentFor(sourceFile);\n if (content != null) {\n if (aSourceMapPath != null) {\n sourceFile = util.join(aSourceMapPath, sourceFile);\n }\n if (sourceRoot != null) {\n sourceFile = util.relative(sourceRoot, sourceFile);\n }\n this.setSourceContent(sourceFile, content);\n }\n }, this);\n };\n\n/**\n * A mapping can have one of the three levels of data:\n *\n * 1. Just the generated position.\n * 2. The Generated position, original position, and original source.\n * 3. Generated and original position, original source, as well as a name\n * token.\n *\n * To maintain consistency, we validate that any new mapping being added falls\n * in to one of these categories.\n */\nSourceMapGenerator.prototype._validateMapping =\n function SourceMapGenerator_validateMapping(aGenerated, aOriginal, aSource,\n aName) {\n // When aOriginal is truthy but has empty values for .line and .column,\n // it is most likely a programmer error. In this case we throw a very\n // specific error message to try to guide them the right way.\n // For example: https://github.com/Polymer/polymer-bundler/pull/519\n if (aOriginal && typeof aOriginal.line !== 'number' && typeof aOriginal.column !== 'number') {\n throw new Error(\n 'original.line and original.column are not numbers -- you probably meant to omit ' +\n 'the original mapping entirely and only map the generated position. If so, pass ' +\n 'null for the original mapping instead of an object with empty or null values.'\n );\n }\n\n if (aGenerated && 'line' in aGenerated && 'column' in aGenerated\n && aGenerated.line > 0 && aGenerated.column >= 0\n && !aOriginal && !aSource && !aName) {\n // Case 1.\n return;\n }\n else if (aGenerated && 'line' in aGenerated && 'column' in aGenerated\n && aOriginal && 'line' in aOriginal && 'column' in aOriginal\n && aGenerated.line > 0 && aGenerated.column >= 0\n && aOriginal.line > 0 && aOriginal.column >= 0\n && aSource) {\n // Cases 2 and 3.\n return;\n }\n else {\n throw new Error('Invalid mapping: ' + JSON.stringify({\n generated: aGenerated,\n source: aSource,\n original: aOriginal,\n name: aName\n }));\n }\n };\n\n/**\n * Serialize the accumulated mappings in to the stream of base 64 VLQs\n * specified by the source map format.\n */\nSourceMapGenerator.prototype._serializeMappings =\n function SourceMapGenerator_serializeMappings() {\n var previousGeneratedColumn = 0;\n var previousGeneratedLine = 1;\n var previousOriginalColumn = 0;\n var previousOriginalLine = 0;\n var previousName = 0;\n var previousSource = 0;\n var result = '';\n var next;\n var mapping;\n var nameIdx;\n var sourceIdx;\n\n var mappings = this._mappings.toArray();\n for (var i = 0, len = mappings.length; i < len; i++) {\n mapping = mappings[i];\n next = ''\n\n if (mapping.generatedLine !== previousGeneratedLine) {\n previousGeneratedColumn = 0;\n while (mapping.generatedLine !== previousGeneratedLine) {\n next += ';';\n previousGeneratedLine++;\n }\n }\n else {\n if (i > 0) {\n if (!util.compareByGeneratedPositionsInflated(mapping, mappings[i - 1])) {\n continue;\n }\n next += ',';\n }\n }\n\n next += base64VLQ.encode(mapping.generatedColumn\n - previousGeneratedColumn);\n previousGeneratedColumn = mapping.generatedColumn;\n\n if (mapping.source != null) {\n sourceIdx = this._sources.indexOf(mapping.source);\n next += base64VLQ.encode(sourceIdx - previousSource);\n previousSource = sourceIdx;\n\n // lines are stored 0-based in SourceMap spec version 3\n next += base64VLQ.encode(mapping.originalLine - 1\n - previousOriginalLine);\n previousOriginalLine = mapping.originalLine - 1;\n\n next += base64VLQ.encode(mapping.originalColumn\n - previousOriginalColumn);\n previousOriginalColumn = mapping.originalColumn;\n\n if (mapping.name != null) {\n nameIdx = this._names.indexOf(mapping.name);\n next += base64VLQ.encode(nameIdx - previousName);\n previousName = nameIdx;\n }\n }\n\n result += next;\n }\n\n return result;\n };\n\nSourceMapGenerator.prototype._generateSourcesContent =\n function SourceMapGenerator_generateSourcesContent(aSources, aSourceRoot) {\n return aSources.map(function (source) {\n if (!this._sourcesContents) {\n return null;\n }\n if (aSourceRoot != null) {\n source = util.relative(aSourceRoot, source);\n }\n var key = util.toSetString(source);\n return Object.prototype.hasOwnProperty.call(this._sourcesContents, key)\n ? this._sourcesContents[key]\n : null;\n }, this);\n };\n\n/**\n * Externalize the source map.\n */\nSourceMapGenerator.prototype.toJSON =\n function SourceMapGenerator_toJSON() {\n var map = {\n version: this._version,\n sources: this._sources.toArray(),\n names: this._names.toArray(),\n mappings: this._serializeMappings()\n };\n if (this._file != null) {\n map.file = this._file;\n }\n if (this._sourceRoot != null) {\n map.sourceRoot = this._sourceRoot;\n }\n if (this._sourcesContents) {\n map.sourcesContent = this._generateSourcesContent(map.sources, map.sourceRoot);\n }\n\n return map;\n };\n\n/**\n * Render the source map being generated to a string.\n */\nSourceMapGenerator.prototype.toString =\n function SourceMapGenerator_toString() {\n return JSON.stringify(this.toJSON());\n };\n\nexports.SourceMapGenerator = SourceMapGenerator;\n",
43
+ "/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\nexports.GREATEST_LOWER_BOUND = 1;\nexports.LEAST_UPPER_BOUND = 2;\n\n/**\n * Recursive implementation of binary search.\n *\n * @param aLow Indices here and lower do not contain the needle.\n * @param aHigh Indices here and higher do not contain the needle.\n * @param aNeedle The element being searched for.\n * @param aHaystack The non-empty array being searched.\n * @param aCompare Function which takes two elements and returns -1, 0, or 1.\n * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or\n * 'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the\n * closest element that is smaller than or greater than the one we are\n * searching for, respectively, if the exact element cannot be found.\n */\nfunction recursiveSearch(aLow, aHigh, aNeedle, aHaystack, aCompare, aBias) {\n // This function terminates when one of the following is true:\n //\n // 1. We find the exact element we are looking for.\n //\n // 2. We did not find the exact element, but we can return the index of\n // the next-closest element.\n //\n // 3. We did not find the exact element, and there is no next-closest\n // element than the one we are searching for, so we return -1.\n var mid = Math.floor((aHigh - aLow) / 2) + aLow;\n var cmp = aCompare(aNeedle, aHaystack[mid], true);\n if (cmp === 0) {\n // Found the element we are looking for.\n return mid;\n }\n else if (cmp > 0) {\n // Our needle is greater than aHaystack[mid].\n if (aHigh - mid > 1) {\n // The element is in the upper half.\n return recursiveSearch(mid, aHigh, aNeedle, aHaystack, aCompare, aBias);\n }\n\n // The exact needle element was not found in this haystack. Determine if\n // we are in termination case (3) or (2) and return the appropriate thing.\n if (aBias == exports.LEAST_UPPER_BOUND) {\n return aHigh < aHaystack.length ? aHigh : -1;\n } else {\n return mid;\n }\n }\n else {\n // Our needle is less than aHaystack[mid].\n if (mid - aLow > 1) {\n // The element is in the lower half.\n return recursiveSearch(aLow, mid, aNeedle, aHaystack, aCompare, aBias);\n }\n\n // we are in termination case (3) or (2) and return the appropriate thing.\n if (aBias == exports.LEAST_UPPER_BOUND) {\n return mid;\n } else {\n return aLow < 0 ? -1 : aLow;\n }\n }\n}\n\n/**\n * This is an implementation of binary search which will always try and return\n * the index of the closest element if there is no exact hit. This is because\n * mappings between original and generated line/col pairs are single points,\n * and there is an implicit region between each of them, so a miss just means\n * that you aren't on the very start of a region.\n *\n * @param aNeedle The element you are looking for.\n * @param aHaystack The array that is being searched.\n * @param aCompare A function which takes the needle and an element in the\n * array and returns -1, 0, or 1 depending on whether the needle is less\n * than, equal to, or greater than the element, respectively.\n * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or\n * 'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the\n * closest element that is smaller than or greater than the one we are\n * searching for, respectively, if the exact element cannot be found.\n * Defaults to 'binarySearch.GREATEST_LOWER_BOUND'.\n */\nexports.search = function search(aNeedle, aHaystack, aCompare, aBias) {\n if (aHaystack.length === 0) {\n return -1;\n }\n\n var index = recursiveSearch(-1, aHaystack.length, aNeedle, aHaystack,\n aCompare, aBias || exports.GREATEST_LOWER_BOUND);\n if (index < 0) {\n return -1;\n }\n\n // We have found either the exact element, or the next-closest element than\n // the one we are searching for. However, there may be more than one such\n // element. Make sure we always return the smallest of these.\n while (index - 1 >= 0) {\n if (aCompare(aHaystack[index], aHaystack[index - 1], true) !== 0) {\n break;\n }\n --index;\n }\n\n return index;\n};\n",
44
+ "/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\n// It turns out that some (most?) JavaScript engines don't self-host\n// `Array.prototype.sort`. This makes sense because C++ will likely remain\n// faster than JS when doing raw CPU-intensive sorting. However, when using a\n// custom comparator function, calling back and forth between the VM's C++ and\n// JIT'd JS is rather slow *and* loses JIT type information, resulting in\n// worse generated code for the comparator function than would be optimal. In\n// fact, when sorting with a comparator, these costs outweigh the benefits of\n// sorting in C++. By using our own JS-implemented Quick Sort (below), we get\n// a ~3500ms mean speed-up in `bench/bench.html`.\n\n/**\n * Swap the elements indexed by `x` and `y` in the array `ary`.\n *\n * @param {Array} ary\n * The array.\n * @param {Number} x\n * The index of the first item.\n * @param {Number} y\n * The index of the second item.\n */\nfunction swap(ary, x, y) {\n var temp = ary[x];\n ary[x] = ary[y];\n ary[y] = temp;\n}\n\n/**\n * Returns a random integer within the range `low .. high` inclusive.\n *\n * @param {Number} low\n * The lower bound on the range.\n * @param {Number} high\n * The upper bound on the range.\n */\nfunction randomIntInRange(low, high) {\n return Math.round(low + (Math.random() * (high - low)));\n}\n\n/**\n * The Quick Sort algorithm.\n *\n * @param {Array} ary\n * An array to sort.\n * @param {function} comparator\n * Function to use to compare two items.\n * @param {Number} p\n * Start index of the array\n * @param {Number} r\n * End index of the array\n */\nfunction doQuickSort(ary, comparator, p, r) {\n // If our lower bound is less than our upper bound, we (1) partition the\n // array into two pieces and (2) recurse on each half. If it is not, this is\n // the empty array and our base case.\n\n if (p < r) {\n // (1) Partitioning.\n //\n // The partitioning chooses a pivot between `p` and `r` and moves all\n // elements that are less than or equal to the pivot to the before it, and\n // all the elements that are greater than it after it. The effect is that\n // once partition is done, the pivot is in the exact place it will be when\n // the array is put in sorted order, and it will not need to be moved\n // again. This runs in O(n) time.\n\n // Always choose a random pivot so that an input array which is reverse\n // sorted does not cause O(n^2) running time.\n var pivotIndex = randomIntInRange(p, r);\n var i = p - 1;\n\n swap(ary, pivotIndex, r);\n var pivot = ary[r];\n\n // Immediately after `j` is incremented in this loop, the following hold\n // true:\n //\n // * Every element in `ary[p .. i]` is less than or equal to the pivot.\n //\n // * Every element in `ary[i+1 .. j-1]` is greater than the pivot.\n for (var j = p; j < r; j++) {\n if (comparator(ary[j], pivot) <= 0) {\n i += 1;\n swap(ary, i, j);\n }\n }\n\n swap(ary, i + 1, j);\n var q = i + 1;\n\n // (2) Recurse on each half.\n\n doQuickSort(ary, comparator, p, q - 1);\n doQuickSort(ary, comparator, q + 1, r);\n }\n}\n\n/**\n * Sort the given array in-place with the given comparator function.\n *\n * @param {Array} ary\n * An array to sort.\n * @param {function} comparator\n * Function to use to compare two items.\n */\nexports.quickSort = function (ary, comparator) {\n doQuickSort(ary, comparator, 0, ary.length - 1);\n};\n",
45
+ "/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\nvar util = require('./util');\nvar binarySearch = require('./binary-search');\nvar ArraySet = require('./array-set').ArraySet;\nvar base64VLQ = require('./base64-vlq');\nvar quickSort = require('./quick-sort').quickSort;\n\nfunction SourceMapConsumer(aSourceMap, aSourceMapURL) {\n var sourceMap = aSourceMap;\n if (typeof aSourceMap === 'string') {\n sourceMap = util.parseSourceMapInput(aSourceMap);\n }\n\n return sourceMap.sections != null\n ? new IndexedSourceMapConsumer(sourceMap, aSourceMapURL)\n : new BasicSourceMapConsumer(sourceMap, aSourceMapURL);\n}\n\nSourceMapConsumer.fromSourceMap = function(aSourceMap, aSourceMapURL) {\n return BasicSourceMapConsumer.fromSourceMap(aSourceMap, aSourceMapURL);\n}\n\n/**\n * The version of the source mapping spec that we are consuming.\n */\nSourceMapConsumer.prototype._version = 3;\n\n// `__generatedMappings` and `__originalMappings` are arrays that hold the\n// parsed mapping coordinates from the source map's \"mappings\" attribute. They\n// are lazily instantiated, accessed via the `_generatedMappings` and\n// `_originalMappings` getters respectively, and we only parse the mappings\n// and create these arrays once queried for a source location. We jump through\n// these hoops because there can be many thousands of mappings, and parsing\n// them is expensive, so we only want to do it if we must.\n//\n// Each object in the arrays is of the form:\n//\n// {\n// generatedLine: The line number in the generated code,\n// generatedColumn: The column number in the generated code,\n// source: The path to the original source file that generated this\n// chunk of code,\n// originalLine: The line number in the original source that\n// corresponds to this chunk of generated code,\n// originalColumn: The column number in the original source that\n// corresponds to this chunk of generated code,\n// name: The name of the original symbol which generated this chunk of\n// code.\n// }\n//\n// All properties except for `generatedLine` and `generatedColumn` can be\n// `null`.\n//\n// `_generatedMappings` is ordered by the generated positions.\n//\n// `_originalMappings` is ordered by the original positions.\n\nSourceMapConsumer.prototype.__generatedMappings = null;\nObject.defineProperty(SourceMapConsumer.prototype, '_generatedMappings', {\n configurable: true,\n enumerable: true,\n get: function () {\n if (!this.__generatedMappings) {\n this._parseMappings(this._mappings, this.sourceRoot);\n }\n\n return this.__generatedMappings;\n }\n});\n\nSourceMapConsumer.prototype.__originalMappings = null;\nObject.defineProperty(SourceMapConsumer.prototype, '_originalMappings', {\n configurable: true,\n enumerable: true,\n get: function () {\n if (!this.__originalMappings) {\n this._parseMappings(this._mappings, this.sourceRoot);\n }\n\n return this.__originalMappings;\n }\n});\n\nSourceMapConsumer.prototype._charIsMappingSeparator =\n function SourceMapConsumer_charIsMappingSeparator(aStr, index) {\n var c = aStr.charAt(index);\n return c === \";\" || c === \",\";\n };\n\n/**\n * Parse the mappings in a string in to a data structure which we can easily\n * query (the ordered arrays in the `this.__generatedMappings` and\n * `this.__originalMappings` properties).\n */\nSourceMapConsumer.prototype._parseMappings =\n function SourceMapConsumer_parseMappings(aStr, aSourceRoot) {\n throw new Error(\"Subclasses must implement _parseMappings\");\n };\n\nSourceMapConsumer.GENERATED_ORDER = 1;\nSourceMapConsumer.ORIGINAL_ORDER = 2;\n\nSourceMapConsumer.GREATEST_LOWER_BOUND = 1;\nSourceMapConsumer.LEAST_UPPER_BOUND = 2;\n\n/**\n * Iterate over each mapping between an original source/line/column and a\n * generated line/column in this source map.\n *\n * @param Function aCallback\n * The function that is called with each mapping.\n * @param Object aContext\n * Optional. If specified, this object will be the value of `this` every\n * time that `aCallback` is called.\n * @param aOrder\n * Either `SourceMapConsumer.GENERATED_ORDER` or\n * `SourceMapConsumer.ORIGINAL_ORDER`. Specifies whether you want to\n * iterate over the mappings sorted by the generated file's line/column\n * order or the original's source/line/column order, respectively. Defaults to\n * `SourceMapConsumer.GENERATED_ORDER`.\n */\nSourceMapConsumer.prototype.eachMapping =\n function SourceMapConsumer_eachMapping(aCallback, aContext, aOrder) {\n var context = aContext || null;\n var order = aOrder || SourceMapConsumer.GENERATED_ORDER;\n\n var mappings;\n switch (order) {\n case SourceMapConsumer.GENERATED_ORDER:\n mappings = this._generatedMappings;\n break;\n case SourceMapConsumer.ORIGINAL_ORDER:\n mappings = this._originalMappings;\n break;\n default:\n throw new Error(\"Unknown order of iteration.\");\n }\n\n var sourceRoot = this.sourceRoot;\n mappings.map(function (mapping) {\n var source = mapping.source === null ? null : this._sources.at(mapping.source);\n source = util.computeSourceURL(sourceRoot, source, this._sourceMapURL);\n return {\n source: source,\n generatedLine: mapping.generatedLine,\n generatedColumn: mapping.generatedColumn,\n originalLine: mapping.originalLine,\n originalColumn: mapping.originalColumn,\n name: mapping.name === null ? null : this._names.at(mapping.name)\n };\n }, this).forEach(aCallback, context);\n };\n\n/**\n * Returns all generated line and column information for the original source,\n * line, and column provided. If no column is provided, returns all mappings\n * corresponding to a either the line we are searching for or the next\n * closest line that has any mappings. Otherwise, returns all mappings\n * corresponding to the given line and either the column we are searching for\n * or the next closest column that has any offsets.\n *\n * The only argument is an object with the following properties:\n *\n * - source: The filename of the original source.\n * - line: The line number in the original source. The line number is 1-based.\n * - column: Optional. the column number in the original source.\n * The column number is 0-based.\n *\n * and an array of objects is returned, each with the following properties:\n *\n * - line: The line number in the generated source, or null. The\n * line number is 1-based.\n * - column: The column number in the generated source, or null.\n * The column number is 0-based.\n */\nSourceMapConsumer.prototype.allGeneratedPositionsFor =\n function SourceMapConsumer_allGeneratedPositionsFor(aArgs) {\n var line = util.getArg(aArgs, 'line');\n\n // When there is no exact match, BasicSourceMapConsumer.prototype._findMapping\n // returns the index of the closest mapping less than the needle. By\n // setting needle.originalColumn to 0, we thus find the last mapping for\n // the given line, provided such a mapping exists.\n var needle = {\n source: util.getArg(aArgs, 'source'),\n originalLine: line,\n originalColumn: util.getArg(aArgs, 'column', 0)\n };\n\n needle.source = this._findSourceIndex(needle.source);\n if (needle.source < 0) {\n return [];\n }\n\n var mappings = [];\n\n var index = this._findMapping(needle,\n this._originalMappings,\n \"originalLine\",\n \"originalColumn\",\n util.compareByOriginalPositions,\n binarySearch.LEAST_UPPER_BOUND);\n if (index >= 0) {\n var mapping = this._originalMappings[index];\n\n if (aArgs.column === undefined) {\n var originalLine = mapping.originalLine;\n\n // Iterate until either we run out of mappings, or we run into\n // a mapping for a different line than the one we found. Since\n // mappings are sorted, this is guaranteed to find all mappings for\n // the line we found.\n while (mapping && mapping.originalLine === originalLine) {\n mappings.push({\n line: util.getArg(mapping, 'generatedLine', null),\n column: util.getArg(mapping, 'generatedColumn', null),\n lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)\n });\n\n mapping = this._originalMappings[++index];\n }\n } else {\n var originalColumn = mapping.originalColumn;\n\n // Iterate until either we run out of mappings, or we run into\n // a mapping for a different line than the one we were searching for.\n // Since mappings are sorted, this is guaranteed to find all mappings for\n // the line we are searching for.\n while (mapping &&\n mapping.originalLine === line &&\n mapping.originalColumn == originalColumn) {\n mappings.push({\n line: util.getArg(mapping, 'generatedLine', null),\n column: util.getArg(mapping, 'generatedColumn', null),\n lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)\n });\n\n mapping = this._originalMappings[++index];\n }\n }\n }\n\n return mappings;\n };\n\nexports.SourceMapConsumer = SourceMapConsumer;\n\n/**\n * A BasicSourceMapConsumer instance represents a parsed source map which we can\n * query for information about the original file positions by giving it a file\n * position in the generated source.\n *\n * The first parameter is the raw source map (either as a JSON string, or\n * already parsed to an object). According to the spec, source maps have the\n * following attributes:\n *\n * - version: Which version of the source map spec this map is following.\n * - sources: An array of URLs to the original source files.\n * - names: An array of identifiers which can be referrenced by individual mappings.\n * - sourceRoot: Optional. The URL root from which all sources are relative.\n * - sourcesContent: Optional. An array of contents of the original source files.\n * - mappings: A string of base64 VLQs which contain the actual mappings.\n * - file: Optional. The generated file this source map is associated with.\n *\n * Here is an example source map, taken from the source map spec[0]:\n *\n * {\n * version : 3,\n * file: \"out.js\",\n * sourceRoot : \"\",\n * sources: [\"foo.js\", \"bar.js\"],\n * names: [\"src\", \"maps\", \"are\", \"fun\"],\n * mappings: \"AA,AB;;ABCDE;\"\n * }\n *\n * The second parameter, if given, is a string whose value is the URL\n * at which the source map was found. This URL is used to compute the\n * sources array.\n *\n * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit?pli=1#\n */\nfunction BasicSourceMapConsumer(aSourceMap, aSourceMapURL) {\n var sourceMap = aSourceMap;\n if (typeof aSourceMap === 'string') {\n sourceMap = util.parseSourceMapInput(aSourceMap);\n }\n\n var version = util.getArg(sourceMap, 'version');\n var sources = util.getArg(sourceMap, 'sources');\n // Sass 3.3 leaves out the 'names' array, so we deviate from the spec (which\n // requires the array) to play nice here.\n var names = util.getArg(sourceMap, 'names', []);\n var sourceRoot = util.getArg(sourceMap, 'sourceRoot', null);\n var sourcesContent = util.getArg(sourceMap, 'sourcesContent', null);\n var mappings = util.getArg(sourceMap, 'mappings');\n var file = util.getArg(sourceMap, 'file', null);\n\n // Once again, Sass deviates from the spec and supplies the version as a\n // string rather than a number, so we use loose equality checking here.\n if (version != this._version) {\n throw new Error('Unsupported version: ' + version);\n }\n\n if (sourceRoot) {\n sourceRoot = util.normalize(sourceRoot);\n }\n\n sources = sources\n .map(String)\n // Some source maps produce relative source paths like \"./foo.js\" instead of\n // \"foo.js\". Normalize these first so that future comparisons will succeed.\n // See bugzil.la/1090768.\n .map(util.normalize)\n // Always ensure that absolute sources are internally stored relative to\n // the source root, if the source root is absolute. Not doing this would\n // be particularly problematic when the source root is a prefix of the\n // source (valid, but why??). See github issue #199 and bugzil.la/1188982.\n .map(function (source) {\n return sourceRoot && util.isAbsolute(sourceRoot) && util.isAbsolute(source)\n ? util.relative(sourceRoot, source)\n : source;\n });\n\n // Pass `true` below to allow duplicate names and sources. While source maps\n // are intended to be compressed and deduplicated, the TypeScript compiler\n // sometimes generates source maps with duplicates in them. See Github issue\n // #72 and bugzil.la/889492.\n this._names = ArraySet.fromArray(names.map(String), true);\n this._sources = ArraySet.fromArray(sources, true);\n\n this._absoluteSources = this._sources.toArray().map(function (s) {\n return util.computeSourceURL(sourceRoot, s, aSourceMapURL);\n });\n\n this.sourceRoot = sourceRoot;\n this.sourcesContent = sourcesContent;\n this._mappings = mappings;\n this._sourceMapURL = aSourceMapURL;\n this.file = file;\n}\n\nBasicSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype);\nBasicSourceMapConsumer.prototype.consumer = SourceMapConsumer;\n\n/**\n * Utility function to find the index of a source. Returns -1 if not\n * found.\n */\nBasicSourceMapConsumer.prototype._findSourceIndex = function(aSource) {\n var relativeSource = aSource;\n if (this.sourceRoot != null) {\n relativeSource = util.relative(this.sourceRoot, relativeSource);\n }\n\n if (this._sources.has(relativeSource)) {\n return this._sources.indexOf(relativeSource);\n }\n\n // Maybe aSource is an absolute URL as returned by |sources|. In\n // this case we can't simply undo the transform.\n var i;\n for (i = 0; i < this._absoluteSources.length; ++i) {\n if (this._absoluteSources[i] == aSource) {\n return i;\n }\n }\n\n return -1;\n};\n\n/**\n * Create a BasicSourceMapConsumer from a SourceMapGenerator.\n *\n * @param SourceMapGenerator aSourceMap\n * The source map that will be consumed.\n * @param String aSourceMapURL\n * The URL at which the source map can be found (optional)\n * @returns BasicSourceMapConsumer\n */\nBasicSourceMapConsumer.fromSourceMap =\n function SourceMapConsumer_fromSourceMap(aSourceMap, aSourceMapURL) {\n var smc = Object.create(BasicSourceMapConsumer.prototype);\n\n var names = smc._names = ArraySet.fromArray(aSourceMap._names.toArray(), true);\n var sources = smc._sources = ArraySet.fromArray(aSourceMap._sources.toArray(), true);\n smc.sourceRoot = aSourceMap._sourceRoot;\n smc.sourcesContent = aSourceMap._generateSourcesContent(smc._sources.toArray(),\n smc.sourceRoot);\n smc.file = aSourceMap._file;\n smc._sourceMapURL = aSourceMapURL;\n smc._absoluteSources = smc._sources.toArray().map(function (s) {\n return util.computeSourceURL(smc.sourceRoot, s, aSourceMapURL);\n });\n\n // Because we are modifying the entries (by converting string sources and\n // names to indices into the sources and names ArraySets), we have to make\n // a copy of the entry or else bad things happen. Shared mutable state\n // strikes again! See github issue #191.\n\n var generatedMappings = aSourceMap._mappings.toArray().slice();\n var destGeneratedMappings = smc.__generatedMappings = [];\n var destOriginalMappings = smc.__originalMappings = [];\n\n for (var i = 0, length = generatedMappings.length; i < length; i++) {\n var srcMapping = generatedMappings[i];\n var destMapping = new Mapping;\n destMapping.generatedLine = srcMapping.generatedLine;\n destMapping.generatedColumn = srcMapping.generatedColumn;\n\n if (srcMapping.source) {\n destMapping.source = sources.indexOf(srcMapping.source);\n destMapping.originalLine = srcMapping.originalLine;\n destMapping.originalColumn = srcMapping.originalColumn;\n\n if (srcMapping.name) {\n destMapping.name = names.indexOf(srcMapping.name);\n }\n\n destOriginalMappings.push(destMapping);\n }\n\n destGeneratedMappings.push(destMapping);\n }\n\n quickSort(smc.__originalMappings, util.compareByOriginalPositions);\n\n return smc;\n };\n\n/**\n * The version of the source mapping spec that we are consuming.\n */\nBasicSourceMapConsumer.prototype._version = 3;\n\n/**\n * The list of original sources.\n */\nObject.defineProperty(BasicSourceMapConsumer.prototype, 'sources', {\n get: function () {\n return this._absoluteSources.slice();\n }\n});\n\n/**\n * Provide the JIT with a nice shape / hidden class.\n */\nfunction Mapping() {\n this.generatedLine = 0;\n this.generatedColumn = 0;\n this.source = null;\n this.originalLine = null;\n this.originalColumn = null;\n this.name = null;\n}\n\n/**\n * Parse the mappings in a string in to a data structure which we can easily\n * query (the ordered arrays in the `this.__generatedMappings` and\n * `this.__originalMappings` properties).\n */\nBasicSourceMapConsumer.prototype._parseMappings =\n function SourceMapConsumer_parseMappings(aStr, aSourceRoot) {\n var generatedLine = 1;\n var previousGeneratedColumn = 0;\n var previousOriginalLine = 0;\n var previousOriginalColumn = 0;\n var previousSource = 0;\n var previousName = 0;\n var length = aStr.length;\n var index = 0;\n var cachedSegments = {};\n var temp = {};\n var originalMappings = [];\n var generatedMappings = [];\n var mapping, str, segment, end, value;\n\n while (index < length) {\n if (aStr.charAt(index) === ';') {\n generatedLine++;\n index++;\n previousGeneratedColumn = 0;\n }\n else if (aStr.charAt(index) === ',') {\n index++;\n }\n else {\n mapping = new Mapping();\n mapping.generatedLine = generatedLine;\n\n // Because each offset is encoded relative to the previous one,\n // many segments often have the same encoding. We can exploit this\n // fact by caching the parsed variable length fields of each segment,\n // allowing us to avoid a second parse if we encounter the same\n // segment again.\n for (end = index; end < length; end++) {\n if (this._charIsMappingSeparator(aStr, end)) {\n break;\n }\n }\n str = aStr.slice(index, end);\n\n segment = cachedSegments[str];\n if (segment) {\n index += str.length;\n } else {\n segment = [];\n while (index < end) {\n base64VLQ.decode(aStr, index, temp);\n value = temp.value;\n index = temp.rest;\n segment.push(value);\n }\n\n if (segment.length === 2) {\n throw new Error('Found a source, but no line and column');\n }\n\n if (segment.length === 3) {\n throw new Error('Found a source and line, but no column');\n }\n\n cachedSegments[str] = segment;\n }\n\n // Generated column.\n mapping.generatedColumn = previousGeneratedColumn + segment[0];\n previousGeneratedColumn = mapping.generatedColumn;\n\n if (segment.length > 1) {\n // Original source.\n mapping.source = previousSource + segment[1];\n previousSource += segment[1];\n\n // Original line.\n mapping.originalLine = previousOriginalLine + segment[2];\n previousOriginalLine = mapping.originalLine;\n // Lines are stored 0-based\n mapping.originalLine += 1;\n\n // Original column.\n mapping.originalColumn = previousOriginalColumn + segment[3];\n previousOriginalColumn = mapping.originalColumn;\n\n if (segment.length > 4) {\n // Original name.\n mapping.name = previousName + segment[4];\n previousName += segment[4];\n }\n }\n\n generatedMappings.push(mapping);\n if (typeof mapping.originalLine === 'number') {\n originalMappings.push(mapping);\n }\n }\n }\n\n quickSort(generatedMappings, util.compareByGeneratedPositionsDeflated);\n this.__generatedMappings = generatedMappings;\n\n quickSort(originalMappings, util.compareByOriginalPositions);\n this.__originalMappings = originalMappings;\n };\n\n/**\n * Find the mapping that best matches the hypothetical \"needle\" mapping that\n * we are searching for in the given \"haystack\" of mappings.\n */\nBasicSourceMapConsumer.prototype._findMapping =\n function SourceMapConsumer_findMapping(aNeedle, aMappings, aLineName,\n aColumnName, aComparator, aBias) {\n // To return the position we are searching for, we must first find the\n // mapping for the given position and then return the opposite position it\n // points to. Because the mappings are sorted, we can use binary search to\n // find the best mapping.\n\n if (aNeedle[aLineName] <= 0) {\n throw new TypeError('Line must be greater than or equal to 1, got '\n + aNeedle[aLineName]);\n }\n if (aNeedle[aColumnName] < 0) {\n throw new TypeError('Column must be greater than or equal to 0, got '\n + aNeedle[aColumnName]);\n }\n\n return binarySearch.search(aNeedle, aMappings, aComparator, aBias);\n };\n\n/**\n * Compute the last column for each generated mapping. The last column is\n * inclusive.\n */\nBasicSourceMapConsumer.prototype.computeColumnSpans =\n function SourceMapConsumer_computeColumnSpans() {\n for (var index = 0; index < this._generatedMappings.length; ++index) {\n var mapping = this._generatedMappings[index];\n\n // Mappings do not contain a field for the last generated columnt. We\n // can come up with an optimistic estimate, however, by assuming that\n // mappings are contiguous (i.e. given two consecutive mappings, the\n // first mapping ends where the second one starts).\n if (index + 1 < this._generatedMappings.length) {\n var nextMapping = this._generatedMappings[index + 1];\n\n if (mapping.generatedLine === nextMapping.generatedLine) {\n mapping.lastGeneratedColumn = nextMapping.generatedColumn - 1;\n continue;\n }\n }\n\n // The last mapping for each line spans the entire line.\n mapping.lastGeneratedColumn = Infinity;\n }\n };\n\n/**\n * Returns the original source, line, and column information for the generated\n * source's line and column positions provided. The only argument is an object\n * with the following properties:\n *\n * - line: The line number in the generated source. The line number\n * is 1-based.\n * - column: The column number in the generated source. The column\n * number is 0-based.\n * - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or\n * 'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the\n * closest element that is smaller than or greater than the one we are\n * searching for, respectively, if the exact element cannot be found.\n * Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'.\n *\n * and an object is returned with the following properties:\n *\n * - source: The original source file, or null.\n * - line: The line number in the original source, or null. The\n * line number is 1-based.\n * - column: The column number in the original source, or null. The\n * column number is 0-based.\n * - name: The original identifier, or null.\n */\nBasicSourceMapConsumer.prototype.originalPositionFor =\n function SourceMapConsumer_originalPositionFor(aArgs) {\n var needle = {\n generatedLine: util.getArg(aArgs, 'line'),\n generatedColumn: util.getArg(aArgs, 'column')\n };\n\n var index = this._findMapping(\n needle,\n this._generatedMappings,\n \"generatedLine\",\n \"generatedColumn\",\n util.compareByGeneratedPositionsDeflated,\n util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND)\n );\n\n if (index >= 0) {\n var mapping = this._generatedMappings[index];\n\n if (mapping.generatedLine === needle.generatedLine) {\n var source = util.getArg(mapping, 'source', null);\n if (source !== null) {\n source = this._sources.at(source);\n source = util.computeSourceURL(this.sourceRoot, source, this._sourceMapURL);\n }\n var name = util.getArg(mapping, 'name', null);\n if (name !== null) {\n name = this._names.at(name);\n }\n return {\n source: source,\n line: util.getArg(mapping, 'originalLine', null),\n column: util.getArg(mapping, 'originalColumn', null),\n name: name\n };\n }\n }\n\n return {\n source: null,\n line: null,\n column: null,\n name: null\n };\n };\n\n/**\n * Return true if we have the source content for every source in the source\n * map, false otherwise.\n */\nBasicSourceMapConsumer.prototype.hasContentsOfAllSources =\n function BasicSourceMapConsumer_hasContentsOfAllSources() {\n if (!this.sourcesContent) {\n return false;\n }\n return this.sourcesContent.length >= this._sources.size() &&\n !this.sourcesContent.some(function (sc) { return sc == null; });\n };\n\n/**\n * Returns the original source content. The only argument is the url of the\n * original source file. Returns null if no original source content is\n * available.\n */\nBasicSourceMapConsumer.prototype.sourceContentFor =\n function SourceMapConsumer_sourceContentFor(aSource, nullOnMissing) {\n if (!this.sourcesContent) {\n return null;\n }\n\n var index = this._findSourceIndex(aSource);\n if (index >= 0) {\n return this.sourcesContent[index];\n }\n\n var relativeSource = aSource;\n if (this.sourceRoot != null) {\n relativeSource = util.relative(this.sourceRoot, relativeSource);\n }\n\n var url;\n if (this.sourceRoot != null\n && (url = util.urlParse(this.sourceRoot))) {\n // XXX: file:// URIs and absolute paths lead to unexpected behavior for\n // many users. We can help them out when they expect file:// URIs to\n // behave like it would if they were running a local HTTP server. See\n // https://bugzilla.mozilla.org/show_bug.cgi?id=885597.\n var fileUriAbsPath = relativeSource.replace(/^file:\\/\\//, \"\");\n if (url.scheme == \"file\"\n && this._sources.has(fileUriAbsPath)) {\n return this.sourcesContent[this._sources.indexOf(fileUriAbsPath)]\n }\n\n if ((!url.path || url.path == \"/\")\n && this._sources.has(\"/\" + relativeSource)) {\n return this.sourcesContent[this._sources.indexOf(\"/\" + relativeSource)];\n }\n }\n\n // This function is used recursively from\n // IndexedSourceMapConsumer.prototype.sourceContentFor. In that case, we\n // don't want to throw if we can't find the source - we just want to\n // return null, so we provide a flag to exit gracefully.\n if (nullOnMissing) {\n return null;\n }\n else {\n throw new Error('\"' + relativeSource + '\" is not in the SourceMap.');\n }\n };\n\n/**\n * Returns the generated line and column information for the original source,\n * line, and column positions provided. The only argument is an object with\n * the following properties:\n *\n * - source: The filename of the original source.\n * - line: The line number in the original source. The line number\n * is 1-based.\n * - column: The column number in the original source. The column\n * number is 0-based.\n * - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or\n * 'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the\n * closest element that is smaller than or greater than the one we are\n * searching for, respectively, if the exact element cannot be found.\n * Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'.\n *\n * and an object is returned with the following properties:\n *\n * - line: The line number in the generated source, or null. The\n * line number is 1-based.\n * - column: The column number in the generated source, or null.\n * The column number is 0-based.\n */\nBasicSourceMapConsumer.prototype.generatedPositionFor =\n function SourceMapConsumer_generatedPositionFor(aArgs) {\n var source = util.getArg(aArgs, 'source');\n source = this._findSourceIndex(source);\n if (source < 0) {\n return {\n line: null,\n column: null,\n lastColumn: null\n };\n }\n\n var needle = {\n source: source,\n originalLine: util.getArg(aArgs, 'line'),\n originalColumn: util.getArg(aArgs, 'column')\n };\n\n var index = this._findMapping(\n needle,\n this._originalMappings,\n \"originalLine\",\n \"originalColumn\",\n util.compareByOriginalPositions,\n util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND)\n );\n\n if (index >= 0) {\n var mapping = this._originalMappings[index];\n\n if (mapping.source === needle.source) {\n return {\n line: util.getArg(mapping, 'generatedLine', null),\n column: util.getArg(mapping, 'generatedColumn', null),\n lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null)\n };\n }\n }\n\n return {\n line: null,\n column: null,\n lastColumn: null\n };\n };\n\nexports.BasicSourceMapConsumer = BasicSourceMapConsumer;\n\n/**\n * An IndexedSourceMapConsumer instance represents a parsed source map which\n * we can query for information. It differs from BasicSourceMapConsumer in\n * that it takes \"indexed\" source maps (i.e. ones with a \"sections\" field) as\n * input.\n *\n * The first parameter is a raw source map (either as a JSON string, or already\n * parsed to an object). According to the spec for indexed source maps, they\n * have the following attributes:\n *\n * - version: Which version of the source map spec this map is following.\n * - file: Optional. The generated file this source map is associated with.\n * - sections: A list of section definitions.\n *\n * Each value under the \"sections\" field has two fields:\n * - offset: The offset into the original specified at which this section\n * begins to apply, defined as an object with a \"line\" and \"column\"\n * field.\n * - map: A source map definition. This source map could also be indexed,\n * but doesn't have to be.\n *\n * Instead of the \"map\" field, it's also possible to have a \"url\" field\n * specifying a URL to retrieve a source map from, but that's currently\n * unsupported.\n *\n * Here's an example source map, taken from the source map spec[0], but\n * modified to omit a section which uses the \"url\" field.\n *\n * {\n * version : 3,\n * file: \"app.js\",\n * sections: [{\n * offset: {line:100, column:10},\n * map: {\n * version : 3,\n * file: \"section.js\",\n * sources: [\"foo.js\", \"bar.js\"],\n * names: [\"src\", \"maps\", \"are\", \"fun\"],\n * mappings: \"AAAA,E;;ABCDE;\"\n * }\n * }],\n * }\n *\n * The second parameter, if given, is a string whose value is the URL\n * at which the source map was found. This URL is used to compute the\n * sources array.\n *\n * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit#heading=h.535es3xeprgt\n */\nfunction IndexedSourceMapConsumer(aSourceMap, aSourceMapURL) {\n var sourceMap = aSourceMap;\n if (typeof aSourceMap === 'string') {\n sourceMap = util.parseSourceMapInput(aSourceMap);\n }\n\n var version = util.getArg(sourceMap, 'version');\n var sections = util.getArg(sourceMap, 'sections');\n\n if (version != this._version) {\n throw new Error('Unsupported version: ' + version);\n }\n\n this._sources = new ArraySet();\n this._names = new ArraySet();\n\n var lastOffset = {\n line: -1,\n column: 0\n };\n this._sections = sections.map(function (s) {\n if (s.url) {\n // The url field will require support for asynchronicity.\n // See https://github.com/mozilla/source-map/issues/16\n throw new Error('Support for url field in sections not implemented.');\n }\n var offset = util.getArg(s, 'offset');\n var offsetLine = util.getArg(offset, 'line');\n var offsetColumn = util.getArg(offset, 'column');\n\n if (offsetLine < lastOffset.line ||\n (offsetLine === lastOffset.line && offsetColumn < lastOffset.column)) {\n throw new Error('Section offsets must be ordered and non-overlapping.');\n }\n lastOffset = offset;\n\n return {\n generatedOffset: {\n // The offset fields are 0-based, but we use 1-based indices when\n // encoding/decoding from VLQ.\n generatedLine: offsetLine + 1,\n generatedColumn: offsetColumn + 1\n },\n consumer: new SourceMapConsumer(util.getArg(s, 'map'), aSourceMapURL)\n }\n });\n}\n\nIndexedSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype);\nIndexedSourceMapConsumer.prototype.constructor = SourceMapConsumer;\n\n/**\n * The version of the source mapping spec that we are consuming.\n */\nIndexedSourceMapConsumer.prototype._version = 3;\n\n/**\n * The list of original sources.\n */\nObject.defineProperty(IndexedSourceMapConsumer.prototype, 'sources', {\n get: function () {\n var sources = [];\n for (var i = 0; i < this._sections.length; i++) {\n for (var j = 0; j < this._sections[i].consumer.sources.length; j++) {\n sources.push(this._sections[i].consumer.sources[j]);\n }\n }\n return sources;\n }\n});\n\n/**\n * Returns the original source, line, and column information for the generated\n * source's line and column positions provided. The only argument is an object\n * with the following properties:\n *\n * - line: The line number in the generated source. The line number\n * is 1-based.\n * - column: The column number in the generated source. The column\n * number is 0-based.\n *\n * and an object is returned with the following properties:\n *\n * - source: The original source file, or null.\n * - line: The line number in the original source, or null. The\n * line number is 1-based.\n * - column: The column number in the original source, or null. The\n * column number is 0-based.\n * - name: The original identifier, or null.\n */\nIndexedSourceMapConsumer.prototype.originalPositionFor =\n function IndexedSourceMapConsumer_originalPositionFor(aArgs) {\n var needle = {\n generatedLine: util.getArg(aArgs, 'line'),\n generatedColumn: util.getArg(aArgs, 'column')\n };\n\n // Find the section containing the generated position we're trying to map\n // to an original position.\n var sectionIndex = binarySearch.search(needle, this._sections,\n function(needle, section) {\n var cmp = needle.generatedLine - section.generatedOffset.generatedLine;\n if (cmp) {\n return cmp;\n }\n\n return (needle.generatedColumn -\n section.generatedOffset.generatedColumn);\n });\n var section = this._sections[sectionIndex];\n\n if (!section) {\n return {\n source: null,\n line: null,\n column: null,\n name: null\n };\n }\n\n return section.consumer.originalPositionFor({\n line: needle.generatedLine -\n (section.generatedOffset.generatedLine - 1),\n column: needle.generatedColumn -\n (section.generatedOffset.generatedLine === needle.generatedLine\n ? section.generatedOffset.generatedColumn - 1\n : 0),\n bias: aArgs.bias\n });\n };\n\n/**\n * Return true if we have the source content for every source in the source\n * map, false otherwise.\n */\nIndexedSourceMapConsumer.prototype.hasContentsOfAllSources =\n function IndexedSourceMapConsumer_hasContentsOfAllSources() {\n return this._sections.every(function (s) {\n return s.consumer.hasContentsOfAllSources();\n });\n };\n\n/**\n * Returns the original source content. The only argument is the url of the\n * original source file. Returns null if no original source content is\n * available.\n */\nIndexedSourceMapConsumer.prototype.sourceContentFor =\n function IndexedSourceMapConsumer_sourceContentFor(aSource, nullOnMissing) {\n for (var i = 0; i < this._sections.length; i++) {\n var section = this._sections[i];\n\n var content = section.consumer.sourceContentFor(aSource, true);\n if (content) {\n return content;\n }\n }\n if (nullOnMissing) {\n return null;\n }\n else {\n throw new Error('\"' + aSource + '\" is not in the SourceMap.');\n }\n };\n\n/**\n * Returns the generated line and column information for the original source,\n * line, and column positions provided. The only argument is an object with\n * the following properties:\n *\n * - source: The filename of the original source.\n * - line: The line number in the original source. The line number\n * is 1-based.\n * - column: The column number in the original source. The column\n * number is 0-based.\n *\n * and an object is returned with the following properties:\n *\n * - line: The line number in the generated source, or null. The\n * line number is 1-based. \n * - column: The column number in the generated source, or null.\n * The column number is 0-based.\n */\nIndexedSourceMapConsumer.prototype.generatedPositionFor =\n function IndexedSourceMapConsumer_generatedPositionFor(aArgs) {\n for (var i = 0; i < this._sections.length; i++) {\n var section = this._sections[i];\n\n // Only consider this section if the requested source is in the list of\n // sources of the consumer.\n if (section.consumer._findSourceIndex(util.getArg(aArgs, 'source')) === -1) {\n continue;\n }\n var generatedPosition = section.consumer.generatedPositionFor(aArgs);\n if (generatedPosition) {\n var ret = {\n line: generatedPosition.line +\n (section.generatedOffset.generatedLine - 1),\n column: generatedPosition.column +\n (section.generatedOffset.generatedLine === generatedPosition.line\n ? section.generatedOffset.generatedColumn - 1\n : 0)\n };\n return ret;\n }\n }\n\n return {\n line: null,\n column: null\n };\n };\n\n/**\n * Parse the mappings in a string in to a data structure which we can easily\n * query (the ordered arrays in the `this.__generatedMappings` and\n * `this.__originalMappings` properties).\n */\nIndexedSourceMapConsumer.prototype._parseMappings =\n function IndexedSourceMapConsumer_parseMappings(aStr, aSourceRoot) {\n this.__generatedMappings = [];\n this.__originalMappings = [];\n for (var i = 0; i < this._sections.length; i++) {\n var section = this._sections[i];\n var sectionMappings = section.consumer._generatedMappings;\n for (var j = 0; j < sectionMappings.length; j++) {\n var mapping = sectionMappings[j];\n\n var source = section.consumer._sources.at(mapping.source);\n source = util.computeSourceURL(section.consumer.sourceRoot, source, this._sourceMapURL);\n this._sources.add(source);\n source = this._sources.indexOf(source);\n\n var name = null;\n if (mapping.name) {\n name = section.consumer._names.at(mapping.name);\n this._names.add(name);\n name = this._names.indexOf(name);\n }\n\n // The mappings coming from the consumer for the section have\n // generated positions relative to the start of the section, so we\n // need to offset them to be relative to the start of the concatenated\n // generated file.\n var adjustedMapping = {\n source: source,\n generatedLine: mapping.generatedLine +\n (section.generatedOffset.generatedLine - 1),\n generatedColumn: mapping.generatedColumn +\n (section.generatedOffset.generatedLine === mapping.generatedLine\n ? section.generatedOffset.generatedColumn - 1\n : 0),\n originalLine: mapping.originalLine,\n originalColumn: mapping.originalColumn,\n name: name\n };\n\n this.__generatedMappings.push(adjustedMapping);\n if (typeof adjustedMapping.originalLine === 'number') {\n this.__originalMappings.push(adjustedMapping);\n }\n }\n }\n\n quickSort(this.__generatedMappings, util.compareByGeneratedPositionsDeflated);\n quickSort(this.__originalMappings, util.compareByOriginalPositions);\n };\n\nexports.IndexedSourceMapConsumer = IndexedSourceMapConsumer;\n",
46
+ "/* -*- Mode: js; js-indent-level: 2; -*- */\n/*\n * Copyright 2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\n\nvar SourceMapGenerator = require('./source-map-generator').SourceMapGenerator;\nvar util = require('./util');\n\n// Matches a Windows-style `\\r\\n` newline or a `\\n` newline used by all other\n// operating systems these days (capturing the result).\nvar REGEX_NEWLINE = /(\\r?\\n)/;\n\n// Newline character code for charCodeAt() comparisons\nvar NEWLINE_CODE = 10;\n\n// Private symbol for identifying `SourceNode`s when multiple versions of\n// the source-map library are loaded. This MUST NOT CHANGE across\n// versions!\nvar isSourceNode = \"$$$isSourceNode$$$\";\n\n/**\n * SourceNodes provide a way to abstract over interpolating/concatenating\n * snippets of generated JavaScript source code while maintaining the line and\n * column information associated with the original source code.\n *\n * @param aLine The original line number.\n * @param aColumn The original column number.\n * @param aSource The original source's filename.\n * @param aChunks Optional. An array of strings which are snippets of\n * generated JS, or other SourceNodes.\n * @param aName The original identifier.\n */\nfunction SourceNode(aLine, aColumn, aSource, aChunks, aName) {\n this.children = [];\n this.sourceContents = {};\n this.line = aLine == null ? null : aLine;\n this.column = aColumn == null ? null : aColumn;\n this.source = aSource == null ? null : aSource;\n this.name = aName == null ? null : aName;\n this[isSourceNode] = true;\n if (aChunks != null) this.add(aChunks);\n}\n\n/**\n * Creates a SourceNode from generated code and a SourceMapConsumer.\n *\n * @param aGeneratedCode The generated code\n * @param aSourceMapConsumer The SourceMap for the generated code\n * @param aRelativePath Optional. The path that relative sources in the\n * SourceMapConsumer should be relative to.\n */\nSourceNode.fromStringWithSourceMap =\n function SourceNode_fromStringWithSourceMap(aGeneratedCode, aSourceMapConsumer, aRelativePath) {\n // The SourceNode we want to fill with the generated code\n // and the SourceMap\n var node = new SourceNode();\n\n // All even indices of this array are one line of the generated code,\n // while all odd indices are the newlines between two adjacent lines\n // (since `REGEX_NEWLINE` captures its match).\n // Processed fragments are accessed by calling `shiftNextLine`.\n var remainingLines = aGeneratedCode.split(REGEX_NEWLINE);\n var remainingLinesIndex = 0;\n var shiftNextLine = function() {\n var lineContents = getNextLine();\n // The last line of a file might not have a newline.\n var newLine = getNextLine() || \"\";\n return lineContents + newLine;\n\n function getNextLine() {\n return remainingLinesIndex < remainingLines.length ?\n remainingLines[remainingLinesIndex++] : undefined;\n }\n };\n\n // We need to remember the position of \"remainingLines\"\n var lastGeneratedLine = 1, lastGeneratedColumn = 0;\n\n // The generate SourceNodes we need a code range.\n // To extract it current and last mapping is used.\n // Here we store the last mapping.\n var lastMapping = null;\n\n aSourceMapConsumer.eachMapping(function (mapping) {\n if (lastMapping !== null) {\n // We add the code from \"lastMapping\" to \"mapping\":\n // First check if there is a new line in between.\n if (lastGeneratedLine < mapping.generatedLine) {\n // Associate first line with \"lastMapping\"\n addMappingWithCode(lastMapping, shiftNextLine());\n lastGeneratedLine++;\n lastGeneratedColumn = 0;\n // The remaining code is added without mapping\n } else {\n // There is no new line in between.\n // Associate the code between \"lastGeneratedColumn\" and\n // \"mapping.generatedColumn\" with \"lastMapping\"\n var nextLine = remainingLines[remainingLinesIndex] || '';\n var code = nextLine.substr(0, mapping.generatedColumn -\n lastGeneratedColumn);\n remainingLines[remainingLinesIndex] = nextLine.substr(mapping.generatedColumn -\n lastGeneratedColumn);\n lastGeneratedColumn = mapping.generatedColumn;\n addMappingWithCode(lastMapping, code);\n // No more remaining code, continue\n lastMapping = mapping;\n return;\n }\n }\n // We add the generated code until the first mapping\n // to the SourceNode without any mapping.\n // Each line is added as separate string.\n while (lastGeneratedLine < mapping.generatedLine) {\n node.add(shiftNextLine());\n lastGeneratedLine++;\n }\n if (lastGeneratedColumn < mapping.generatedColumn) {\n var nextLine = remainingLines[remainingLinesIndex] || '';\n node.add(nextLine.substr(0, mapping.generatedColumn));\n remainingLines[remainingLinesIndex] = nextLine.substr(mapping.generatedColumn);\n lastGeneratedColumn = mapping.generatedColumn;\n }\n lastMapping = mapping;\n }, this);\n // We have processed all mappings.\n if (remainingLinesIndex < remainingLines.length) {\n if (lastMapping) {\n // Associate the remaining code in the current line with \"lastMapping\"\n addMappingWithCode(lastMapping, shiftNextLine());\n }\n // and add the remaining lines without any mapping\n node.add(remainingLines.splice(remainingLinesIndex).join(\"\"));\n }\n\n // Copy sourcesContent into SourceNode\n aSourceMapConsumer.sources.forEach(function (sourceFile) {\n var content = aSourceMapConsumer.sourceContentFor(sourceFile);\n if (content != null) {\n if (aRelativePath != null) {\n sourceFile = util.join(aRelativePath, sourceFile);\n }\n node.setSourceContent(sourceFile, content);\n }\n });\n\n return node;\n\n function addMappingWithCode(mapping, code) {\n if (mapping === null || mapping.source === undefined) {\n node.add(code);\n } else {\n var source = aRelativePath\n ? util.join(aRelativePath, mapping.source)\n : mapping.source;\n node.add(new SourceNode(mapping.originalLine,\n mapping.originalColumn,\n source,\n code,\n mapping.name));\n }\n }\n };\n\n/**\n * Add a chunk of generated JS to this source node.\n *\n * @param aChunk A string snippet of generated JS code, another instance of\n * SourceNode, or an array where each member is one of those things.\n */\nSourceNode.prototype.add = function SourceNode_add(aChunk) {\n if (Array.isArray(aChunk)) {\n aChunk.forEach(function (chunk) {\n this.add(chunk);\n }, this);\n }\n else if (aChunk[isSourceNode] || typeof aChunk === \"string\") {\n if (aChunk) {\n this.children.push(aChunk);\n }\n }\n else {\n throw new TypeError(\n \"Expected a SourceNode, string, or an array of SourceNodes and strings. Got \" + aChunk\n );\n }\n return this;\n};\n\n/**\n * Add a chunk of generated JS to the beginning of this source node.\n *\n * @param aChunk A string snippet of generated JS code, another instance of\n * SourceNode, or an array where each member is one of those things.\n */\nSourceNode.prototype.prepend = function SourceNode_prepend(aChunk) {\n if (Array.isArray(aChunk)) {\n for (var i = aChunk.length-1; i >= 0; i--) {\n this.prepend(aChunk[i]);\n }\n }\n else if (aChunk[isSourceNode] || typeof aChunk === \"string\") {\n this.children.unshift(aChunk);\n }\n else {\n throw new TypeError(\n \"Expected a SourceNode, string, or an array of SourceNodes and strings. Got \" + aChunk\n );\n }\n return this;\n};\n\n/**\n * Walk over the tree of JS snippets in this node and its children. The\n * walking function is called once for each snippet of JS and is passed that\n * snippet and the its original associated source's line/column location.\n *\n * @param aFn The traversal function.\n */\nSourceNode.prototype.walk = function SourceNode_walk(aFn) {\n var chunk;\n for (var i = 0, len = this.children.length; i < len; i++) {\n chunk = this.children[i];\n if (chunk[isSourceNode]) {\n chunk.walk(aFn);\n }\n else {\n if (chunk !== '') {\n aFn(chunk, { source: this.source,\n line: this.line,\n column: this.column,\n name: this.name });\n }\n }\n }\n};\n\n/**\n * Like `String.prototype.join` except for SourceNodes. Inserts `aStr` between\n * each of `this.children`.\n *\n * @param aSep The separator.\n */\nSourceNode.prototype.join = function SourceNode_join(aSep) {\n var newChildren;\n var i;\n var len = this.children.length;\n if (len > 0) {\n newChildren = [];\n for (i = 0; i < len-1; i++) {\n newChildren.push(this.children[i]);\n newChildren.push(aSep);\n }\n newChildren.push(this.children[i]);\n this.children = newChildren;\n }\n return this;\n};\n\n/**\n * Call String.prototype.replace on the very right-most source snippet. Useful\n * for trimming whitespace from the end of a source node, etc.\n *\n * @param aPattern The pattern to replace.\n * @param aReplacement The thing to replace the pattern with.\n */\nSourceNode.prototype.replaceRight = function SourceNode_replaceRight(aPattern, aReplacement) {\n var lastChild = this.children[this.children.length - 1];\n if (lastChild[isSourceNode]) {\n lastChild.replaceRight(aPattern, aReplacement);\n }\n else if (typeof lastChild === 'string') {\n this.children[this.children.length - 1] = lastChild.replace(aPattern, aReplacement);\n }\n else {\n this.children.push(''.replace(aPattern, aReplacement));\n }\n return this;\n};\n\n/**\n * Set the source content for a source file. This will be added to the SourceMapGenerator\n * in the sourcesContent field.\n *\n * @param aSourceFile The filename of the source file\n * @param aSourceContent The content of the source file\n */\nSourceNode.prototype.setSourceContent =\n function SourceNode_setSourceContent(aSourceFile, aSourceContent) {\n this.sourceContents[util.toSetString(aSourceFile)] = aSourceContent;\n };\n\n/**\n * Walk over the tree of SourceNodes. The walking function is called for each\n * source file content and is passed the filename and source content.\n *\n * @param aFn The traversal function.\n */\nSourceNode.prototype.walkSourceContents =\n function SourceNode_walkSourceContents(aFn) {\n for (var i = 0, len = this.children.length; i < len; i++) {\n if (this.children[i][isSourceNode]) {\n this.children[i].walkSourceContents(aFn);\n }\n }\n\n var sources = Object.keys(this.sourceContents);\n for (var i = 0, len = sources.length; i < len; i++) {\n aFn(util.fromSetString(sources[i]), this.sourceContents[sources[i]]);\n }\n };\n\n/**\n * Return the string representation of this source node. Walks over the tree\n * and concatenates all the various snippets together to one string.\n */\nSourceNode.prototype.toString = function SourceNode_toString() {\n var str = \"\";\n this.walk(function (chunk) {\n str += chunk;\n });\n return str;\n};\n\n/**\n * Returns the string representation of this source node along with a source\n * map.\n */\nSourceNode.prototype.toStringWithSourceMap = function SourceNode_toStringWithSourceMap(aArgs) {\n var generated = {\n code: \"\",\n line: 1,\n column: 0\n };\n var map = new SourceMapGenerator(aArgs);\n var sourceMappingActive = false;\n var lastOriginalSource = null;\n var lastOriginalLine = null;\n var lastOriginalColumn = null;\n var lastOriginalName = null;\n this.walk(function (chunk, original) {\n generated.code += chunk;\n if (original.source !== null\n && original.line !== null\n && original.column !== null) {\n if(lastOriginalSource !== original.source\n || lastOriginalLine !== original.line\n || lastOriginalColumn !== original.column\n || lastOriginalName !== original.name) {\n map.addMapping({\n source: original.source,\n original: {\n line: original.line,\n column: original.column\n },\n generated: {\n line: generated.line,\n column: generated.column\n },\n name: original.name\n });\n }\n lastOriginalSource = original.source;\n lastOriginalLine = original.line;\n lastOriginalColumn = original.column;\n lastOriginalName = original.name;\n sourceMappingActive = true;\n } else if (sourceMappingActive) {\n map.addMapping({\n generated: {\n line: generated.line,\n column: generated.column\n }\n });\n lastOriginalSource = null;\n sourceMappingActive = false;\n }\n for (var idx = 0, length = chunk.length; idx < length; idx++) {\n if (chunk.charCodeAt(idx) === NEWLINE_CODE) {\n generated.line++;\n generated.column = 0;\n // Mappings end at eol\n if (idx + 1 === length) {\n lastOriginalSource = null;\n sourceMappingActive = false;\n } else if (sourceMappingActive) {\n map.addMapping({\n source: original.source,\n original: {\n line: original.line,\n column: original.column\n },\n generated: {\n line: generated.line,\n column: generated.column\n },\n name: original.name\n });\n }\n } else {\n generated.column++;\n }\n }\n });\n this.walkSourceContents(function (sourceFile, sourceContent) {\n map.setSourceContent(sourceFile, sourceContent);\n });\n\n return { code: generated.code, map: map };\n};\n\nexports.SourceNode = SourceNode;\n",
47
+ "/*\n * Copyright 2009-2011 Mozilla Foundation and contributors\n * Licensed under the New BSD license. See LICENSE.txt or:\n * http://opensource.org/licenses/BSD-3-Clause\n */\nexports.SourceMapGenerator = require('./lib/source-map-generator').SourceMapGenerator;\nexports.SourceMapConsumer = require('./lib/source-map-consumer').SourceMapConsumer;\nexports.SourceNode = require('./lib/source-node').SourceNode;\n",
48
+ "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isTrailingCommaEnabled = exports.getParentExportDeclaration = exports.isExportDeclaration = exports.fixFaultyLocations = exports.getTrueLoc = exports.composeSourceMaps = exports.copyPos = exports.comparePos = exports.getUnionOfKeys = exports.getOption = exports.isBrowser = exports.getLineTerminator = void 0;\nvar tslib_1 = require(\"tslib\");\nvar tiny_invariant_1 = tslib_1.__importDefault(require(\"tiny-invariant\"));\nvar types = tslib_1.__importStar(require(\"ast-types\"));\nvar n = types.namedTypes;\nvar source_map_1 = tslib_1.__importDefault(require(\"source-map\"));\nvar SourceMapConsumer = source_map_1.default.SourceMapConsumer;\nvar SourceMapGenerator = source_map_1.default.SourceMapGenerator;\nvar hasOwn = Object.prototype.hasOwnProperty;\nfunction getLineTerminator() {\n return isBrowser() ? \"\\n\" : require(\"os\").EOL || \"\\n\";\n}\nexports.getLineTerminator = getLineTerminator;\nfunction isBrowser() {\n return (typeof window !== \"undefined\" && typeof window.document !== \"undefined\");\n}\nexports.isBrowser = isBrowser;\nfunction getOption(options, key, defaultValue) {\n if (options && hasOwn.call(options, key)) {\n return options[key];\n }\n return defaultValue;\n}\nexports.getOption = getOption;\nfunction getUnionOfKeys() {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var result = {};\n var argc = args.length;\n for (var i = 0; i < argc; ++i) {\n var keys = Object.keys(args[i]);\n var keyCount = keys.length;\n for (var j = 0; j < keyCount; ++j) {\n result[keys[j]] = true;\n }\n }\n return result;\n}\nexports.getUnionOfKeys = getUnionOfKeys;\nfunction comparePos(pos1, pos2) {\n return pos1.line - pos2.line || pos1.column - pos2.column;\n}\nexports.comparePos = comparePos;\nfunction copyPos(pos) {\n return {\n line: pos.line,\n column: pos.column,\n };\n}\nexports.copyPos = copyPos;\nfunction composeSourceMaps(formerMap, latterMap) {\n if (formerMap) {\n if (!latterMap) {\n return formerMap;\n }\n }\n else {\n return latterMap || null;\n }\n var smcFormer = new SourceMapConsumer(formerMap);\n var smcLatter = new SourceMapConsumer(latterMap);\n var smg = new SourceMapGenerator({\n file: latterMap.file,\n sourceRoot: latterMap.sourceRoot,\n });\n var sourcesToContents = {};\n smcLatter.eachMapping(function (mapping) {\n var origPos = smcFormer.originalPositionFor({\n line: mapping.originalLine,\n column: mapping.originalColumn,\n });\n var sourceName = origPos.source;\n if (sourceName === null) {\n return;\n }\n smg.addMapping({\n source: sourceName,\n original: copyPos(origPos),\n generated: {\n line: mapping.generatedLine,\n column: mapping.generatedColumn,\n },\n name: mapping.name,\n });\n var sourceContent = smcFormer.sourceContentFor(sourceName);\n if (sourceContent && !hasOwn.call(sourcesToContents, sourceName)) {\n sourcesToContents[sourceName] = sourceContent;\n smg.setSourceContent(sourceName, sourceContent);\n }\n });\n return smg.toJSON();\n}\nexports.composeSourceMaps = composeSourceMaps;\nfunction getTrueLoc(node, lines) {\n // It's possible that node is newly-created (not parsed by Esprima),\n // in which case it probably won't have a .loc property (or an\n // .original property for that matter). That's fine; we'll just\n // pretty-print it as usual.\n if (!node.loc) {\n return null;\n }\n var result = {\n start: node.loc.start,\n end: node.loc.end,\n };\n function include(node) {\n expandLoc(result, node.loc);\n }\n // If the node is an export declaration and its .declaration has any\n // decorators, their locations might contribute to the true start/end\n // positions of the export declaration node.\n if (node.declaration &&\n node.declaration.decorators &&\n isExportDeclaration(node)) {\n node.declaration.decorators.forEach(include);\n }\n if (comparePos(result.start, result.end) < 0) {\n // Trim leading whitespace.\n result.start = copyPos(result.start);\n lines.skipSpaces(result.start, false, true);\n if (comparePos(result.start, result.end) < 0) {\n // Trim trailing whitespace, if the end location is not already the\n // same as the start location.\n result.end = copyPos(result.end);\n lines.skipSpaces(result.end, true, true);\n }\n }\n // If the node has any comments, their locations might contribute to\n // the true start/end positions of the node.\n if (node.comments) {\n node.comments.forEach(include);\n }\n return result;\n}\nexports.getTrueLoc = getTrueLoc;\nfunction expandLoc(parentLoc, childLoc) {\n if (parentLoc && childLoc) {\n if (comparePos(childLoc.start, parentLoc.start) < 0) {\n parentLoc.start = childLoc.start;\n }\n if (comparePos(parentLoc.end, childLoc.end) < 0) {\n parentLoc.end = childLoc.end;\n }\n }\n}\nfunction fixFaultyLocations(node, lines) {\n var loc = node.loc;\n if (loc) {\n if (loc.start.line < 1) {\n loc.start.line = 1;\n }\n if (loc.end.line < 1) {\n loc.end.line = 1;\n }\n }\n if (node.type === \"File\") {\n // Babylon returns File nodes whose .loc.{start,end} do not include\n // leading or trailing whitespace.\n loc.start = lines.firstPos();\n loc.end = lines.lastPos();\n }\n fixForLoopHead(node, lines);\n fixTemplateLiteral(node, lines);\n if (loc && node.decorators) {\n // Expand the .loc of the node responsible for printing the decorators\n // (here, the decorated node) so that it includes node.decorators.\n node.decorators.forEach(function (decorator) {\n expandLoc(loc, decorator.loc);\n });\n }\n else if (node.declaration && isExportDeclaration(node)) {\n // Nullify .loc information for the child declaration so that we never\n // try to reprint it without also reprinting the export declaration.\n node.declaration.loc = null;\n // Expand the .loc of the node responsible for printing the decorators\n // (here, the export declaration) so that it includes node.decorators.\n var decorators = node.declaration.decorators;\n if (decorators) {\n decorators.forEach(function (decorator) {\n expandLoc(loc, decorator.loc);\n });\n }\n }\n else if ((n.MethodDefinition && n.MethodDefinition.check(node)) ||\n (n.Property.check(node) && (node.method || node.shorthand))) {\n // If the node is a MethodDefinition or a .method or .shorthand\n // Property, then the location information stored in\n // node.value.loc is very likely untrustworthy (just the {body}\n // part of a method, or nothing in the case of shorthand\n // properties), so we null out that information to prevent\n // accidental reuse of bogus source code during reprinting.\n node.value.loc = null;\n if (n.FunctionExpression.check(node.value)) {\n // FunctionExpression method values should be anonymous,\n // because their .id fields are ignored anyway.\n node.value.id = null;\n }\n }\n else if (node.type === \"ObjectTypeProperty\") {\n var loc_1 = node.loc;\n var end = loc_1 && loc_1.end;\n if (end) {\n end = copyPos(end);\n if (lines.prevPos(end) && lines.charAt(end) === \",\") {\n // Some parsers accidentally include trailing commas in the\n // .loc.end information for ObjectTypeProperty nodes.\n if ((end = lines.skipSpaces(end, true, true))) {\n loc_1.end = end;\n }\n }\n }\n }\n}\nexports.fixFaultyLocations = fixFaultyLocations;\nfunction fixForLoopHead(node, lines) {\n if (node.type !== \"ForStatement\") {\n return;\n }\n function fix(child) {\n var loc = child && child.loc;\n var start = loc && loc.start;\n var end = loc && copyPos(loc.end);\n while (start && end && comparePos(start, end) < 0) {\n lines.prevPos(end);\n if (lines.charAt(end) === \";\") {\n // Update child.loc.end to *exclude* the ';' character.\n loc.end.line = end.line;\n loc.end.column = end.column;\n }\n else {\n break;\n }\n }\n }\n fix(node.init);\n fix(node.test);\n fix(node.update);\n}\nfunction fixTemplateLiteral(node, lines) {\n if (node.type !== \"TemplateLiteral\") {\n return;\n }\n if (node.quasis.length === 0) {\n // If there are no quasi elements, then there is nothing to fix.\n return;\n }\n // node.loc is not present when using export default with a template literal\n if (node.loc) {\n // First we need to exclude the opening ` from the .loc of the first\n // quasi element, in case the parser accidentally decided to include it.\n var afterLeftBackTickPos = copyPos(node.loc.start);\n (0, tiny_invariant_1.default)(lines.charAt(afterLeftBackTickPos) === \"`\");\n (0, tiny_invariant_1.default)(lines.nextPos(afterLeftBackTickPos));\n var firstQuasi = node.quasis[0];\n if (comparePos(firstQuasi.loc.start, afterLeftBackTickPos) < 0) {\n firstQuasi.loc.start = afterLeftBackTickPos;\n }\n // Next we need to exclude the closing ` from the .loc of the last quasi\n // element, in case the parser accidentally decided to include it.\n var rightBackTickPos = copyPos(node.loc.end);\n (0, tiny_invariant_1.default)(lines.prevPos(rightBackTickPos));\n (0, tiny_invariant_1.default)(lines.charAt(rightBackTickPos) === \"`\");\n var lastQuasi = node.quasis[node.quasis.length - 1];\n if (comparePos(rightBackTickPos, lastQuasi.loc.end) < 0) {\n lastQuasi.loc.end = rightBackTickPos;\n }\n }\n // Now we need to exclude ${ and } characters from the .loc's of all\n // quasi elements, since some parsers accidentally include them.\n node.expressions.forEach(function (expr, i) {\n // Rewind from expr.loc.start over any whitespace and the ${ that\n // precedes the expression. The position of the $ should be the same\n // as the .loc.end of the preceding quasi element, but some parsers\n // accidentally include the ${ in the .loc of the quasi element.\n var dollarCurlyPos = lines.skipSpaces(expr.loc.start, true, false);\n if (lines.prevPos(dollarCurlyPos) &&\n lines.charAt(dollarCurlyPos) === \"{\" &&\n lines.prevPos(dollarCurlyPos) &&\n lines.charAt(dollarCurlyPos) === \"$\") {\n var quasiBefore = node.quasis[i];\n if (comparePos(dollarCurlyPos, quasiBefore.loc.end) < 0) {\n quasiBefore.loc.end = dollarCurlyPos;\n }\n }\n // Likewise, some parsers accidentally include the } that follows\n // the expression in the .loc of the following quasi element.\n var rightCurlyPos = lines.skipSpaces(expr.loc.end, false, false);\n if (lines.charAt(rightCurlyPos) === \"}\") {\n (0, tiny_invariant_1.default)(lines.nextPos(rightCurlyPos));\n // Now rightCurlyPos is technically the position just after the }.\n var quasiAfter = node.quasis[i + 1];\n if (comparePos(quasiAfter.loc.start, rightCurlyPos) < 0) {\n quasiAfter.loc.start = rightCurlyPos;\n }\n }\n });\n}\nfunction isExportDeclaration(node) {\n if (node)\n switch (node.type) {\n case \"ExportDeclaration\":\n case \"ExportDefaultDeclaration\":\n case \"ExportDefaultSpecifier\":\n case \"DeclareExportDeclaration\":\n case \"ExportNamedDeclaration\":\n case \"ExportAllDeclaration\":\n return true;\n }\n return false;\n}\nexports.isExportDeclaration = isExportDeclaration;\nfunction getParentExportDeclaration(path) {\n var parentNode = path.getParentNode();\n if (path.getName() === \"declaration\" && isExportDeclaration(parentNode)) {\n return parentNode;\n }\n return null;\n}\nexports.getParentExportDeclaration = getParentExportDeclaration;\nfunction isTrailingCommaEnabled(options, context) {\n var trailingComma = options.trailingComma;\n if (typeof trailingComma === \"object\") {\n return !!trailingComma[context];\n }\n return !!trailingComma;\n}\nexports.isTrailingCommaEnabled = isTrailingCommaEnabled;\n"
49
+ ],
50
+ "mappings": "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",
51
+ "debugId": "90436B32A64FC78464756e2164756e21",
52
+ "names": []
53
+ }