Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@glimmer/program

Package Overview
Dependencies
Maintainers
10
Versions
243
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@glimmer/program - npm Package Compare versions

Comparing version 0.28.3 to 0.29.0

157

dist/amd/es5/glimmer-program.js

@@ -25,10 +25,23 @@ define('@glimmer/program', ['exports', '@glimmer/encoder'], function (exports, _glimmer_encoder) { 'use strict';

this.floats = [];
this.negatives = [];
}
WriteOnlyConstants.prototype.float = function float(_float) {
return this.floats.push(_float);
var index = this.floats.indexOf(_float);
if (index > -1) {
return index;
}
return this.floats.push(_float) - 1;
};
WriteOnlyConstants.prototype.negative = function negative(_negative) {
return this.negatives.push(_negative);
};
WriteOnlyConstants.prototype.string = function string(value) {
return this.strings.push(value);
var index = this.strings.indexOf(value);
if (index > -1) {
return index;
}
return this.strings.push(value) - 1;
};

@@ -45,7 +58,15 @@

WriteOnlyConstants.prototype.array = function array(values) {
return this.arrays.push(values);
var index = this.arrays.indexOf(values);
if (index > -1) {
return index;
}
return this.arrays.push(values) - 1;
};
WriteOnlyConstants.prototype.table = function table(t) {
return this.tables.push(t);
var index = this.tables.indexOf(t);
if (index > -1) {
return index;
}
return this.tables.push(t) - 1;
};

@@ -59,3 +80,7 @@

WriteOnlyConstants.prototype.serializable = function serializable(value) {
return this.serializables.push(value);
var index = this.serializables.indexOf(value);
if (index > -1) {
return index;
}
return this.serializables.push(value) - 1;
};

@@ -70,3 +95,4 @@

serializables: this.serializables,
floats: this.floats
floats: this.floats,
negatives: this.negatives
};

@@ -89,2 +115,3 @@ };

