symbol-table.js 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
  2. function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
  3. function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
  4. function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
  5. var __classPrivateFieldSet = this && this.__classPrivateFieldSet || function (receiver, privateMap, value) {
  6. if (!privateMap.has(receiver)) {
  7. throw new TypeError("attempted to set private field on non-instance");
  8. }
  9. privateMap.set(receiver, value);
  10. return value;
  11. };
  12. var __classPrivateFieldGet = this && this.__classPrivateFieldGet || function (receiver, privateMap) {
  13. if (!privateMap.has(receiver)) {
  14. throw new TypeError("attempted to get private field on non-instance");
  15. }
  16. return privateMap.get(receiver);
  17. };
  18. var _hasEval;
  19. import { dict } from '@glimmer/util';
  20. import { isUpperCase } from './utils';
  21. export var SymbolTable = /*#__PURE__*/function () {
  22. function SymbolTable() {}
  23. SymbolTable.top = function top(locals, customizeComponentName) {
  24. return new ProgramSymbolTable(locals, customizeComponentName);
  25. };
  26. var _proto = SymbolTable.prototype;
  27. _proto.child = function child(locals) {
  28. var _this = this;
  29. var symbols = locals.map(function (name) {
  30. return _this.allocate(name);
  31. });
  32. return new BlockSymbolTable(this, locals, symbols);
  33. };
  34. return SymbolTable;
  35. }();
  36. export var ProgramSymbolTable = /*#__PURE__*/function (_SymbolTable) {
  37. _inheritsLoose(ProgramSymbolTable, _SymbolTable);
  38. function ProgramSymbolTable(templateLocals, customizeComponentName) {
  39. var _this2;
  40. _this2 = _SymbolTable.call(this) || this;
  41. _this2.templateLocals = templateLocals;
  42. _this2.customizeComponentName = customizeComponentName;
  43. _this2.symbols = [];
  44. _this2.upvars = [];
  45. _this2.size = 1;
  46. _this2.named = dict();
  47. _this2.blocks = dict();
  48. _this2.usedTemplateLocals = [];
  49. _hasEval.set(_assertThisInitialized(_this2), false);
  50. return _this2;
  51. }
  52. var _proto2 = ProgramSymbolTable.prototype;
  53. _proto2.getUsedTemplateLocals = function getUsedTemplateLocals() {
  54. return this.usedTemplateLocals;
  55. };
  56. _proto2.setHasEval = function setHasEval() {
  57. __classPrivateFieldSet(this, _hasEval, true);
  58. };
  59. _proto2.has = function has(name) {
  60. return this.templateLocals.indexOf(name) !== -1;
  61. };
  62. _proto2.get = function get(name) {
  63. var index = this.usedTemplateLocals.indexOf(name);
  64. if (index !== -1) {
  65. return [index, true];
  66. }
  67. index = this.usedTemplateLocals.length;
  68. this.usedTemplateLocals.push(name);
  69. return [index, true];
  70. };
  71. _proto2.getLocalsMap = function getLocalsMap() {
  72. return dict();
  73. };
  74. _proto2.getEvalInfo = function getEvalInfo() {
  75. var locals = this.getLocalsMap();
  76. return Object.keys(locals).map(function (symbol) {
  77. return locals[symbol];
  78. });
  79. };
  80. _proto2.allocateFree = function allocateFree(name, resolution) {
  81. // If the name in question is an uppercase (i.e. angle-bracket) component invocation, run
  82. // the optional `customizeComponentName` function provided to the precompiler.
  83. if (resolution.resolution() === 39
  84. /* GetFreeAsComponentHead */
  85. && resolution.isAngleBracket && isUpperCase(name)) {
  86. name = this.customizeComponentName(name);
  87. }
  88. var index = this.upvars.indexOf(name);
  89. if (index !== -1) {
  90. return index;
  91. }
  92. index = this.upvars.length;
  93. this.upvars.push(name);
  94. return index;
  95. };
  96. _proto2.allocateNamed = function allocateNamed(name) {
  97. var named = this.named[name];
  98. if (!named) {
  99. named = this.named[name] = this.allocate(name);
  100. }
  101. return named;
  102. };
  103. _proto2.allocateBlock = function allocateBlock(name) {
  104. if (name === 'inverse') {
  105. name = 'else';
  106. }
  107. var block = this.blocks[name];
  108. if (!block) {
  109. block = this.blocks[name] = this.allocate("&" + name);
  110. }
  111. return block;
  112. };
  113. _proto2.allocate = function allocate(identifier) {
  114. this.symbols.push(identifier);
  115. return this.size++;
  116. };
  117. _createClass(ProgramSymbolTable, [{
  118. key: "hasEval",
  119. get: function get() {
  120. return __classPrivateFieldGet(this, _hasEval);
  121. }
  122. }]);
  123. return ProgramSymbolTable;
  124. }(SymbolTable);
  125. _hasEval = new WeakMap();
  126. export var BlockSymbolTable = /*#__PURE__*/function (_SymbolTable2) {
  127. _inheritsLoose(BlockSymbolTable, _SymbolTable2);
  128. function BlockSymbolTable(parent, symbols, slots) {
  129. var _this3;
  130. _this3 = _SymbolTable2.call(this) || this;
  131. _this3.parent = parent;
  132. _this3.symbols = symbols;
  133. _this3.slots = slots;
  134. return _this3;
  135. }
  136. var _proto3 = BlockSymbolTable.prototype;
  137. _proto3.has = function has(name) {
  138. return this.symbols.indexOf(name) !== -1 || this.parent.has(name);
  139. };
  140. _proto3.get = function get(name) {
  141. var slot = this.symbols.indexOf(name);
  142. return slot === -1 ? this.parent.get(name) : [this.slots[slot], false];
  143. };
  144. _proto3.getLocalsMap = function getLocalsMap() {
  145. var _this4 = this;
  146. var dict = this.parent.getLocalsMap();
  147. this.symbols.forEach(function (symbol) {
  148. return dict[symbol] = _this4.get(symbol)[0];
  149. });
  150. return dict;
  151. };
  152. _proto3.getEvalInfo = function getEvalInfo() {
  153. var locals = this.getLocalsMap();
  154. return Object.keys(locals).map(function (symbol) {
  155. return locals[symbol];
  156. });
  157. };
  158. _proto3.setHasEval = function setHasEval() {
  159. this.parent.setHasEval();
  160. };
  161. _proto3.allocateFree = function allocateFree(name, resolution) {
  162. return this.parent.allocateFree(name, resolution);
  163. };
  164. _proto3.allocateNamed = function allocateNamed(name) {
  165. return this.parent.allocateNamed(name);
  166. };
  167. _proto3.allocateBlock = function allocateBlock(name) {
  168. return this.parent.allocateBlock(name);
  169. };
  170. _proto3.allocate = function allocate(identifier) {
  171. return this.parent.allocate(identifier);
  172. };
  173. _createClass(BlockSymbolTable, [{
  174. key: "locals",
  175. get: function get() {
  176. return this.symbols;
  177. }
  178. }]);
  179. return BlockSymbolTable;
  180. }(SymbolTable);
  181. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../packages/@glimmer/syntax/lib/symbol-table.ts"],"names":[],"mappings":"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","sourcesContent":["import { Core, Dict, SexpOpcodes } from '@glimmer/interfaces';\nimport { dict } from '@glimmer/util';\n\nimport { ASTv2 } from '..';\nimport { isUpperCase } from './utils';\n\nexport abstract class SymbolTable {\n  static top(\n    locals: string[],\n    customizeComponentName: (input: string) => string\n  ): ProgramSymbolTable {\n    return new ProgramSymbolTable(locals, customizeComponentName);\n  }\n\n  abstract has(name: string): boolean;\n  abstract get(name: string): [symbol: number, isRoot: boolean];\n\n  abstract getLocalsMap(): Dict<number>;\n  abstract getEvalInfo(): Core.EvalInfo;\n\n  abstract allocateFree(name: string, resolution: ASTv2.FreeVarResolution): number;\n  abstract allocateNamed(name: string): number;\n  abstract allocateBlock(name: string): number;\n  abstract allocate(identifier: string): number;\n\n  abstract setHasEval(): void;\n\n  child(locals: string[]): BlockSymbolTable {\n    let symbols = locals.map((name) => this.allocate(name));\n    return new BlockSymbolTable(this, locals, symbols);\n  }\n}\n\nexport class ProgramSymbolTable extends SymbolTable {\n  constructor(\n    private templateLocals: string[],\n    private customizeComponentName: (input: string) => string\n  ) {\n    super();\n  }\n\n  public symbols: string[] = [];\n  public upvars: string[] = [];\n\n  private size = 1;\n  private named = dict<number>();\n  private blocks = dict<number>();\n  private usedTemplateLocals: string[] = [];\n\n  #hasEval = false;\n\n  getUsedTemplateLocals(): string[] {\n    return this.usedTemplateLocals;\n  }\n\n  setHasEval(): void {\n    this.#hasEval = true;\n  }\n\n  get hasEval(): boolean {\n    return this.#hasEval;\n  }\n\n  has(name: string): boolean {\n    return this.templateLocals.indexOf(name) !== -1;\n  }\n\n  get(name: string): [number, boolean] {\n    let index = this.usedTemplateLocals.indexOf(name);\n\n    if (index !== -1) {\n      return [index, true];\n    }\n\n    index = this.usedTemplateLocals.length;\n    this.usedTemplateLocals.push(name);\n    return [index, true];\n  }\n\n  getLocalsMap(): Dict<number> {\n    return dict();\n  }\n\n  getEvalInfo(): Core.EvalInfo {\n    let locals = this.getLocalsMap();\n    return Object.keys(locals).map((symbol) => locals[symbol]);\n  }\n\n  allocateFree(name: string, resolution: ASTv2.FreeVarResolution): number {\n    // If the name in question is an uppercase (i.e. angle-bracket) component invocation, run\n    // the optional `customizeComponentName` function provided to the precompiler.\n    if (\n      resolution.resolution() === SexpOpcodes.GetFreeAsComponentHead &&\n      resolution.isAngleBracket &&\n      isUpperCase(name)\n    ) {\n      name = this.customizeComponentName(name);\n    }\n\n    let index = this.upvars.indexOf(name);\n\n    if (index !== -1) {\n      return index;\n    }\n\n    index = this.upvars.length;\n    this.upvars.push(name);\n    return index;\n  }\n\n  allocateNamed(name: string): number {\n    let named = this.named[name];\n\n    if (!named) {\n      named = this.named[name] = this.allocate(name);\n    }\n\n    return named;\n  }\n\n  allocateBlock(name: string): number {\n    if (name === 'inverse') {\n      name = 'else';\n    }\n\n    let block = this.blocks[name];\n\n    if (!block) {\n      block = this.blocks[name] = this.allocate(`&${name}`);\n    }\n\n    return block;\n  }\n\n  allocate(identifier: string): number {\n    this.symbols.push(identifier);\n    return this.size++;\n  }\n}\n\nexport class BlockSymbolTable extends SymbolTable {\n  constructor(private parent: SymbolTable, public symbols: string[], public slots: number[]) {\n    super();\n  }\n\n  get locals(): string[] {\n    return this.symbols;\n  }\n\n  has(name: string): boolean {\n    return this.symbols.indexOf(name) !== -1 || this.parent.has(name);\n  }\n\n  get(name: string): [number, boolean] {\n    let slot = this.symbols.indexOf(name);\n    return slot === -1 ? this.parent.get(name) : [this.slots[slot], false];\n  }\n\n  getLocalsMap(): Dict<number> {\n    let dict = this.parent.getLocalsMap();\n    this.symbols.forEach((symbol) => (dict[symbol] = this.get(symbol)[0]));\n    return dict;\n  }\n\n  getEvalInfo(): Core.EvalInfo {\n    let locals = this.getLocalsMap();\n    return Object.keys(locals).map((symbol) => locals[symbol]);\n  }\n\n  setHasEval(): void {\n    this.parent.setHasEval();\n  }\n\n  allocateFree(name: string, resolution: ASTv2.FreeVarResolution): number {\n    return this.parent.allocateFree(name, resolution);\n  }\n\n  allocateNamed(name: string): number {\n    return this.parent.allocateNamed(name);\n  }\n\n  allocateBlock(name: string): number {\n    return this.parent.allocateBlock(name);\n  }\n\n  allocate(identifier: string): number {\n    return this.parent.allocate(identifier);\n  }\n}\n"],"sourceRoot":""}