@glimmer/program
Advanced tools
Comparing version 0.32.3 to 0.32.4
@@ -302,2 +302,3 @@ define('@glimmer/program', ['exports', '@glimmer/util'], function (exports, util) { 'use strict'; | ||
} | ||
var PAGE_SIZE = 0x100000; | ||
/** | ||
@@ -330,2 +331,3 @@ * The Heap is responsible for dynamically allocating | ||
this.handle = 0; | ||
this.capacity = PAGE_SIZE; | ||
if (serializedHeap) { | ||
@@ -340,4 +342,5 @@ var buffer = serializedHeap.buffer, | ||
this.handle = handle; | ||
this.capacity = 0; | ||
} else { | ||
this.heap = new Uint16Array(0x100000); | ||
this.heap = new Uint16Array(PAGE_SIZE); | ||
this.table = []; | ||
@@ -348,5 +351,16 @@ } | ||
Heap.prototype.push = function push(item) { | ||
this.sizeCheck(); | ||
this.heap[this.offset++] = item; | ||
}; | ||
Heap.prototype.sizeCheck = function sizeCheck() { | ||
if (this.capacity === 0) { | ||
var heap = slice(this.heap, 0, this.offset); | ||
this.heap = new Uint16Array(heap.length + PAGE_SIZE); | ||
this.heap.set(heap, 0); | ||
this.capacity = PAGE_SIZE; | ||
} | ||
this.capacity--; | ||
}; | ||
Heap.prototype.getbyaddr = function getbyaddr(address) { | ||
@@ -448,2 +462,3 @@ return this.heap[address]; | ||
Heap.prototype.pushPlaceholder = function pushPlaceholder(valueFunc) { | ||
this.sizeCheck(); | ||
var address = this.offset++; | ||
@@ -467,5 +482,7 @@ this.heap[address] = 65535 /* MAX_SIZE */; | ||
Heap.prototype.capture = function capture() { | ||
var offset = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.offset; | ||
this.patchPlaceholders(); | ||
// Only called in eager mode | ||
var buffer = slice(this.heap, 0, this.offset); | ||
var buffer = slice(this.heap, 0, offset).buffer; | ||
return { | ||
@@ -533,16 +550,12 @@ handle: this.handle, | ||
function slice(arr, start, end) { | ||
if (arr instanceof Uint16Array) { | ||
if (arr.slice !== undefined) { | ||
return arr.slice(start, end).buffer; | ||
} | ||
var ret = new Uint16Array(end); | ||
for (; start < end; start++) { | ||
ret[start] = arr[start]; | ||
} | ||
return ret.buffer; | ||
if (arr.slice !== undefined) { | ||
return arr.slice(start, end); | ||
} | ||
return null; | ||
var ret = new Uint16Array(end); | ||
for (; start < end; start++) { | ||
ret[start] = arr[start]; | ||
} | ||
return ret; | ||
} | ||
exports.WELL_KNOWN_EMPTY_ARRAY_POSITION = WELL_KNOWN_EMPTY_ARRAY_POSITION; | ||
exports.WriteOnlyConstants = WriteOnlyConstants; | ||
@@ -561,2 +574,2 @@ exports.RuntimeConstants = RuntimeConstants; | ||
}); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"glimmer-program.js","sources":["../../../../../../packages/@glimmer/program/lib/constants.ts","../../../../../../packages/@glimmer/program/lib/opcode.ts","../../../../../../packages/@glimmer/program/lib/program.ts"],"sourcesContent":["import { Opaque, SymbolTable, RuntimeResolver, CompileTimeConstants } from \"@glimmer/interfaces\";\n\nconst UNRESOLVED = {};\n\nexport const WELL_KNOWN_EMPTY_ARRAY_POSITION = 0;\nconst WELL_KNOW_EMPTY_ARRAY = Object.freeze([]);\nexport type EMPTY_ARRAY = Array<ReadonlyArray<never>>;\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][] | EMPTY_ARRAY;\n  handles: number[];\n  numbers: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b000,\n  FLOAT           = 0b001,\n  STRING          = 0b010,\n  BOOLEAN_OR_VOID = 0b011,\n  NEGATIVE        = 0b100,\n  BIG_NUM         = 0b101\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] | EMPTY_ARRAY = [WELL_KNOW_EMPTY_ARRAY];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected resolved: Opaque[] = [];\n  protected numbers: number[] = [];\n\n  string(value: string): number {\n    let index = this.strings.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(value) - 1;\n  }\n\n  stringArray(strings: string[]): number {\n    let _strings: number[] = new Array(strings.length);\n\n    for (let i = 0; i < strings.length; i++) {\n      _strings[i] = this.string(strings[i]);\n    }\n\n    return this.array(_strings);\n  }\n\n  array(values: number[]): number {\n    if (values.length === 0) {\n      return WELL_KNOWN_EMPTY_ARRAY_POSITION;\n    }\n\n    let index = (this.arrays as number[][]).indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return (this.arrays as number[][]).push(values) - 1;\n  }\n\n  handle(handle: number): number {\n    let index = this.handles.indexOf(handle);\n    if (index > -1) {\n      return index;\n    }\n\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle) - 1;\n  }\n\n  serializable(value: Opaque): number {\n    let str = JSON.stringify(value);\n    let index = this.strings.indexOf(str);\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(str) - 1;\n  }\n\n  number(number: number): number {\n    let index = this.numbers.indexOf(number);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.numbers.push(number) - 1;\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      handles: this.handles,\n      numbers: this.numbers\n    };\n  }\n}\n\nexport class RuntimeConstants<Locator> {\n  protected strings: string[];\n  protected arrays: number[][] | EMPTY_ARRAY;\n  protected handles: number[];\n  protected resolved: Opaque[];\n  protected numbers: number[];\n\n  constructor(public resolver: RuntimeResolver<Locator>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.handles = pool.handles;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n    this.numbers = pool.numbers;\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class Constants<Locator> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Locator>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.handles = pool.handles;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n      this.numbers = pool.numbers;\n    }\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\n  protected serializables: Opaque[] = [];\n\n  serializable(value: Opaque): number {\n    let index = this.serializables.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.serializables.push(value) - 1;\n  }\n\n  getSerializable<T>(s: number): T {\n    return this.serializables[s] as T;\n  }\n\n  getOther<T>(value: number): T {\n    return this.others[value - 1] as T;\n  }\n\n  other(other: Opaque): number {\n    return this.others.push(other);\n  }\n}\n","import { Heap } from './program';\nimport { OpcodeSize } from \"@glimmer/encoder\";\n\nexport class Opcode {\n  public offset = 0;\n  constructor(private heap: Heap) {}\n\n  get size() {\n    let rawType = this.heap.getbyaddr(this.offset);\n    return ((rawType & OpcodeSize.OPERAND_LEN_MASK) >> OpcodeSize.ARG_SHIFT) + 1;\n  }\n\n  get isMachine() {\n    let rawType = this.heap.getbyaddr(this.offset);\n    return rawType & OpcodeSize.MACHINE_MASK;\n  }\n\n  get type() {\n    return (this.heap.getbyaddr(this.offset) & OpcodeSize.TYPE_MASK);\n  }\n\n  get op1() {\n    return this.heap.getbyaddr(this.offset + 1);\n  }\n\n  get op2() {\n    return this.heap.getbyaddr(this.offset + 2);\n  }\n\n  get op3() {\n    return this.heap.getbyaddr(this.offset + 3);\n  }\n}\n","\nimport { CompileTimeProgram, Recast, VMHandle, RuntimeResolver, CompileTimeHeap } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants, ConstantPool } from './constants';\nimport { Opcode } from './opcode';\nimport { assert } from \"@glimmer/util\";\n\nconst enum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst enum Size {\n  ENTRY_SIZE = 2,\n  INFO_OFFSET = 1,\n  MAX_SIZE   = 0b1111111111111111,\n  SIZE_MASK  = 0b00000000000000001111111111111111,\n  SCOPE_MASK = 0b00111111111111110000000000000000,\n  STATE_MASK = 0b11000000000000000000000000000000,\n}\n\nfunction encodeTableInfo(size: number, scopeSize: number, state: number) {\n  return size | (scopeSize << 16) | state << 30;\n}\n\nfunction changeState(info: number, newState: number) {\n  return info | newState << 30;\n}\n\nexport interface SerializedHeap {\n  buffer: ArrayBuffer;\n  table: number[];\n  handle: number;\n}\n\nexport type Placeholder = [number, () => number];\n\n/**\n * The Heap is responsible for dynamically allocating\n * memory in which we read/write the VM's instructions\n * from/to. When we malloc we pass out a VMHandle, which\n * is used as an indirect way of accessing the memory during\n * execution of the VM. Internally we track the different\n * regions of the memory in an int array known as the table.\n *\n * The table 32-bit aligned and has the following layout:\n *\n * | ... | hp (u32) |       info (u32)          |\n * | ... |  Handle  | Size | Scope Size | State |\n * | ... | 32-bits  | 16b  |    14b     |  2b   |\n *\n * With this information we effectively have the ability to\n * control when we want to free memory. That being said you\n * can not free during execution as raw address are only\n * valid during the execution. This means you cannot close\n * over them as you will have a bad memory access exception.\n */\nexport class Heap implements CompileTimeHeap {\n  private heap: Uint16Array | Array<number>;\n  private placeholders: Placeholder[] = [];\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n\n  constructor(serializedHeap?: SerializedHeap) {\n    if (serializedHeap) {\n      let { buffer, table, handle } = serializedHeap;\n      this.heap = new Uint16Array(buffer);\n      this.table = table;\n      this.offset = this.heap.length;\n      this.handle = handle;\n    } else {\n      this.heap = new Uint16Array(0x100000);\n      this.table = [];\n    }\n  }\n\n  push(item: number): void {\n    this.heap[this.offset++] = item;\n  }\n\n  getbyaddr(address: number): number {\n    return this.heap[address];\n  }\n\n  setbyaddr(address: number, value: number) {\n    this.heap[address] = value;\n  }\n\n  malloc(): number {\n    this.table.push(this.offset, 0);\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  finishMalloc(handle: number, scopeSize: number): void {\n    let start = this.table[handle];\n    let finish = this.offset;\n    let instructionSize = finish - start;\n    let info = encodeTableInfo(instructionSize, scopeSize, TableSlotState.Allocated);\n    this.table[handle + Size.INFO_OFFSET] = info;\n  }\n\n  size(): number {\n    return this.offset;\n  }\n\n  // It is illegal to close over this address, as compaction\n  // may move it. However, it is legal to use this address\n  // multiple times between compactions.\n  getaddr(handle: number): number {\n    return this.table[handle];\n  }\n\n  gethandle(address: number): number {\n    this.table.push(address, encodeTableInfo(0, 0, TableSlotState.Pointer));\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  sizeof(handle: number): number {\n    if (DEBUG) {\n      let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n      return info & Size.SIZE_MASK;\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: number): number {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    return (info & Size.SCOPE_MASK) >> 16;\n  }\n\n  free(handle: VMHandle): void {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET] = changeState(info, TableSlotState.Freed);\n  }\n\n  /**\n   * The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift\n   * reachable memory to the bottom of the heap and freeable\n   * memory to the top of the heap. When we have shifted all\n   * the reachable memory to the top of the heap, we move the\n   * offset to the next free position.\n   */\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=Size.ENTRY_SIZE) {\n      let offset = table[i];\n      let info = table[i + Size.INFO_OFFSET];\n      let size = info & Size.SIZE_MASK;\n      let state = info & Size.STATE_MASK >> 30;\n\n      if (state === TableSlotState.Purged) {\n        continue;\n      } else if (state === TableSlotState.Freed) {\n        // transition to \"already freed\" aka \"purged\"\n        // a good improvement would be to reuse\n        // these slots\n        table[i + Size.INFO_OFFSET] = changeState(info, TableSlotState.Purged);\n        compactedSize += size;\n      } else if (state === TableSlotState.Allocated) {\n        for (let j=offset; j<=i+size; j++) {\n          heap[j - compactedSize] = heap[j];\n        }\n\n        table[i] = offset - compactedSize;\n      } else if (state === TableSlotState.Pointer) {\n        table[i] = offset - compactedSize;\n      }\n    }\n\n    this.offset = this.offset - compactedSize;\n  }\n\n  pushPlaceholder(valueFunc: () => number): void {\n    let address = this.offset++;\n    this.heap[address] = Size.MAX_SIZE;\n    this.placeholders.push([address, valueFunc]);\n  }\n\n  private patchPlaceholders() {\n    let { placeholders } = this;\n\n    for (let i = 0; i < placeholders.length; i++) {\n      let [address, getValue] = placeholders[i];\n\n      assert(this.getbyaddr(address) === Size.MAX_SIZE, `expected to find a placeholder value at ${address}`);\n      this.setbyaddr(address, getValue());\n    }\n  }\n\n  capture(): SerializedHeap {\n    this.patchPlaceholders();\n\n    // Only called in eager mode\n    let buffer = slice(this.heap, 0, this.offset);\n    return {\n      handle: this.handle,\n      table: this.table,\n      buffer: buffer as ArrayBuffer\n    };\n  }\n}\n\nexport class WriteOnlyProgram implements CompileTimeProgram {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: WriteOnlyConstants = new WriteOnlyConstants(), public heap = new Heap()) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class RuntimeProgram<Locator> {\n  [key: number]: never;\n\n  static hydrate<Locator>(rawHeap: SerializedHeap, pool: ConstantPool, resolver: RuntimeResolver<Locator>) {\n    let heap = new Heap(rawHeap);\n    let constants = new RuntimeConstants(resolver, pool);\n\n    return new RuntimeProgram(constants, heap);\n  }\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Locator>, public heap: Heap) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class Program<Locator> extends WriteOnlyProgram {\n  public constants: Constants<Locator>;\n}\n\nfunction slice(arr: Uint16Array | number[], start: number, end: number) {\n  if (arr instanceof Uint16Array) {\n    if (arr.slice !== undefined) {\n      return arr.slice(start, end).buffer;\n    }\n\n    let ret = new Uint16Array(end);\n\n    for (; start < end; start++) {\n      ret[start]  = arr[start];\n    }\n\n    return ret.buffer;\n  }\n\n  return null;\n}\n"],"names":[],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"glimmer-program.js","sources":["../../../../../../packages/@glimmer/program/lib/constants.ts","../../../../../../packages/@glimmer/program/lib/opcode.ts","../../../../../../packages/@glimmer/program/lib/program.ts"],"sourcesContent":["import { Opaque, SymbolTable, RuntimeResolver, CompileTimeConstants } from \"@glimmer/interfaces\";\n\nconst UNRESOLVED = {};\n\nconst WELL_KNOWN_EMPTY_ARRAY_POSITION = 0;\nconst WELL_KNOW_EMPTY_ARRAY = Object.freeze([]);\nexport type EMPTY_ARRAY = Array<ReadonlyArray<never>>;\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][] | EMPTY_ARRAY;\n  handles: number[];\n  numbers: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b000,\n  FLOAT           = 0b001,\n  STRING          = 0b010,\n  BOOLEAN_OR_VOID = 0b011,\n  NEGATIVE        = 0b100,\n  BIG_NUM         = 0b101\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] | EMPTY_ARRAY = [WELL_KNOW_EMPTY_ARRAY];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected resolved: Opaque[] = [];\n  protected numbers: number[] = [];\n\n  string(value: string): number {\n    let index = this.strings.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(value) - 1;\n  }\n\n  stringArray(strings: string[]): number {\n    let _strings: number[] = new Array(strings.length);\n\n    for (let i = 0; i < strings.length; i++) {\n      _strings[i] = this.string(strings[i]);\n    }\n\n    return this.array(_strings);\n  }\n\n  array(values: number[]): number {\n    if (values.length === 0) {\n      return WELL_KNOWN_EMPTY_ARRAY_POSITION;\n    }\n\n    let index = (this.arrays as number[][]).indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return (this.arrays as number[][]).push(values) - 1;\n  }\n\n  handle(handle: number): number {\n    let index = this.handles.indexOf(handle);\n    if (index > -1) {\n      return index;\n    }\n\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle) - 1;\n  }\n\n  serializable(value: Opaque): number {\n    let str = JSON.stringify(value);\n    let index = this.strings.indexOf(str);\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(str) - 1;\n  }\n\n  number(number: number): number {\n    let index = this.numbers.indexOf(number);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.numbers.push(number) - 1;\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      handles: this.handles,\n      numbers: this.numbers\n    };\n  }\n}\n\nexport class RuntimeConstants<TemplateMeta> {\n  protected strings: string[];\n  protected arrays: number[][] | EMPTY_ARRAY;\n  protected handles: number[];\n  protected resolved: Opaque[];\n  protected numbers: number[];\n\n  constructor(public resolver: RuntimeResolver<TemplateMeta>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.handles = pool.handles;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n    this.numbers = pool.numbers;\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class Constants<TemplateMeta> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<TemplateMeta>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.handles = pool.handles;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n      this.numbers = pool.numbers;\n    }\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\n  protected serializables: Opaque[] = [];\n\n  serializable(value: Opaque): number {\n    let index = this.serializables.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.serializables.push(value) - 1;\n  }\n\n  getSerializable<T>(s: number): T {\n    return this.serializables[s] as T;\n  }\n\n  getOther<T>(value: number): T {\n    return this.others[value - 1] as T;\n  }\n\n  other(other: Opaque): number {\n    return this.others.push(other);\n  }\n}\n","import { Heap } from './program';\nimport { OpcodeSize } from \"@glimmer/encoder\";\n\nexport class Opcode {\n  public offset = 0;\n  constructor(private heap: Heap) {}\n\n  get size() {\n    let rawType = this.heap.getbyaddr(this.offset);\n    return ((rawType & OpcodeSize.OPERAND_LEN_MASK) >> OpcodeSize.ARG_SHIFT) + 1;\n  }\n\n  get isMachine() {\n    let rawType = this.heap.getbyaddr(this.offset);\n    return rawType & OpcodeSize.MACHINE_MASK;\n  }\n\n  get type() {\n    return (this.heap.getbyaddr(this.offset) & OpcodeSize.TYPE_MASK);\n  }\n\n  get op1() {\n    return this.heap.getbyaddr(this.offset + 1);\n  }\n\n  get op2() {\n    return this.heap.getbyaddr(this.offset + 2);\n  }\n\n  get op3() {\n    return this.heap.getbyaddr(this.offset + 3);\n  }\n}\n","\nimport { CompileTimeProgram, Recast, VMHandle, RuntimeResolver, CompileTimeHeap } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants, ConstantPool } from './constants';\nimport { Opcode } from './opcode';\nimport { assert } from \"@glimmer/util\";\n\nconst enum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst enum Size {\n  ENTRY_SIZE = 2,\n  INFO_OFFSET = 1,\n  MAX_SIZE   = 0b1111111111111111,\n  SIZE_MASK  = 0b00000000000000001111111111111111,\n  SCOPE_MASK = 0b00111111111111110000000000000000,\n  STATE_MASK = 0b11000000000000000000000000000000,\n}\n\nfunction encodeTableInfo(size: number, scopeSize: number, state: number) {\n  return size | (scopeSize << 16) | state << 30;\n}\n\nfunction changeState(info: number, newState: number) {\n  return info | newState << 30;\n}\n\nexport interface SerializedHeap {\n  buffer: ArrayBuffer;\n  table: number[];\n  handle: number;\n}\n\nexport type Placeholder = [number, () => number];\n\nconst PAGE_SIZE = 0x100000;\n\n/**\n * The Heap is responsible for dynamically allocating\n * memory in which we read/write the VM's instructions\n * from/to. When we malloc we pass out a VMHandle, which\n * is used as an indirect way of accessing the memory during\n * execution of the VM. Internally we track the different\n * regions of the memory in an int array known as the table.\n *\n * The table 32-bit aligned and has the following layout:\n *\n * | ... | hp (u32) |       info (u32)          |\n * | ... |  Handle  | Size | Scope Size | State |\n * | ... | 32-bits  | 16b  |    14b     |  2b   |\n *\n * With this information we effectively have the ability to\n * control when we want to free memory. That being said you\n * can not free during execution as raw address are only\n * valid during the execution. This means you cannot close\n * over them as you will have a bad memory access exception.\n */\nexport class Heap implements CompileTimeHeap {\n  private heap: Uint16Array;\n  private placeholders: Placeholder[] = [];\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n  private capacity = PAGE_SIZE;\n\n  constructor(serializedHeap?: SerializedHeap) {\n    if (serializedHeap) {\n      let { buffer, table, handle } = serializedHeap;\n      this.heap = new Uint16Array(buffer);\n      this.table = table;\n      this.offset = this.heap.length;\n      this.handle = handle;\n      this.capacity = 0;\n    } else {\n      this.heap = new Uint16Array(PAGE_SIZE);\n      this.table = [];\n    }\n  }\n\n  push(item: number): void {\n    this.sizeCheck();\n    this.heap[this.offset++] = item;\n  }\n\n  private sizeCheck() {\n    if (this.capacity === 0) {\n      let heap = slice(this.heap, 0, this.offset);\n      this.heap = new Uint16Array(heap.length + PAGE_SIZE);\n      this.heap.set(heap, 0);\n      this.capacity = PAGE_SIZE;\n    }\n    this.capacity--;\n  }\n\n  getbyaddr(address: number): number {\n    return this.heap[address];\n  }\n\n  setbyaddr(address: number, value: number) {\n    this.heap[address] = value;\n  }\n\n  malloc(): number {\n    this.table.push(this.offset, 0);\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  finishMalloc(handle: number, scopeSize: number): void {\n    let start = this.table[handle];\n    let finish = this.offset;\n    let instructionSize = finish - start;\n    let info = encodeTableInfo(instructionSize, scopeSize, TableSlotState.Allocated);\n    this.table[handle + Size.INFO_OFFSET] = info;\n  }\n\n  size(): number {\n    return this.offset;\n  }\n\n  // It is illegal to close over this address, as compaction\n  // may move it. However, it is legal to use this address\n  // multiple times between compactions.\n  getaddr(handle: number): number {\n    return this.table[handle];\n  }\n\n  gethandle(address: number): number {\n    this.table.push(address, encodeTableInfo(0, 0, TableSlotState.Pointer));\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  sizeof(handle: number): number {\n    if (DEBUG) {\n      let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n      return info & Size.SIZE_MASK;\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: number): number {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    return (info & Size.SCOPE_MASK) >> 16;\n  }\n\n  free(handle: VMHandle): void {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET] = changeState(info, TableSlotState.Freed);\n  }\n\n  /**\n   * The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift\n   * reachable memory to the bottom of the heap and freeable\n   * memory to the top of the heap. When we have shifted all\n   * the reachable memory to the top of the heap, we move the\n   * offset to the next free position.\n   */\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=Size.ENTRY_SIZE) {\n      let offset = table[i];\n      let info = table[i + Size.INFO_OFFSET];\n      let size = info & Size.SIZE_MASK;\n      let state = info & Size.STATE_MASK >> 30;\n\n      if (state === TableSlotState.Purged) {\n        continue;\n      } else if (state === TableSlotState.Freed) {\n        // transition to \"already freed\" aka \"purged\"\n        // a good improvement would be to reuse\n        // these slots\n        table[i + Size.INFO_OFFSET] = changeState(info, TableSlotState.Purged);\n        compactedSize += size;\n      } else if (state === TableSlotState.Allocated) {\n        for (let j=offset; j<=i+size; j++) {\n          heap[j - compactedSize] = heap[j];\n        }\n\n        table[i] = offset - compactedSize;\n      } else if (state === TableSlotState.Pointer) {\n        table[i] = offset - compactedSize;\n      }\n    }\n\n    this.offset = this.offset - compactedSize;\n  }\n\n  pushPlaceholder(valueFunc: () => number): void {\n    this.sizeCheck();\n    let address = this.offset++;\n    this.heap[address] = Size.MAX_SIZE;\n    this.placeholders.push([address, valueFunc]);\n  }\n\n  private patchPlaceholders() {\n    let { placeholders } = this;\n\n    for (let i = 0; i < placeholders.length; i++) {\n      let [address, getValue] = placeholders[i];\n\n      assert(this.getbyaddr(address) === Size.MAX_SIZE, `expected to find a placeholder value at ${address}`);\n      this.setbyaddr(address, getValue());\n    }\n  }\n\n  capture(offset = this.offset): SerializedHeap {\n    this.patchPlaceholders();\n\n    // Only called in eager mode\n    let buffer = slice(this.heap, 0, offset).buffer;\n    return {\n      handle: this.handle,\n      table: this.table,\n      buffer: buffer as ArrayBuffer\n    };\n  }\n}\n\nexport class WriteOnlyProgram implements CompileTimeProgram {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: WriteOnlyConstants = new WriteOnlyConstants(), public heap = new Heap()) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class RuntimeProgram<TemplateMeta> {\n  [key: number]: never;\n\n  static hydrate<TemplateMeta>(rawHeap: SerializedHeap, pool: ConstantPool, resolver: RuntimeResolver<TemplateMeta>) {\n    let heap = new Heap(rawHeap);\n    let constants = new RuntimeConstants(resolver, pool);\n\n    return new RuntimeProgram(constants, heap);\n  }\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<TemplateMeta>, public heap: Heap) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class Program<TemplateMeta> extends WriteOnlyProgram {\n  public constants: Constants<TemplateMeta>;\n}\n\nfunction slice(arr: Uint16Array, start: number, end: number): Uint16Array {\n  if (arr.slice !== undefined) {\n    return arr.slice(start, end);\n  }\n\n  let ret = new Uint16Array(end);\n\n  for (; start < end; start++) {\n    ret[start]  = arr[start];\n  }\n\n  return ret;\n}\n"],"names":[],"mappings":"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"} |
@@ -7,3 +7,3 @@ "use strict"; | ||
const UNRESOLVED = {}; | ||
const WELL_KNOWN_EMPTY_ARRAY_POSITION = exports.WELL_KNOWN_EMPTY_ARRAY_POSITION = 0; | ||
const WELL_KNOWN_EMPTY_ARRAY_POSITION = 0; | ||
const WELL_KNOW_EMPTY_ARRAY = Object.freeze([]); | ||
@@ -184,2 +184,2 @@ class WriteOnlyConstants { | ||
exports.LazyConstants = LazyConstants; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/constants.ts"],"names":[],"mappings":"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","sourcesContent":["import { Opaque, SymbolTable, RuntimeResolver, CompileTimeConstants } from \"@glimmer/interfaces\";\n\nconst UNRESOLVED = {};\n\nexport const WELL_KNOWN_EMPTY_ARRAY_POSITION = 0;\nconst WELL_KNOW_EMPTY_ARRAY = Object.freeze([]);\nexport type EMPTY_ARRAY = Array<ReadonlyArray<never>>;\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][] | EMPTY_ARRAY;\n  handles: number[];\n  numbers: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b000,\n  FLOAT           = 0b001,\n  STRING          = 0b010,\n  BOOLEAN_OR_VOID = 0b011,\n  NEGATIVE        = 0b100,\n  BIG_NUM         = 0b101\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] | EMPTY_ARRAY = [WELL_KNOW_EMPTY_ARRAY];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected resolved: Opaque[] = [];\n  protected numbers: number[] = [];\n\n  string(value: string): number {\n    let index = this.strings.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(value) - 1;\n  }\n\n  stringArray(strings: string[]): number {\n    let _strings: number[] = new Array(strings.length);\n\n    for (let i = 0; i < strings.length; i++) {\n      _strings[i] = this.string(strings[i]);\n    }\n\n    return this.array(_strings);\n  }\n\n  array(values: number[]): number {\n    if (values.length === 0) {\n      return WELL_KNOWN_EMPTY_ARRAY_POSITION;\n    }\n\n    let index = (this.arrays as number[][]).indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return (this.arrays as number[][]).push(values) - 1;\n  }\n\n  handle(handle: number): number {\n    let index = this.handles.indexOf(handle);\n    if (index > -1) {\n      return index;\n    }\n\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle) - 1;\n  }\n\n  serializable(value: Opaque): number {\n    let str = JSON.stringify(value);\n    let index = this.strings.indexOf(str);\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(str) - 1;\n  }\n\n  number(number: number): number {\n    let index = this.numbers.indexOf(number);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.numbers.push(number) - 1;\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      handles: this.handles,\n      numbers: this.numbers\n    };\n  }\n}\n\nexport class RuntimeConstants<Locator> {\n  protected strings: string[];\n  protected arrays: number[][] | EMPTY_ARRAY;\n  protected handles: number[];\n  protected resolved: Opaque[];\n  protected numbers: number[];\n\n  constructor(public resolver: RuntimeResolver<Locator>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.handles = pool.handles;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n    this.numbers = pool.numbers;\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class Constants<Locator> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Locator>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.handles = pool.handles;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n      this.numbers = pool.numbers;\n    }\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\n  protected serializables: Opaque[] = [];\n\n  serializable(value: Opaque): number {\n    let index = this.serializables.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.serializables.push(value) - 1;\n  }\n\n  getSerializable<T>(s: number): T {\n    return this.serializables[s] as T;\n  }\n\n  getOther<T>(value: number): T {\n    return this.others[value - 1] as T;\n  }\n\n  other(other: Opaque): number {\n    return this.others.push(other);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/constants.ts"],"names":[],"mappings":"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","sourcesContent":["import { Opaque, SymbolTable, RuntimeResolver, CompileTimeConstants } from \"@glimmer/interfaces\";\n\nconst UNRESOLVED = {};\n\nconst WELL_KNOWN_EMPTY_ARRAY_POSITION = 0;\nconst WELL_KNOW_EMPTY_ARRAY = Object.freeze([]);\nexport type EMPTY_ARRAY = Array<ReadonlyArray<never>>;\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][] | EMPTY_ARRAY;\n  handles: number[];\n  numbers: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b000,\n  FLOAT           = 0b001,\n  STRING          = 0b010,\n  BOOLEAN_OR_VOID = 0b011,\n  NEGATIVE        = 0b100,\n  BIG_NUM         = 0b101\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] | EMPTY_ARRAY = [WELL_KNOW_EMPTY_ARRAY];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected resolved: Opaque[] = [];\n  protected numbers: number[] = [];\n\n  string(value: string): number {\n    let index = this.strings.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(value) - 1;\n  }\n\n  stringArray(strings: string[]): number {\n    let _strings: number[] = new Array(strings.length);\n\n    for (let i = 0; i < strings.length; i++) {\n      _strings[i] = this.string(strings[i]);\n    }\n\n    return this.array(_strings);\n  }\n\n  array(values: number[]): number {\n    if (values.length === 0) {\n      return WELL_KNOWN_EMPTY_ARRAY_POSITION;\n    }\n\n    let index = (this.arrays as number[][]).indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return (this.arrays as number[][]).push(values) - 1;\n  }\n\n  handle(handle: number): number {\n    let index = this.handles.indexOf(handle);\n    if (index > -1) {\n      return index;\n    }\n\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle) - 1;\n  }\n\n  serializable(value: Opaque): number {\n    let str = JSON.stringify(value);\n    let index = this.strings.indexOf(str);\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(str) - 1;\n  }\n\n  number(number: number): number {\n    let index = this.numbers.indexOf(number);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.numbers.push(number) - 1;\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      handles: this.handles,\n      numbers: this.numbers\n    };\n  }\n}\n\nexport class RuntimeConstants<TemplateMeta> {\n  protected strings: string[];\n  protected arrays: number[][] | EMPTY_ARRAY;\n  protected handles: number[];\n  protected resolved: Opaque[];\n  protected numbers: number[];\n\n  constructor(public resolver: RuntimeResolver<TemplateMeta>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.handles = pool.handles;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n    this.numbers = pool.numbers;\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class Constants<TemplateMeta> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<TemplateMeta>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.handles = pool.handles;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n      this.numbers = pool.numbers;\n    }\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\n  protected serializables: Opaque[] = [];\n\n  serializable(value: Opaque): number {\n    let index = this.serializables.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.serializables.push(value) - 1;\n  }\n\n  getSerializable<T>(s: number): T {\n    return this.serializables[s] as T;\n  }\n\n  getOther<T>(value: number): T {\n    return this.others[value - 1] as T;\n  }\n\n  other(other: Opaque): number {\n    return this.others.push(other);\n  }\n}\n"]} |
"use strict"; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJuYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci9wcm9ncmFtL2xpYi9pbnRlcm5hbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVW5pcXVlLCBSdW50aW1lUmVzb2x2ZXIgYXMgSVJlc29sdmVyIH0gZnJvbSAnQGdsaW1tZXIvaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCB0eXBlIExvY2F0b3IgPSBVbmlxdWU8J0xvY2F0b3InPjtcbmV4cG9ydCB0eXBlIFJlZmVycmVyID0gVW5pcXVlPCdSZWZlcnJlcic+O1xuZXhwb3J0IHR5cGUgUmVzb2x2ZXIgPSBJUmVzb2x2ZXI8TG9jYXRvcj47XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJuYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci9wcm9ncmFtL2xpYi9pbnRlcm5hbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVW5pcXVlLCBSdW50aW1lUmVzb2x2ZXIgYXMgSVJlc29sdmVyIH0gZnJvbSAnQGdsaW1tZXIvaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCB0eXBlIFRlbXBsYXRlTWV0YSA9IFVuaXF1ZTwnVGVtcGxhdGVNZXRhJz47XG5leHBvcnQgdHlwZSBSZWZlcnJlciA9IFVuaXF1ZTwnUmVmZXJyZXInPjtcbmV4cG9ydCB0eXBlIFJlc29sdmVyID0gSVJlc29sdmVyPFRlbXBsYXRlTWV0YT47XG4iXX0= |
@@ -20,2 +20,3 @@ 'use strict'; | ||
} | ||
const PAGE_SIZE = 0x100000; | ||
/** | ||
@@ -46,2 +47,3 @@ * The Heap is responsible for dynamically allocating | ||
this.handle = 0; | ||
this.capacity = PAGE_SIZE; | ||
if (serializedHeap) { | ||
@@ -53,4 +55,5 @@ let { buffer, table, handle } = serializedHeap; | ||
this.handle = handle; | ||
this.capacity = 0; | ||
} else { | ||
this.heap = new Uint16Array(0x100000); | ||
this.heap = new Uint16Array(PAGE_SIZE); | ||
this.table = []; | ||
@@ -60,4 +63,14 @@ } | ||
push(item) { | ||
this.sizeCheck(); | ||
this.heap[this.offset++] = item; | ||
} | ||
sizeCheck() { | ||
if (this.capacity === 0) { | ||
let heap = slice(this.heap, 0, this.offset); | ||
this.heap = new Uint16Array(heap.length + PAGE_SIZE); | ||
this.heap.set(heap, 0); | ||
this.capacity = PAGE_SIZE; | ||
} | ||
this.capacity--; | ||
} | ||
getbyaddr(address) { | ||
@@ -147,2 +160,3 @@ return this.heap[address]; | ||
pushPlaceholder(valueFunc) { | ||
this.sizeCheck(); | ||
let address = this.offset++; | ||
@@ -161,6 +175,6 @@ this.heap[address] = 65535 /* MAX_SIZE */; | ||
} | ||
capture() { | ||
capture(offset = this.offset) { | ||
this.patchPlaceholders(); | ||
// Only called in eager mode | ||
let buffer = slice(this.heap, 0, this.offset); | ||
let buffer = slice(this.heap, 0, offset).buffer; | ||
return { | ||
@@ -206,14 +220,11 @@ handle: this.handle, | ||
function slice(arr, start, end) { | ||
if (arr instanceof Uint16Array) { | ||
if (arr.slice !== undefined) { | ||
return arr.slice(start, end).buffer; | ||
} | ||
let ret = new Uint16Array(end); | ||
for (; start < end; start++) { | ||
ret[start] = arr[start]; | ||
} | ||
return ret.buffer; | ||
if (arr.slice !== undefined) { | ||
return arr.slice(start, end); | ||
} | ||
return null; | ||
let ret = new Uint16Array(end); | ||
for (; start < end; start++) { | ||
ret[start] = arr[start]; | ||
} | ||
return ret; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"program.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/program.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport { CompileTimeProgram, Recast, VMHandle, RuntimeResolver, CompileTimeHeap } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants, ConstantPool } from './constants';\nimport { Opcode } from './opcode';\nimport { assert } from \"@glimmer/util\";\n\nconst enum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst enum Size {\n  ENTRY_SIZE = 2,\n  INFO_OFFSET = 1,\n  MAX_SIZE   = 0b1111111111111111,\n  SIZE_MASK  = 0b00000000000000001111111111111111,\n  SCOPE_MASK = 0b00111111111111110000000000000000,\n  STATE_MASK = 0b11000000000000000000000000000000,\n}\n\nfunction encodeTableInfo(size: number, scopeSize: number, state: number) {\n  return size | (scopeSize << 16) | state << 30;\n}\n\nfunction changeState(info: number, newState: number) {\n  return info | newState << 30;\n}\n\nexport interface SerializedHeap {\n  buffer: ArrayBuffer;\n  table: number[];\n  handle: number;\n}\n\nexport type Placeholder = [number, () => number];\n\n/**\n * The Heap is responsible for dynamically allocating\n * memory in which we read/write the VM's instructions\n * from/to. When we malloc we pass out a VMHandle, which\n * is used as an indirect way of accessing the memory during\n * execution of the VM. Internally we track the different\n * regions of the memory in an int array known as the table.\n *\n * The table 32-bit aligned and has the following layout:\n *\n * | ... | hp (u32) |       info (u32)          |\n * | ... |  Handle  | Size | Scope Size | State |\n * | ... | 32-bits  | 16b  |    14b     |  2b   |\n *\n * With this information we effectively have the ability to\n * control when we want to free memory. That being said you\n * can not free during execution as raw address are only\n * valid during the execution. This means you cannot close\n * over them as you will have a bad memory access exception.\n */\nexport class Heap implements CompileTimeHeap {\n  private heap: Uint16Array | Array<number>;\n  private placeholders: Placeholder[] = [];\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n\n  constructor(serializedHeap?: SerializedHeap) {\n    if (serializedHeap) {\n      let { buffer, table, handle } = serializedHeap;\n      this.heap = new Uint16Array(buffer);\n      this.table = table;\n      this.offset = this.heap.length;\n      this.handle = handle;\n    } else {\n      this.heap = new Uint16Array(0x100000);\n      this.table = [];\n    }\n  }\n\n  push(item: number): void {\n    this.heap[this.offset++] = item;\n  }\n\n  getbyaddr(address: number): number {\n    return this.heap[address];\n  }\n\n  setbyaddr(address: number, value: number) {\n    this.heap[address] = value;\n  }\n\n  malloc(): number {\n    this.table.push(this.offset, 0);\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  finishMalloc(handle: number, scopeSize: number): void {\n    let start = this.table[handle];\n    let finish = this.offset;\n    let instructionSize = finish - start;\n    let info = encodeTableInfo(instructionSize, scopeSize, TableSlotState.Allocated);\n    this.table[handle + Size.INFO_OFFSET] = info;\n  }\n\n  size(): number {\n    return this.offset;\n  }\n\n  // It is illegal to close over this address, as compaction\n  // may move it. However, it is legal to use this address\n  // multiple times between compactions.\n  getaddr(handle: number): number {\n    return this.table[handle];\n  }\n\n  gethandle(address: number): number {\n    this.table.push(address, encodeTableInfo(0, 0, TableSlotState.Pointer));\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  sizeof(handle: number): number {\n    if (DEBUG) {\n      let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n      return info & Size.SIZE_MASK;\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: number): number {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    return (info & Size.SCOPE_MASK) >> 16;\n  }\n\n  free(handle: VMHandle): void {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET] = changeState(info, TableSlotState.Freed);\n  }\n\n  /**\n   * The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift\n   * reachable memory to the bottom of the heap and freeable\n   * memory to the top of the heap. When we have shifted all\n   * the reachable memory to the top of the heap, we move the\n   * offset to the next free position.\n   */\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=Size.ENTRY_SIZE) {\n      let offset = table[i];\n      let info = table[i + Size.INFO_OFFSET];\n      let size = info & Size.SIZE_MASK;\n      let state = info & Size.STATE_MASK >> 30;\n\n      if (state === TableSlotState.Purged) {\n        continue;\n      } else if (state === TableSlotState.Freed) {\n        // transition to \"already freed\" aka \"purged\"\n        // a good improvement would be to reuse\n        // these slots\n        table[i + Size.INFO_OFFSET] = changeState(info, TableSlotState.Purged);\n        compactedSize += size;\n      } else if (state === TableSlotState.Allocated) {\n        for (let j=offset; j<=i+size; j++) {\n          heap[j - compactedSize] = heap[j];\n        }\n\n        table[i] = offset - compactedSize;\n      } else if (state === TableSlotState.Pointer) {\n        table[i] = offset - compactedSize;\n      }\n    }\n\n    this.offset = this.offset - compactedSize;\n  }\n\n  pushPlaceholder(valueFunc: () => number): void {\n    let address = this.offset++;\n    this.heap[address] = Size.MAX_SIZE;\n    this.placeholders.push([address, valueFunc]);\n  }\n\n  private patchPlaceholders() {\n    let { placeholders } = this;\n\n    for (let i = 0; i < placeholders.length; i++) {\n      let [address, getValue] = placeholders[i];\n\n      assert(this.getbyaddr(address) === Size.MAX_SIZE, `expected to find a placeholder value at ${address}`);\n      this.setbyaddr(address, getValue());\n    }\n  }\n\n  capture(): SerializedHeap {\n    this.patchPlaceholders();\n\n    // Only called in eager mode\n    let buffer = slice(this.heap, 0, this.offset);\n    return {\n      handle: this.handle,\n      table: this.table,\n      buffer: buffer as ArrayBuffer\n    };\n  }\n}\n\nexport class WriteOnlyProgram implements CompileTimeProgram {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: WriteOnlyConstants = new WriteOnlyConstants(), public heap = new Heap()) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class RuntimeProgram<Locator> {\n  [key: number]: never;\n\n  static hydrate<Locator>(rawHeap: SerializedHeap, pool: ConstantPool, resolver: RuntimeResolver<Locator>) {\n    let heap = new Heap(rawHeap);\n    let constants = new RuntimeConstants(resolver, pool);\n\n    return new RuntimeProgram(constants, heap);\n  }\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Locator>, public heap: Heap) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class Program<Locator> extends WriteOnlyProgram {\n  public constants: Constants<Locator>;\n}\n\nfunction slice(arr: Uint16Array | number[], start: number, end: number) {\n  if (arr instanceof Uint16Array) {\n    if (arr.slice !== undefined) {\n      return arr.slice(start, end).buffer;\n    }\n\n    let ret = new Uint16Array(end);\n\n    for (; start < end; start++) {\n      ret[start]  = arr[start];\n    }\n\n    return ret.buffer;\n  }\n\n  return null;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"program.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/program.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport { CompileTimeProgram, Recast, VMHandle, RuntimeResolver, CompileTimeHeap } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants, ConstantPool } from './constants';\nimport { Opcode } from './opcode';\nimport { assert } from \"@glimmer/util\";\n\nconst enum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst enum Size {\n  ENTRY_SIZE = 2,\n  INFO_OFFSET = 1,\n  MAX_SIZE   = 0b1111111111111111,\n  SIZE_MASK  = 0b00000000000000001111111111111111,\n  SCOPE_MASK = 0b00111111111111110000000000000000,\n  STATE_MASK = 0b11000000000000000000000000000000,\n}\n\nfunction encodeTableInfo(size: number, scopeSize: number, state: number) {\n  return size | (scopeSize << 16) | state << 30;\n}\n\nfunction changeState(info: number, newState: number) {\n  return info | newState << 30;\n}\n\nexport interface SerializedHeap {\n  buffer: ArrayBuffer;\n  table: number[];\n  handle: number;\n}\n\nexport type Placeholder = [number, () => number];\n\nconst PAGE_SIZE = 0x100000;\n\n/**\n * The Heap is responsible for dynamically allocating\n * memory in which we read/write the VM's instructions\n * from/to. When we malloc we pass out a VMHandle, which\n * is used as an indirect way of accessing the memory during\n * execution of the VM. Internally we track the different\n * regions of the memory in an int array known as the table.\n *\n * The table 32-bit aligned and has the following layout:\n *\n * | ... | hp (u32) |       info (u32)          |\n * | ... |  Handle  | Size | Scope Size | State |\n * | ... | 32-bits  | 16b  |    14b     |  2b   |\n *\n * With this information we effectively have the ability to\n * control when we want to free memory. That being said you\n * can not free during execution as raw address are only\n * valid during the execution. This means you cannot close\n * over them as you will have a bad memory access exception.\n */\nexport class Heap implements CompileTimeHeap {\n  private heap: Uint16Array;\n  private placeholders: Placeholder[] = [];\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n  private capacity = PAGE_SIZE;\n\n  constructor(serializedHeap?: SerializedHeap) {\n    if (serializedHeap) {\n      let { buffer, table, handle } = serializedHeap;\n      this.heap = new Uint16Array(buffer);\n      this.table = table;\n      this.offset = this.heap.length;\n      this.handle = handle;\n      this.capacity = 0;\n    } else {\n      this.heap = new Uint16Array(PAGE_SIZE);\n      this.table = [];\n    }\n  }\n\n  push(item: number): void {\n    this.sizeCheck();\n    this.heap[this.offset++] = item;\n  }\n\n  private sizeCheck() {\n    if (this.capacity === 0) {\n      let heap = slice(this.heap, 0, this.offset);\n      this.heap = new Uint16Array(heap.length + PAGE_SIZE);\n      this.heap.set(heap, 0);\n      this.capacity = PAGE_SIZE;\n    }\n    this.capacity--;\n  }\n\n  getbyaddr(address: number): number {\n    return this.heap[address];\n  }\n\n  setbyaddr(address: number, value: number) {\n    this.heap[address] = value;\n  }\n\n  malloc(): number {\n    this.table.push(this.offset, 0);\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  finishMalloc(handle: number, scopeSize: number): void {\n    let start = this.table[handle];\n    let finish = this.offset;\n    let instructionSize = finish - start;\n    let info = encodeTableInfo(instructionSize, scopeSize, TableSlotState.Allocated);\n    this.table[handle + Size.INFO_OFFSET] = info;\n  }\n\n  size(): number {\n    return this.offset;\n  }\n\n  // It is illegal to close over this address, as compaction\n  // may move it. However, it is legal to use this address\n  // multiple times between compactions.\n  getaddr(handle: number): number {\n    return this.table[handle];\n  }\n\n  gethandle(address: number): number {\n    this.table.push(address, encodeTableInfo(0, 0, TableSlotState.Pointer));\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  sizeof(handle: number): number {\n    if (DEBUG) {\n      let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n      return info & Size.SIZE_MASK;\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: number): number {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    return (info & Size.SCOPE_MASK) >> 16;\n  }\n\n  free(handle: VMHandle): void {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET] = changeState(info, TableSlotState.Freed);\n  }\n\n  /**\n   * The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift\n   * reachable memory to the bottom of the heap and freeable\n   * memory to the top of the heap. When we have shifted all\n   * the reachable memory to the top of the heap, we move the\n   * offset to the next free position.\n   */\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=Size.ENTRY_SIZE) {\n      let offset = table[i];\n      let info = table[i + Size.INFO_OFFSET];\n      let size = info & Size.SIZE_MASK;\n      let state = info & Size.STATE_MASK >> 30;\n\n      if (state === TableSlotState.Purged) {\n        continue;\n      } else if (state === TableSlotState.Freed) {\n        // transition to \"already freed\" aka \"purged\"\n        // a good improvement would be to reuse\n        // these slots\n        table[i + Size.INFO_OFFSET] = changeState(info, TableSlotState.Purged);\n        compactedSize += size;\n      } else if (state === TableSlotState.Allocated) {\n        for (let j=offset; j<=i+size; j++) {\n          heap[j - compactedSize] = heap[j];\n        }\n\n        table[i] = offset - compactedSize;\n      } else if (state === TableSlotState.Pointer) {\n        table[i] = offset - compactedSize;\n      }\n    }\n\n    this.offset = this.offset - compactedSize;\n  }\n\n  pushPlaceholder(valueFunc: () => number): void {\n    this.sizeCheck();\n    let address = this.offset++;\n    this.heap[address] = Size.MAX_SIZE;\n    this.placeholders.push([address, valueFunc]);\n  }\n\n  private patchPlaceholders() {\n    let { placeholders } = this;\n\n    for (let i = 0; i < placeholders.length; i++) {\n      let [address, getValue] = placeholders[i];\n\n      assert(this.getbyaddr(address) === Size.MAX_SIZE, `expected to find a placeholder value at ${address}`);\n      this.setbyaddr(address, getValue());\n    }\n  }\n\n  capture(offset = this.offset): SerializedHeap {\n    this.patchPlaceholders();\n\n    // Only called in eager mode\n    let buffer = slice(this.heap, 0, offset).buffer;\n    return {\n      handle: this.handle,\n      table: this.table,\n      buffer: buffer as ArrayBuffer\n    };\n  }\n}\n\nexport class WriteOnlyProgram implements CompileTimeProgram {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: WriteOnlyConstants = new WriteOnlyConstants(), public heap = new Heap()) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class RuntimeProgram<TemplateMeta> {\n  [key: number]: never;\n\n  static hydrate<TemplateMeta>(rawHeap: SerializedHeap, pool: ConstantPool, resolver: RuntimeResolver<TemplateMeta>) {\n    let heap = new Heap(rawHeap);\n    let constants = new RuntimeConstants(resolver, pool);\n\n    return new RuntimeProgram(constants, heap);\n  }\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<TemplateMeta>, public heap: Heap) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class Program<TemplateMeta> extends WriteOnlyProgram {\n  public constants: Constants<TemplateMeta>;\n}\n\nfunction slice(arr: Uint16Array, start: number, end: number): Uint16Array {\n  if (arr.slice !== undefined) {\n    return arr.slice(start, end);\n  }\n\n  let ret = new Uint16Array(end);\n\n  for (; start < end; start++) {\n    ret[start]  = arr[start];\n  }\n\n  return ret;\n}\n"]} |
@@ -33,3 +33,3 @@ "use strict"; | ||
var UNRESOLVED = {}; | ||
var WELL_KNOWN_EMPTY_ARRAY_POSITION = exports.WELL_KNOWN_EMPTY_ARRAY_POSITION = 0; | ||
var WELL_KNOWN_EMPTY_ARRAY_POSITION = 0; | ||
var WELL_KNOW_EMPTY_ARRAY = Object.freeze([]); | ||
@@ -263,2 +263,2 @@ | ||
exports.LazyConstants = LazyConstants; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/constants.ts"],"names":[],"mappings":"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","sourcesContent":["import { Opaque, SymbolTable, RuntimeResolver, CompileTimeConstants } from \"@glimmer/interfaces\";\n\nconst UNRESOLVED = {};\n\nexport const WELL_KNOWN_EMPTY_ARRAY_POSITION = 0;\nconst WELL_KNOW_EMPTY_ARRAY = Object.freeze([]);\nexport type EMPTY_ARRAY = Array<ReadonlyArray<never>>;\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][] | EMPTY_ARRAY;\n  handles: number[];\n  numbers: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b000,\n  FLOAT           = 0b001,\n  STRING          = 0b010,\n  BOOLEAN_OR_VOID = 0b011,\n  NEGATIVE        = 0b100,\n  BIG_NUM         = 0b101\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] | EMPTY_ARRAY = [WELL_KNOW_EMPTY_ARRAY];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected resolved: Opaque[] = [];\n  protected numbers: number[] = [];\n\n  string(value: string): number {\n    let index = this.strings.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(value) - 1;\n  }\n\n  stringArray(strings: string[]): number {\n    let _strings: number[] = new Array(strings.length);\n\n    for (let i = 0; i < strings.length; i++) {\n      _strings[i] = this.string(strings[i]);\n    }\n\n    return this.array(_strings);\n  }\n\n  array(values: number[]): number {\n    if (values.length === 0) {\n      return WELL_KNOWN_EMPTY_ARRAY_POSITION;\n    }\n\n    let index = (this.arrays as number[][]).indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return (this.arrays as number[][]).push(values) - 1;\n  }\n\n  handle(handle: number): number {\n    let index = this.handles.indexOf(handle);\n    if (index > -1) {\n      return index;\n    }\n\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle) - 1;\n  }\n\n  serializable(value: Opaque): number {\n    let str = JSON.stringify(value);\n    let index = this.strings.indexOf(str);\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(str) - 1;\n  }\n\n  number(number: number): number {\n    let index = this.numbers.indexOf(number);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.numbers.push(number) - 1;\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      handles: this.handles,\n      numbers: this.numbers\n    };\n  }\n}\n\nexport class RuntimeConstants<Locator> {\n  protected strings: string[];\n  protected arrays: number[][] | EMPTY_ARRAY;\n  protected handles: number[];\n  protected resolved: Opaque[];\n  protected numbers: number[];\n\n  constructor(public resolver: RuntimeResolver<Locator>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.handles = pool.handles;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n    this.numbers = pool.numbers;\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class Constants<Locator> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Locator>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.handles = pool.handles;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n      this.numbers = pool.numbers;\n    }\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\n  protected serializables: Opaque[] = [];\n\n  serializable(value: Opaque): number {\n    let index = this.serializables.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.serializables.push(value) - 1;\n  }\n\n  getSerializable<T>(s: number): T {\n    return this.serializables[s] as T;\n  }\n\n  getOther<T>(value: number): T {\n    return this.others[value - 1] as T;\n  }\n\n  other(other: Opaque): number {\n    return this.others.push(other);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/constants.ts"],"names":[],"mappings":"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","sourcesContent":["import { Opaque, SymbolTable, RuntimeResolver, CompileTimeConstants } from \"@glimmer/interfaces\";\n\nconst UNRESOLVED = {};\n\nconst WELL_KNOWN_EMPTY_ARRAY_POSITION = 0;\nconst WELL_KNOW_EMPTY_ARRAY = Object.freeze([]);\nexport type EMPTY_ARRAY = Array<ReadonlyArray<never>>;\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][] | EMPTY_ARRAY;\n  handles: number[];\n  numbers: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b000,\n  FLOAT           = 0b001,\n  STRING          = 0b010,\n  BOOLEAN_OR_VOID = 0b011,\n  NEGATIVE        = 0b100,\n  BIG_NUM         = 0b101\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] | EMPTY_ARRAY = [WELL_KNOW_EMPTY_ARRAY];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected resolved: Opaque[] = [];\n  protected numbers: number[] = [];\n\n  string(value: string): number {\n    let index = this.strings.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(value) - 1;\n  }\n\n  stringArray(strings: string[]): number {\n    let _strings: number[] = new Array(strings.length);\n\n    for (let i = 0; i < strings.length; i++) {\n      _strings[i] = this.string(strings[i]);\n    }\n\n    return this.array(_strings);\n  }\n\n  array(values: number[]): number {\n    if (values.length === 0) {\n      return WELL_KNOWN_EMPTY_ARRAY_POSITION;\n    }\n\n    let index = (this.arrays as number[][]).indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return (this.arrays as number[][]).push(values) - 1;\n  }\n\n  handle(handle: number): number {\n    let index = this.handles.indexOf(handle);\n    if (index > -1) {\n      return index;\n    }\n\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle) - 1;\n  }\n\n  serializable(value: Opaque): number {\n    let str = JSON.stringify(value);\n    let index = this.strings.indexOf(str);\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(str) - 1;\n  }\n\n  number(number: number): number {\n    let index = this.numbers.indexOf(number);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.numbers.push(number) - 1;\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      handles: this.handles,\n      numbers: this.numbers\n    };\n  }\n}\n\nexport class RuntimeConstants<TemplateMeta> {\n  protected strings: string[];\n  protected arrays: number[][] | EMPTY_ARRAY;\n  protected handles: number[];\n  protected resolved: Opaque[];\n  protected numbers: number[];\n\n  constructor(public resolver: RuntimeResolver<TemplateMeta>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.handles = pool.handles;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n    this.numbers = pool.numbers;\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class Constants<TemplateMeta> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<TemplateMeta>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.handles = pool.handles;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n      this.numbers = pool.numbers;\n    }\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\n  protected serializables: Opaque[] = [];\n\n  serializable(value: Opaque): number {\n    let index = this.serializables.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.serializables.push(value) - 1;\n  }\n\n  getSerializable<T>(s: number): T {\n    return this.serializables[s] as T;\n  }\n\n  getOther<T>(value: number): T {\n    return this.others[value - 1] as T;\n  }\n\n  other(other: Opaque): number {\n    return this.others.push(other);\n  }\n}\n"]} |
"use strict"; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJuYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci9wcm9ncmFtL2xpYi9pbnRlcm5hbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVW5pcXVlLCBSdW50aW1lUmVzb2x2ZXIgYXMgSVJlc29sdmVyIH0gZnJvbSAnQGdsaW1tZXIvaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCB0eXBlIExvY2F0b3IgPSBVbmlxdWU8J0xvY2F0b3InPjtcbmV4cG9ydCB0eXBlIFJlZmVycmVyID0gVW5pcXVlPCdSZWZlcnJlcic+O1xuZXhwb3J0IHR5cGUgUmVzb2x2ZXIgPSBJUmVzb2x2ZXI8TG9jYXRvcj47XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJuYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci9wcm9ncmFtL2xpYi9pbnRlcm5hbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVW5pcXVlLCBSdW50aW1lUmVzb2x2ZXIgYXMgSVJlc29sdmVyIH0gZnJvbSAnQGdsaW1tZXIvaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCB0eXBlIFRlbXBsYXRlTWV0YSA9IFVuaXF1ZTwnVGVtcGxhdGVNZXRhJz47XG5leHBvcnQgdHlwZSBSZWZlcnJlciA9IFVuaXF1ZTwnUmVmZXJyZXInPjtcbmV4cG9ydCB0eXBlIFJlc29sdmVyID0gSVJlc29sdmVyPFRlbXBsYXRlTWV0YT47XG4iXX0= |
@@ -46,2 +46,3 @@ "use strict"; | ||
} | ||
var PAGE_SIZE = 0x100000; | ||
/** | ||
@@ -74,2 +75,3 @@ * The Heap is responsible for dynamically allocating | ||
this.handle = 0; | ||
this.capacity = PAGE_SIZE; | ||
if (serializedHeap) { | ||
@@ -84,4 +86,5 @@ var buffer = serializedHeap.buffer, | ||
this.handle = handle; | ||
this.capacity = 0; | ||
} else { | ||
this.heap = new Uint16Array(0x100000); | ||
this.heap = new Uint16Array(PAGE_SIZE); | ||
this.table = []; | ||
@@ -92,5 +95,16 @@ } | ||
Heap.prototype.push = function push(item) { | ||
this.sizeCheck(); | ||
this.heap[this.offset++] = item; | ||
}; | ||
Heap.prototype.sizeCheck = function sizeCheck() { | ||
if (this.capacity === 0) { | ||
var heap = slice(this.heap, 0, this.offset); | ||
this.heap = new Uint16Array(heap.length + PAGE_SIZE); | ||
this.heap.set(heap, 0); | ||
this.capacity = PAGE_SIZE; | ||
} | ||
this.capacity--; | ||
}; | ||
Heap.prototype.getbyaddr = function getbyaddr(address) { | ||
@@ -195,2 +209,3 @@ return this.heap[address]; | ||
Heap.prototype.pushPlaceholder = function pushPlaceholder(valueFunc) { | ||
this.sizeCheck(); | ||
var address = this.offset++; | ||
@@ -216,5 +231,7 @@ this.heap[address] = 65535 /* MAX_SIZE */; | ||
Heap.prototype.capture = function capture() { | ||
var offset = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.offset; | ||
this.patchPlaceholders(); | ||
// Only called in eager mode | ||
var buffer = slice(this.heap, 0, this.offset); | ||
var buffer = slice(this.heap, 0, offset).buffer; | ||
return { | ||
@@ -282,14 +299,11 @@ handle: this.handle, | ||
function slice(arr, start, end) { | ||
if (arr instanceof Uint16Array) { | ||
if (arr.slice !== undefined) { | ||
return arr.slice(start, end).buffer; | ||
} | ||
var ret = new Uint16Array(end); | ||
for (; start < end; start++) { | ||
ret[start] = arr[start]; | ||
} | ||
return ret.buffer; | ||
if (arr.slice !== undefined) { | ||
return arr.slice(start, end); | ||
} | ||
return null; | ||
var ret = new Uint16Array(end); | ||
for (; start < end; start++) { | ||
ret[start] = arr[start]; | ||
} | ||
return ret; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"program.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/program.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport { CompileTimeProgram, Recast, VMHandle, RuntimeResolver, CompileTimeHeap } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants, ConstantPool } from './constants';\nimport { Opcode } from './opcode';\nimport { assert } from \"@glimmer/util\";\n\nconst enum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst enum Size {\n  ENTRY_SIZE = 2,\n  INFO_OFFSET = 1,\n  MAX_SIZE   = 0b1111111111111111,\n  SIZE_MASK  = 0b00000000000000001111111111111111,\n  SCOPE_MASK = 0b00111111111111110000000000000000,\n  STATE_MASK = 0b11000000000000000000000000000000,\n}\n\nfunction encodeTableInfo(size: number, scopeSize: number, state: number) {\n  return size | (scopeSize << 16) | state << 30;\n}\n\nfunction changeState(info: number, newState: number) {\n  return info | newState << 30;\n}\n\nexport interface SerializedHeap {\n  buffer: ArrayBuffer;\n  table: number[];\n  handle: number;\n}\n\nexport type Placeholder = [number, () => number];\n\n/**\n * The Heap is responsible for dynamically allocating\n * memory in which we read/write the VM's instructions\n * from/to. When we malloc we pass out a VMHandle, which\n * is used as an indirect way of accessing the memory during\n * execution of the VM. Internally we track the different\n * regions of the memory in an int array known as the table.\n *\n * The table 32-bit aligned and has the following layout:\n *\n * | ... | hp (u32) |       info (u32)          |\n * | ... |  Handle  | Size | Scope Size | State |\n * | ... | 32-bits  | 16b  |    14b     |  2b   |\n *\n * With this information we effectively have the ability to\n * control when we want to free memory. That being said you\n * can not free during execution as raw address are only\n * valid during the execution. This means you cannot close\n * over them as you will have a bad memory access exception.\n */\nexport class Heap implements CompileTimeHeap {\n  private heap: Uint16Array | Array<number>;\n  private placeholders: Placeholder[] = [];\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n\n  constructor(serializedHeap?: SerializedHeap) {\n    if (serializedHeap) {\n      let { buffer, table, handle } = serializedHeap;\n      this.heap = new Uint16Array(buffer);\n      this.table = table;\n      this.offset = this.heap.length;\n      this.handle = handle;\n    } else {\n      this.heap = new Uint16Array(0x100000);\n      this.table = [];\n    }\n  }\n\n  push(item: number): void {\n    this.heap[this.offset++] = item;\n  }\n\n  getbyaddr(address: number): number {\n    return this.heap[address];\n  }\n\n  setbyaddr(address: number, value: number) {\n    this.heap[address] = value;\n  }\n\n  malloc(): number {\n    this.table.push(this.offset, 0);\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  finishMalloc(handle: number, scopeSize: number): void {\n    let start = this.table[handle];\n    let finish = this.offset;\n    let instructionSize = finish - start;\n    let info = encodeTableInfo(instructionSize, scopeSize, TableSlotState.Allocated);\n    this.table[handle + Size.INFO_OFFSET] = info;\n  }\n\n  size(): number {\n    return this.offset;\n  }\n\n  // It is illegal to close over this address, as compaction\n  // may move it. However, it is legal to use this address\n  // multiple times between compactions.\n  getaddr(handle: number): number {\n    return this.table[handle];\n  }\n\n  gethandle(address: number): number {\n    this.table.push(address, encodeTableInfo(0, 0, TableSlotState.Pointer));\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  sizeof(handle: number): number {\n    if (DEBUG) {\n      let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n      return info & Size.SIZE_MASK;\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: number): number {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    return (info & Size.SCOPE_MASK) >> 16;\n  }\n\n  free(handle: VMHandle): void {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET] = changeState(info, TableSlotState.Freed);\n  }\n\n  /**\n   * The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift\n   * reachable memory to the bottom of the heap and freeable\n   * memory to the top of the heap. When we have shifted all\n   * the reachable memory to the top of the heap, we move the\n   * offset to the next free position.\n   */\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=Size.ENTRY_SIZE) {\n      let offset = table[i];\n      let info = table[i + Size.INFO_OFFSET];\n      let size = info & Size.SIZE_MASK;\n      let state = info & Size.STATE_MASK >> 30;\n\n      if (state === TableSlotState.Purged) {\n        continue;\n      } else if (state === TableSlotState.Freed) {\n        // transition to \"already freed\" aka \"purged\"\n        // a good improvement would be to reuse\n        // these slots\n        table[i + Size.INFO_OFFSET] = changeState(info, TableSlotState.Purged);\n        compactedSize += size;\n      } else if (state === TableSlotState.Allocated) {\n        for (let j=offset; j<=i+size; j++) {\n          heap[j - compactedSize] = heap[j];\n        }\n\n        table[i] = offset - compactedSize;\n      } else if (state === TableSlotState.Pointer) {\n        table[i] = offset - compactedSize;\n      }\n    }\n\n    this.offset = this.offset - compactedSize;\n  }\n\n  pushPlaceholder(valueFunc: () => number): void {\n    let address = this.offset++;\n    this.heap[address] = Size.MAX_SIZE;\n    this.placeholders.push([address, valueFunc]);\n  }\n\n  private patchPlaceholders() {\n    let { placeholders } = this;\n\n    for (let i = 0; i < placeholders.length; i++) {\n      let [address, getValue] = placeholders[i];\n\n      assert(this.getbyaddr(address) === Size.MAX_SIZE, `expected to find a placeholder value at ${address}`);\n      this.setbyaddr(address, getValue());\n    }\n  }\n\n  capture(): SerializedHeap {\n    this.patchPlaceholders();\n\n    // Only called in eager mode\n    let buffer = slice(this.heap, 0, this.offset);\n    return {\n      handle: this.handle,\n      table: this.table,\n      buffer: buffer as ArrayBuffer\n    };\n  }\n}\n\nexport class WriteOnlyProgram implements CompileTimeProgram {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: WriteOnlyConstants = new WriteOnlyConstants(), public heap = new Heap()) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class RuntimeProgram<Locator> {\n  [key: number]: never;\n\n  static hydrate<Locator>(rawHeap: SerializedHeap, pool: ConstantPool, resolver: RuntimeResolver<Locator>) {\n    let heap = new Heap(rawHeap);\n    let constants = new RuntimeConstants(resolver, pool);\n\n    return new RuntimeProgram(constants, heap);\n  }\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Locator>, public heap: Heap) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class Program<Locator> extends WriteOnlyProgram {\n  public constants: Constants<Locator>;\n}\n\nfunction slice(arr: Uint16Array | number[], start: number, end: number) {\n  if (arr instanceof Uint16Array) {\n    if (arr.slice !== undefined) {\n      return arr.slice(start, end).buffer;\n    }\n\n    let ret = new Uint16Array(end);\n\n    for (; start < end; start++) {\n      ret[start]  = arr[start];\n    }\n\n    return ret.buffer;\n  }\n\n  return null;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"program.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/program.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport { CompileTimeProgram, Recast, VMHandle, RuntimeResolver, CompileTimeHeap } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants, ConstantPool } from './constants';\nimport { Opcode } from './opcode';\nimport { assert } from \"@glimmer/util\";\n\nconst enum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst enum Size {\n  ENTRY_SIZE = 2,\n  INFO_OFFSET = 1,\n  MAX_SIZE   = 0b1111111111111111,\n  SIZE_MASK  = 0b00000000000000001111111111111111,\n  SCOPE_MASK = 0b00111111111111110000000000000000,\n  STATE_MASK = 0b11000000000000000000000000000000,\n}\n\nfunction encodeTableInfo(size: number, scopeSize: number, state: number) {\n  return size | (scopeSize << 16) | state << 30;\n}\n\nfunction changeState(info: number, newState: number) {\n  return info | newState << 30;\n}\n\nexport interface SerializedHeap {\n  buffer: ArrayBuffer;\n  table: number[];\n  handle: number;\n}\n\nexport type Placeholder = [number, () => number];\n\nconst PAGE_SIZE = 0x100000;\n\n/**\n * The Heap is responsible for dynamically allocating\n * memory in which we read/write the VM's instructions\n * from/to. When we malloc we pass out a VMHandle, which\n * is used as an indirect way of accessing the memory during\n * execution of the VM. Internally we track the different\n * regions of the memory in an int array known as the table.\n *\n * The table 32-bit aligned and has the following layout:\n *\n * | ... | hp (u32) |       info (u32)          |\n * | ... |  Handle  | Size | Scope Size | State |\n * | ... | 32-bits  | 16b  |    14b     |  2b   |\n *\n * With this information we effectively have the ability to\n * control when we want to free memory. That being said you\n * can not free during execution as raw address are only\n * valid during the execution. This means you cannot close\n * over them as you will have a bad memory access exception.\n */\nexport class Heap implements CompileTimeHeap {\n  private heap: Uint16Array;\n  private placeholders: Placeholder[] = [];\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n  private capacity = PAGE_SIZE;\n\n  constructor(serializedHeap?: SerializedHeap) {\n    if (serializedHeap) {\n      let { buffer, table, handle } = serializedHeap;\n      this.heap = new Uint16Array(buffer);\n      this.table = table;\n      this.offset = this.heap.length;\n      this.handle = handle;\n      this.capacity = 0;\n    } else {\n      this.heap = new Uint16Array(PAGE_SIZE);\n      this.table = [];\n    }\n  }\n\n  push(item: number): void {\n    this.sizeCheck();\n    this.heap[this.offset++] = item;\n  }\n\n  private sizeCheck() {\n    if (this.capacity === 0) {\n      let heap = slice(this.heap, 0, this.offset);\n      this.heap = new Uint16Array(heap.length + PAGE_SIZE);\n      this.heap.set(heap, 0);\n      this.capacity = PAGE_SIZE;\n    }\n    this.capacity--;\n  }\n\n  getbyaddr(address: number): number {\n    return this.heap[address];\n  }\n\n  setbyaddr(address: number, value: number) {\n    this.heap[address] = value;\n  }\n\n  malloc(): number {\n    this.table.push(this.offset, 0);\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  finishMalloc(handle: number, scopeSize: number): void {\n    let start = this.table[handle];\n    let finish = this.offset;\n    let instructionSize = finish - start;\n    let info = encodeTableInfo(instructionSize, scopeSize, TableSlotState.Allocated);\n    this.table[handle + Size.INFO_OFFSET] = info;\n  }\n\n  size(): number {\n    return this.offset;\n  }\n\n  // It is illegal to close over this address, as compaction\n  // may move it. However, it is legal to use this address\n  // multiple times between compactions.\n  getaddr(handle: number): number {\n    return this.table[handle];\n  }\n\n  gethandle(address: number): number {\n    this.table.push(address, encodeTableInfo(0, 0, TableSlotState.Pointer));\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  sizeof(handle: number): number {\n    if (DEBUG) {\n      let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n      return info & Size.SIZE_MASK;\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: number): number {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    return (info & Size.SCOPE_MASK) >> 16;\n  }\n\n  free(handle: VMHandle): void {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET] = changeState(info, TableSlotState.Freed);\n  }\n\n  /**\n   * The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift\n   * reachable memory to the bottom of the heap and freeable\n   * memory to the top of the heap. When we have shifted all\n   * the reachable memory to the top of the heap, we move the\n   * offset to the next free position.\n   */\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=Size.ENTRY_SIZE) {\n      let offset = table[i];\n      let info = table[i + Size.INFO_OFFSET];\n      let size = info & Size.SIZE_MASK;\n      let state = info & Size.STATE_MASK >> 30;\n\n      if (state === TableSlotState.Purged) {\n        continue;\n      } else if (state === TableSlotState.Freed) {\n        // transition to \"already freed\" aka \"purged\"\n        // a good improvement would be to reuse\n        // these slots\n        table[i + Size.INFO_OFFSET] = changeState(info, TableSlotState.Purged);\n        compactedSize += size;\n      } else if (state === TableSlotState.Allocated) {\n        for (let j=offset; j<=i+size; j++) {\n          heap[j - compactedSize] = heap[j];\n        }\n\n        table[i] = offset - compactedSize;\n      } else if (state === TableSlotState.Pointer) {\n        table[i] = offset - compactedSize;\n      }\n    }\n\n    this.offset = this.offset - compactedSize;\n  }\n\n  pushPlaceholder(valueFunc: () => number): void {\n    this.sizeCheck();\n    let address = this.offset++;\n    this.heap[address] = Size.MAX_SIZE;\n    this.placeholders.push([address, valueFunc]);\n  }\n\n  private patchPlaceholders() {\n    let { placeholders } = this;\n\n    for (let i = 0; i < placeholders.length; i++) {\n      let [address, getValue] = placeholders[i];\n\n      assert(this.getbyaddr(address) === Size.MAX_SIZE, `expected to find a placeholder value at ${address}`);\n      this.setbyaddr(address, getValue());\n    }\n  }\n\n  capture(offset = this.offset): SerializedHeap {\n    this.patchPlaceholders();\n\n    // Only called in eager mode\n    let buffer = slice(this.heap, 0, offset).buffer;\n    return {\n      handle: this.handle,\n      table: this.table,\n      buffer: buffer as ArrayBuffer\n    };\n  }\n}\n\nexport class WriteOnlyProgram implements CompileTimeProgram {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: WriteOnlyConstants = new WriteOnlyConstants(), public heap = new Heap()) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class RuntimeProgram<TemplateMeta> {\n  [key: number]: never;\n\n  static hydrate<TemplateMeta>(rawHeap: SerializedHeap, pool: ConstantPool, resolver: RuntimeResolver<TemplateMeta>) {\n    let heap = new Heap(rawHeap);\n    let constants = new RuntimeConstants(resolver, pool);\n\n    return new RuntimeProgram(constants, heap);\n  }\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<TemplateMeta>, public heap: Heap) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class Program<TemplateMeta> extends WriteOnlyProgram {\n  public constants: Constants<TemplateMeta>;\n}\n\nfunction slice(arr: Uint16Array, start: number, end: number): Uint16Array {\n  if (arr.slice !== undefined) {\n    return arr.slice(start, end);\n  }\n\n  let ret = new Uint16Array(end);\n\n  for (; start < end; start++) {\n    ret[start]  = arr[start];\n  }\n\n  return ret;\n}\n"]} |
const UNRESOLVED = {}; | ||
export const WELL_KNOWN_EMPTY_ARRAY_POSITION = 0; | ||
const WELL_KNOWN_EMPTY_ARRAY_POSITION = 0; | ||
const WELL_KNOW_EMPTY_ARRAY = Object.freeze([]); | ||
@@ -174,2 +174,2 @@ export class WriteOnlyConstants { | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/constants.ts"],"names":[],"mappings":"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","sourcesContent":["import { Opaque, SymbolTable, RuntimeResolver, CompileTimeConstants } from \"@glimmer/interfaces\";\n\nconst UNRESOLVED = {};\n\nexport const WELL_KNOWN_EMPTY_ARRAY_POSITION = 0;\nconst WELL_KNOW_EMPTY_ARRAY = Object.freeze([]);\nexport type EMPTY_ARRAY = Array<ReadonlyArray<never>>;\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][] | EMPTY_ARRAY;\n  handles: number[];\n  numbers: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b000,\n  FLOAT           = 0b001,\n  STRING          = 0b010,\n  BOOLEAN_OR_VOID = 0b011,\n  NEGATIVE        = 0b100,\n  BIG_NUM         = 0b101\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] | EMPTY_ARRAY = [WELL_KNOW_EMPTY_ARRAY];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected resolved: Opaque[] = [];\n  protected numbers: number[] = [];\n\n  string(value: string): number {\n    let index = this.strings.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(value) - 1;\n  }\n\n  stringArray(strings: string[]): number {\n    let _strings: number[] = new Array(strings.length);\n\n    for (let i = 0; i < strings.length; i++) {\n      _strings[i] = this.string(strings[i]);\n    }\n\n    return this.array(_strings);\n  }\n\n  array(values: number[]): number {\n    if (values.length === 0) {\n      return WELL_KNOWN_EMPTY_ARRAY_POSITION;\n    }\n\n    let index = (this.arrays as number[][]).indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return (this.arrays as number[][]).push(values) - 1;\n  }\n\n  handle(handle: number): number {\n    let index = this.handles.indexOf(handle);\n    if (index > -1) {\n      return index;\n    }\n\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle) - 1;\n  }\n\n  serializable(value: Opaque): number {\n    let str = JSON.stringify(value);\n    let index = this.strings.indexOf(str);\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(str) - 1;\n  }\n\n  number(number: number): number {\n    let index = this.numbers.indexOf(number);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.numbers.push(number) - 1;\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      handles: this.handles,\n      numbers: this.numbers\n    };\n  }\n}\n\nexport class RuntimeConstants<Locator> {\n  protected strings: string[];\n  protected arrays: number[][] | EMPTY_ARRAY;\n  protected handles: number[];\n  protected resolved: Opaque[];\n  protected numbers: number[];\n\n  constructor(public resolver: RuntimeResolver<Locator>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.handles = pool.handles;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n    this.numbers = pool.numbers;\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class Constants<Locator> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Locator>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.handles = pool.handles;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n      this.numbers = pool.numbers;\n    }\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\n  protected serializables: Opaque[] = [];\n\n  serializable(value: Opaque): number {\n    let index = this.serializables.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.serializables.push(value) - 1;\n  }\n\n  getSerializable<T>(s: number): T {\n    return this.serializables[s] as T;\n  }\n\n  getOther<T>(value: number): T {\n    return this.others[value - 1] as T;\n  }\n\n  other(other: Opaque): number {\n    return this.others.push(other);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/constants.ts"],"names":[],"mappings":"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","sourcesContent":["import { Opaque, SymbolTable, RuntimeResolver, CompileTimeConstants } from \"@glimmer/interfaces\";\n\nconst UNRESOLVED = {};\n\nconst WELL_KNOWN_EMPTY_ARRAY_POSITION = 0;\nconst WELL_KNOW_EMPTY_ARRAY = Object.freeze([]);\nexport type EMPTY_ARRAY = Array<ReadonlyArray<never>>;\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][] | EMPTY_ARRAY;\n  handles: number[];\n  numbers: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b000,\n  FLOAT           = 0b001,\n  STRING          = 0b010,\n  BOOLEAN_OR_VOID = 0b011,\n  NEGATIVE        = 0b100,\n  BIG_NUM         = 0b101\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] | EMPTY_ARRAY = [WELL_KNOW_EMPTY_ARRAY];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected resolved: Opaque[] = [];\n  protected numbers: number[] = [];\n\n  string(value: string): number {\n    let index = this.strings.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(value) - 1;\n  }\n\n  stringArray(strings: string[]): number {\n    let _strings: number[] = new Array(strings.length);\n\n    for (let i = 0; i < strings.length; i++) {\n      _strings[i] = this.string(strings[i]);\n    }\n\n    return this.array(_strings);\n  }\n\n  array(values: number[]): number {\n    if (values.length === 0) {\n      return WELL_KNOWN_EMPTY_ARRAY_POSITION;\n    }\n\n    let index = (this.arrays as number[][]).indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return (this.arrays as number[][]).push(values) - 1;\n  }\n\n  handle(handle: number): number {\n    let index = this.handles.indexOf(handle);\n    if (index > -1) {\n      return index;\n    }\n\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle) - 1;\n  }\n\n  serializable(value: Opaque): number {\n    let str = JSON.stringify(value);\n    let index = this.strings.indexOf(str);\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(str) - 1;\n  }\n\n  number(number: number): number {\n    let index = this.numbers.indexOf(number);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.numbers.push(number) - 1;\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      handles: this.handles,\n      numbers: this.numbers\n    };\n  }\n}\n\nexport class RuntimeConstants<TemplateMeta> {\n  protected strings: string[];\n  protected arrays: number[][] | EMPTY_ARRAY;\n  protected handles: number[];\n  protected resolved: Opaque[];\n  protected numbers: number[];\n\n  constructor(public resolver: RuntimeResolver<TemplateMeta>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.handles = pool.handles;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n    this.numbers = pool.numbers;\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class Constants<TemplateMeta> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<TemplateMeta>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.handles = pool.handles;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n      this.numbers = pool.numbers;\n    }\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\n  protected serializables: Opaque[] = [];\n\n  serializable(value: Opaque): number {\n    let index = this.serializables.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.serializables.push(value) - 1;\n  }\n\n  getSerializable<T>(s: number): T {\n    return this.serializables[s] as T;\n  }\n\n  getOther<T>(value: number): T {\n    return this.others[value - 1] as T;\n  }\n\n  other(other: Opaque): number {\n    return this.others.push(other);\n  }\n}\n"]} |
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJuYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci9wcm9ncmFtL2xpYi9pbnRlcm5hbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVW5pcXVlLCBSdW50aW1lUmVzb2x2ZXIgYXMgSVJlc29sdmVyIH0gZnJvbSAnQGdsaW1tZXIvaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCB0eXBlIExvY2F0b3IgPSBVbmlxdWU8J0xvY2F0b3InPjtcbmV4cG9ydCB0eXBlIFJlZmVycmVyID0gVW5pcXVlPCdSZWZlcnJlcic+O1xuZXhwb3J0IHR5cGUgUmVzb2x2ZXIgPSBJUmVzb2x2ZXI8TG9jYXRvcj47XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJuYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci9wcm9ncmFtL2xpYi9pbnRlcm5hbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVW5pcXVlLCBSdW50aW1lUmVzb2x2ZXIgYXMgSVJlc29sdmVyIH0gZnJvbSAnQGdsaW1tZXIvaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCB0eXBlIFRlbXBsYXRlTWV0YSA9IFVuaXF1ZTwnVGVtcGxhdGVNZXRhJz47XG5leHBvcnQgdHlwZSBSZWZlcnJlciA9IFVuaXF1ZTwnUmVmZXJyZXInPjtcbmV4cG9ydCB0eXBlIFJlc29sdmVyID0gSVJlc29sdmVyPFRlbXBsYXRlTWV0YT47XG4iXX0= |
@@ -11,2 +11,3 @@ | ||
} | ||
const PAGE_SIZE = 0x100000; | ||
/** | ||
@@ -37,2 +38,3 @@ * The Heap is responsible for dynamically allocating | ||
this.handle = 0; | ||
this.capacity = PAGE_SIZE; | ||
if (serializedHeap) { | ||
@@ -44,4 +46,5 @@ let { buffer, table, handle } = serializedHeap; | ||
this.handle = handle; | ||
this.capacity = 0; | ||
} else { | ||
this.heap = new Uint16Array(0x100000); | ||
this.heap = new Uint16Array(PAGE_SIZE); | ||
this.table = []; | ||
@@ -51,4 +54,14 @@ } | ||
push(item) { | ||
this.sizeCheck(); | ||
this.heap[this.offset++] = item; | ||
} | ||
sizeCheck() { | ||
if (this.capacity === 0) { | ||
let heap = slice(this.heap, 0, this.offset); | ||
this.heap = new Uint16Array(heap.length + PAGE_SIZE); | ||
this.heap.set(heap, 0); | ||
this.capacity = PAGE_SIZE; | ||
} | ||
this.capacity--; | ||
} | ||
getbyaddr(address) { | ||
@@ -138,2 +151,3 @@ return this.heap[address]; | ||
pushPlaceholder(valueFunc) { | ||
this.sizeCheck(); | ||
let address = this.offset++; | ||
@@ -152,6 +166,6 @@ this.heap[address] = 65535 /* MAX_SIZE */; | ||
} | ||
capture() { | ||
capture(offset = this.offset) { | ||
this.patchPlaceholders(); | ||
// Only called in eager mode | ||
let buffer = slice(this.heap, 0, this.offset); | ||
let buffer = slice(this.heap, 0, offset).buffer; | ||
return { | ||
@@ -193,14 +207,11 @@ handle: this.handle, | ||
function slice(arr, start, end) { | ||
if (arr instanceof Uint16Array) { | ||
if (arr.slice !== undefined) { | ||
return arr.slice(start, end).buffer; | ||
} | ||
let ret = new Uint16Array(end); | ||
for (; start < end; start++) { | ||
ret[start] = arr[start]; | ||
} | ||
return ret.buffer; | ||
if (arr.slice !== undefined) { | ||
return arr.slice(start, end); | ||
} | ||
return null; | ||
let ret = new Uint16Array(end); | ||
for (; start < end; start++) { | ||
ret[start] = arr[start]; | ||
} | ||
return ret; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"program.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/program.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport { CompileTimeProgram, Recast, VMHandle, RuntimeResolver, CompileTimeHeap } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants, ConstantPool } from './constants';\nimport { Opcode } from './opcode';\nimport { assert } from \"@glimmer/util\";\n\nconst enum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst enum Size {\n  ENTRY_SIZE = 2,\n  INFO_OFFSET = 1,\n  MAX_SIZE   = 0b1111111111111111,\n  SIZE_MASK  = 0b00000000000000001111111111111111,\n  SCOPE_MASK = 0b00111111111111110000000000000000,\n  STATE_MASK = 0b11000000000000000000000000000000,\n}\n\nfunction encodeTableInfo(size: number, scopeSize: number, state: number) {\n  return size | (scopeSize << 16) | state << 30;\n}\n\nfunction changeState(info: number, newState: number) {\n  return info | newState << 30;\n}\n\nexport interface SerializedHeap {\n  buffer: ArrayBuffer;\n  table: number[];\n  handle: number;\n}\n\nexport type Placeholder = [number, () => number];\n\n/**\n * The Heap is responsible for dynamically allocating\n * memory in which we read/write the VM's instructions\n * from/to. When we malloc we pass out a VMHandle, which\n * is used as an indirect way of accessing the memory during\n * execution of the VM. Internally we track the different\n * regions of the memory in an int array known as the table.\n *\n * The table 32-bit aligned and has the following layout:\n *\n * | ... | hp (u32) |       info (u32)          |\n * | ... |  Handle  | Size | Scope Size | State |\n * | ... | 32-bits  | 16b  |    14b     |  2b   |\n *\n * With this information we effectively have the ability to\n * control when we want to free memory. That being said you\n * can not free during execution as raw address are only\n * valid during the execution. This means you cannot close\n * over them as you will have a bad memory access exception.\n */\nexport class Heap implements CompileTimeHeap {\n  private heap: Uint16Array | Array<number>;\n  private placeholders: Placeholder[] = [];\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n\n  constructor(serializedHeap?: SerializedHeap) {\n    if (serializedHeap) {\n      let { buffer, table, handle } = serializedHeap;\n      this.heap = new Uint16Array(buffer);\n      this.table = table;\n      this.offset = this.heap.length;\n      this.handle = handle;\n    } else {\n      this.heap = new Uint16Array(0x100000);\n      this.table = [];\n    }\n  }\n\n  push(item: number): void {\n    this.heap[this.offset++] = item;\n  }\n\n  getbyaddr(address: number): number {\n    return this.heap[address];\n  }\n\n  setbyaddr(address: number, value: number) {\n    this.heap[address] = value;\n  }\n\n  malloc(): number {\n    this.table.push(this.offset, 0);\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  finishMalloc(handle: number, scopeSize: number): void {\n    let start = this.table[handle];\n    let finish = this.offset;\n    let instructionSize = finish - start;\n    let info = encodeTableInfo(instructionSize, scopeSize, TableSlotState.Allocated);\n    this.table[handle + Size.INFO_OFFSET] = info;\n  }\n\n  size(): number {\n    return this.offset;\n  }\n\n  // It is illegal to close over this address, as compaction\n  // may move it. However, it is legal to use this address\n  // multiple times between compactions.\n  getaddr(handle: number): number {\n    return this.table[handle];\n  }\n\n  gethandle(address: number): number {\n    this.table.push(address, encodeTableInfo(0, 0, TableSlotState.Pointer));\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  sizeof(handle: number): number {\n    if (DEBUG) {\n      let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n      return info & Size.SIZE_MASK;\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: number): number {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    return (info & Size.SCOPE_MASK) >> 16;\n  }\n\n  free(handle: VMHandle): void {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET] = changeState(info, TableSlotState.Freed);\n  }\n\n  /**\n   * The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift\n   * reachable memory to the bottom of the heap and freeable\n   * memory to the top of the heap. When we have shifted all\n   * the reachable memory to the top of the heap, we move the\n   * offset to the next free position.\n   */\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=Size.ENTRY_SIZE) {\n      let offset = table[i];\n      let info = table[i + Size.INFO_OFFSET];\n      let size = info & Size.SIZE_MASK;\n      let state = info & Size.STATE_MASK >> 30;\n\n      if (state === TableSlotState.Purged) {\n        continue;\n      } else if (state === TableSlotState.Freed) {\n        // transition to \"already freed\" aka \"purged\"\n        // a good improvement would be to reuse\n        // these slots\n        table[i + Size.INFO_OFFSET] = changeState(info, TableSlotState.Purged);\n        compactedSize += size;\n      } else if (state === TableSlotState.Allocated) {\n        for (let j=offset; j<=i+size; j++) {\n          heap[j - compactedSize] = heap[j];\n        }\n\n        table[i] = offset - compactedSize;\n      } else if (state === TableSlotState.Pointer) {\n        table[i] = offset - compactedSize;\n      }\n    }\n\n    this.offset = this.offset - compactedSize;\n  }\n\n  pushPlaceholder(valueFunc: () => number): void {\n    let address = this.offset++;\n    this.heap[address] = Size.MAX_SIZE;\n    this.placeholders.push([address, valueFunc]);\n  }\n\n  private patchPlaceholders() {\n    let { placeholders } = this;\n\n    for (let i = 0; i < placeholders.length; i++) {\n      let [address, getValue] = placeholders[i];\n\n      assert(this.getbyaddr(address) === Size.MAX_SIZE, `expected to find a placeholder value at ${address}`);\n      this.setbyaddr(address, getValue());\n    }\n  }\n\n  capture(): SerializedHeap {\n    this.patchPlaceholders();\n\n    // Only called in eager mode\n    let buffer = slice(this.heap, 0, this.offset);\n    return {\n      handle: this.handle,\n      table: this.table,\n      buffer: buffer as ArrayBuffer\n    };\n  }\n}\n\nexport class WriteOnlyProgram implements CompileTimeProgram {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: WriteOnlyConstants = new WriteOnlyConstants(), public heap = new Heap()) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class RuntimeProgram<Locator> {\n  [key: number]: never;\n\n  static hydrate<Locator>(rawHeap: SerializedHeap, pool: ConstantPool, resolver: RuntimeResolver<Locator>) {\n    let heap = new Heap(rawHeap);\n    let constants = new RuntimeConstants(resolver, pool);\n\n    return new RuntimeProgram(constants, heap);\n  }\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Locator>, public heap: Heap) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class Program<Locator> extends WriteOnlyProgram {\n  public constants: Constants<Locator>;\n}\n\nfunction slice(arr: Uint16Array | number[], start: number, end: number) {\n  if (arr instanceof Uint16Array) {\n    if (arr.slice !== undefined) {\n      return arr.slice(start, end).buffer;\n    }\n\n    let ret = new Uint16Array(end);\n\n    for (; start < end; start++) {\n      ret[start]  = arr[start];\n    }\n\n    return ret.buffer;\n  }\n\n  return null;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"program.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/program.ts"],"names":[],"mappings":";AAGA,AAAO,SAAa,AAAkB,oBAAE,AAAgB,AAAgB,wBAAM,AAAa,AAAC;AAC5F,AAAO,SAAE,AAAM,AAAE,cAAM,AAAU,AAAC;AAClC,AAAO,SAAE,AAAM,AAAE,cAAM,AAAe,AAAC;AAkBvC,yBAAyB,AAAY,MAAE,AAAiB,WAAE,AAAa;AACrE,AAAM,WAAC,AAAI,AAAG,OAAC,AAAS,aAAI,AAAE,AAAC,KAAG,AAAK,SAAI,AAAE,AAAC,AAChD;AAAC;AAED,qBAAqB,AAAY,MAAE,AAAgB;AACjD,AAAM,WAAC,AAAI,OAAG,AAAQ,YAAI,AAAE,AAAC,AAC/B;AAAC;AAUD,MAAM,AAAS,YAAG,AAAQ,AAAC;AAE3B,AAmBG;;;;;;;;;;;;;;;;;;;;AACH,AAAM;AAQJ,gBAAY,AAA+B;AANnC,aAAY,eAAkB,AAAE,AAAC;AAEjC,aAAM,SAAG,AAAC,AAAC;AACX,aAAM,SAAG,AAAC,AAAC;AACX,aAAQ,WAAG,AAAS,AAAC;AAG3B,AAAE,AAAC,YAAC,AAAc,AAAC,gBAAC,AAAC;AACnB,gBAAI,EAAE,AAAM,QAAE,AAAK,OAAE,AAAM,AAAE,WAAG,AAAc,AAAC;AAC/C,AAAI,iBAAC,AAAI,OAAG,IAAI,AAAW,YAAC,AAAM,AAAC,AAAC;AACpC,AAAI,iBAAC,AAAK,QAAG,AAAK,AAAC;AACnB,AAAI,iBAAC,AAAM,SAAG,AAAI,KAAC,AAAI,KAAC,AAAM,AAAC;AAC/B,AAAI,iBAAC,AAAM,SAAG,AAAM,AAAC;AACrB,AAAI,iBAAC,AAAQ,WAAG,AAAC,AAAC,AACpB;AAAC,AAAC,AAAI,eAAC,AAAC;AACN,AAAI,iBAAC,AAAI,OAAG,IAAI,AAAW,YAAC,AAAS,AAAC,AAAC;AACvC,AAAI,iBAAC,AAAK,QAAG,AAAE,AAAC,AAClB;AAAC,AACH;AAAC;AAED,AAAI,SAAC,AAAY;AACf,AAAI,aAAC,AAAS,AAAE,AAAC;AACjB,AAAI,aAAC,AAAI,KAAC,AAAI,KAAC,AAAM,AAAE,AAAC,YAAG,AAAI,AAAC,AAClC;AAAC;AAEO,AAAS;AACf,AAAE,AAAC,YAAC,AAAI,KAAC,AAAQ,aAAK,AAAC,AAAC,GAAC,AAAC;AACxB,gBAAI,AAAI,OAAG,AAAK,MAAC,AAAI,KAAC,AAAI,MAAE,AAAC,GAAE,AAAI,KAAC,AAAM,AAAC,AAAC;AAC5C,AAAI,iBAAC,AAAI,OAAG,IAAI,AAAW,YAAC,AAAI,KAAC,AAAM,SAAG,AAAS,AAAC,AAAC;AACrD,AAAI,iBAAC,AAAI,KAAC,AAAG,IAAC,AAAI,MAAE,AAAC,AAAC,AAAC;AACvB,AAAI,iBAAC,AAAQ,WAAG,AAAS,AAAC,AAC5B;AAAC;AACD,AAAI,aAAC,AAAQ,AAAE,AAAC,AAClB;AAAC;AAED,AAAS,cAAC,AAAe;AACvB,AAAM,eAAC,AAAI,KAAC,AAAI,KAAC,AAAO,AAAC,AAAC,AAC5B;AAAC;AAED,AAAS,cAAC,AAAe,SAAE,AAAa;AACtC,AAAI,aAAC,AAAI,KAAC,AAAO,AAAC,WAAG,AAAK,AAAC,AAC7B;AAAC;AAED,AAAM;AACJ,AAAI,aAAC,AAAK,MAAC,AAAI,KAAC,AAAI,KAAC,AAAM,QAAE,AAAC,AAAC,AAAC;AAChC,YAAI,AAAM,SAAG,AAAI,KAAC,AAAM,AAAC;AACzB,AAAI,aAAC,AAAM,YAAmB,AAAC;AAC/B,AAAM,eAAC,AAAM,AAAC,AAChB;AAAC;AAED,AAAY,iBAAC,AAAc,QAAE,AAAiB;AAC5C,YAAI,AAAK,QAAG,AAAI,KAAC,AAAK,MAAC,AAAM,AAAC,AAAC;AAC/B,YAAI,AAAM,SAAG,AAAI,KAAC,AAAM,AAAC;AACzB,YAAI,AAAe,kBAAG,AAAM,SAAG,AAAK,AAAC;AACrC,YAAI,AAAI,OAAG,AAAe,gBAAC,AAAe,iBAAE,AAAS,aAA2B,AAAC;AACjF,AAAI,aAAC,AAAK,MAAC,AAAM,WAAmB,AAAC,qBAAG,AAAI,AAAC,AAC/C;AAAC;AAED,AAAI;AACF,AAAM,eAAC,AAAI,KAAC,AAAM,AAAC,AACrB;AAAC;AAED,AAA0D;AAC1D,AAAwD;AACxD,AAAsC;AACtC,AAAO,YAAC,AAAc;AACpB,AAAM,eAAC,AAAI,KAAC,AAAK,MAAC,AAAM,AAAC,AAAC,AAC5B;AAAC;AAED,AAAS,cAAC,AAAe;AACvB,AAAI,aAAC,AAAK,MAAC,AAAI,KAAC,AAAO,SAAE,AAAe,gBAAC,AAAC,GAAE,AAAC,KAAyB,AAAC,AAAC;AACxE,YAAI,AAAM,SAAG,AAAI,KAAC,AAAM,AAAC;AACzB,AAAI,aAAC,AAAM,YAAmB,AAAC;AAC/B,AAAM,eAAC,AAAM,AAAC,AAChB;AAAC;AAED,AAAM,WAAC,AAAc;AACnB,AAAE,AAAC,AAAC,AAAK,AAAC,mBAAC,AAAC;AACV,gBAAI,AAAI,OAAG,AAAI,KAAC,AAAK,MAAE,AAAmC,WAAmB,AAAC,AAAC;AAC/E,AAAM,mBAAC,AAAI,aAAiB,AAAC,AAC/B;AAAC;AACD,AAAM,eAAC,CAAC,AAAC,AAAC,AACZ;AAAC;AAED,AAAW,gBAAC,AAAc;AACxB,YAAI,AAAI,OAAG,AAAI,KAAC,AAAK,MAAE,AAAmC,WAAmB,AAAC,AAAC;AAC/E,AAAM,eAAC,CAAC,AAAI,kBAAkB,AAAC,qBAAI,AAAE,AAAC,AACxC;AAAC;AAED,AAAI,SAAC,AAAgB;AACnB,YAAI,AAAI,OAAG,AAAI,KAAC,AAAK,MAAE,AAAmC,WAAmB,AAAC,AAAC;AAC/E,AAAI,aAAC,AAAK,MAAE,AAAmC,WAAmB,AAAC,qBAAG,AAAW,YAAC,AAAI,QAAuB,AAAC,AAChH;AAAC;AAED,AAMG;;;;;;;AACH,AAAO;AACL,YAAI,AAAa,gBAAG,AAAC,AAAC;AACtB,YAAI,EAAE,AAAK,OAAE,AAAK,OAAE,EAAE,AAAM,AAAE,UAAE,AAAI,AAAE,SAAG,AAAI,AAAC;AAE9C,AAAG,AAAC,aAAC,IAAI,AAAC,IAAC,AAAC,GAAE,AAAC,IAAC,AAAM,QAAE,AAAC,OAAiB,kBAAE,AAAC;AAC3C,gBAAI,AAAM,SAAG,AAAK,MAAC,AAAC,AAAC,AAAC;AACtB,gBAAI,AAAI,OAAG,AAAK,MAAC,AAAC,MAAmB,AAAC,AAAC;AACvC,gBAAI,AAAI,OAAG,AAAI,aAAiB,AAAC;AACjC,gBAAI,AAAK,QAAG,AAAI,OAAG,+BAAmB,AAAE,AAAC;AAEzC,AAAE,AAAC,gBAAC,AAAK,YAA0B,AAAC,cAAC,AAAC;AACpC,AAAQ,AAAC,AACX;AAAC,AAAC,AAAI,2BAAK,AAAK,YAAyB,AAAC,aAAC,AAAC;AAC1C,AAA6C;AAC7C,AAAuC;AACvC,AAAc;AACd,AAAK,0BAAC,AAAC,MAAmB,AAAC,qBAAG,AAAW,YAAC,AAAI,QAAwB,AAAC;AACvE,AAAa,qCAAI,AAAI,AAAC,AACxB;AAAC,AAAC,AAAI,iBANC,AAAE,AAAC,UAMC,AAAK,YAA6B,AAAC,iBAAC,AAAC;AAC9C,AAAG,AAAC,yBAAC,IAAI,AAAC,IAAC,AAAM,QAAE,AAAC,KAAE,AAAC,IAAC,AAAI,MAAE,AAAC,AAAE,KAAE,AAAC;AAClC,AAAI,6BAAC,AAAC,IAAG,AAAa,AAAC,iBAAG,AAAI,KAAC,AAAC,AAAC,AAAC,AACpC;AAAC;AAED,AAAK,0BAAC,AAAC,AAAC,KAAG,AAAM,SAAG,AAAa,AAAC,AACpC;AAAC,AAAC,AAAI,iBANC,AAAE,AAAC,MAMH,AAAE,AAAC,IAAC,AAAK,YAA2B,AAAC,eAAC,AAAC;AAC5C,AAAK,0BAAC,AAAC,AAAC,KAAG,AAAM,SAAG,AAAa,AAAC,AACpC;AAAC,AACH;AAAC;AAED,AAAI,aAAC,AAAM,SAAG,AAAI,KAAC,AAAM,SAAG,AAAa,AAAC,AAC5C;AAAC;AAED,AAAe,oBAAC,AAAuB;AACrC,AAAI,aAAC,AAAS,AAAE,AAAC;AACjB,YAAI,AAAO,UAAG,AAAI,KAAC,AAAM,AAAE,AAAC;AAC5B,AAAI,aAAC,AAAI,KAAC,AAAO,AAAC,iBAAgB,AAAC;AACnC,AAAI,aAAC,AAAY,aAAC,AAAI,KAAC,CAAC,AAAO,SAAE,AAAS,AAAC,AAAC,AAAC,AAC/C;AAAC;AAEO,AAAiB;AACvB,YAAI,EAAE,AAAY,AAAE,iBAAG,AAAI,AAAC;AAE5B,AAAG,AAAC,aAAC,IAAI,AAAC,IAAG,AAAC,GAAE,AAAC,IAAG,AAAY,aAAC,AAAM,QAAE,AAAC,AAAE;AAC1C,gBAAI,CAAC,AAAO,SAAE,AAAQ,AAAC,YAAG,AAAY,aAAC,AAAC,AAAC,AAAC;AADE,AAAC,sBAG7C,AAAM,OAAC,AAAI,KAAC,AAAS,UAAC,AAAO,AAAC,mBAAkB,AAAE,2DAA2C,AAAO,OAAE,AAAC,AAAC;;AACxG,AAAI,iBAAC,AAAS,UAAC,AAAO,SAAE,AAAQ,AAAE,AAAC,AAAC,AACtC;AAAC,AACH;AAAC;AAED,AAAO,YAAC,AAAM,SAAG,AAAI,KAAC,AAAM;AAC1B,AAAI,aAAC,AAAiB,AAAE,AAAC;AAEzB,AAA4B;AAC5B,YAAI,AAAM,SAAG,AAAK,MAAC,AAAI,KAAC,AAAI,MAAE,AAAC,GAAE,AAAM,AAAC,QAAC,AAAM,AAAC;AAChD,AAAM;AACJ,AAAM,oBAAE,AAAI,KAAC,AAAM;AACnB,AAAK,mBAAE,AAAI,KAAC,AAAK;AACjB,AAAM,oBAAE,AAAqB,AAC9B,AAAC,AACJ;AALS;AAKR,AACF;;AAED,AAAM;AAKJ,gBAAmB,YAAgC,IAAI,AAAkB,AAAE,sBAAS,OAAO,IAAI,AAAI,AAAE;AAAlF,aAAS,YAAT,AAAS,AAA+C;AAAS,aAAI,OAAJ,AAAI,AAAa;AACnG,AAAI,aAAC,AAAO,UAAG,IAAI,AAAM,OAAC,AAAI,KAAC,AAAI,AAAC,AAAC,AACvC;AAAC;AAED,AAAM,WAAC,AAAc;AACnB,AAAI,aAAC,AAAO,QAAC,AAAM,SAAG,AAAM,AAAC;AAC7B,AAAM,eAAC,AAAI,KAAC,AAAO,AAAC,AACtB;AAAC,AACF;;AAED,AAAM;AAYJ,gBAAmB,AAAyC,WAAS,AAAU;AAA5D,aAAS,YAAT,AAAS,AAAgC;AAAS,aAAI,OAAJ,AAAI,AAAM;AAC7E,AAAI,aAAC,AAAO,UAAG,IAAI,AAAM,OAAC,AAAI,KAAC,AAAI,AAAC,AAAC,AACvC;AAAC;AAXD,AAAM,WAAC,AAAO,QAAe,AAAuB,SAAE,AAAkB,MAAE,AAAuC;AAC/G,YAAI,AAAI,OAAG,IAAI,AAAI,KAAC,AAAO,AAAC,AAAC;AAC7B,YAAI,AAAS,YAAG,IAAI,AAAgB,iBAAC,AAAQ,UAAE,AAAI,AAAC,AAAC;AAErD,AAAM,eAAC,IAAI,AAAc,eAAC,AAAS,WAAE,AAAI,AAAC,AAAC,AAC7C;AAAC;AAQD,AAAM,WAAC,AAAc;AACnB,AAAI,aAAC,AAAO,QAAC,AAAM,SAAG,AAAM,AAAC;AAC7B,AAAM,eAAC,AAAI,KAAC,AAAO,AAAC,AACtB;AAAC,AACF;;AAED,AAAM,aAA6B,gBAAQ,AAAgB,iBAE1D;AAED,eAAe,AAAgB,KAAE,AAAa,OAAE,AAAW;AACzD,AAAE,AAAC,QAAC,AAAG,IAAC,AAAK,UAAK,AAAS,AAAC,WAAC,AAAC;AAC5B,AAAM,eAAC,AAAG,IAAC,AAAK,MAAC,AAAK,OAAE,AAAG,AAAC,AAAC,AAC/B;AAAC;AAED,QAAI,AAAG,MAAG,IAAI,AAAW,YAAC,AAAG,AAAC,AAAC;AAE/B,AAAG,AAAC,AAAC,WAAE,AAAK,QAAG,AAAG,KAAE,AAAK,AAAE,SAAE,AAAC;AAC5B,AAAG,YAAC,AAAK,AAAC,SAAI,AAAG,IAAC,AAAK,AAAC,AAAC,AAC3B;AAAC;AAED,AAAM,WAAC,AAAG,AAAC,AACb;AAAC","sourcesContent":["\nimport { CompileTimeProgram, Recast, VMHandle, RuntimeResolver, CompileTimeHeap } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants, ConstantPool } from './constants';\nimport { Opcode } from './opcode';\nimport { assert } from \"@glimmer/util\";\n\nconst enum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst enum Size {\n  ENTRY_SIZE = 2,\n  INFO_OFFSET = 1,\n  MAX_SIZE   = 0b1111111111111111,\n  SIZE_MASK  = 0b00000000000000001111111111111111,\n  SCOPE_MASK = 0b00111111111111110000000000000000,\n  STATE_MASK = 0b11000000000000000000000000000000,\n}\n\nfunction encodeTableInfo(size: number, scopeSize: number, state: number) {\n  return size | (scopeSize << 16) | state << 30;\n}\n\nfunction changeState(info: number, newState: number) {\n  return info | newState << 30;\n}\n\nexport interface SerializedHeap {\n  buffer: ArrayBuffer;\n  table: number[];\n  handle: number;\n}\n\nexport type Placeholder = [number, () => number];\n\nconst PAGE_SIZE = 0x100000;\n\n/**\n * The Heap is responsible for dynamically allocating\n * memory in which we read/write the VM's instructions\n * from/to. When we malloc we pass out a VMHandle, which\n * is used as an indirect way of accessing the memory during\n * execution of the VM. Internally we track the different\n * regions of the memory in an int array known as the table.\n *\n * The table 32-bit aligned and has the following layout:\n *\n * | ... | hp (u32) |       info (u32)          |\n * | ... |  Handle  | Size | Scope Size | State |\n * | ... | 32-bits  | 16b  |    14b     |  2b   |\n *\n * With this information we effectively have the ability to\n * control when we want to free memory. That being said you\n * can not free during execution as raw address are only\n * valid during the execution. This means you cannot close\n * over them as you will have a bad memory access exception.\n */\nexport class Heap implements CompileTimeHeap {\n  private heap: Uint16Array;\n  private placeholders: Placeholder[] = [];\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n  private capacity = PAGE_SIZE;\n\n  constructor(serializedHeap?: SerializedHeap) {\n    if (serializedHeap) {\n      let { buffer, table, handle } = serializedHeap;\n      this.heap = new Uint16Array(buffer);\n      this.table = table;\n      this.offset = this.heap.length;\n      this.handle = handle;\n      this.capacity = 0;\n    } else {\n      this.heap = new Uint16Array(PAGE_SIZE);\n      this.table = [];\n    }\n  }\n\n  push(item: number): void {\n    this.sizeCheck();\n    this.heap[this.offset++] = item;\n  }\n\n  private sizeCheck() {\n    if (this.capacity === 0) {\n      let heap = slice(this.heap, 0, this.offset);\n      this.heap = new Uint16Array(heap.length + PAGE_SIZE);\n      this.heap.set(heap, 0);\n      this.capacity = PAGE_SIZE;\n    }\n    this.capacity--;\n  }\n\n  getbyaddr(address: number): number {\n    return this.heap[address];\n  }\n\n  setbyaddr(address: number, value: number) {\n    this.heap[address] = value;\n  }\n\n  malloc(): number {\n    this.table.push(this.offset, 0);\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  finishMalloc(handle: number, scopeSize: number): void {\n    let start = this.table[handle];\n    let finish = this.offset;\n    let instructionSize = finish - start;\n    let info = encodeTableInfo(instructionSize, scopeSize, TableSlotState.Allocated);\n    this.table[handle + Size.INFO_OFFSET] = info;\n  }\n\n  size(): number {\n    return this.offset;\n  }\n\n  // It is illegal to close over this address, as compaction\n  // may move it. However, it is legal to use this address\n  // multiple times between compactions.\n  getaddr(handle: number): number {\n    return this.table[handle];\n  }\n\n  gethandle(address: number): number {\n    this.table.push(address, encodeTableInfo(0, 0, TableSlotState.Pointer));\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  sizeof(handle: number): number {\n    if (DEBUG) {\n      let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n      return info & Size.SIZE_MASK;\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: number): number {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    return (info & Size.SCOPE_MASK) >> 16;\n  }\n\n  free(handle: VMHandle): void {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET] = changeState(info, TableSlotState.Freed);\n  }\n\n  /**\n   * The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift\n   * reachable memory to the bottom of the heap and freeable\n   * memory to the top of the heap. When we have shifted all\n   * the reachable memory to the top of the heap, we move the\n   * offset to the next free position.\n   */\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=Size.ENTRY_SIZE) {\n      let offset = table[i];\n      let info = table[i + Size.INFO_OFFSET];\n      let size = info & Size.SIZE_MASK;\n      let state = info & Size.STATE_MASK >> 30;\n\n      if (state === TableSlotState.Purged) {\n        continue;\n      } else if (state === TableSlotState.Freed) {\n        // transition to \"already freed\" aka \"purged\"\n        // a good improvement would be to reuse\n        // these slots\n        table[i + Size.INFO_OFFSET] = changeState(info, TableSlotState.Purged);\n        compactedSize += size;\n      } else if (state === TableSlotState.Allocated) {\n        for (let j=offset; j<=i+size; j++) {\n          heap[j - compactedSize] = heap[j];\n        }\n\n        table[i] = offset - compactedSize;\n      } else if (state === TableSlotState.Pointer) {\n        table[i] = offset - compactedSize;\n      }\n    }\n\n    this.offset = this.offset - compactedSize;\n  }\n\n  pushPlaceholder(valueFunc: () => number): void {\n    this.sizeCheck();\n    let address = this.offset++;\n    this.heap[address] = Size.MAX_SIZE;\n    this.placeholders.push([address, valueFunc]);\n  }\n\n  private patchPlaceholders() {\n    let { placeholders } = this;\n\n    for (let i = 0; i < placeholders.length; i++) {\n      let [address, getValue] = placeholders[i];\n\n      assert(this.getbyaddr(address) === Size.MAX_SIZE, `expected to find a placeholder value at ${address}`);\n      this.setbyaddr(address, getValue());\n    }\n  }\n\n  capture(offset = this.offset): SerializedHeap {\n    this.patchPlaceholders();\n\n    // Only called in eager mode\n    let buffer = slice(this.heap, 0, offset).buffer;\n    return {\n      handle: this.handle,\n      table: this.table,\n      buffer: buffer as ArrayBuffer\n    };\n  }\n}\n\nexport class WriteOnlyProgram implements CompileTimeProgram {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: WriteOnlyConstants = new WriteOnlyConstants(), public heap = new Heap()) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class RuntimeProgram<TemplateMeta> {\n  [key: number]: never;\n\n  static hydrate<TemplateMeta>(rawHeap: SerializedHeap, pool: ConstantPool, resolver: RuntimeResolver<TemplateMeta>) {\n    let heap = new Heap(rawHeap);\n    let constants = new RuntimeConstants(resolver, pool);\n\n    return new RuntimeProgram(constants, heap);\n  }\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<TemplateMeta>, public heap: Heap) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class Program<TemplateMeta> extends WriteOnlyProgram {\n  public constants: Constants<TemplateMeta>;\n}\n\nfunction slice(arr: Uint16Array, start: number, end: number): Uint16Array {\n  if (arr.slice !== undefined) {\n    return arr.slice(start, end);\n  }\n\n  let ret = new Uint16Array(end);\n\n  for (; start < end; start++) {\n    ret[start]  = arr[start];\n  }\n\n  return ret;\n}\n"]} |
@@ -10,3 +10,3 @@ function _defaults(obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; } | ||
var UNRESOLVED = {}; | ||
export var WELL_KNOWN_EMPTY_ARRAY_POSITION = 0; | ||
var WELL_KNOWN_EMPTY_ARRAY_POSITION = 0; | ||
var WELL_KNOW_EMPTY_ARRAY = Object.freeze([]); | ||
@@ -241,2 +241,2 @@ | ||
export { LazyConstants }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/constants.ts"],"names":[],"mappings":"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","sourcesContent":["import { Opaque, SymbolTable, RuntimeResolver, CompileTimeConstants } from \"@glimmer/interfaces\";\n\nconst UNRESOLVED = {};\n\nexport const WELL_KNOWN_EMPTY_ARRAY_POSITION = 0;\nconst WELL_KNOW_EMPTY_ARRAY = Object.freeze([]);\nexport type EMPTY_ARRAY = Array<ReadonlyArray<never>>;\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][] | EMPTY_ARRAY;\n  handles: number[];\n  numbers: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b000,\n  FLOAT           = 0b001,\n  STRING          = 0b010,\n  BOOLEAN_OR_VOID = 0b011,\n  NEGATIVE        = 0b100,\n  BIG_NUM         = 0b101\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] | EMPTY_ARRAY = [WELL_KNOW_EMPTY_ARRAY];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected resolved: Opaque[] = [];\n  protected numbers: number[] = [];\n\n  string(value: string): number {\n    let index = this.strings.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(value) - 1;\n  }\n\n  stringArray(strings: string[]): number {\n    let _strings: number[] = new Array(strings.length);\n\n    for (let i = 0; i < strings.length; i++) {\n      _strings[i] = this.string(strings[i]);\n    }\n\n    return this.array(_strings);\n  }\n\n  array(values: number[]): number {\n    if (values.length === 0) {\n      return WELL_KNOWN_EMPTY_ARRAY_POSITION;\n    }\n\n    let index = (this.arrays as number[][]).indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return (this.arrays as number[][]).push(values) - 1;\n  }\n\n  handle(handle: number): number {\n    let index = this.handles.indexOf(handle);\n    if (index > -1) {\n      return index;\n    }\n\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle) - 1;\n  }\n\n  serializable(value: Opaque): number {\n    let str = JSON.stringify(value);\n    let index = this.strings.indexOf(str);\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(str) - 1;\n  }\n\n  number(number: number): number {\n    let index = this.numbers.indexOf(number);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.numbers.push(number) - 1;\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      handles: this.handles,\n      numbers: this.numbers\n    };\n  }\n}\n\nexport class RuntimeConstants<Locator> {\n  protected strings: string[];\n  protected arrays: number[][] | EMPTY_ARRAY;\n  protected handles: number[];\n  protected resolved: Opaque[];\n  protected numbers: number[];\n\n  constructor(public resolver: RuntimeResolver<Locator>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.handles = pool.handles;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n    this.numbers = pool.numbers;\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class Constants<Locator> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Locator>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.handles = pool.handles;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n      this.numbers = pool.numbers;\n    }\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\n  protected serializables: Opaque[] = [];\n\n  serializable(value: Opaque): number {\n    let index = this.serializables.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.serializables.push(value) - 1;\n  }\n\n  getSerializable<T>(s: number): T {\n    return this.serializables[s] as T;\n  }\n\n  getOther<T>(value: number): T {\n    return this.others[value - 1] as T;\n  }\n\n  other(other: Opaque): number {\n    return this.others.push(other);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/constants.ts"],"names":[],"mappings":"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","sourcesContent":["import { Opaque, SymbolTable, RuntimeResolver, CompileTimeConstants } from \"@glimmer/interfaces\";\n\nconst UNRESOLVED = {};\n\nconst WELL_KNOWN_EMPTY_ARRAY_POSITION = 0;\nconst WELL_KNOW_EMPTY_ARRAY = Object.freeze([]);\nexport type EMPTY_ARRAY = Array<ReadonlyArray<never>>;\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][] | EMPTY_ARRAY;\n  handles: number[];\n  numbers: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b000,\n  FLOAT           = 0b001,\n  STRING          = 0b010,\n  BOOLEAN_OR_VOID = 0b011,\n  NEGATIVE        = 0b100,\n  BIG_NUM         = 0b101\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] | EMPTY_ARRAY = [WELL_KNOW_EMPTY_ARRAY];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected resolved: Opaque[] = [];\n  protected numbers: number[] = [];\n\n  string(value: string): number {\n    let index = this.strings.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(value) - 1;\n  }\n\n  stringArray(strings: string[]): number {\n    let _strings: number[] = new Array(strings.length);\n\n    for (let i = 0; i < strings.length; i++) {\n      _strings[i] = this.string(strings[i]);\n    }\n\n    return this.array(_strings);\n  }\n\n  array(values: number[]): number {\n    if (values.length === 0) {\n      return WELL_KNOWN_EMPTY_ARRAY_POSITION;\n    }\n\n    let index = (this.arrays as number[][]).indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return (this.arrays as number[][]).push(values) - 1;\n  }\n\n  handle(handle: number): number {\n    let index = this.handles.indexOf(handle);\n    if (index > -1) {\n      return index;\n    }\n\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle) - 1;\n  }\n\n  serializable(value: Opaque): number {\n    let str = JSON.stringify(value);\n    let index = this.strings.indexOf(str);\n    if (index > -1) {\n      return index;\n    }\n\n    return this.strings.push(str) - 1;\n  }\n\n  number(number: number): number {\n    let index = this.numbers.indexOf(number);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.numbers.push(number) - 1;\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      handles: this.handles,\n      numbers: this.numbers\n    };\n  }\n}\n\nexport class RuntimeConstants<TemplateMeta> {\n  protected strings: string[];\n  protected arrays: number[][] | EMPTY_ARRAY;\n  protected handles: number[];\n  protected resolved: Opaque[];\n  protected numbers: number[];\n\n  constructor(public resolver: RuntimeResolver<TemplateMeta>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.handles = pool.handles;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n    this.numbers = pool.numbers;\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class Constants<TemplateMeta> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<TemplateMeta>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.handles = pool.handles;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n      this.numbers = pool.numbers;\n    }\n  }\n\n  getNumber(value: number): number {\n    return this.numbers[value];\n  }\n\n  getString(value: number): string {\n    return this.strings[value];\n  }\n\n  getStringArray(value: number): string[] {\n    let names = this.getArray(value);\n    let _names: string[] = new Array(names.length);\n\n    for (let i = 0; i < names.length; i++) {\n      let n = names[i];\n      _names[i] = this.getString(n);\n    }\n\n    return _names;\n  }\n\n  getArray(value: number): number[] {\n    return (this.arrays as number[][])[value];\n  }\n\n  resolveHandle<T>(index: number): T {\n    let resolved = this.resolved[index];\n\n    if (resolved === UNRESOLVED) {\n      let handle = this.handles[index];\n      resolved = this.resolved[index] = this.resolver.resolve(handle);\n    }\n\n    return resolved as T;\n  }\n\n  getSerializable<T>(s: number): T {\n    return JSON.parse(this.strings[s]) as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\n  protected serializables: Opaque[] = [];\n\n  serializable(value: Opaque): number {\n    let index = this.serializables.indexOf(value);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.serializables.push(value) - 1;\n  }\n\n  getSerializable<T>(s: number): T {\n    return this.serializables[s] as T;\n  }\n\n  getOther<T>(value: number): T {\n    return this.others[value - 1] as T;\n  }\n\n  other(other: Opaque): number {\n    return this.others.push(other);\n  }\n}\n"]} |
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJuYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci9wcm9ncmFtL2xpYi9pbnRlcm5hbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVW5pcXVlLCBSdW50aW1lUmVzb2x2ZXIgYXMgSVJlc29sdmVyIH0gZnJvbSAnQGdsaW1tZXIvaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCB0eXBlIExvY2F0b3IgPSBVbmlxdWU8J0xvY2F0b3InPjtcbmV4cG9ydCB0eXBlIFJlZmVycmVyID0gVW5pcXVlPCdSZWZlcnJlcic+O1xuZXhwb3J0IHR5cGUgUmVzb2x2ZXIgPSBJUmVzb2x2ZXI8TG9jYXRvcj47XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJuYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci9wcm9ncmFtL2xpYi9pbnRlcm5hbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVW5pcXVlLCBSdW50aW1lUmVzb2x2ZXIgYXMgSVJlc29sdmVyIH0gZnJvbSAnQGdsaW1tZXIvaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCB0eXBlIFRlbXBsYXRlTWV0YSA9IFVuaXF1ZTwnVGVtcGxhdGVNZXRhJz47XG5leHBvcnQgdHlwZSBSZWZlcnJlciA9IFVuaXF1ZTwnUmVmZXJyZXInPjtcbmV4cG9ydCB0eXBlIFJlc29sdmVyID0gSVJlc29sdmVyPFRlbXBsYXRlTWV0YT47XG4iXX0= |
@@ -18,2 +18,3 @@ function _defaults(obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; } | ||
} | ||
var PAGE_SIZE = 0x100000; | ||
/** | ||
@@ -46,2 +47,3 @@ * The Heap is responsible for dynamically allocating | ||
this.handle = 0; | ||
this.capacity = PAGE_SIZE; | ||
if (serializedHeap) { | ||
@@ -56,4 +58,5 @@ var buffer = serializedHeap.buffer, | ||
this.handle = handle; | ||
this.capacity = 0; | ||
} else { | ||
this.heap = new Uint16Array(0x100000); | ||
this.heap = new Uint16Array(PAGE_SIZE); | ||
this.table = []; | ||
@@ -64,5 +67,16 @@ } | ||
Heap.prototype.push = function push(item) { | ||
this.sizeCheck(); | ||
this.heap[this.offset++] = item; | ||
}; | ||
Heap.prototype.sizeCheck = function sizeCheck() { | ||
if (this.capacity === 0) { | ||
var heap = slice(this.heap, 0, this.offset); | ||
this.heap = new Uint16Array(heap.length + PAGE_SIZE); | ||
this.heap.set(heap, 0); | ||
this.capacity = PAGE_SIZE; | ||
} | ||
this.capacity--; | ||
}; | ||
Heap.prototype.getbyaddr = function getbyaddr(address) { | ||
@@ -168,2 +182,3 @@ return this.heap[address]; | ||
Heap.prototype.pushPlaceholder = function pushPlaceholder(valueFunc) { | ||
this.sizeCheck(); | ||
var address = this.offset++; | ||
@@ -189,5 +204,7 @@ this.heap[address] = 65535 /* MAX_SIZE */; | ||
Heap.prototype.capture = function capture() { | ||
var offset = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.offset; | ||
this.patchPlaceholders(); | ||
// Only called in eager mode | ||
var buffer = slice(this.heap, 0, this.offset); | ||
var buffer = slice(this.heap, 0, offset).buffer; | ||
return { | ||
@@ -255,14 +272,11 @@ handle: this.handle, | ||
function slice(arr, start, end) { | ||
if (arr instanceof Uint16Array) { | ||
if (arr.slice !== undefined) { | ||
return arr.slice(start, end).buffer; | ||
} | ||
var ret = new Uint16Array(end); | ||
for (; start < end; start++) { | ||
ret[start] = arr[start]; | ||
} | ||
return ret.buffer; | ||
if (arr.slice !== undefined) { | ||
return arr.slice(start, end); | ||
} | ||
return null; | ||
var ret = new Uint16Array(end); | ||
for (; start < end; start++) { | ||
ret[start] = arr[start]; | ||
} | ||
return ret; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"program.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/program.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport { CompileTimeProgram, Recast, VMHandle, RuntimeResolver, CompileTimeHeap } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants, ConstantPool } from './constants';\nimport { Opcode } from './opcode';\nimport { assert } from \"@glimmer/util\";\n\nconst enum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst enum Size {\n  ENTRY_SIZE = 2,\n  INFO_OFFSET = 1,\n  MAX_SIZE   = 0b1111111111111111,\n  SIZE_MASK  = 0b00000000000000001111111111111111,\n  SCOPE_MASK = 0b00111111111111110000000000000000,\n  STATE_MASK = 0b11000000000000000000000000000000,\n}\n\nfunction encodeTableInfo(size: number, scopeSize: number, state: number) {\n  return size | (scopeSize << 16) | state << 30;\n}\n\nfunction changeState(info: number, newState: number) {\n  return info | newState << 30;\n}\n\nexport interface SerializedHeap {\n  buffer: ArrayBuffer;\n  table: number[];\n  handle: number;\n}\n\nexport type Placeholder = [number, () => number];\n\n/**\n * The Heap is responsible for dynamically allocating\n * memory in which we read/write the VM's instructions\n * from/to. When we malloc we pass out a VMHandle, which\n * is used as an indirect way of accessing the memory during\n * execution of the VM. Internally we track the different\n * regions of the memory in an int array known as the table.\n *\n * The table 32-bit aligned and has the following layout:\n *\n * | ... | hp (u32) |       info (u32)          |\n * | ... |  Handle  | Size | Scope Size | State |\n * | ... | 32-bits  | 16b  |    14b     |  2b   |\n *\n * With this information we effectively have the ability to\n * control when we want to free memory. That being said you\n * can not free during execution as raw address are only\n * valid during the execution. This means you cannot close\n * over them as you will have a bad memory access exception.\n */\nexport class Heap implements CompileTimeHeap {\n  private heap: Uint16Array | Array<number>;\n  private placeholders: Placeholder[] = [];\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n\n  constructor(serializedHeap?: SerializedHeap) {\n    if (serializedHeap) {\n      let { buffer, table, handle } = serializedHeap;\n      this.heap = new Uint16Array(buffer);\n      this.table = table;\n      this.offset = this.heap.length;\n      this.handle = handle;\n    } else {\n      this.heap = new Uint16Array(0x100000);\n      this.table = [];\n    }\n  }\n\n  push(item: number): void {\n    this.heap[this.offset++] = item;\n  }\n\n  getbyaddr(address: number): number {\n    return this.heap[address];\n  }\n\n  setbyaddr(address: number, value: number) {\n    this.heap[address] = value;\n  }\n\n  malloc(): number {\n    this.table.push(this.offset, 0);\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  finishMalloc(handle: number, scopeSize: number): void {\n    let start = this.table[handle];\n    let finish = this.offset;\n    let instructionSize = finish - start;\n    let info = encodeTableInfo(instructionSize, scopeSize, TableSlotState.Allocated);\n    this.table[handle + Size.INFO_OFFSET] = info;\n  }\n\n  size(): number {\n    return this.offset;\n  }\n\n  // It is illegal to close over this address, as compaction\n  // may move it. However, it is legal to use this address\n  // multiple times between compactions.\n  getaddr(handle: number): number {\n    return this.table[handle];\n  }\n\n  gethandle(address: number): number {\n    this.table.push(address, encodeTableInfo(0, 0, TableSlotState.Pointer));\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  sizeof(handle: number): number {\n    if (DEBUG) {\n      let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n      return info & Size.SIZE_MASK;\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: number): number {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    return (info & Size.SCOPE_MASK) >> 16;\n  }\n\n  free(handle: VMHandle): void {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET] = changeState(info, TableSlotState.Freed);\n  }\n\n  /**\n   * The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift\n   * reachable memory to the bottom of the heap and freeable\n   * memory to the top of the heap. When we have shifted all\n   * the reachable memory to the top of the heap, we move the\n   * offset to the next free position.\n   */\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=Size.ENTRY_SIZE) {\n      let offset = table[i];\n      let info = table[i + Size.INFO_OFFSET];\n      let size = info & Size.SIZE_MASK;\n      let state = info & Size.STATE_MASK >> 30;\n\n      if (state === TableSlotState.Purged) {\n        continue;\n      } else if (state === TableSlotState.Freed) {\n        // transition to \"already freed\" aka \"purged\"\n        // a good improvement would be to reuse\n        // these slots\n        table[i + Size.INFO_OFFSET] = changeState(info, TableSlotState.Purged);\n        compactedSize += size;\n      } else if (state === TableSlotState.Allocated) {\n        for (let j=offset; j<=i+size; j++) {\n          heap[j - compactedSize] = heap[j];\n        }\n\n        table[i] = offset - compactedSize;\n      } else if (state === TableSlotState.Pointer) {\n        table[i] = offset - compactedSize;\n      }\n    }\n\n    this.offset = this.offset - compactedSize;\n  }\n\n  pushPlaceholder(valueFunc: () => number): void {\n    let address = this.offset++;\n    this.heap[address] = Size.MAX_SIZE;\n    this.placeholders.push([address, valueFunc]);\n  }\n\n  private patchPlaceholders() {\n    let { placeholders } = this;\n\n    for (let i = 0; i < placeholders.length; i++) {\n      let [address, getValue] = placeholders[i];\n\n      assert(this.getbyaddr(address) === Size.MAX_SIZE, `expected to find a placeholder value at ${address}`);\n      this.setbyaddr(address, getValue());\n    }\n  }\n\n  capture(): SerializedHeap {\n    this.patchPlaceholders();\n\n    // Only called in eager mode\n    let buffer = slice(this.heap, 0, this.offset);\n    return {\n      handle: this.handle,\n      table: this.table,\n      buffer: buffer as ArrayBuffer\n    };\n  }\n}\n\nexport class WriteOnlyProgram implements CompileTimeProgram {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: WriteOnlyConstants = new WriteOnlyConstants(), public heap = new Heap()) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class RuntimeProgram<Locator> {\n  [key: number]: never;\n\n  static hydrate<Locator>(rawHeap: SerializedHeap, pool: ConstantPool, resolver: RuntimeResolver<Locator>) {\n    let heap = new Heap(rawHeap);\n    let constants = new RuntimeConstants(resolver, pool);\n\n    return new RuntimeProgram(constants, heap);\n  }\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Locator>, public heap: Heap) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class Program<Locator> extends WriteOnlyProgram {\n  public constants: Constants<Locator>;\n}\n\nfunction slice(arr: Uint16Array | number[], start: number, end: number) {\n  if (arr instanceof Uint16Array) {\n    if (arr.slice !== undefined) {\n      return arr.slice(start, end).buffer;\n    }\n\n    let ret = new Uint16Array(end);\n\n    for (; start < end; start++) {\n      ret[start]  = arr[start];\n    }\n\n    return ret.buffer;\n  }\n\n  return null;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"program.js","sourceRoot":"","sources":["../../../../packages/@glimmer/program/lib/program.ts"],"names":[],"mappings":";;;;;;;;AAGA,AAAO,SAAa,AAAkB,oBAAE,AAAgB,AAAgB,wBAAM,AAAa,AAAC;AAC5F,AAAO,SAAE,AAAM,AAAE,cAAM,AAAU,AAAC;AAClC,AAAO,SAAE,AAAM,AAAE,cAAM,AAAe,AAAC;AAkBvC,yBAAyB,AAAY,MAAE,AAAiB,WAAE,AAAa,OACrE,AAAM;WAAC,AAAI,AAAG,OAAC,AAAS,aAAI,AAAE,AAAC,KAAG,AAAK,SAAI,AAAE,AAAC,AAChD,AAAC;;AAED,qBAAqB,AAAY,MAAE,AAAgB,UACjD,AAAM;WAAC,AAAI,OAAG,AAAQ,YAAI,AAAE,AAAC,AAC/B,AAAC;;AAUD,IAAM,AAAS,YAAG,AAAQ,AAAC;AAE3B,AAmBG;;;;;;;;;;;;;;;;;;;;AACH,AAAM,WAQJ;kBAAY,AAA+B;AANnC;;aAAY,eAAkB,AAAE,AAAC,AAEjC;aAAM,SAAG,AAAC,AAAC,AACX;aAAM,SAAG,AAAC,AAAC,AACX;aAAQ,WAAG,AAAS,AAAC,AAG3B,AAAE,AAAC;YAAC,AAAc,AAAC;AAAC,AAAC,AACnB,AAAI,gBAAE,AAAM;gBAAE,AAAK,QAAa,AAAc,AAAC,AAC/C,AAAI;gBADiB,AAAM,AAAE;;iBACxB,AAAI,OAAG,IAAI,AAAW,YAAC,AAAM,AAAC,AAAC,AACpC,AAAI;iBAAC,AAAK,QAAG,AAAK,AAAC,AACnB,AAAI;iBAAC,AAAM,SAAG,AAAI,KAAC,AAAI,KAAC,AAAM,AAAC,AAC/B,AAAI;iBAAC,AAAM,SAAG,AAAM,AAAC,AACrB,AAAI;iBAAC,AAAQ,WAAG,AAAC,AAAC,AACpB,AAAC,AAAC,AAAI;eAAC,AAAC,AACN,AAAI;iBAAC,AAAI,OAAG,IAAI,AAAW,YAAC,AAAS,AAAC,AAAC,AACvC,AAAI;iBAAC,AAAK,QAAG,AAAE,AAAC,AAClB,AAAC,AACH;AAAC;AAED,AAAI;;wCAAC,AAAY,MACf,AAAI;aAAC,AAAS,AAAE,AAAC,AACjB,AAAI;aAAC,AAAI,KAAC,AAAI,KAAC,AAAM,AAAE,AAAC,YAAG,AAAI,AAAC,AAClC,AAAC;AAEO,AAAS;;oDACf,AAAE,AAAC;YAAC,AAAI,KAAC,AAAQ,aAAK,AAAC,AAAC,GAAC,AAAC,AACxB;gBAAI,AAAI,OAAG,AAAK,MAAC,AAAI,KAAC,AAAI,MAAE,AAAC,GAAE,AAAI,KAAC,AAAM,AAAC,AAAC,AAC5C,AAAI;iBAAC,AAAI,OAAG,IAAI,AAAW,YAAC,AAAI,KAAC,AAAM,SAAG,AAAS,AAAC,AAAC,AACrD,AAAI;iBAAC,AAAI,KAAC,AAAG,IAAC,AAAI,MAAE,AAAC,AAAC,AAAC,AACvB,AAAI;iBAAC,AAAQ,WAAG,AAAS,AAAC,AAC5B,AAAC;AACD,AAAI;aAAC,AAAQ,AAAE,AAAC,AAClB,AAAC;AAED,AAAS;;kDAAC,AAAe,SACvB,AAAM;eAAC,AAAI,KAAC,AAAI,KAAC,AAAO,AAAC,AAAC,AAC5B,AAAC;AAED,AAAS;;kDAAC,AAAe,SAAE,AAAa,OACtC,AAAI;aAAC,AAAI,KAAC,AAAO,AAAC,WAAG,AAAK,AAAC,AAC7B,AAAC;AAED,AAAM;;8CACJ,AAAI;aAAC,AAAK,MAAC,AAAI,KAAC,AAAI,KAAC,AAAM,QAAE,AAAC,AAAC,AAAC,AAChC;YAAI,AAAM,SAAG,AAAI,KAAC,AAAM,AAAC,AACzB,AAAI;aAAC,AAAM,YAAmB,AAAC,AAC/B,AAAM;eAAC,AAAM,AAAC,AAChB,AAAC;AAED,AAAY;;wDAAC,AAAc,QAAE,AAAiB,WAC5C;YAAI,AAAK,QAAG,AAAI,KAAC,AAAK,MAAC,AAAM,AAAC,AAAC,AAC/B;YAAI,AAAM,SAAG,AAAI,KAAC,AAAM,AAAC,AACzB;YAAI,AAAe,kBAAG,AAAM,SAAG,AAAK,AAAC,AACrC;YAAI,AAAI,OAAG,AAAe,gBAAC,AAAe,iBAAE,AAAS,aAA2B,AAAC,AACjF,AAAI;aAAC,AAAK,MAAC,AAAM,WAAmB,AAAC,qBAAG,AAAI,AAAC,AAC/C,AAAC;AAED,AAAI;;0CACF,AAAM;eAAC,AAAI,KAAC,AAAM,AAAC,AACrB,AAAC;AAED,AAA0D;AAC1D,AAAwD;AACxD,AAAsC;AACtC,AAAO;;;8CAAC,AAAc,QACpB,AAAM;eAAC,AAAI,KAAC,AAAK,MAAC,AAAM,AAAC,AAAC,AAC5B,AAAC;AAED,AAAS;;kDAAC,AAAe,SACvB,AAAI;aAAC,AAAK,MAAC,AAAI,KAAC,AAAO,SAAE,AAAe,gBAAC,AAAC,GAAE,AAAC,KAAyB,AAAC,AAAC,AACxE;YAAI,AAAM,SAAG,AAAI,KAAC,AAAM,AAAC,AACzB,AAAI;aAAC,AAAM,YAAmB,AAAC,AAC/B,AAAM;eAAC,AAAM,AAAC,AAChB,AAAC;AAED,AAAM;;4CAAC,AAAc,QACnB,AAAE,AAAC,AAAC,AAAK,AAAC;mBAAC,AAAC,AACV;gBAAI,AAAI,OAAG,AAAI,KAAC,AAAK,MAAE,AAAmC,WAAmB,AAAC,AAAC,AAC/E,AAAM;mBAAC,AAAI,aAAiB,AAAC,AAC/B,AAAC;AACD,AAAM;eAAC,CAAC,AAAC,AAAC,AACZ,AAAC;AAED,AAAW;;sDAAC,AAAc,QACxB;YAAI,AAAI,OAAG,AAAI,KAAC,AAAK,MAAE,AAAmC,WAAmB,AAAC,AAAC,AAC/E,AAAM;eAAC,CAAC,AAAI,kBAAkB,AAAC,qBAAI,AAAE,AAAC,AACxC,AAAC;AAED,AAAI;;wCAAC,AAAgB,QACnB;YAAI,AAAI,OAAG,AAAI,KAAC,AAAK,MAAE,AAAmC,WAAmB,AAAC,AAAC,AAC/E,AAAI;aAAC,AAAK,MAAE,AAAmC,WAAmB,AAAC,qBAAG,AAAW,YAAC,AAAI,QAAuB,AAAC,AAChH,AAAC;AAED,AAMG;AACH,AAAO;;;;;;;;;;YACD,AAAa,gBAAG,AAAC,AAAC,AACtB,AAAI;AADJ,YACM,AAAK;YAAW,AAAM,AAAE,cAAjB,AAAK,AAAE;YAAY,AAAI,AAAE,OAAG,AAAI,AAAC,AAE9C,AAAG,AAAC;;aAAC,IAAI,AAAC,IAAC,AAAC,GAAE,AAAC,IAAC,AAAM,QAAE,AAAC,OAAiB,kBAAE,AAAC,AAC3C;gBAAI,AAAM,SAAG,AAAK,MAAC,AAAC,AAAC,AAAC,AACtB;gBAAI,AAAI,OAAG,AAAK,MAAC,AAAC,MAAmB,AAAC,AAAC,AACvC;gBAAI,AAAI,OAAG,AAAI,aAAiB,AAAC,AACjC;gBAAI,AAAK,QAAG,AAAI,OAAG,+BAAmB,AAAE,AAAC,AAEzC,AAAE,AAAC;gBAAC,AAAK,YAA0B,AAAC,cAAC,AAAC,AACpC,AAAQ,AAAC,AACX;AAAC,AAAC,AAAI;2BAAK,AAAK,YAAyB,AAAC,aAAC,AAAC,AAC1C,AAA6C;AAC7C,AAAuC;AACvC,AAAc;AACd,AAAK;0BAAC,AAAC,MAAmB,AAAC,qBAAG,AAAW,YAAC,AAAI,QAAwB,AAAC,AACvE,AAAa;qCAAI,AAAI,AAAC,AACxB,AAAC,AAAC,AAAI;AANC,AAAE,AAAC,2BAMC,AAAK,YAA6B,AAAC,iBAAC,AAAC,AAC9C,AAAG,AAAC;yBAAC,IAAI,AAAC,IAAC,AAAM,QAAE,AAAC,KAAE,AAAC,IAAC,AAAI,MAAE,AAAC,AAAE,KAAE,AAAC,AAClC,AAAI;6BAAC,AAAC,IAAG,AAAa,AAAC,iBAAG,AAAI,KAAC,AAAC,AAAC,AAAC,AACpC,AAAC;AAED,AAAK;0BAAC,AAAC,AAAC,KAAG,AAAM,SAAG,AAAa,AAAC,AACpC,AAAC,AAAC,AAAI;AANC,AAAE,AAAC,uBAMH,AAAE,AAAC,IAAC,AAAK,YAA2B,AAAC,eAAC,AAAC,AAC5C,AAAK;0BAAC,AAAC,AAAC,KAAG,AAAM,SAAG,AAAa,AAAC,AACpC,AAAC,AACH;AAAC;AAED,AAAI;aAAC,AAAM,SAAG,AAAI,KAAC,AAAM,SAAG,AAAa,AAAC,AAC5C,AAAC;AAED,AAAe;;8DAAC,AAAuB,WACrC,AAAI;aAAC,AAAS,AAAE,AAAC,AACjB;YAAI,AAAO,UAAG,AAAI,KAAC,AAAM,AAAE,AAAC,AAC5B,AAAI;aAAC,AAAI,KAAC,AAAO,AAAC,iBAAgB,AAAC,AACnC,AAAI;aAAC,AAAY,aAAC,AAAI,KAAC,CAAC,AAAO,SAAE,AAAS,AAAC,AAAC,AAAC,AAC/C,AAAC;AAEO,AAAiB;;;AACvB,AAAI,YAAE,AAAY,AAAE,eAAG,AAAI,AAAC,AAE5B,AAAG,AAAC;;aAAC,IAAI,AAAC,IAAG,AAAC,GAAE,AAAC,IAAG,AAAY,aAAC,AAAM,QAAE,AAAC,AAAE;AAC1C,AAAI,kCAAsB,AAAY,aADM,AAAC,AACN,AAAC,AAAC,AAAC;gBAArC,AAAO;gBAAE,AAAQ,AAAC;;qBAEvB,AAAM,OAAC,AAAI,KAAC,AAAS,UAAC,AAAO,AAAC,mBAAkB,AAAE,6DAA2C,AAAO,AAAE,AAAC,AAAC,AACxG,AAAI;;iBAAC,AAAS,UAAC,AAAO,SAAE,AAAQ,AAAE,AAAC,AAAC,AACtC,AAAC,AACH;AAAC;AAED,AAAO;;;AACL,AAAI,YADE,AAAM,6EAAG,AAAI,KAAC,AAAM;;aACrB,AAAiB,AAAE,AAAC,AAEzB,AAA4B;AAC5B;YAAI,AAAM,SAAG,AAAK,MAAC,AAAI,KAAC,AAAI,MAAE,AAAC,GAAE,AAAM,AAAC,QAAC,AAAM,AAAC,AAChD,AAAM;;oBACI,AAAI,KAAC,AAAM,AACnB,AAAK;mBAAE,AAAI,KAAC,AAAK,AACjB,AAAM;oBAHD,AAGG,AAAqB,AAC9B,AAAC,AACJ,AAAC,AACF;AALK,AAAM;;;;;AAOZ,AAAM,WAKJ;;AAAmB,YAAA,gFAAgC,IAAI,AAAkB,AAAE;YAAS,2EAAO,IAAI,AAAI,AAAE;;;;aAAzE,YAAT,AAAS,AAA+C,AAAS;aAAI,OAAJ,AAAI,AAAa,AACnG,AAAI;aAAC,AAAO,UAAG,IAAI,AAAM,OAAC,AAAI,KAAC,AAAI,AAAC,AAAC,AACvC,AAAC;AAED,AAAM;;wDAAC,AAAc,QACnB,AAAI;aAAC,AAAO,QAAC,AAAM,SAAG,AAAM,AAAC,AAC7B,AAAM;eAAC,AAAI,KAAC,AAAO,AAAC,AACtB,AAAC,AACF;;;;;AAED,AAAM,WAYJ;4BAAmB,AAAyC,WAAS,AAAU;AAA5D;;aAAS,YAAT,AAAS,AAAgC,AAAS;aAAI,OAAJ,AAAI,AAAM,AAC7E,AAAI;aAAC,AAAO,UAAG,IAAI,AAAM,OAAC,AAAI,KAAC,AAAI,AAAC,AAAC,AACvC,AAAC;AAXD,AAAM;;mBAAC,AAAO,2BAAe,AAAuB,SAAE,AAAkB,MAAE,AAAuC,UAC/G;YAAI,AAAI,OAAG,IAAI,AAAI,KAAC,AAAO,AAAC,AAAC,AAC7B;YAAI,AAAS,YAAG,IAAI,AAAgB,iBAAC,AAAQ,UAAE,AAAI,AAAC,AAAC,AAErD,AAAM;eAAC,IAAI,AAAc,eAAC,AAAS,WAAE,AAAI,AAAC,AAAC,AAC7C,AAAC;AAQD,AAAM;;sDAAC,AAAc,QACnB,AAAI;aAAC,AAAO,QAAC,AAAM,SAAG,AAAM,AAAC,AAC7B,AAAM;eAAC,AAAI,KAAC,AAAO,AAAC,AACtB,AAAC,AACF;;;;;AAED,AAAM,WAA6B;;;;;;;;;;EAAQ,AAAgB,AAE1D;AAED,eAAe,AAAgB,KAAE,AAAa,OAAE,AAAW,KACzD,AAAE,AAAC;QAAC,AAAG,IAAC,AAAK,UAAK,AAAS,AAAC,WAAC,AAAC,AAC5B,AAAM;eAAC,AAAG,IAAC,AAAK,MAAC,AAAK,OAAE,AAAG,AAAC,AAAC,AAC/B,AAAC;AAED;QAAI,AAAG,MAAG,IAAI,AAAW,YAAC,AAAG,AAAC,AAAC,AAE/B,AAAG,AAAC,AAAC;WAAE,AAAK,QAAG,AAAG,KAAE,AAAK,AAAE,SAAE,AAAC,AAC5B,AAAG;YAAC,AAAK,AAAC,SAAI,AAAG,IAAC,AAAK,AAAC,AAAC,AAC3B,AAAC;AAED,AAAM;WAAC,AAAG,AAAC,AACb,AAAC","sourcesContent":["\nimport { CompileTimeProgram, Recast, VMHandle, RuntimeResolver, CompileTimeHeap } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants, ConstantPool } from './constants';\nimport { Opcode } from './opcode';\nimport { assert } from \"@glimmer/util\";\n\nconst enum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst enum Size {\n  ENTRY_SIZE = 2,\n  INFO_OFFSET = 1,\n  MAX_SIZE   = 0b1111111111111111,\n  SIZE_MASK  = 0b00000000000000001111111111111111,\n  SCOPE_MASK = 0b00111111111111110000000000000000,\n  STATE_MASK = 0b11000000000000000000000000000000,\n}\n\nfunction encodeTableInfo(size: number, scopeSize: number, state: number) {\n  return size | (scopeSize << 16) | state << 30;\n}\n\nfunction changeState(info: number, newState: number) {\n  return info | newState << 30;\n}\n\nexport interface SerializedHeap {\n  buffer: ArrayBuffer;\n  table: number[];\n  handle: number;\n}\n\nexport type Placeholder = [number, () => number];\n\nconst PAGE_SIZE = 0x100000;\n\n/**\n * The Heap is responsible for dynamically allocating\n * memory in which we read/write the VM's instructions\n * from/to. When we malloc we pass out a VMHandle, which\n * is used as an indirect way of accessing the memory during\n * execution of the VM. Internally we track the different\n * regions of the memory in an int array known as the table.\n *\n * The table 32-bit aligned and has the following layout:\n *\n * | ... | hp (u32) |       info (u32)          |\n * | ... |  Handle  | Size | Scope Size | State |\n * | ... | 32-bits  | 16b  |    14b     |  2b   |\n *\n * With this information we effectively have the ability to\n * control when we want to free memory. That being said you\n * can not free during execution as raw address are only\n * valid during the execution. This means you cannot close\n * over them as you will have a bad memory access exception.\n */\nexport class Heap implements CompileTimeHeap {\n  private heap: Uint16Array;\n  private placeholders: Placeholder[] = [];\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n  private capacity = PAGE_SIZE;\n\n  constructor(serializedHeap?: SerializedHeap) {\n    if (serializedHeap) {\n      let { buffer, table, handle } = serializedHeap;\n      this.heap = new Uint16Array(buffer);\n      this.table = table;\n      this.offset = this.heap.length;\n      this.handle = handle;\n      this.capacity = 0;\n    } else {\n      this.heap = new Uint16Array(PAGE_SIZE);\n      this.table = [];\n    }\n  }\n\n  push(item: number): void {\n    this.sizeCheck();\n    this.heap[this.offset++] = item;\n  }\n\n  private sizeCheck() {\n    if (this.capacity === 0) {\n      let heap = slice(this.heap, 0, this.offset);\n      this.heap = new Uint16Array(heap.length + PAGE_SIZE);\n      this.heap.set(heap, 0);\n      this.capacity = PAGE_SIZE;\n    }\n    this.capacity--;\n  }\n\n  getbyaddr(address: number): number {\n    return this.heap[address];\n  }\n\n  setbyaddr(address: number, value: number) {\n    this.heap[address] = value;\n  }\n\n  malloc(): number {\n    this.table.push(this.offset, 0);\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  finishMalloc(handle: number, scopeSize: number): void {\n    let start = this.table[handle];\n    let finish = this.offset;\n    let instructionSize = finish - start;\n    let info = encodeTableInfo(instructionSize, scopeSize, TableSlotState.Allocated);\n    this.table[handle + Size.INFO_OFFSET] = info;\n  }\n\n  size(): number {\n    return this.offset;\n  }\n\n  // It is illegal to close over this address, as compaction\n  // may move it. However, it is legal to use this address\n  // multiple times between compactions.\n  getaddr(handle: number): number {\n    return this.table[handle];\n  }\n\n  gethandle(address: number): number {\n    this.table.push(address, encodeTableInfo(0, 0, TableSlotState.Pointer));\n    let handle = this.handle;\n    this.handle += Size.ENTRY_SIZE;\n    return handle;\n  }\n\n  sizeof(handle: number): number {\n    if (DEBUG) {\n      let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n      return info & Size.SIZE_MASK;\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: number): number {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    return (info & Size.SCOPE_MASK) >> 16;\n  }\n\n  free(handle: VMHandle): void {\n    let info = this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET];\n    this.table[(handle as Recast<VMHandle, number>) + Size.INFO_OFFSET] = changeState(info, TableSlotState.Freed);\n  }\n\n  /**\n   * The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift\n   * reachable memory to the bottom of the heap and freeable\n   * memory to the top of the heap. When we have shifted all\n   * the reachable memory to the top of the heap, we move the\n   * offset to the next free position.\n   */\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=Size.ENTRY_SIZE) {\n      let offset = table[i];\n      let info = table[i + Size.INFO_OFFSET];\n      let size = info & Size.SIZE_MASK;\n      let state = info & Size.STATE_MASK >> 30;\n\n      if (state === TableSlotState.Purged) {\n        continue;\n      } else if (state === TableSlotState.Freed) {\n        // transition to \"already freed\" aka \"purged\"\n        // a good improvement would be to reuse\n        // these slots\n        table[i + Size.INFO_OFFSET] = changeState(info, TableSlotState.Purged);\n        compactedSize += size;\n      } else if (state === TableSlotState.Allocated) {\n        for (let j=offset; j<=i+size; j++) {\n          heap[j - compactedSize] = heap[j];\n        }\n\n        table[i] = offset - compactedSize;\n      } else if (state === TableSlotState.Pointer) {\n        table[i] = offset - compactedSize;\n      }\n    }\n\n    this.offset = this.offset - compactedSize;\n  }\n\n  pushPlaceholder(valueFunc: () => number): void {\n    this.sizeCheck();\n    let address = this.offset++;\n    this.heap[address] = Size.MAX_SIZE;\n    this.placeholders.push([address, valueFunc]);\n  }\n\n  private patchPlaceholders() {\n    let { placeholders } = this;\n\n    for (let i = 0; i < placeholders.length; i++) {\n      let [address, getValue] = placeholders[i];\n\n      assert(this.getbyaddr(address) === Size.MAX_SIZE, `expected to find a placeholder value at ${address}`);\n      this.setbyaddr(address, getValue());\n    }\n  }\n\n  capture(offset = this.offset): SerializedHeap {\n    this.patchPlaceholders();\n\n    // Only called in eager mode\n    let buffer = slice(this.heap, 0, offset).buffer;\n    return {\n      handle: this.handle,\n      table: this.table,\n      buffer: buffer as ArrayBuffer\n    };\n  }\n}\n\nexport class WriteOnlyProgram implements CompileTimeProgram {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: WriteOnlyConstants = new WriteOnlyConstants(), public heap = new Heap()) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class RuntimeProgram<TemplateMeta> {\n  [key: number]: never;\n\n  static hydrate<TemplateMeta>(rawHeap: SerializedHeap, pool: ConstantPool, resolver: RuntimeResolver<TemplateMeta>) {\n    let heap = new Heap(rawHeap);\n    let constants = new RuntimeConstants(resolver, pool);\n\n    return new RuntimeProgram(constants, heap);\n  }\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<TemplateMeta>, public heap: Heap) {\n    this._opcode = new Opcode(this.heap);\n  }\n\n  opcode(offset: number): Opcode {\n    this._opcode.offset = offset;\n    return this._opcode;\n  }\n}\n\nexport class Program<TemplateMeta> extends WriteOnlyProgram {\n  public constants: Constants<TemplateMeta>;\n}\n\nfunction slice(arr: Uint16Array, start: number, end: number): Uint16Array {\n  if (arr.slice !== undefined) {\n    return arr.slice(start, end);\n  }\n\n  let ret = new Uint16Array(end);\n\n  for (; start < end; start++) {\n    ret[start]  = arr[start];\n  }\n\n  return ret;\n}\n"]} |
import { Opaque, SymbolTable, RuntimeResolver, CompileTimeConstants } from "@glimmer/interfaces"; | ||
export declare const WELL_KNOWN_EMPTY_ARRAY_POSITION = 0; | ||
export declare type EMPTY_ARRAY = Array<ReadonlyArray<never>>; | ||
@@ -33,4 +32,4 @@ export interface ConstantPool { | ||
} | ||
export declare class RuntimeConstants<Locator> { | ||
resolver: RuntimeResolver<Locator>; | ||
export declare class RuntimeConstants<TemplateMeta> { | ||
resolver: RuntimeResolver<TemplateMeta>; | ||
protected strings: string[]; | ||
@@ -41,3 +40,3 @@ protected arrays: number[][] | EMPTY_ARRAY; | ||
protected numbers: number[]; | ||
constructor(resolver: RuntimeResolver<Locator>, pool: ConstantPool); | ||
constructor(resolver: RuntimeResolver<TemplateMeta>, pool: ConstantPool); | ||
getString(value: number): string; | ||
@@ -50,5 +49,5 @@ getNumber(value: number): number; | ||
} | ||
export declare class Constants<Locator> extends WriteOnlyConstants { | ||
resolver: RuntimeResolver<Locator>; | ||
constructor(resolver: RuntimeResolver<Locator>, pool?: ConstantPool); | ||
export declare class Constants<TemplateMeta> extends WriteOnlyConstants { | ||
resolver: RuntimeResolver<TemplateMeta>; | ||
constructor(resolver: RuntimeResolver<TemplateMeta>, pool?: ConstantPool); | ||
getNumber(value: number): number; | ||
@@ -55,0 +54,0 @@ getString(value: number): string; |
import { Unique, RuntimeResolver as IResolver } from '@glimmer/interfaces'; | ||
export declare type Locator = Unique<'Locator'>; | ||
export declare type TemplateMeta = Unique<'TemplateMeta'>; | ||
export declare type Referrer = Unique<'Referrer'>; | ||
export declare type Resolver = IResolver<Locator>; | ||
export declare type Resolver = IResolver<TemplateMeta>; |
@@ -36,4 +36,6 @@ import { CompileTimeProgram, VMHandle, RuntimeResolver, CompileTimeHeap } from "@glimmer/interfaces"; | ||
private handle; | ||
private capacity; | ||
constructor(serializedHeap?: SerializedHeap); | ||
push(item: number): void; | ||
private sizeCheck(); | ||
getbyaddr(address: number): number; | ||
@@ -59,3 +61,3 @@ setbyaddr(address: number, value: number): void; | ||
private patchPlaceholders(); | ||
capture(): SerializedHeap; | ||
capture(offset?: number): SerializedHeap; | ||
} | ||
@@ -70,13 +72,13 @@ export declare class WriteOnlyProgram implements CompileTimeProgram { | ||
} | ||
export declare class RuntimeProgram<Locator> { | ||
constants: RuntimeConstants<Locator>; | ||
export declare class RuntimeProgram<TemplateMeta> { | ||
constants: RuntimeConstants<TemplateMeta>; | ||
heap: Heap; | ||
[key: number]: never; | ||
static hydrate<Locator>(rawHeap: SerializedHeap, pool: ConstantPool, resolver: RuntimeResolver<Locator>): RuntimeProgram<Locator>; | ||
static hydrate<TemplateMeta>(rawHeap: SerializedHeap, pool: ConstantPool, resolver: RuntimeResolver<TemplateMeta>): RuntimeProgram<TemplateMeta>; | ||
private _opcode; | ||
constructor(constants: RuntimeConstants<Locator>, heap: Heap); | ||
constructor(constants: RuntimeConstants<TemplateMeta>, heap: Heap); | ||
opcode(offset: number): Opcode; | ||
} | ||
export declare class Program<Locator> extends WriteOnlyProgram { | ||
constants: Constants<Locator>; | ||
export declare class Program<TemplateMeta> extends WriteOnlyProgram { | ||
constants: Constants<TemplateMeta>; | ||
} |
{ | ||
"name": "@glimmer/program", | ||
"version": "0.32.3", | ||
"version": "0.32.4", | ||
"repository": "https://github.com/glimmerjs/glimmer-vm/tree/master/packages/@glimmer/program", | ||
"dependencies": { | ||
"@glimmer/util": "^0.32.3", | ||
"@glimmer/interfaces": "^0.32.3", | ||
"@glimmer/encoder": "^0.32.3" | ||
"@glimmer/util": "^0.32.4", | ||
"@glimmer/interfaces": "^0.32.4", | ||
"@glimmer/encoder": "^0.32.4" | ||
}, | ||
@@ -10,0 +10,0 @@ "devDependencies": { |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
282919
2562
Updated@glimmer/encoder@^0.32.4
Updated@glimmer/interfaces@^0.32.4
Updated@glimmer/util@^0.32.4