this.floats = pool.floats;
this.negatives = pool.negatives;
this.resolved = this.handles.map(function () {

@@ -98,7 +125,11 @@ return UNRESOLVED;

RuntimeConstants.prototype.getFloat = function getFloat(value) {
return this.floats[value - 1];
return this.floats[value];
};
RuntimeConstants.prototype.getNegative = function getNegative(value) {
return this.negatives[value - 1];
};
RuntimeConstants.prototype.getString = function getString(value) {
return this.strings[value - 1];
return this.strings[value];
};

@@ -117,7 +148,7 @@

RuntimeConstants.prototype.getArray = function getArray(value) {
return this.arrays[value - 1];
return this.arrays[value];
};
RuntimeConstants.prototype.getSymbolTable = function getSymbolTable(value) {
return this.tables[value - 1];
return this.tables[value];
};

@@ -136,3 +167,3 @@

RuntimeConstants.prototype.getSerializable = function getSerializable(s) {
return this.serializables[s - 1];
return this.serializables[s];
};

@@ -157,2 +188,4 @@

_this.serializables = pool.serializables;
_this.floats = pool.floats;
_this.negatives = pool.negatives;
_this.resolved = _this.handles.map(function () {

@@ -167,4 +200,12 @@ return UNRESOLVED;

Constants.prototype.getFloat = function getFloat(value) {
return this.floats[value - 1];
};
Constants.prototype.getNegative = function getNegative(value) {
return this.negatives[value - 1];
};
Constants.prototype.getString = function getString(value) {
return this.strings[value - 1];
return this.strings[value];
};

@@ -183,7 +224,7 @@

Constants.prototype.getArray = function getArray(value) {
return this.arrays[value - 1];
return this.arrays[value];
};
Constants.prototype.getSymbolTable = function getSymbolTable(value) {
return this.tables[value - 1];
return this.tables[value];
};

@@ -202,3 +243,3 @@

Constants.prototype.getSerializable = function getSerializable(s) {
return this.serializables[s - 1];
return this.serializables[s];
};

@@ -294,18 +335,49 @@

var STATE_OFFSET = 3;
/**
* The Heap is responsible for dynamically allocating
* memory in which we read/write the VM's instructions
* from/to. When we malloc we pass out a VMHandle, which
* is used as an indirect way of accessing the memory during
* execution of the VM. Internally we track the different
* regions of the memory in an int array known as the table.
*
* The table has the following layout:
*
* | ... | table entry |
* | ... | hp | size | scope size | state |
* | ... | 0 | 122 | 3 | 0 |
* handle ^ | | ^ region state (allocated, freed, purged)
* region size ^ |
* number of symbols ^
*
* With this information we effectively have the ability to
* control when we want to free memory. That being said you
* can not free during execution as raw address are only
* valid during the execution. This means you cannot close
* over them as you will have a bad memory access exception.
*/
var Heap = function () {
function Heap() {
function Heap(serializedHeap) {
_classCallCheck$1(this, Heap);
this.heap = [];
this.offset = 0;
this.handle = 0;
/**
* layout:
*
* - pointer into heap
* - size
* - scope size
* - freed (0 or 1)
*/
this.table = [];
if (serializedHeap) {
var buffer = serializedHeap.buffer,
table = serializedHeap.table,
handle = serializedHeap.handle;
this.heap = new Uint16Array(buffer);
this.table = table;
this.offset = this.heap.length;
this.handle = handle;
} else {
if (typeof Uint16Array !== 'undefined') {
this.heap = new Uint16Array(0x100000);
} else {
// FIXME remove once we drop IE9
this.heap = new Array(0x100000);
}
this.table = [];
}
}

@@ -369,3 +441,11 @@

};
/**
* The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift
* reachable memory to the bottom of the heap and freeable
* memory to the top of the heap. When we have shifted all
* the reachable memory to the top of the heap, we move the
* offset to the next free position.
*/
Heap.prototype.compact = function compact() {

@@ -401,4 +481,10 @@ var compactedSize = 0;

Heap.prototype.toArray = function toArray() {
return this.heap.slice();
Heap.prototype.capture = function capture() {
// Only called in eager mode
var buffer = slice(this.heap, 0, this.offset);
return {
handle: this.handle,
table: this.table,
buffer: buffer
};
};

@@ -454,2 +540,15 @@

}(WriteOnlyProgram);
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;
}
return null;
}

@@ -470,2 +569,2 @@ exports.WriteOnlyConstants = WriteOnlyConstants;

//# 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 } from \"@glimmer/interfaces\";\nimport { CompileTimeConstants } from \"@glimmer/opcode-compiler\";\n\nconst UNRESOLVED = {};\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][];\n  tables: SymbolTable[];\n  handles: number[];\n  serializables: Opaque[];\n  floats: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b00,\n  FLOAT           = 0b01,\n  STRING          = 0b10,\n  BOOLEAN_OR_VOID = 0b11\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] = [];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected serializables: Opaque[] = [];\n  protected resolved: Opaque[] = [];\n  protected floats: number[] = [];\n\n  float(float: number) {\n    return this.floats.push(float);\n  }\n\n  string(value: string): number {\n    return this.strings.push(value);\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    return this.arrays.push(values);\n  }\n\n  table(t: SymbolTable): number {\n    return this.tables.push(t);\n  }\n\n  handle(handle: number): number {\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle);\n  }\n\n  serializable(value: Opaque): number {\n    return this.serializables.push(value);\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      tables: this.tables,\n      handles: this.handles,\n      serializables: this.serializables,\n      floats: this.floats\n    };\n  }\n}\n\nexport class RuntimeConstants<Specifier> {\n  protected strings: string[];\n  protected arrays: number[][];\n  protected tables: SymbolTable[];\n  protected handles: number[];\n  protected serializables: Opaque[];\n  protected resolved: Opaque[];\n  protected floats: number[];\n\n  constructor(public resolver: RuntimeResolver<Specifier>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.tables = pool.tables;\n    this.handles = pool.handles;\n    this.serializables = pool.serializables;\n    this.floats = pool.floats;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n  }\n\n  // `0` means NULL\n\n  getFloat(value: number): number {\n    return this.floats[value - 1];\n  }\n\n  getString(value: number): string {\n    return this.strings[value - 1];\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[value - 1];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value - 1] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s - 1] as T;\n  }\n}\n\nexport class Constants<Specifier> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Specifier>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.tables = pool.tables;\n      this.handles = pool.handles;\n      this.serializables = pool.serializables;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n    }\n  }\n\n  // `0` means NULL\n\n  getString(value: number): string {\n    return this.strings[value - 1];\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[value - 1];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value - 1] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s - 1] as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\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 { TYPE_MASK, OPERAND_LEN_MASK, ARG_SHIFT } 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 & OPERAND_LEN_MASK) >> ARG_SHIFT) + 1;\n  }\n\n  get type() {\n    return (this.heap.getbyaddr(this.offset) & 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 { Recast, VMHandle } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants } from './constants';\nimport { Opcode } from './opcode';\nimport { CompileTimeProgram } from \"@glimmer/opcode-compiler\";\n\nenum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst ENTRY_SIZE = 4;\nconst SIZE_OFFSET = 1;\nconst SCOPESIZE_OFFSET = 2;\nconst STATE_OFFSET = 3;\n\nexport class Heap {\n  private heap: number[] = [];\n  private offset = 0;\n  private handle = 0;\n\n  /**\n   * layout:\n   *\n   * - pointer into heap\n   * - size\n   * - scope size\n   * - freed (0 or 1)\n   */\n  private table: number[] = [];\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(): VMHandle {\n    this.table.push(this.offset, 0, 0, 0);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  finishMalloc(handle: VMHandle, scopeSize: number): void {\n    let start = this.table[handle as Recast<VMHandle, number>];\n    let finish = this.offset;\n    this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET] = finish - start;\n    this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET] = scopeSize;\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: VMHandle): number {\n    return this.table[handle as Recast<VMHandle, number>];\n  }\n\n  gethandle(address: number): VMHandle {\n    this.table.push(address, 0, 0, TableSlotState.Pointer);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  sizeof(handle: VMHandle): number {\n    if (DEBUG) {\n      return this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET];\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: VMHandle): number {\n    return this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET];\n  }\n\n  free(handle: VMHandle): void {\n    this.table[(handle as Recast<VMHandle, number>) + STATE_OFFSET] = 1;\n  }\n\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=ENTRY_SIZE) {\n      let offset = table[i];\n      let size = table[i + SIZE_OFFSET];\n      let state = table[i + STATE_OFFSET];\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 + STATE_OFFSET] = 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  toArray(): number[] {\n    return this.heap.slice();\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<Specifier> {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Specifier>, 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<Specifier> extends WriteOnlyProgram {\n  public constants: Constants<Specifier>;\n}\n"],"names":["OPERAND_LEN_MASK","ARG_SHIFT","TYPE_MASK"],"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\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][];\n  tables: SymbolTable[];\n  handles: number[];\n  serializables: Opaque[];\n  floats: number[];\n  negatives: 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}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] = [];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected serializables: Opaque[] = [];\n  protected resolved: Opaque[] = [];\n  protected floats: number[] = [];\n  protected negatives: number[] = [];\n\n  float(float: number) {\n    let index = this.floats.indexOf(float);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.floats.push(float) - 1;\n  }\n\n  negative(negative: number) {\n    return this.negatives.push(negative);\n  }\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    let index = this.arrays.indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.arrays.push(values) - 1;\n  }\n\n  table(t: SymbolTable): number {\n    let index = this.tables.indexOf(t);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.tables.push(t) - 1;\n  }\n\n  handle(handle: number): number {\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle);\n  }\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  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      tables: this.tables,\n      handles: this.handles,\n      serializables: this.serializables,\n      floats: this.floats,\n      negatives: this.negatives\n    };\n  }\n}\n\nexport class RuntimeConstants<Specifier> {\n  protected strings: string[];\n  protected arrays: number[][];\n  protected tables: SymbolTable[];\n  protected handles: number[];\n  protected serializables: Opaque[];\n  protected resolved: Opaque[];\n  protected floats: number[];\n  protected negatives: number[];\n\n  constructor(public resolver: RuntimeResolver<Specifier>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.tables = pool.tables;\n    this.handles = pool.handles;\n    this.serializables = pool.serializables;\n    this.floats = pool.floats;\n    this.negatives = pool.negatives;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n  }\n\n  // `0` means NULL\n\n  getFloat(value: number): number {\n    return this.floats[value];\n  }\n\n  getNegative(value: number): number {\n    return this.negatives[value - 1];\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[value];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s] as T;\n  }\n}\n\nexport class Constants<Specifier> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Specifier>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.tables = pool.tables;\n      this.handles = pool.handles;\n      this.serializables = pool.serializables;\n      this.floats = pool.floats;\n      this.negatives = pool.negatives;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n    }\n  }\n\n  // `0` means NULL\n  getFloat(value: number): number {\n    return this.floats[value - 1];\n  }\n\n  getNegative(value: number): number {\n    return this.negatives[value - 1];\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[value];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s] as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\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 { TYPE_MASK, OPERAND_LEN_MASK, ARG_SHIFT } 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 & OPERAND_LEN_MASK) >> ARG_SHIFT) + 1;\n  }\n\n  get type() {\n    return (this.heap.getbyaddr(this.offset) & 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 } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants } from './constants';\nimport { Opcode } from './opcode';\n\nenum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst ENTRY_SIZE = 4;\nconst SIZE_OFFSET = 1;\nconst SCOPESIZE_OFFSET = 2;\nconst STATE_OFFSET = 3;\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 has the following layout:\n *\n * | ... |           table entry          |\n * | ... | hp | size | scope size | state |\n * | ... | 0  | 122  |      3     |   0   |\n *  handle ^     |          |         ^ region state (allocated, freed, purged)\n *   region size ^          |\n *        number of symbols ^\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 {\n  private heap: Uint16Array | Array<number>;\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n\n  constructor(serializedHeap?: { buffer: ArrayBuffer, table: number[], handle: number }) {\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      if (typeof Uint16Array !== 'undefined') {\n        this.heap = new Uint16Array(0x100000);\n      } else {\n        // FIXME remove once we drop IE9\n        this.heap = new Array(0x100000);\n      }\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(): VMHandle {\n    this.table.push(this.offset, 0, 0, 0);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  finishMalloc(handle: VMHandle, scopeSize: number): void {\n    let start = this.table[handle as Recast<VMHandle, number>];\n    let finish = this.offset;\n    this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET] = finish - start;\n    this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET] = scopeSize;\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: VMHandle): number {\n    return this.table[handle as Recast<VMHandle, number>];\n  }\n\n  gethandle(address: number): VMHandle {\n    this.table.push(address, 0, 0, TableSlotState.Pointer);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  sizeof(handle: VMHandle): number {\n    if (DEBUG) {\n      return this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET];\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: VMHandle): number {\n    return this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET];\n  }\n\n  free(handle: VMHandle): void {\n    this.table[(handle as Recast<VMHandle, number>) + STATE_OFFSET] = 1;\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+=ENTRY_SIZE) {\n      let offset = table[i];\n      let size = table[i + SIZE_OFFSET];\n      let state = table[i + STATE_OFFSET];\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 + STATE_OFFSET] = 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  capture() {\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<Specifier> {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Specifier>, 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<Specifier> extends WriteOnlyProgram {\n  public constants: Constants<Specifier>;\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":["OPERAND_LEN_MASK","ARG_SHIFT","TYPE_MASK"],"mappings":"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"}

69

dist/commonjs/es2017/lib/constants.js

@@ -17,8 +17,20 @@ "use strict";

this.floats = [];
this.negatives = [];
}
float(float) {
return this.floats.push(float);
let index = this.floats.indexOf(float);
if (index > -1) {
return index;
}
return this.floats.push(float) - 1;
}
negative(negative) {
return this.negatives.push(negative);
}
string(value) {
return this.strings.push(value);
let index = this.strings.indexOf(value);
if (index > -1) {
return index;
}
return this.strings.push(value) - 1;
}

@@ -33,6 +45,14 @@ stringArray(strings) {

array(values) {
return this.arrays.push(values);
let index = this.arrays.indexOf(values);
if (index > -1) {
return index;
}
return this.arrays.push(values) - 1;
}
table(t) {
return this.tables.push(t);
let index = this.tables.indexOf(t);
if (index > -1) {
return index;
}
return this.tables.push(t) - 1;
}

@@ -44,3 +64,7 @@ handle(handle) {

serializable(value) {
return this.serializables.push(value);
let index = this.serializables.indexOf(value);
if (index > -1) {
return index;
}
return this.serializables.push(value) - 1;
}

@@ -54,3 +78,4 @@ toPool() {

serializables: this.serializables,
floats: this.floats
floats: this.floats,
negatives: this.negatives
};

@@ -69,2 +94,3 @@ }

this.floats = pool.floats;
this.negatives = pool.negatives;
this.resolved = this.handles.map(() => UNRESOLVED);

@@ -74,6 +100,9 @@ }

getFloat(value) {
return this.floats[value - 1];
return this.floats[value];
}
getNegative(value) {
return this.negatives[value - 1];
}
getString(value) {
return this.strings[value - 1];
return this.strings[value];
}

@@ -90,6 +119,6 @@ getStringArray(value) {

getArray(value) {
return this.arrays[value - 1];
return this.arrays[value];
}
getSymbolTable(value) {
return this.tables[value - 1];
return this.tables[value];
}

@@ -106,3 +135,3 @@ resolveHandle(s) {

getSerializable(s) {
return this.serializables[s - 1];
return this.serializables[s];
}

@@ -121,2 +150,4 @@ }

this.serializables = pool.serializables;
this.floats = pool.floats;
this.negatives = pool.negatives;
this.resolved = this.handles.map(() => UNRESOLVED);

@@ -126,4 +157,10 @@ }

// `0` means NULL
getFloat(value) {
return this.floats[value - 1];
}
getNegative(value) {
return this.negatives[value - 1];
}
getString(value) {
return this.strings[value - 1];
return this.strings[value];
}

@@ -140,6 +177,6 @@ getStringArray(value) {

getArray(value) {
return this.arrays[value - 1];
return this.arrays[value];
}
getSymbolTable(value) {
return this.tables[value - 1];
return this.tables[value];
}

@@ -156,3 +193,3 @@ resolveHandle(s) {

getSerializable(s) {
return this.serializables[s - 1];
return this.serializables[s];
}

@@ -174,2 +211,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 } from \"@glimmer/interfaces\";\nimport { CompileTimeConstants } from \"@glimmer/opcode-compiler\";\n\nconst UNRESOLVED = {};\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][];\n  tables: SymbolTable[];\n  handles: number[];\n  serializables: Opaque[];\n  floats: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b00,\n  FLOAT           = 0b01,\n  STRING          = 0b10,\n  BOOLEAN_OR_VOID = 0b11\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] = [];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected serializables: Opaque[] = [];\n  protected resolved: Opaque[] = [];\n  protected floats: number[] = [];\n\n  float(float: number) {\n    return this.floats.push(float);\n  }\n\n  string(value: string): number {\n    return this.strings.push(value);\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    return this.arrays.push(values);\n  }\n\n  table(t: SymbolTable): number {\n    return this.tables.push(t);\n  }\n\n  handle(handle: number): number {\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle);\n  }\n\n  serializable(value: Opaque): number {\n    return this.serializables.push(value);\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      tables: this.tables,\n      handles: this.handles,\n      serializables: this.serializables,\n      floats: this.floats\n    };\n  }\n}\n\nexport class RuntimeConstants<Specifier> {\n  protected strings: string[];\n  protected arrays: number[][];\n  protected tables: SymbolTable[];\n  protected handles: number[];\n  protected serializables: Opaque[];\n  protected resolved: Opaque[];\n  protected floats: number[];\n\n  constructor(public resolver: RuntimeResolver<Specifier>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.tables = pool.tables;\n    this.handles = pool.handles;\n    this.serializables = pool.serializables;\n    this.floats = pool.floats;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n  }\n\n  // `0` means NULL\n\n  getFloat(value: number): number {\n    return this.floats[value - 1];\n  }\n\n  getString(value: number): string {\n    return this.strings[value - 1];\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[value - 1];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value - 1] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s - 1] as T;\n  }\n}\n\nexport class Constants<Specifier> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Specifier>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.tables = pool.tables;\n      this.handles = pool.handles;\n      this.serializables = pool.serializables;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n    }\n  }\n\n  // `0` means NULL\n\n  getString(value: number): string {\n    return this.strings[value - 1];\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[value - 1];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value - 1] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s - 1] as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\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\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][];\n  tables: SymbolTable[];\n  handles: number[];\n  serializables: Opaque[];\n  floats: number[];\n  negatives: 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}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] = [];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected serializables: Opaque[] = [];\n  protected resolved: Opaque[] = [];\n  protected floats: number[] = [];\n  protected negatives: number[] = [];\n\n  float(float: number) {\n    let index = this.floats.indexOf(float);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.floats.push(float) - 1;\n  }\n\n  negative(negative: number) {\n    return this.negatives.push(negative);\n  }\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    let index = this.arrays.indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.arrays.push(values) - 1;\n  }\n\n  table(t: SymbolTable): number {\n    let index = this.tables.indexOf(t);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.tables.push(t) - 1;\n  }\n\n  handle(handle: number): number {\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle);\n  }\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  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      tables: this.tables,\n      handles: this.handles,\n      serializables: this.serializables,\n      floats: this.floats,\n      negatives: this.negatives\n    };\n  }\n}\n\nexport class RuntimeConstants<Specifier> {\n  protected strings: string[];\n  protected arrays: number[][];\n  protected tables: SymbolTable[];\n  protected handles: number[];\n  protected serializables: Opaque[];\n  protected resolved: Opaque[];\n  protected floats: number[];\n  protected negatives: number[];\n\n  constructor(public resolver: RuntimeResolver<Specifier>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.tables = pool.tables;\n    this.handles = pool.handles;\n    this.serializables = pool.serializables;\n    this.floats = pool.floats;\n    this.negatives = pool.negatives;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n  }\n\n  // `0` means NULL\n\n  getFloat(value: number): number {\n    return this.floats[value];\n  }\n\n  getNegative(value: number): number {\n    return this.negatives[value - 1];\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[value];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s] as T;\n  }\n}\n\nexport class Constants<Specifier> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Specifier>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.tables = pool.tables;\n      this.handles = pool.handles;\n      this.serializables = pool.serializables;\n      this.floats = pool.floats;\n      this.negatives = pool.negatives;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n    }\n  }\n\n  // `0` means NULL\n  getFloat(value: number): number {\n    return this.floats[value - 1];\n  }\n\n  getNegative(value: number): number {\n    return this.negatives[value - 1];\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[value];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s] as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\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"]}

@@ -23,16 +23,44 @@ 'use strict';

const STATE_OFFSET = 3;
/**
* The Heap is responsible for dynamically allocating
* memory in which we read/write the VM's instructions
* from/to. When we malloc we pass out a VMHandle, which
* is used as an indirect way of accessing the memory during
* execution of the VM. Internally we track the different
* regions of the memory in an int array known as the table.
*
* The table has the following layout:
*
* | ... | table entry |
* | ... | hp | size | scope size | state |
* | ... | 0 | 122 | 3 | 0 |
* handle ^ | | ^ region state (allocated, freed, purged)
* region size ^ |
* number of symbols ^
*
* With this information we effectively have the ability to
* control when we want to free memory. That being said you
* can not free during execution as raw address are only
* valid during the execution. This means you cannot close
* over them as you will have a bad memory access exception.
*/
class Heap {
constructor() {
this.heap = [];
constructor(serializedHeap) {
this.offset = 0;
this.handle = 0;
/**
* layout:
*
* - pointer into heap
* - size
* - scope size
* - freed (0 or 1)
*/
this.table = [];
if (serializedHeap) {
let { buffer, table, handle } = serializedHeap;
this.heap = new Uint16Array(buffer);
this.table = table;
this.offset = this.heap.length;
this.handle = handle;
} else {
if (typeof Uint16Array !== 'undefined') {
this.heap = new Uint16Array(0x100000);
} else {
// FIXME remove once we drop IE9
this.heap = new Array(0x100000);
}
this.table = [];
}
}

@@ -87,2 +115,9 @@ push(item) {

}
/**
* The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift
* reachable memory to the bottom of the heap and freeable
* memory to the top of the heap. When we have shifted all
* the reachable memory to the top of the heap, we move the
* offset to the next free position.
*/
compact() {

@@ -114,4 +149,10 @@ let compactedSize = 0;

}
toArray() {
return this.heap.slice();
capture() {
// Only called in eager mode
let buffer = slice(this.heap, 0, this.offset);
return {
handle: this.handle,
table: this.table,
buffer: buffer
};
}

@@ -146,2 +187,15 @@ }

exports.Program = Program;
//# 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 { Recast, VMHandle } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants } from './constants';\nimport { Opcode } from './opcode';\nimport { CompileTimeProgram } from \"@glimmer/opcode-compiler\";\n\nenum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst ENTRY_SIZE = 4;\nconst SIZE_OFFSET = 1;\nconst SCOPESIZE_OFFSET = 2;\nconst STATE_OFFSET = 3;\n\nexport class Heap {\n  private heap: number[] = [];\n  private offset = 0;\n  private handle = 0;\n\n  /**\n   * layout:\n   *\n   * - pointer into heap\n   * - size\n   * - scope size\n   * - freed (0 or 1)\n   */\n  private table: number[] = [];\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(): VMHandle {\n    this.table.push(this.offset, 0, 0, 0);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  finishMalloc(handle: VMHandle, scopeSize: number): void {\n    let start = this.table[handle as Recast<VMHandle, number>];\n    let finish = this.offset;\n    this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET] = finish - start;\n    this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET] = scopeSize;\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: VMHandle): number {\n    return this.table[handle as Recast<VMHandle, number>];\n  }\n\n  gethandle(address: number): VMHandle {\n    this.table.push(address, 0, 0, TableSlotState.Pointer);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  sizeof(handle: VMHandle): number {\n    if (DEBUG) {\n      return this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET];\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: VMHandle): number {\n    return this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET];\n  }\n\n  free(handle: VMHandle): void {\n    this.table[(handle as Recast<VMHandle, number>) + STATE_OFFSET] = 1;\n  }\n\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=ENTRY_SIZE) {\n      let offset = table[i];\n      let size = table[i + SIZE_OFFSET];\n      let state = table[i + STATE_OFFSET];\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 + STATE_OFFSET] = 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  toArray(): number[] {\n    return this.heap.slice();\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<Specifier> {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Specifier>, 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<Specifier> extends WriteOnlyProgram {\n  public constants: Constants<Specifier>;\n}\n"]}
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;
}
return null;
}
//# 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 } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants } from './constants';\nimport { Opcode } from './opcode';\n\nenum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst ENTRY_SIZE = 4;\nconst SIZE_OFFSET = 1;\nconst SCOPESIZE_OFFSET = 2;\nconst STATE_OFFSET = 3;\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 has the following layout:\n *\n * | ... |           table entry          |\n * | ... | hp | size | scope size | state |\n * | ... | 0  | 122  |      3     |   0   |\n *  handle ^     |          |         ^ region state (allocated, freed, purged)\n *   region size ^          |\n *        number of symbols ^\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 {\n  private heap: Uint16Array | Array<number>;\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n\n  constructor(serializedHeap?: { buffer: ArrayBuffer, table: number[], handle: number }) {\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      if (typeof Uint16Array !== 'undefined') {\n        this.heap = new Uint16Array(0x100000);\n      } else {\n        // FIXME remove once we drop IE9\n        this.heap = new Array(0x100000);\n      }\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(): VMHandle {\n    this.table.push(this.offset, 0, 0, 0);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  finishMalloc(handle: VMHandle, scopeSize: number): void {\n    let start = this.table[handle as Recast<VMHandle, number>];\n    let finish = this.offset;\n    this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET] = finish - start;\n    this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET] = scopeSize;\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: VMHandle): number {\n    return this.table[handle as Recast<VMHandle, number>];\n  }\n\n  gethandle(address: number): VMHandle {\n    this.table.push(address, 0, 0, TableSlotState.Pointer);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  sizeof(handle: VMHandle): number {\n    if (DEBUG) {\n      return this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET];\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: VMHandle): number {\n    return this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET];\n  }\n\n  free(handle: VMHandle): void {\n    this.table[(handle as Recast<VMHandle, number>) + STATE_OFFSET] = 1;\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+=ENTRY_SIZE) {\n      let offset = table[i];\n      let size = table[i + SIZE_OFFSET];\n      let state = table[i + STATE_OFFSET];\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 + STATE_OFFSET] = 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  capture() {\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<Specifier> {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Specifier>, 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<Specifier> extends WriteOnlyProgram {\n  public constants: Constants<Specifier>;\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"]}

@@ -46,10 +46,23 @@ "use strict";

this.floats = [];
this.negatives = [];
}
WriteOnlyConstants.prototype.float = function float(_float) {
return this.floats.push(_float);
var index = this.floats.indexOf(_float);
if (index > -1) {
return index;
}
return this.floats.push(_float) - 1;
};
WriteOnlyConstants.prototype.negative = function negative(_negative) {
return this.negatives.push(_negative);
};
WriteOnlyConstants.prototype.string = function string(value) {
return this.strings.push(value);
var index = this.strings.indexOf(value);
if (index > -1) {
return index;
}
return this.strings.push(value) - 1;
};

@@ -66,7 +79,15 @@

WriteOnlyConstants.prototype.array = function array(values) {
return this.arrays.push(values);
var index = this.arrays.indexOf(values);
if (index > -1) {
return index;
}
return this.arrays.push(values) - 1;
};
WriteOnlyConstants.prototype.table = function table(t) {
return this.tables.push(t);
var index = this.tables.indexOf(t);
if (index > -1) {
return index;
}
return this.tables.push(t) - 1;
};

@@ -80,3 +101,7 @@

WriteOnlyConstants.prototype.serializable = function serializable(value) {
return this.serializables.push(value);
var index = this.serializables.indexOf(value);
if (index > -1) {
return index;
}
return this.serializables.push(value) - 1;
};

@@ -91,3 +116,4 @@

serializables: this.serializables,
floats: this.floats
floats: this.floats,
negatives: this.negatives
};

@@ -111,2 +137,3 @@ };

this.floats = pool.floats;
this.negatives = pool.negatives;
this.resolved = this.handles.map(function () {

@@ -120,7 +147,11 @@ return UNRESOLVED;

RuntimeConstants.prototype.getFloat = function getFloat(value) {
return this.floats[value - 1];
return this.floats[value];
};
RuntimeConstants.prototype.getNegative = function getNegative(value) {
return this.negatives[value - 1];
};
RuntimeConstants.prototype.getString = function getString(value) {
return this.strings[value - 1];
return this.strings[value];
};

@@ -139,7 +170,7 @@

RuntimeConstants.prototype.getArray = function getArray(value) {
return this.arrays[value - 1];
return this.arrays[value];
};
RuntimeConstants.prototype.getSymbolTable = function getSymbolTable(value) {
return this.tables[value - 1];
return this.tables[value];
};

@@ -158,3 +189,3 @@

RuntimeConstants.prototype.getSerializable = function getSerializable(s) {
return this.serializables[s - 1];
return this.serializables[s];
};

@@ -179,2 +210,4 @@

_this.serializables = pool.serializables;
_this.floats = pool.floats;
_this.negatives = pool.negatives;
_this.resolved = _this.handles.map(function () {

@@ -189,4 +222,12 @@ return UNRESOLVED;

Constants.prototype.getFloat = function getFloat(value) {
return this.floats[value - 1];
};
Constants.prototype.getNegative = function getNegative(value) {
return this.negatives[value - 1];
};
Constants.prototype.getString = function getString(value) {
return this.strings[value - 1];
return this.strings[value];
};

@@ -205,7 +246,7 @@

Constants.prototype.getArray = function getArray(value) {
return this.arrays[value - 1];
return this.arrays[value];
};
Constants.prototype.getSymbolTable = function getSymbolTable(value) {
return this.tables[value - 1];
return this.tables[value];
};

@@ -224,3 +265,3 @@

Constants.prototype.getSerializable = function getSerializable(s) {
return this.serializables[s - 1];
return this.serializables[s];
};

@@ -255,2 +296,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 } from \"@glimmer/interfaces\";\nimport { CompileTimeConstants } from \"@glimmer/opcode-compiler\";\n\nconst UNRESOLVED = {};\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][];\n  tables: SymbolTable[];\n  handles: number[];\n  serializables: Opaque[];\n  floats: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b00,\n  FLOAT           = 0b01,\n  STRING          = 0b10,\n  BOOLEAN_OR_VOID = 0b11\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] = [];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected serializables: Opaque[] = [];\n  protected resolved: Opaque[] = [];\n  protected floats: number[] = [];\n\n  float(float: number) {\n    return this.floats.push(float);\n  }\n\n  string(value: string): number {\n    return this.strings.push(value);\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    return this.arrays.push(values);\n  }\n\n  table(t: SymbolTable): number {\n    return this.tables.push(t);\n  }\n\n  handle(handle: number): number {\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle);\n  }\n\n  serializable(value: Opaque): number {\n    return this.serializables.push(value);\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      tables: this.tables,\n      handles: this.handles,\n      serializables: this.serializables,\n      floats: this.floats\n    };\n  }\n}\n\nexport class RuntimeConstants<Specifier> {\n  protected strings: string[];\n  protected arrays: number[][];\n  protected tables: SymbolTable[];\n  protected handles: number[];\n  protected serializables: Opaque[];\n  protected resolved: Opaque[];\n  protected floats: number[];\n\n  constructor(public resolver: RuntimeResolver<Specifier>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.tables = pool.tables;\n    this.handles = pool.handles;\n    this.serializables = pool.serializables;\n    this.floats = pool.floats;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n  }\n\n  // `0` means NULL\n\n  getFloat(value: number): number {\n    return this.floats[value - 1];\n  }\n\n  getString(value: number): string {\n    return this.strings[value - 1];\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[value - 1];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value - 1] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s - 1] as T;\n  }\n}\n\nexport class Constants<Specifier> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Specifier>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.tables = pool.tables;\n      this.handles = pool.handles;\n      this.serializables = pool.serializables;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n    }\n  }\n\n  // `0` means NULL\n\n  getString(value: number): string {\n    return this.strings[value - 1];\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[value - 1];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value - 1] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s - 1] as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\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\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][];\n  tables: SymbolTable[];\n  handles: number[];\n  serializables: Opaque[];\n  floats: number[];\n  negatives: 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}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] = [];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected serializables: Opaque[] = [];\n  protected resolved: Opaque[] = [];\n  protected floats: number[] = [];\n  protected negatives: number[] = [];\n\n  float(float: number) {\n    let index = this.floats.indexOf(float);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.floats.push(float) - 1;\n  }\n\n  negative(negative: number) {\n    return this.negatives.push(negative);\n  }\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    let index = this.arrays.indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.arrays.push(values) - 1;\n  }\n\n  table(t: SymbolTable): number {\n    let index = this.tables.indexOf(t);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.tables.push(t) - 1;\n  }\n\n  handle(handle: number): number {\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle);\n  }\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  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      tables: this.tables,\n      handles: this.handles,\n      serializables: this.serializables,\n      floats: this.floats,\n      negatives: this.negatives\n    };\n  }\n}\n\nexport class RuntimeConstants<Specifier> {\n  protected strings: string[];\n  protected arrays: number[][];\n  protected tables: SymbolTable[];\n  protected handles: number[];\n  protected serializables: Opaque[];\n  protected resolved: Opaque[];\n  protected floats: number[];\n  protected negatives: number[];\n\n  constructor(public resolver: RuntimeResolver<Specifier>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.tables = pool.tables;\n    this.handles = pool.handles;\n    this.serializables = pool.serializables;\n    this.floats = pool.floats;\n    this.negatives = pool.negatives;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n  }\n\n  // `0` means NULL\n\n  getFloat(value: number): number {\n    return this.floats[value];\n  }\n\n  getNegative(value: number): number {\n    return this.negatives[value - 1];\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[value];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s] as T;\n  }\n}\n\nexport class Constants<Specifier> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Specifier>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.tables = pool.tables;\n      this.handles = pool.handles;\n      this.serializables = pool.serializables;\n      this.floats = pool.floats;\n      this.negatives = pool.negatives;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n    }\n  }\n\n  // `0` means NULL\n  getFloat(value: number): number {\n    return this.floats[value - 1];\n  }\n\n  getNegative(value: number): number {\n    return this.negatives[value - 1];\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[value];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s] as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\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"]}

@@ -49,18 +49,49 @@ "use strict";

var STATE_OFFSET = 3;
/**
* The Heap is responsible for dynamically allocating
* memory in which we read/write the VM's instructions
* from/to. When we malloc we pass out a VMHandle, which
* is used as an indirect way of accessing the memory during
* execution of the VM. Internally we track the different
* regions of the memory in an int array known as the table.
*
* The table has the following layout:
*
* | ... | table entry |
* | ... | hp | size | scope size | state |
* | ... | 0 | 122 | 3 | 0 |
* handle ^ | | ^ region state (allocated, freed, purged)
* region size ^ |
* number of symbols ^
*
* With this information we effectively have the ability to
* control when we want to free memory. That being said you
* can not free during execution as raw address are only
* valid during the execution. This means you cannot close
* over them as you will have a bad memory access exception.
*/
var Heap = exports.Heap = function () {
function Heap() {
function Heap(serializedHeap) {
_classCallCheck(this, Heap);
this.heap = [];
this.offset = 0;
this.handle = 0;
/**
* layout:
*
* - pointer into heap
* - size
* - scope size
* - freed (0 or 1)
*/
this.table = [];
if (serializedHeap) {
var buffer = serializedHeap.buffer,
table = serializedHeap.table,
handle = serializedHeap.handle;
this.heap = new Uint16Array(buffer);
this.table = table;
this.offset = this.heap.length;
this.handle = handle;
} else {
if (typeof Uint16Array !== 'undefined') {
this.heap = new Uint16Array(0x100000);
} else {
// FIXME remove once we drop IE9
this.heap = new Array(0x100000);
}
this.table = [];
}
}

@@ -127,2 +158,9 @@

};
/**
* The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift
* reachable memory to the bottom of the heap and freeable
* memory to the top of the heap. When we have shifted all
* the reachable memory to the top of the heap, we move the
* offset to the next free position.
*/

@@ -159,4 +197,10 @@ Heap.prototype.compact = function compact() {

Heap.prototype.toArray = function toArray() {
return this.heap.slice();
Heap.prototype.capture = function capture() {
// Only called in eager mode
var buffer = slice(this.heap, 0, this.offset);
return {
handle: this.handle,
table: this.table,
buffer: buffer
};
};

@@ -212,2 +256,15 @@

}(WriteOnlyProgram);
//# 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 { Recast, VMHandle } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants } from './constants';\nimport { Opcode } from './opcode';\nimport { CompileTimeProgram } from \"@glimmer/opcode-compiler\";\n\nenum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst ENTRY_SIZE = 4;\nconst SIZE_OFFSET = 1;\nconst SCOPESIZE_OFFSET = 2;\nconst STATE_OFFSET = 3;\n\nexport class Heap {\n  private heap: number[] = [];\n  private offset = 0;\n  private handle = 0;\n\n  /**\n   * layout:\n   *\n   * - pointer into heap\n   * - size\n   * - scope size\n   * - freed (0 or 1)\n   */\n  private table: number[] = [];\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(): VMHandle {\n    this.table.push(this.offset, 0, 0, 0);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  finishMalloc(handle: VMHandle, scopeSize: number): void {\n    let start = this.table[handle as Recast<VMHandle, number>];\n    let finish = this.offset;\n    this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET] = finish - start;\n    this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET] = scopeSize;\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: VMHandle): number {\n    return this.table[handle as Recast<VMHandle, number>];\n  }\n\n  gethandle(address: number): VMHandle {\n    this.table.push(address, 0, 0, TableSlotState.Pointer);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  sizeof(handle: VMHandle): number {\n    if (DEBUG) {\n      return this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET];\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: VMHandle): number {\n    return this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET];\n  }\n\n  free(handle: VMHandle): void {\n    this.table[(handle as Recast<VMHandle, number>) + STATE_OFFSET] = 1;\n  }\n\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=ENTRY_SIZE) {\n      let offset = table[i];\n      let size = table[i + SIZE_OFFSET];\n      let state = table[i + STATE_OFFSET];\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 + STATE_OFFSET] = 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  toArray(): number[] {\n    return this.heap.slice();\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<Specifier> {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Specifier>, 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<Specifier> extends WriteOnlyProgram {\n  public constants: Constants<Specifier>;\n}\n"]}
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;
}
return null;
}
//# 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 } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants } from './constants';\nimport { Opcode } from './opcode';\n\nenum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst ENTRY_SIZE = 4;\nconst SIZE_OFFSET = 1;\nconst SCOPESIZE_OFFSET = 2;\nconst STATE_OFFSET = 3;\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 has the following layout:\n *\n * | ... |           table entry          |\n * | ... | hp | size | scope size | state |\n * | ... | 0  | 122  |      3     |   0   |\n *  handle ^     |          |         ^ region state (allocated, freed, purged)\n *   region size ^          |\n *        number of symbols ^\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 {\n  private heap: Uint16Array | Array<number>;\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n\n  constructor(serializedHeap?: { buffer: ArrayBuffer, table: number[], handle: number }) {\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      if (typeof Uint16Array !== 'undefined') {\n        this.heap = new Uint16Array(0x100000);\n      } else {\n        // FIXME remove once we drop IE9\n        this.heap = new Array(0x100000);\n      }\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(): VMHandle {\n    this.table.push(this.offset, 0, 0, 0);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  finishMalloc(handle: VMHandle, scopeSize: number): void {\n    let start = this.table[handle as Recast<VMHandle, number>];\n    let finish = this.offset;\n    this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET] = finish - start;\n    this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET] = scopeSize;\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: VMHandle): number {\n    return this.table[handle as Recast<VMHandle, number>];\n  }\n\n  gethandle(address: number): VMHandle {\n    this.table.push(address, 0, 0, TableSlotState.Pointer);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  sizeof(handle: VMHandle): number {\n    if (DEBUG) {\n      return this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET];\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: VMHandle): number {\n    return this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET];\n  }\n\n  free(handle: VMHandle): void {\n    this.table[(handle as Recast<VMHandle, number>) + STATE_OFFSET] = 1;\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+=ENTRY_SIZE) {\n      let offset = table[i];\n      let size = table[i + SIZE_OFFSET];\n      let state = table[i + STATE_OFFSET];\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 + STATE_OFFSET] = 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  capture() {\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<Specifier> {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Specifier>, 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<Specifier> extends WriteOnlyProgram {\n  public constants: Constants<Specifier>;\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"]}

@@ -12,8 +12,20 @@ const UNRESOLVED = {};

this.floats = [];
this.negatives = [];
}
float(float) {
return this.floats.push(float);
let index = this.floats.indexOf(float);
if (index > -1) {
return index;
}
return this.floats.push(float) - 1;
}
negative(negative) {
return this.negatives.push(negative);
}
string(value) {
return this.strings.push(value);
let index = this.strings.indexOf(value);
if (index > -1) {
return index;
}
return this.strings.push(value) - 1;
}

@@ -28,6 +40,14 @@ stringArray(strings) {

array(values) {
return this.arrays.push(values);
let index = this.arrays.indexOf(values);
if (index > -1) {
return index;
}
return this.arrays.push(values) - 1;
}
table(t) {
return this.tables.push(t);
let index = this.tables.indexOf(t);
if (index > -1) {
return index;
}
return this.tables.push(t) - 1;
}

@@ -39,3 +59,7 @@ handle(handle) {

serializable(value) {
return this.serializables.push(value);
let index = this.serializables.indexOf(value);
if (index > -1) {
return index;
}
return this.serializables.push(value) - 1;
}

@@ -49,3 +73,4 @@ toPool() {

serializables: this.serializables,
floats: this.floats
floats: this.floats,
negatives: this.negatives
};

@@ -63,2 +88,3 @@ }

this.floats = pool.floats;
this.negatives = pool.negatives;
this.resolved = this.handles.map(() => UNRESOLVED);

@@ -68,6 +94,9 @@ }

getFloat(value) {
return this.floats[value - 1];
return this.floats[value];
}
getNegative(value) {
return this.negatives[value - 1];
}
getString(value) {
return this.strings[value - 1];
return this.strings[value];
}

@@ -84,6 +113,6 @@ getStringArray(value) {

getArray(value) {
return this.arrays[value - 1];
return this.arrays[value];
}
getSymbolTable(value) {
return this.tables[value - 1];
return this.tables[value];
}

@@ -100,3 +129,3 @@ resolveHandle(s) {

getSerializable(s) {
return this.serializables[s - 1];
return this.serializables[s];
}

@@ -114,2 +143,4 @@ }

this.serializables = pool.serializables;
this.floats = pool.floats;
this.negatives = pool.negatives;
this.resolved = this.handles.map(() => UNRESOLVED);

@@ -119,4 +150,10 @@ }

// `0` means NULL
getFloat(value) {
return this.floats[value - 1];
}
getNegative(value) {
return this.negatives[value - 1];
}
getString(value) {
return this.strings[value - 1];
return this.strings[value];
}

@@ -133,6 +170,6 @@ getStringArray(value) {

getArray(value) {
return this.arrays[value - 1];
return this.arrays[value];
}
getSymbolTable(value) {
return this.tables[value - 1];
return this.tables[value];
}

@@ -149,3 +186,3 @@ resolveHandle(s) {

getSerializable(s) {
return this.serializables[s - 1];
return this.serializables[s];
}

@@ -165,2 +202,2 @@ }

}
//# 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 } from \"@glimmer/interfaces\";\nimport { CompileTimeConstants } from \"@glimmer/opcode-compiler\";\n\nconst UNRESOLVED = {};\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][];\n  tables: SymbolTable[];\n  handles: number[];\n  serializables: Opaque[];\n  floats: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b00,\n  FLOAT           = 0b01,\n  STRING          = 0b10,\n  BOOLEAN_OR_VOID = 0b11\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] = [];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected serializables: Opaque[] = [];\n  protected resolved: Opaque[] = [];\n  protected floats: number[] = [];\n\n  float(float: number) {\n    return this.floats.push(float);\n  }\n\n  string(value: string): number {\n    return this.strings.push(value);\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    return this.arrays.push(values);\n  }\n\n  table(t: SymbolTable): number {\n    return this.tables.push(t);\n  }\n\n  handle(handle: number): number {\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle);\n  }\n\n  serializable(value: Opaque): number {\n    return this.serializables.push(value);\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      tables: this.tables,\n      handles: this.handles,\n      serializables: this.serializables,\n      floats: this.floats\n    };\n  }\n}\n\nexport class RuntimeConstants<Specifier> {\n  protected strings: string[];\n  protected arrays: number[][];\n  protected tables: SymbolTable[];\n  protected handles: number[];\n  protected serializables: Opaque[];\n  protected resolved: Opaque[];\n  protected floats: number[];\n\n  constructor(public resolver: RuntimeResolver<Specifier>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.tables = pool.tables;\n    this.handles = pool.handles;\n    this.serializables = pool.serializables;\n    this.floats = pool.floats;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n  }\n\n  // `0` means NULL\n\n  getFloat(value: number): number {\n    return this.floats[value - 1];\n  }\n\n  getString(value: number): string {\n    return this.strings[value - 1];\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[value - 1];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value - 1] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s - 1] as T;\n  }\n}\n\nexport class Constants<Specifier> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Specifier>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.tables = pool.tables;\n      this.handles = pool.handles;\n      this.serializables = pool.serializables;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n    }\n  }\n\n  // `0` means NULL\n\n  getString(value: number): string {\n    return this.strings[value - 1];\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[value - 1];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value - 1] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s - 1] as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\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\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][];\n  tables: SymbolTable[];\n  handles: number[];\n  serializables: Opaque[];\n  floats: number[];\n  negatives: 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}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] = [];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected serializables: Opaque[] = [];\n  protected resolved: Opaque[] = [];\n  protected floats: number[] = [];\n  protected negatives: number[] = [];\n\n  float(float: number) {\n    let index = this.floats.indexOf(float);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.floats.push(float) - 1;\n  }\n\n  negative(negative: number) {\n    return this.negatives.push(negative);\n  }\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    let index = this.arrays.indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.arrays.push(values) - 1;\n  }\n\n  table(t: SymbolTable): number {\n    let index = this.tables.indexOf(t);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.tables.push(t) - 1;\n  }\n\n  handle(handle: number): number {\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle);\n  }\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  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      tables: this.tables,\n      handles: this.handles,\n      serializables: this.serializables,\n      floats: this.floats,\n      negatives: this.negatives\n    };\n  }\n}\n\nexport class RuntimeConstants<Specifier> {\n  protected strings: string[];\n  protected arrays: number[][];\n  protected tables: SymbolTable[];\n  protected handles: number[];\n  protected serializables: Opaque[];\n  protected resolved: Opaque[];\n  protected floats: number[];\n  protected negatives: number[];\n\n  constructor(public resolver: RuntimeResolver<Specifier>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.tables = pool.tables;\n    this.handles = pool.handles;\n    this.serializables = pool.serializables;\n    this.floats = pool.floats;\n    this.negatives = pool.negatives;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n  }\n\n  // `0` means NULL\n\n  getFloat(value: number): number {\n    return this.floats[value];\n  }\n\n  getNegative(value: number): number {\n    return this.negatives[value - 1];\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[value];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s] as T;\n  }\n}\n\nexport class Constants<Specifier> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Specifier>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.tables = pool.tables;\n      this.handles = pool.handles;\n      this.serializables = pool.serializables;\n      this.floats = pool.floats;\n      this.negatives = pool.negatives;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n    }\n  }\n\n  // `0` means NULL\n  getFloat(value: number): number {\n    return this.floats[value - 1];\n  }\n\n  getNegative(value: number): number {\n    return this.negatives[value - 1];\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[value];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s] as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\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"]}

@@ -15,16 +15,44 @@

const STATE_OFFSET = 3;
/**
* The Heap is responsible for dynamically allocating
* memory in which we read/write the VM's instructions
* from/to. When we malloc we pass out a VMHandle, which
* is used as an indirect way of accessing the memory during
* execution of the VM. Internally we track the different
* regions of the memory in an int array known as the table.
*
* The table has the following layout:
*
* | ... | table entry |
* | ... | hp | size | scope size | state |
* | ... | 0 | 122 | 3 | 0 |
* handle ^ | | ^ region state (allocated, freed, purged)
* region size ^ |
* number of symbols ^
*
* With this information we effectively have the ability to
* control when we want to free memory. That being said you
* can not free during execution as raw address are only
* valid during the execution. This means you cannot close
* over them as you will have a bad memory access exception.
*/
export class Heap {
constructor() {
this.heap = [];
constructor(serializedHeap) {
this.offset = 0;
this.handle = 0;
/**
* layout:
*
* - pointer into heap
* - size
* - scope size
* - freed (0 or 1)
*/
this.table = [];
if (serializedHeap) {
let { buffer, table, handle } = serializedHeap;
this.heap = new Uint16Array(buffer);
this.table = table;
this.offset = this.heap.length;
this.handle = handle;
} else {
if (typeof Uint16Array !== 'undefined') {
this.heap = new Uint16Array(0x100000);
} else {
// FIXME remove once we drop IE9
this.heap = new Array(0x100000);
}
this.table = [];
}
}

@@ -79,2 +107,9 @@ push(item) {

}
/**
* The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift
* reachable memory to the bottom of the heap and freeable
* memory to the top of the heap. When we have shifted all
* the reachable memory to the top of the heap, we move the
* offset to the next free position.
*/
compact() {

@@ -106,4 +141,10 @@ let compactedSize = 0;

}
toArray() {
return this.heap.slice();
capture() {
// Only called in eager mode
let buffer = slice(this.heap, 0, this.offset);
return {
handle: this.handle,
table: this.table,
buffer: buffer
};
}

@@ -134,2 +175,15 @@ }

export class Program extends WriteOnlyProgram {}
//# 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 { Recast, VMHandle } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants } from './constants';\nimport { Opcode } from './opcode';\nimport { CompileTimeProgram } from \"@glimmer/opcode-compiler\";\n\nenum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst ENTRY_SIZE = 4;\nconst SIZE_OFFSET = 1;\nconst SCOPESIZE_OFFSET = 2;\nconst STATE_OFFSET = 3;\n\nexport class Heap {\n  private heap: number[] = [];\n  private offset = 0;\n  private handle = 0;\n\n  /**\n   * layout:\n   *\n   * - pointer into heap\n   * - size\n   * - scope size\n   * - freed (0 or 1)\n   */\n  private table: number[] = [];\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(): VMHandle {\n    this.table.push(this.offset, 0, 0, 0);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  finishMalloc(handle: VMHandle, scopeSize: number): void {\n    let start = this.table[handle as Recast<VMHandle, number>];\n    let finish = this.offset;\n    this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET] = finish - start;\n    this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET] = scopeSize;\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: VMHandle): number {\n    return this.table[handle as Recast<VMHandle, number>];\n  }\n\n  gethandle(address: number): VMHandle {\n    this.table.push(address, 0, 0, TableSlotState.Pointer);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  sizeof(handle: VMHandle): number {\n    if (DEBUG) {\n      return this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET];\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: VMHandle): number {\n    return this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET];\n  }\n\n  free(handle: VMHandle): void {\n    this.table[(handle as Recast<VMHandle, number>) + STATE_OFFSET] = 1;\n  }\n\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=ENTRY_SIZE) {\n      let offset = table[i];\n      let size = table[i + SIZE_OFFSET];\n      let state = table[i + STATE_OFFSET];\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 + STATE_OFFSET] = 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  toArray(): number[] {\n    return this.heap.slice();\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<Specifier> {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Specifier>, 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<Specifier> extends WriteOnlyProgram {\n  public constants: Constants<Specifier>;\n}\n"]}
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;
}
return null;
}
//# 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 } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants } from './constants';\nimport { Opcode } from './opcode';\n\nenum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst ENTRY_SIZE = 4;\nconst SIZE_OFFSET = 1;\nconst SCOPESIZE_OFFSET = 2;\nconst STATE_OFFSET = 3;\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 has the following layout:\n *\n * | ... |           table entry          |\n * | ... | hp | size | scope size | state |\n * | ... | 0  | 122  |      3     |   0   |\n *  handle ^     |          |         ^ region state (allocated, freed, purged)\n *   region size ^          |\n *        number of symbols ^\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 {\n  private heap: Uint16Array | Array<number>;\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n\n  constructor(serializedHeap?: { buffer: ArrayBuffer, table: number[], handle: number }) {\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      if (typeof Uint16Array !== 'undefined') {\n        this.heap = new Uint16Array(0x100000);\n      } else {\n        // FIXME remove once we drop IE9\n        this.heap = new Array(0x100000);\n      }\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(): VMHandle {\n    this.table.push(this.offset, 0, 0, 0);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  finishMalloc(handle: VMHandle, scopeSize: number): void {\n    let start = this.table[handle as Recast<VMHandle, number>];\n    let finish = this.offset;\n    this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET] = finish - start;\n    this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET] = scopeSize;\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: VMHandle): number {\n    return this.table[handle as Recast<VMHandle, number>];\n  }\n\n  gethandle(address: number): VMHandle {\n    this.table.push(address, 0, 0, TableSlotState.Pointer);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  sizeof(handle: VMHandle): number {\n    if (DEBUG) {\n      return this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET];\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: VMHandle): number {\n    return this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET];\n  }\n\n  free(handle: VMHandle): void {\n    this.table[(handle as Recast<VMHandle, number>) + STATE_OFFSET] = 1;\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+=ENTRY_SIZE) {\n      let offset = table[i];\n      let size = table[i + SIZE_OFFSET];\n      let state = table[i + STATE_OFFSET];\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 + STATE_OFFSET] = 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  capture() {\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<Specifier> {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Specifier>, 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<Specifier> extends WriteOnlyProgram {\n  public constants: Constants<Specifier>;\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"]}

@@ -23,10 +23,23 @@ 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; }

this.floats = [];
this.negatives = [];
}
WriteOnlyConstants.prototype.float = function float(_float) {
return this.floats.push(_float);
var index = this.floats.indexOf(_float);
if (index > -1) {
return index;
}
return this.floats.push(_float) - 1;
};
WriteOnlyConstants.prototype.negative = function negative(_negative) {
return this.negatives.push(_negative);
};
WriteOnlyConstants.prototype.string = function string(value) {
return this.strings.push(value);
var index = this.strings.indexOf(value);
if (index > -1) {
return index;
}
return this.strings.push(value) - 1;
};

@@ -43,7 +56,15 @@

WriteOnlyConstants.prototype.array = function array(values) {
return this.arrays.push(values);
var index = this.arrays.indexOf(values);
if (index > -1) {
return index;
}
return this.arrays.push(values) - 1;
};
WriteOnlyConstants.prototype.table = function table(t) {
return this.tables.push(t);
var index = this.tables.indexOf(t);
if (index > -1) {
return index;
}
return this.tables.push(t) - 1;
};

@@ -57,3 +78,7 @@

WriteOnlyConstants.prototype.serializable = function serializable(value) {
return this.serializables.push(value);
var index = this.serializables.indexOf(value);
if (index > -1) {
return index;
}
return this.serializables.push(value) - 1;
};

@@ -68,3 +93,4 @@

serializables: this.serializables,
floats: this.floats
floats: this.floats,
negatives: this.negatives
};

@@ -89,2 +115,3 @@ };

this.floats = pool.floats;
this.negatives = pool.negatives;
this.resolved = this.handles.map(function () {

@@ -98,7 +125,11 @@ return UNRESOLVED;

RuntimeConstants.prototype.getFloat = function getFloat(value) {
return this.floats[value - 1];
return this.floats[value];
};
RuntimeConstants.prototype.getNegative = function getNegative(value) {
return this.negatives[value - 1];
};
RuntimeConstants.prototype.getString = function getString(value) {
return this.strings[value - 1];
return this.strings[value];
};

@@ -117,7 +148,7 @@

RuntimeConstants.prototype.getArray = function getArray(value) {
return this.arrays[value - 1];
return this.arrays[value];
};
RuntimeConstants.prototype.getSymbolTable = function getSymbolTable(value) {
return this.tables[value - 1];
return this.tables[value];
};

@@ -136,3 +167,3 @@

RuntimeConstants.prototype.getSerializable = function getSerializable(s) {
return this.serializables[s - 1];
return this.serializables[s];
};

@@ -157,2 +188,4 @@

_this.serializables = pool.serializables;
_this.floats = pool.floats;
_this.negatives = pool.negatives;
_this.resolved = _this.handles.map(function () {

@@ -167,4 +200,12 @@ return UNRESOLVED;

Constants.prototype.getFloat = function getFloat(value) {
return this.floats[value - 1];
};
Constants.prototype.getNegative = function getNegative(value) {
return this.negatives[value - 1];
};
Constants.prototype.getString = function getString(value) {
return this.strings[value - 1];
return this.strings[value];
};

@@ -183,7 +224,7 @@

Constants.prototype.getArray = function getArray(value) {
return this.arrays[value - 1];
return this.arrays[value];
};
Constants.prototype.getSymbolTable = function getSymbolTable(value) {
return this.tables[value - 1];
return this.tables[value];
};

@@ -202,3 +243,3 @@

Constants.prototype.getSerializable = function getSerializable(s) {
return this.serializables[s - 1];
return this.serializables[s];
};

@@ -233,2 +274,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 } from \"@glimmer/interfaces\";\nimport { CompileTimeConstants } from \"@glimmer/opcode-compiler\";\n\nconst UNRESOLVED = {};\n\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][];\n  tables: SymbolTable[];\n  handles: number[];\n  serializables: Opaque[];\n  floats: number[];\n}\n\nexport const enum PrimitiveType {\n  NUMBER          = 0b00,\n  FLOAT           = 0b01,\n  STRING          = 0b10,\n  BOOLEAN_OR_VOID = 0b11\n}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] = [];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected serializables: Opaque[] = [];\n  protected resolved: Opaque[] = [];\n  protected floats: number[] = [];\n\n  float(float: number) {\n    return this.floats.push(float);\n  }\n\n  string(value: string): number {\n    return this.strings.push(value);\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    return this.arrays.push(values);\n  }\n\n  table(t: SymbolTable): number {\n    return this.tables.push(t);\n  }\n\n  handle(handle: number): number {\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle);\n  }\n\n  serializable(value: Opaque): number {\n    return this.serializables.push(value);\n  }\n\n  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      tables: this.tables,\n      handles: this.handles,\n      serializables: this.serializables,\n      floats: this.floats\n    };\n  }\n}\n\nexport class RuntimeConstants<Specifier> {\n  protected strings: string[];\n  protected arrays: number[][];\n  protected tables: SymbolTable[];\n  protected handles: number[];\n  protected serializables: Opaque[];\n  protected resolved: Opaque[];\n  protected floats: number[];\n\n  constructor(public resolver: RuntimeResolver<Specifier>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.tables = pool.tables;\n    this.handles = pool.handles;\n    this.serializables = pool.serializables;\n    this.floats = pool.floats;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n  }\n\n  // `0` means NULL\n\n  getFloat(value: number): number {\n    return this.floats[value - 1];\n  }\n\n  getString(value: number): string {\n    return this.strings[value - 1];\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[value - 1];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value - 1] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s - 1] as T;\n  }\n}\n\nexport class Constants<Specifier> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Specifier>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.tables = pool.tables;\n      this.handles = pool.handles;\n      this.serializables = pool.serializables;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n    }\n  }\n\n  // `0` means NULL\n\n  getString(value: number): string {\n    return this.strings[value - 1];\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[value - 1];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value - 1] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s - 1] as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\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\nexport interface ConstantPool {\n  strings: string[];\n  arrays: number[][];\n  tables: SymbolTable[];\n  handles: number[];\n  serializables: Opaque[];\n  floats: number[];\n  negatives: 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}\n\nexport class WriteOnlyConstants implements CompileTimeConstants {\n  // `0` means NULL\n\n  protected strings: string[] = [];\n  protected arrays: number[][] = [];\n  protected tables: SymbolTable[] = [];\n  protected handles: number[] = [];\n  protected serializables: Opaque[] = [];\n  protected resolved: Opaque[] = [];\n  protected floats: number[] = [];\n  protected negatives: number[] = [];\n\n  float(float: number) {\n    let index = this.floats.indexOf(float);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.floats.push(float) - 1;\n  }\n\n  negative(negative: number) {\n    return this.negatives.push(negative);\n  }\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    let index = this.arrays.indexOf(values);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.arrays.push(values) - 1;\n  }\n\n  table(t: SymbolTable): number {\n    let index = this.tables.indexOf(t);\n\n    if (index > -1) {\n      return index;\n    }\n\n    return this.tables.push(t) - 1;\n  }\n\n  handle(handle: number): number {\n    this.resolved.push(UNRESOLVED);\n    return this.handles.push(handle);\n  }\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  toPool(): ConstantPool {\n    return {\n      strings: this.strings,\n      arrays: this.arrays,\n      tables: this.tables,\n      handles: this.handles,\n      serializables: this.serializables,\n      floats: this.floats,\n      negatives: this.negatives\n    };\n  }\n}\n\nexport class RuntimeConstants<Specifier> {\n  protected strings: string[];\n  protected arrays: number[][];\n  protected tables: SymbolTable[];\n  protected handles: number[];\n  protected serializables: Opaque[];\n  protected resolved: Opaque[];\n  protected floats: number[];\n  protected negatives: number[];\n\n  constructor(public resolver: RuntimeResolver<Specifier>, pool: ConstantPool) {\n    this.strings = pool.strings;\n    this.arrays = pool.arrays;\n    this.tables = pool.tables;\n    this.handles = pool.handles;\n    this.serializables = pool.serializables;\n    this.floats = pool.floats;\n    this.negatives = pool.negatives;\n    this.resolved = this.handles.map(() => UNRESOLVED);\n  }\n\n  // `0` means NULL\n\n  getFloat(value: number): number {\n    return this.floats[value];\n  }\n\n  getNegative(value: number): number {\n    return this.negatives[value - 1];\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[value];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s] as T;\n  }\n}\n\nexport class Constants<Specifier> extends WriteOnlyConstants {\n  constructor(public resolver: RuntimeResolver<Specifier>, pool?: ConstantPool) {\n    super();\n\n    if (pool) {\n      this.strings = pool.strings;\n      this.arrays = pool.arrays;\n      this.tables = pool.tables;\n      this.handles = pool.handles;\n      this.serializables = pool.serializables;\n      this.floats = pool.floats;\n      this.negatives = pool.negatives;\n      this.resolved = this.handles.map(() => UNRESOLVED);\n    }\n  }\n\n  // `0` means NULL\n  getFloat(value: number): number {\n    return this.floats[value - 1];\n  }\n\n  getNegative(value: number): number {\n    return this.negatives[value - 1];\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[value];\n  }\n\n  getSymbolTable<T extends SymbolTable>(value: number): T {\n    return this.tables[value] as T;\n  }\n\n  resolveHandle<T>(s: number): T {\n    let index = s - 1;\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 this.serializables[s] as T;\n  }\n}\n\nexport class LazyConstants extends Constants<Opaque> {\n  private others: Opaque[] = [];\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"]}

@@ -22,18 +22,49 @@ 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 STATE_OFFSET = 3;
/**
* The Heap is responsible for dynamically allocating
* memory in which we read/write the VM's instructions
* from/to. When we malloc we pass out a VMHandle, which
* is used as an indirect way of accessing the memory during
* execution of the VM. Internally we track the different
* regions of the memory in an int array known as the table.
*
* The table has the following layout:
*
* | ... | table entry |
* | ... | hp | size | scope size | state |
* | ... | 0 | 122 | 3 | 0 |
* handle ^ | | ^ region state (allocated, freed, purged)
* region size ^ |
* number of symbols ^
*
* With this information we effectively have the ability to
* control when we want to free memory. That being said you
* can not free during execution as raw address are only
* valid during the execution. This means you cannot close
* over them as you will have a bad memory access exception.
*/
export var Heap = function () {
function Heap() {
function Heap(serializedHeap) {
_classCallCheck(this, Heap);
this.heap = [];
this.offset = 0;
this.handle = 0;
/**
* layout:
*
* - pointer into heap
* - size
* - scope size
* - freed (0 or 1)
*/
this.table = [];
if (serializedHeap) {
var buffer = serializedHeap.buffer,
table = serializedHeap.table,
handle = serializedHeap.handle;
this.heap = new Uint16Array(buffer);
this.table = table;
this.offset = this.heap.length;
this.handle = handle;
} else {
if (typeof Uint16Array !== 'undefined') {
this.heap = new Uint16Array(0x100000);
} else {
// FIXME remove once we drop IE9
this.heap = new Array(0x100000);
}
this.table = [];
}
}

@@ -100,3 +131,11 @@

};
/**
* The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift
* reachable memory to the bottom of the heap and freeable
* memory to the top of the heap. When we have shifted all
* the reachable memory to the top of the heap, we move the
* offset to the next free position.
*/
Heap.prototype.compact = function compact() {

@@ -132,4 +171,10 @@ var compactedSize = 0;

Heap.prototype.toArray = function toArray() {
return this.heap.slice();
Heap.prototype.capture = function capture() {
// Only called in eager mode
var buffer = slice(this.heap, 0, this.offset);
return {
handle: this.handle,
table: this.table,
buffer: buffer
};
};

@@ -185,2 +230,15 @@

}(WriteOnlyProgram);
//# 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 { Recast, VMHandle } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants } from './constants';\nimport { Opcode } from './opcode';\nimport { CompileTimeProgram } from \"@glimmer/opcode-compiler\";\n\nenum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst ENTRY_SIZE = 4;\nconst SIZE_OFFSET = 1;\nconst SCOPESIZE_OFFSET = 2;\nconst STATE_OFFSET = 3;\n\nexport class Heap {\n  private heap: number[] = [];\n  private offset = 0;\n  private handle = 0;\n\n  /**\n   * layout:\n   *\n   * - pointer into heap\n   * - size\n   * - scope size\n   * - freed (0 or 1)\n   */\n  private table: number[] = [];\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(): VMHandle {\n    this.table.push(this.offset, 0, 0, 0);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  finishMalloc(handle: VMHandle, scopeSize: number): void {\n    let start = this.table[handle as Recast<VMHandle, number>];\n    let finish = this.offset;\n    this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET] = finish - start;\n    this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET] = scopeSize;\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: VMHandle): number {\n    return this.table[handle as Recast<VMHandle, number>];\n  }\n\n  gethandle(address: number): VMHandle {\n    this.table.push(address, 0, 0, TableSlotState.Pointer);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  sizeof(handle: VMHandle): number {\n    if (DEBUG) {\n      return this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET];\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: VMHandle): number {\n    return this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET];\n  }\n\n  free(handle: VMHandle): void {\n    this.table[(handle as Recast<VMHandle, number>) + STATE_OFFSET] = 1;\n  }\n\n  compact(): void {\n    let compactedSize = 0;\n    let { table, table: { length }, heap } = this;\n\n    for (let i=0; i<length; i+=ENTRY_SIZE) {\n      let offset = table[i];\n      let size = table[i + SIZE_OFFSET];\n      let state = table[i + STATE_OFFSET];\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 + STATE_OFFSET] = 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  toArray(): number[] {\n    return this.heap.slice();\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<Specifier> {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Specifier>, 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<Specifier> extends WriteOnlyProgram {\n  public constants: Constants<Specifier>;\n}\n"]}
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;
}
return null;
}
//# 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 } from \"@glimmer/interfaces\";\nimport { DEBUG } from \"@glimmer/local-debug-flags\";\nimport { Constants, WriteOnlyConstants, RuntimeConstants } from './constants';\nimport { Opcode } from './opcode';\n\nenum TableSlotState {\n  Allocated,\n  Freed,\n  Purged,\n  Pointer\n}\n\nconst ENTRY_SIZE = 4;\nconst SIZE_OFFSET = 1;\nconst SCOPESIZE_OFFSET = 2;\nconst STATE_OFFSET = 3;\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 has the following layout:\n *\n * | ... |           table entry          |\n * | ... | hp | size | scope size | state |\n * | ... | 0  | 122  |      3     |   0   |\n *  handle ^     |          |         ^ region state (allocated, freed, purged)\n *   region size ^          |\n *        number of symbols ^\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 {\n  private heap: Uint16Array | Array<number>;\n  private table: number[];\n  private offset = 0;\n  private handle = 0;\n\n  constructor(serializedHeap?: { buffer: ArrayBuffer, table: number[], handle: number }) {\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      if (typeof Uint16Array !== 'undefined') {\n        this.heap = new Uint16Array(0x100000);\n      } else {\n        // FIXME remove once we drop IE9\n        this.heap = new Array(0x100000);\n      }\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(): VMHandle {\n    this.table.push(this.offset, 0, 0, 0);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  finishMalloc(handle: VMHandle, scopeSize: number): void {\n    let start = this.table[handle as Recast<VMHandle, number>];\n    let finish = this.offset;\n    this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET] = finish - start;\n    this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET] = scopeSize;\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: VMHandle): number {\n    return this.table[handle as Recast<VMHandle, number>];\n  }\n\n  gethandle(address: number): VMHandle {\n    this.table.push(address, 0, 0, TableSlotState.Pointer);\n    let handle = this.handle;\n    this.handle += ENTRY_SIZE;\n    return handle as Recast<number, VMHandle>;\n  }\n\n  sizeof(handle: VMHandle): number {\n    if (DEBUG) {\n      return this.table[(handle as Recast<VMHandle, number>) + SIZE_OFFSET];\n    }\n    return -1;\n  }\n\n  scopesizeof(handle: VMHandle): number {\n    return this.table[(handle as Recast<VMHandle, number>) + SCOPESIZE_OFFSET];\n  }\n\n  free(handle: VMHandle): void {\n    this.table[(handle as Recast<VMHandle, number>) + STATE_OFFSET] = 1;\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+=ENTRY_SIZE) {\n      let offset = table[i];\n      let size = table[i + SIZE_OFFSET];\n      let state = table[i + STATE_OFFSET];\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 + STATE_OFFSET] = 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  capture() {\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<Specifier> {\n  [key: number]: never;\n\n  private _opcode: Opcode;\n\n  constructor(public constants: RuntimeConstants<Specifier>, 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<Specifier> extends WriteOnlyProgram {\n  public constants: Constants<Specifier>;\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"]}

@@ -1,3 +0,2 @@

import { Opaque, SymbolTable, RuntimeResolver } from "@glimmer/interfaces";
import { CompileTimeConstants } from "@glimmer/opcode-compiler";
import { Opaque, SymbolTable, RuntimeResolver, CompileTimeConstants } from "@glimmer/interfaces";
export interface ConstantPool {

@@ -10,2 +9,3 @@ strings: string[];

floats: number[];
negatives: number[];
}

@@ -17,2 +17,3 @@ export declare const enum PrimitiveType {

BOOLEAN_OR_VOID = 3,
NEGATIVE = 4,
}

@@ -27,3 +28,5 @@ export declare class WriteOnlyConstants implements CompileTimeConstants {

protected floats: number[];
protected negatives: number[];
float(float: number): number;
negative(negative: number): number;
string(value: string): number;

@@ -46,4 +49,6 @@ stringArray(strings: string[]): number;

protected floats: number[];
protected negatives: number[];
constructor(resolver: RuntimeResolver<Specifier>, pool: ConstantPool);
getFloat(value: number): number;
getNegative(value: number): number;
getString(value: number): string;

@@ -59,2 +64,4 @@ getStringArray(value: number): string[];

constructor(resolver: RuntimeResolver<Specifier>, pool?: ConstantPool);
getFloat(value: number): number;
getNegative(value: number): number;
getString(value: number): string;

@@ -61,0 +68,0 @@ getStringArray(value: number): string[];

@@ -1,18 +0,37 @@

import { VMHandle } from "@glimmer/interfaces";
import { CompileTimeProgram, VMHandle } from "@glimmer/interfaces";
import { Constants, WriteOnlyConstants, RuntimeConstants } from './constants';
import { Opcode } from './opcode';
import { CompileTimeProgram } from "@glimmer/opcode-compiler";
/**
* The Heap is responsible for dynamically allocating
* memory in which we read/write the VM's instructions
* from/to. When we malloc we pass out a VMHandle, which
* is used as an indirect way of accessing the memory during
* execution of the VM. Internally we track the different
* regions of the memory in an int array known as the table.
*
* The table has the following layout:
*
* | ... | table entry |
* | ... | hp | size | scope size | state |
* | ... | 0 | 122 | 3 | 0 |
* handle ^ | | ^ region state (allocated, freed, purged)
* region size ^ |
* number of symbols ^
*
* With this information we effectively have the ability to
* control when we want to free memory. That being said you
* can not free during execution as raw address are only
* valid during the execution. This means you cannot close
* over them as you will have a bad memory access exception.
*/
export declare class Heap {
private heap;
private table;
private offset;
private handle;
/**
* layout:
*
* - pointer into heap
* - size
* - scope size
* - freed (0 or 1)
*/
private table;
constructor(serializedHeap?: {
buffer: ArrayBuffer;
table: number[];
handle: number;
});
push(item: number): void;

@@ -29,4 +48,15 @@ getbyaddr(address: number): number;

free(handle: VMHandle): void;
/**
* The heap uses the [Mark-Compact Algorithm](https://en.wikipedia.org/wiki/Mark-compact_algorithm) to shift
* reachable memory to the bottom of the heap and freeable
* memory to the top of the heap. When we have shifted all
* the reachable memory to the top of the heap, we move the
* offset to the next free position.
*/
compact(): void;
toArray(): number[];
capture(): {
handle: number;
table: number[];
buffer: ArrayBuffer;
};
}

@@ -33,0 +63,0 @@ export declare class WriteOnlyProgram implements CompileTimeProgram {

{
"name": "@glimmer/program",
"version": "0.28.3",
"version": "0.29.0",
"repository": "https://github.com/glimmerjs/glimmer-vm/tree/master/packages/@glimmer/program",
"dependencies": {
"@glimmer/util": "^0.28.3",
"@glimmer/interfaces": "^0.28.3",
"@glimmer/encoder": "^0.28.3"
"@glimmer/util": "^0.29.0",
"@glimmer/interfaces": "^0.29.0",
"@glimmer/encoder": "^0.29.0"
},

@@ -10,0 +10,0 @@ "devDependencies": {

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc