Socket
Socket
Sign inDemoInstall

@glimmer/runtime

Package Overview
Dependencies
Maintainers
10
Versions
289
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@glimmer/runtime - npm Package Compare versions

Comparing version 0.23.0-alpha.9 to 0.23.0-alpha.10

9

dist/commonjs/es2017/lib/vm/append.js

@@ -72,3 +72,2 @@ 'use strict';

exports.EvaluationStack = EvaluationStack;
let i = 0;
class VM {

@@ -153,5 +152,2 @@ constructor(env, scope, dynamicScope, elementStack) {

return() {
if (this.pc === this.ra + 4) {
throw "ZOMG";
}
this.pc = this.ra;

@@ -306,5 +302,2 @@ }

let opcode;
if (i++ > 100000) {
throw "zomg";
}
if (opcode = this.nextStatement(env)) {

@@ -340,2 +333,2 @@ _opcodes.APPEND_OPCODES.evaluate(this, opcode, opcode.type);

exports.default = VM;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"append.js","sourceRoot":"","sources":["append.ts"],"names":[],"mappings":"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","sourcesContent":["import { Register } from '../opcodes';\nimport { Scope, DynamicScope, Environment, Opcode } from '../environment';\nimport { ElementStack } from '../builder';\nimport { Option, Destroyable, Stack, LinkedList, ListSlice, Opaque, assert, expect } from '@glimmer/util';\nimport { ReferenceIterator, PathReference, VersionedPathReference, combineSlice } from '@glimmer/reference';\nimport { CompiledDynamicProgram } from '../compiled/blocks';\nimport { LabelOpcode, JumpIfNotModifiedOpcode, DidModifyOpcode } from '../compiled/opcodes/vm';\nimport { VMState, ListBlockOpcode, TryOpcode, BlockOpcode } from './update';\nimport RenderResult from './render-result';\n\nimport {\n  APPEND_OPCODES,\n  UpdatingOpcode\n} from '../opcodes';\n\nimport {\n  Constants,\n  ConstantString\n} from '../environment/constants';\n\nexport interface PublicVM {\n  env: Environment;\n  dynamicScope(): DynamicScope;\n  getSelf(): PathReference<Opaque>;\n  newDestroyable(d: Destroyable): void;\n}\n\nexport type CapturedStack = Opaque[];\n\nexport class EvaluationStack {\n  static empty(): EvaluationStack {\n    return new this([], 0, -1);\n  }\n\n  static restore(snapshot: CapturedStack): EvaluationStack {\n    return new this(snapshot.slice(), 0, snapshot.length - 1);\n  }\n\n  constructor(private stack: Opaque[], public fp: number, public sp: number) {\n    Object.seal(this);\n  }\n\n  isEmpty() {\n    return this.sp === -1;\n  }\n\n  push(value: Opaque): void {\n    this.stack[++this.sp] = value;\n  }\n\n  dup(position = this.sp): void {\n    this.push(this.stack[position]);\n  }\n\n  pop<T>(n = 1): T {\n    let top = this.stack[this.sp] as T;\n    this.sp -= n;\n    return top;\n  }\n\n  peek<T>(): T {\n    return this.stack[this.sp] as T;\n  }\n\n  fromBase<T>(offset: number): T {\n    return this.stack[this.fp - offset] as T;\n  }\n\n  fromTop<T>(offset: number): T {\n    return this.stack[this.sp - offset] as T;\n  }\n\n  capture(items: number): CapturedStack {\n    let end = this.sp + 1;\n    let start = end - items;\n    return this.stack.slice(start, end);\n  }\n\n  toArray() {\n    return this.stack.slice(this.fp, this.sp + 1);\n  }\n}\n\nexport type IteratorResult<T> = {\n  done: false;\n  value: null;\n} | {\n  done: true;\n  value: T;\n};\n\nlet i = 0;\n\nexport default class VM implements PublicVM {\n  private dynamicScopeStack = new Stack<DynamicScope>();\n  private scopeStack = new Stack<Scope>();\n  public updatingOpcodeStack = new Stack<LinkedList<UpdatingOpcode>>();\n  public cacheGroups = new Stack<Option<UpdatingOpcode>>();\n  public listBlockStack = new Stack<ListBlockOpcode>();\n  public constants: Constants;\n\n  public stack = EvaluationStack.empty();\n\n  /** Registers **/\n\n  private pc = -1;\n  private ra = -1;\n\n  private get fp(): number {\n    return this.stack.fp;\n  }\n\n  private set fp(fp: number) {\n    this.stack.fp = fp;\n  }\n\n  private get sp(): number {\n    return this.stack.sp;\n  }\n\n  private set sp(sp: number) {\n    this.stack.sp = sp;\n  }\n\n  public s0: any = null;\n  public s1: any = null;\n  public t0: any = null;\n  public t1: any = null;\n\n  // Fetch a value from a register onto the stack\n  fetch(register: Register) {\n    this.stack.push(this[Register[register]]);\n  }\n\n  // Load a value from the stack into a register\n  load(register: Register) {\n    this[Register[register]] = this.stack.pop();\n  }\n\n  // Fetch a value from a register\n  fetchValue<T>(register: Register): T {\n    return this[Register[register]];\n  }\n\n  // Load a value into a register\n  loadValue<T>(register: Register, value: T) {\n    this[Register[register]] = value;\n  }\n\n  // Start a new frame and save $ra and $fp on the stack\n  pushFrame() {\n    this.stack.push(this.ra);\n    this.stack.push(this.fp);\n    this.fp = this.sp - 1;\n    // this.fp = this.sp + 1;\n  }\n\n  // Restore $ra, $sp and $fp\n  popFrame() {\n    this.sp = this.fp - 1;\n    this.ra = this.stack.fromBase<number>(0);\n    this.fp = this.stack.fromBase<number>(-1);\n  }\n\n  // Jump to an address in `program`\n  goto(pc: number) {\n    this.pc = pc;\n  }\n\n  // Save $pc into $ra, then jump to a new address in `program` (jal in MIPS)\n  call(pc: number) {\n    this.ra = this.pc;\n    this.pc = pc;\n  }\n\n  // Put a specific `program` address in $ra\n  returnTo(ra: number) {\n    this.ra = ra;\n  }\n\n  // Return to the `program` address stored in $ra\n  return() {\n    if (this.pc === (this.ra + 4)) {\n      throw \"ZOMG\";\n    }\n\n    this.pc = this.ra;\n  }\n\n  static initial(\n    env: Environment,\n    self: PathReference<Opaque>,\n    dynamicScope: DynamicScope,\n    elementStack: ElementStack,\n    program: CompiledDynamicProgram\n  ) {\n    let scope = Scope.root(self, program.symbolTable.symbols.length);\n    let vm = new VM(env, scope, dynamicScope, elementStack);\n    vm.pc = program.start;\n    vm.updatingOpcodeStack.push(new LinkedList<UpdatingOpcode>());\n    return vm;\n  }\n\n  constructor(\n    public env: Environment,\n    scope: Scope,\n    dynamicScope: DynamicScope,\n    private elementStack: ElementStack,\n  ) {\n    this.env = env;\n    this.constants = env.constants;\n    this.elementStack = elementStack;\n    this.scopeStack.push(scope);\n    this.dynamicScopeStack.push(dynamicScope);\n  }\n\n  capture(args: number): VMState {\n    return {\n      env: this.env,\n      scope: this.scope(),\n      dynamicScope: this.dynamicScope(),\n      stack: this.stack.capture(args)\n    };\n  }\n\n  beginCacheGroup() {\n    this.cacheGroups.push(this.updating().tail());\n  }\n\n  commitCacheGroup() {\n    //        JumpIfNotModified(END)\n    //        (head)\n    //        (....)\n    //        (tail)\n    //        DidModify\n    // END:   Noop\n\n    let END = new LabelOpcode(\"END\");\n\n    let opcodes = this.updating();\n    let marker = this.cacheGroups.pop();\n    let head = marker ? opcodes.nextNode(marker) : opcodes.head();\n    let tail = opcodes.tail();\n    let tag = combineSlice(new ListSlice(head, tail));\n\n    let guard = new JumpIfNotModifiedOpcode(tag, END);\n\n    opcodes.insertBefore(guard, head);\n    opcodes.append(new DidModifyOpcode(guard));\n    opcodes.append(END);\n  }\n\n  enter(args: number) {\n    let updating = new LinkedList<UpdatingOpcode>();\n\n    let state = this.capture(args);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    let tryOpcode = new TryOpcode(this.pc, state, tracker, updating);\n\n    this.didEnter(tryOpcode);\n  }\n\n  iterate(memo: VersionedPathReference<Opaque>, value: VersionedPathReference<Opaque>, updating = new LinkedList<UpdatingOpcode>()): TryOpcode {\n    let stack = this.stack;\n    stack.push(value);\n    stack.push(memo);\n\n    let state = this.capture(2);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    // let ip = this.ip;\n    // this.ip = end + 4;\n    // this.frames.push(ip);\n\n    return new TryOpcode(this.pc, state, tracker, updating);\n  }\n\n  enterItem(key: string, opcode: TryOpcode) {\n    this.listBlock().map[key] = opcode;\n    this.didEnter(opcode);\n  }\n\n  enterList(start: number) {\n    let updating = new LinkedList<BlockOpcode>();\n\n    let state = this.capture(0);\n    let tracker = this.elements().pushBlockList(updating);\n    let artifacts = this.stack.peek<ReferenceIterator>().artifacts;\n\n    let opcode = new ListBlockOpcode(start, state, tracker, updating, artifacts);\n\n    this.listBlockStack.push(opcode);\n\n    this.didEnter(opcode);\n  }\n\n  private didEnter(opcode: BlockOpcode) {\n    this.updateWith(opcode);\n    this.updatingOpcodeStack.push(opcode.children);\n  }\n\n  exit() {\n    this.elements().popBlock();\n    this.updatingOpcodeStack.pop();\n\n    let parent = this.updating().tail() as BlockOpcode;\n\n    parent.didInitializeChildren();\n  }\n\n  exitList() {\n    this.exit();\n    this.listBlockStack.pop();\n  }\n\n  updateWith(opcode: UpdatingOpcode) {\n    this.updating().append(opcode);\n  }\n\n  listBlock(): ListBlockOpcode {\n    return expect(this.listBlockStack.current, 'expected a list block');\n  }\n\n  updating(): LinkedList<UpdatingOpcode> {\n    return expect(this.updatingOpcodeStack.current, 'expected updating opcode on the updating opcode stack');\n  }\n\n  elements(): ElementStack {\n    return this.elementStack;\n  }\n\n  scope(): Scope {\n    return expect(this.scopeStack.current, 'expected scope on the scope stack');\n  }\n\n  dynamicScope(): DynamicScope {\n    return expect(this.dynamicScopeStack.current, 'expected dynamic scope on the dynamic scope stack');\n  }\n\n  pushChildScope() {\n    this.scopeStack.push(this.scope().child());\n  }\n\n  pushCallerScope(childScope = false) {\n    let callerScope = expect(this.scope().getCallerScope(), 'pushCallerScope is called when a caller scope is present');\n    this.scopeStack.push(childScope ? callerScope.child() : callerScope);\n  }\n\n  pushDynamicScope(): DynamicScope {\n    let child = this.dynamicScope().child();\n    this.dynamicScopeStack.push(child);\n    return child;\n  }\n\n  pushRootScope(size: number, bindCaller: boolean): Scope {\n    let scope = Scope.sized(size);\n    if (bindCaller) scope.bindCallerScope(this.scope());\n    this.scopeStack.push(scope);\n    return scope;\n  }\n\n  popScope() {\n    this.scopeStack.pop();\n  }\n\n  popDynamicScope() {\n    this.dynamicScopeStack.pop();\n  }\n\n  newDestroyable(d: Destroyable) {\n    this.elements().newDestroyable(d);\n  }\n\n  /// SCOPE HELPERS\n\n  getSelf(): PathReference<any> {\n    return this.scope().getSelf();\n  }\n\n  referenceForSymbol(symbol: number): PathReference<any> {\n    return this.scope().getSymbol(symbol);\n  }\n\n  /// EXECUTION\n\n  execute(start: number, initialize?: (vm: VM) => void): RenderResult {\n    this.pc = start;\n\n    if (initialize) initialize(this);\n\n    let result: IteratorResult<RenderResult>;\n\n    while (true) {\n      result = this.next();\n      if (result.done) break;\n    }\n\n    return result.value as RenderResult;\n  }\n\n  next(): IteratorResult<RenderResult> {\n    let { env, updatingOpcodeStack, elementStack } = this;\n    let opcode: Option<Opcode>;\n\n    if (i++ > 100000) {\n      throw \"zomg\";\n    }\n\n    if (opcode = this.nextStatement(env)) {\n      APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n      return { done: false, value: null };\n    }\n\n    return {\n      done: true,\n      value: new RenderResult(\n        env,\n        expect(updatingOpcodeStack.pop(), 'there should be a final updating opcode stack'),\n        elementStack.popBlock()\n      )\n    };\n  }\n\n  private nextStatement(env: Environment): Option<Opcode> {\n    let { pc } = this;\n\n    if (pc === -1) {\n      return null;\n    }\n\n    let program = env.program;\n    this.pc += 4;\n    return program.opcode(pc);\n  }\n\n  evaluateOpcode(opcode: Opcode) {\n    APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n  }\n\n  bindDynamicScope(names: ConstantString[]) {\n    let scope = this.dynamicScope();\n\n    for(let i=names.length - 1; i>=0; i--) {\n      let name = this.constants.getString(names[i]);\n      scope.set(name, this.stack.pop<VersionedPathReference<Opaque>>());\n    }\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"append.js","sourceRoot":"","sources":["append.ts"],"names":[],"mappings":";;;;;;;AAAA,AAAO,AAAE,AAAQ,AAAE,AAAM,AAAY,AAAC;;AACtC,AAAO,AAAE,AAAK,AAAqC,AAAM,AAAgB,AAAC;;AAE1E,AAAO,AAAuB,AAAK,AAAE,AAAU,AAAE,AAAS,AAAkB,AAAM,AAAE,AAAM,AAAe,AAAC;;AAC1G,AAAO,AAA4D,AAAY,AAAE,AAAM,AAAoB,AAAC;;AAE5G,AAAO,AAAE,AAAW,AAAE,AAAuB,AAAE,AAAe,AAAE,AAAM,AAAwB,AAAC;;AAC/F,AAAO,AAAW,AAAe,AAAE,AAAS,AAAe,AAAM,AAAU,AAAC;;AAC5E,AAAO,AAAY,AAAM,AAAiB,AAAC,AAE3C,AAAO,AACL,AAAc,AAEf,AAAM,AAAY,AAAC,AAgBpB,AAAM;;;;;;;AASJ,gBAAoB,AAAe,OAAS,AAAU,IAAS,AAAU;AAArD,aAAK,QAAL,AAAK,AAAU;AAAS,aAAE,KAAF,AAAE,AAAQ;AAAS,aAAE,KAAF,AAAE,AAAQ;AACvE,AAAM,eAAC,AAAI,KAAC,AAAI,AAAC,AAAC,AACpB;AAAC;AAVD,AAAM,WAAC,AAAK;AACV,AAAM,eAAC,IAAI,AAAI,KAAC,AAAE,IAAE,AAAC,GAAE,CAAC,AAAC,AAAC,AAAC,AAC7B;AAAC;AAED,AAAM,WAAC,AAAO,QAAC,AAAuB;AACpC,AAAM,eAAC,IAAI,AAAI,KAAC,AAAQ,SAAC,AAAK,AAAE,SAAE,AAAC,GAAE,AAAQ,SAAC,AAAM,SAAG,AAAC,AAAC,AAAC,AAC5D;AAAC;AAMD,AAAO;AACL,AAAM,eAAC,AAAI,KAAC,AAAE,OAAK,CAAC,AAAC,AAAC,AACxB;AAAC;AAED,AAAI,SAAC,AAAa;AAChB,AAAI,aAAC,AAAK,MAAC,EAAE,AAAI,KAAC,AAAE,AAAC,MAAG,AAAK,AAAC,AAChC;AAAC;AAED,AAAG,QAAC,AAAQ,WAAG,AAAI,KAAC,AAAE;AACpB,AAAI,aAAC,AAAI,KAAC,AAAI,KAAC,AAAK,MAAC,AAAQ,AAAC,AAAC,AAAC,AAClC;AAAC;AAED,AAAG,QAAI,AAAC,IAAG,AAAC;AACV,YAAI,AAAG,MAAG,AAAI,KAAC,AAAK,MAAC,AAAI,KAAC,AAAE,AAAM,AAAC;AACnC,AAAI,aAAC,AAAE,MAAI,AAAC,AAAC;AACb,AAAM,eAAC,AAAG,AAAC,AACb;AAAC;AAED,AAAI;AACF,AAAM,eAAC,AAAI,KAAC,AAAK,MAAC,AAAI,KAAC,AAAE,AAAM,AAAC,AAClC;AAAC;AAED,AAAQ,aAAI,AAAc;AACxB,AAAM,eAAC,AAAI,KAAC,AAAK,MAAC,AAAI,KAAC,AAAE,KAAG,AAAM,AAAM,AAAC,AAC3C;AAAC;AAED,AAAO,YAAI,AAAc;AACvB,AAAM,eAAC,AAAI,KAAC,AAAK,MAAC,AAAI,KAAC,AAAE,KAAG,AAAM,AAAM,AAAC,AAC3C;AAAC;AAED,AAAO,YAAC,AAAa;AACnB,YAAI,AAAG,MAAG,AAAI,KAAC,AAAE,KAAG,AAAC,AAAC;AACtB,YAAI,AAAK,QAAG,AAAG,MAAG,AAAK,AAAC;AACxB,AAAM,eAAC,AAAI,KAAC,AAAK,MAAC,AAAK,MAAC,AAAK,OAAE,AAAG,AAAC,AAAC,AACtC;AAAC;AAED,AAAO;AACL,AAAM,eAAC,AAAI,KAAC,AAAK,MAAC,AAAK,MAAC,AAAI,KAAC,AAAE,IAAE,AAAI,KAAC,AAAE,KAAG,AAAC,AAAC,AAAC,AAChD;AAAC,AACF,AAUD,AAAM,AAAC,AAAO;;;;AA0GZ,gBACS,AAAgB,KACvB,AAAY,OACZ,AAA0B,cAClB,AAA0B;AAH3B,aAAG,MAAH,AAAG,AAAa;AAGf,aAAY,eAAZ,AAAY,AAAc;AA7G5B,aAAiB,oBAAG,AAAI,AAAK,AAAgB,AAAC;AAC9C,aAAU,aAAG,AAAI,AAAK,AAAS,AAAC;AACjC,aAAmB,sBAAG,AAAI,AAAK,AAA8B,AAAC;AAC9D,aAAW,cAAG,AAAI,AAAK,AAA0B,AAAC;AAClD,aAAc,iBAAG,AAAI,AAAK,AAAmB,AAAC;AAG9C,aAAK,QAAG,AAAe,gBAAC,AAAK,AAAE,AAAC;AAEvC,AAAiB;AAET,aAAE,KAAG,CAAC,AAAC,AAAC;AACR,aAAE,KAAG,CAAC,AAAC,AAAC;AAkBT,aAAE,KAAQ,AAAI,AAAC;AACf,aAAE,KAAQ,AAAI,AAAC;AACf,aAAE,KAAQ,AAAI,AAAC;AACf,aAAE,KAAQ,AAAI,AAAC;AA8EpB,AAAI,aAAC,AAAG,MAAG,AAAG,AAAC;AACf,AAAI,aAAC,AAAS,YAAG,AAAG,IAAC,AAAS,AAAC;AAC/B,AAAI,aAAC,AAAY,eAAG,AAAY,AAAC;AACjC,AAAI,aAAC,AAAU,WAAC,AAAI,KAAC,AAAK,AAAC,AAAC;AAC5B,AAAI,aAAC,AAAiB,kBAAC,AAAI,KAAC,AAAY,AAAC,AAAC,AAC5C;AAAC;AAtGD,QAAY,AAAE;AACZ,AAAM,eAAC,AAAI,KAAC,AAAK,MAAC,AAAE,AAAC,AACvB;AAAC;AAED,QAAY,AAAE,GAAC,AAAU;AACvB,AAAI,aAAC,AAAK,MAAC,AAAE,KAAG,AAAE,AAAC,AACrB;AAAC;AAED,QAAY,AAAE;AACZ,AAAM,eAAC,AAAI,KAAC,AAAK,MAAC,AAAE,AAAC,AACvB;AAAC;AAED,QAAY,AAAE,GAAC,AAAU;AACvB,AAAI,aAAC,AAAK,MAAC,AAAE,KAAG,AAAE,AAAC,AACrB;AAAC;AAOD,AAA+C;AAC/C,AAAK,UAAC,AAAkB;AACtB,AAAI,aAAC,AAAK,MAAC,AAAI,KAAC,AAAI,KAAC,AAAQ,kBAAC,AAAQ,AAAC,AAAC,AAAC,AAAC,AAC5C;AAAC;AAED,AAA8C;AAC9C,AAAI,SAAC,AAAkB;AACrB,AAAI,aAAC,AAAQ,kBAAC,AAAQ,AAAC,AAAC,aAAG,AAAI,KAAC,AAAK,MAAC,AAAG,AAAE,AAAC,AAC9C;AAAC;AAED,AAAgC;AAChC,AAAU,eAAI,AAAkB;AAC9B,AAAM,eAAC,AAAI,KAAC,AAAQ,kBAAC,AAAQ,AAAC,AAAC,AAAC,AAClC;AAAC;AAED,AAA+B;AAC/B,AAAS,cAAI,AAAkB,UAAE,AAAQ;AACvC,AAAI,aAAC,AAAQ,kBAAC,AAAQ,AAAC,AAAC,aAAG,AAAK,AAAC,AACnC;AAAC;AAED,AAAsD;AACtD,AAAS;AACP,AAAI,aAAC,AAAK,MAAC,AAAI,KAAC,AAAI,KAAC,AAAE,AAAC,AAAC;AACzB,AAAI,aAAC,AAAK,MAAC,AAAI,KAAC,AAAI,KAAC,AAAE,AAAC,AAAC;AACzB,AAAI,aAAC,AAAE,KAAG,AAAI,KAAC,AAAE,KAAG,AAAC,AAAC;AACtB,AAAyB,AAC3B;AAAC;AAED,AAA2B;AAC3B,AAAQ;AACN,AAAI,aAAC,AAAE,KAAG,AAAI,KAAC,AAAE,KAAG,AAAC,AAAC;AACtB,AAAI,aAAC,AAAE,KAAG,AAAI,KAAC,AAAK,MAAC,AAAQ,SAAS,AAAC,AAAC,AAAC;AACzC,AAAI,aAAC,AAAE,KAAG,AAAI,KAAC,AAAK,MAAC,AAAQ,SAAS,CAAC,AAAC,AAAC,AAAC,AAC5C;AAAC;AAED,AAAkC;AAClC,AAAI,SAAC,AAAU;AACb,AAAI,aAAC,AAAE,KAAG,AAAE,AAAC,AACf;AAAC;AAED,AAA2E;AAC3E,AAAI,SAAC,AAAU;AACb,AAAI,aAAC,AAAE,KAAG,AAAI,KAAC,AAAE,AAAC;AAClB,AAAI,aAAC,AAAE,KAAG,AAAE,AAAC,AACf;AAAC;AAED,AAA0C;AAC1C,AAAQ,aAAC,AAAU;AACjB,AAAI,aAAC,AAAE,KAAG,AAAE,AAAC,AACf;AAAC;AAED,AAAgD;AAChD,AAAM;AACJ,AAAI,aAAC,AAAE,KAAG,AAAI,KAAC,AAAE,AAAC,AACpB;AAAC;AAED,AAAM,WAAC,AAAO,QACZ,AAAgB,KAChB,AAA2B,MAC3B,AAA0B,cAC1B,AAA0B,cAC1B,AAA+B;AAE/B,YAAI,AAAK,QAAG,AAAK,mBAAC,AAAI,KAAC,AAAI,MAAE,AAAO,QAAC,AAAW,YAAC,AAAO,QAAC,AAAM,AAAC,AAAC;AACjE,YAAI,AAAE,KAAG,IAAI,AAAE,GAAC,AAAG,KAAE,AAAK,OAAE,AAAY,cAAE,AAAY,AAAC,AAAC;AACxD,AAAE,WAAC,AAAE,KAAG,AAAO,QAAC,AAAK,AAAC;AACtB,AAAE,WAAC,AAAmB,oBAAC,AAAI,KAAC,AAAI,AAAU,AAAkB,AAAC,AAAC;AAC9D,AAAM,eAAC,AAAE,AAAC,AACZ;AAAC;AAeD,AAAO,YAAC,AAAY;AAClB,AAAM;AACJ,AAAG,iBAAE,AAAI,KAAC,AAAG;AACb,AAAK,mBAAE,AAAI,KAAC,AAAK,AAAE;AACnB,AAAY,0BAAE,AAAI,KAAC,AAAY,AAAE;AACjC,AAAK,mBAAE,AAAI,KAAC,AAAK,MAAC,AAAO,QAAC,AAAI,AAAC,AAChC,AAAC,AACJ;AANS;AAMR;AAED,AAAe;AACb,AAAI,aAAC,AAAW,YAAC,AAAI,KAAC,AAAI,KAAC,AAAQ,AAAE,WAAC,AAAI,AAAE,AAAC,AAAC,AAChD;AAAC;AAED,AAAgB;AACd,AAAgC;AAChC,AAAgB;AAChB,AAAgB;AAChB,AAAgB;AAChB,AAAmB;AACnB,AAAc;AAEd,YAAI,AAAG,MAAG,AAAI,AAAW,oBAAC,AAAK,AAAC,AAAC;AAEjC,YAAI,AAAO,UAAG,AAAI,KAAC,AAAQ,AAAE,AAAC;AAC9B,YAAI,AAAM,SAAG,AAAI,KAAC,AAAW,YAAC,AAAG,AAAE,AAAC;AACpC,YAAI,AAAI,OAAG,AAAM,SAAG,AAAO,QAAC,AAAQ,SAAC,AAAM,AAAC,UAAG,AAAO,QAAC,AAAI,AAAE,AAAC;AAC9D,YAAI,AAAI,OAAG,AAAO,QAAC,AAAI,AAAE,AAAC;AAC1B,YAAI,AAAG,MAAG,AAAY,6BAAC,AAAI,AAAS,oBAAC,AAAI,MAAE,AAAI,AAAC,AAAC,AAAC;AAElD,YAAI,AAAK,QAAG,AAAI,AAAuB,gCAAC,AAAG,KAAE,AAAG,AAAC,AAAC;AAElD,AAAO,gBAAC,AAAY,aAAC,AAAK,OAAE,AAAI,AAAC,AAAC;AAClC,AAAO,gBAAC,AAAM,OAAC,AAAI,AAAe,wBAAC,AAAK,AAAC,AAAC,AAAC;AAC3C,AAAO,gBAAC,AAAM,OAAC,AAAG,AAAC,AAAC,AACtB;AAAC;AAED,AAAK,UAAC,AAAY;AAChB,YAAI,AAAQ,WAAG,AAAI,AAAU,AAAkB,AAAC;AAEhD,YAAI,AAAK,QAAG,AAAI,KAAC,AAAO,QAAC,AAAI,AAAC,AAAC;AAC/B,YAAI,AAAO,UAAG,AAAI,KAAC,AAAQ,AAAE,WAAC,AAAkB,AAAE,AAAC;AAEnD,YAAI,AAAS,YAAG,AAAI,AAAS,sBAAC,AAAI,KAAC,AAAE,IAAE,AAAK,OAAE,AAAO,SAAE,AAAQ,AAAC,AAAC;AAEjE,AAAI,aAAC,AAAQ,SAAC,AAAS,AAAC,AAAC,AAC3B;AAAC;AAED,AAAO,YAAC,AAAoC,MAAE,AAAqC,OAAE,AAAQ,WAAG,AAAI,AAAU,AAAkB;AAC9H,YAAI,AAAK,QAAG,AAAI,KAAC,AAAK,AAAC;AACvB,AAAK,cAAC,AAAI,KAAC,AAAK,AAAC,AAAC;AAClB,AAAK,cAAC,AAAI,KAAC,AAAI,AAAC,AAAC;AAEjB,YAAI,AAAK,QAAG,AAAI,KAAC,AAAO,QAAC,AAAC,AAAC,AAAC;AAC5B,YAAI,AAAO,UAAG,AAAI,KAAC,AAAQ,AAAE,WAAC,AAAkB,AAAE,AAAC;AAEnD,AAAoB;AACpB,AAAqB;AACrB,AAAwB;AAExB,AAAM,eAAC,AAAI,AAAS,sBAAC,AAAI,KAAC,AAAE,IAAE,AAAK,OAAE,AAAO,SAAE,AAAQ,AAAC,AAAC,AAC1D;AAAC;AAED,AAAS,cAAC,AAAW,KAAE,AAAiB;AACtC,AAAI,aAAC,AAAS,AAAE,YAAC,AAAG,IAAC,AAAG,AAAC,OAAG,AAAM,AAAC;AACnC,AAAI,aAAC,AAAQ,SAAC,AAAM,AAAC,AAAC,AACxB;AAAC;AAED,AAAS,cAAC,AAAa;AACrB,YAAI,AAAQ,WAAG,AAAI,AAAU,AAAe,AAAC;AAE7C,YAAI,AAAK,QAAG,AAAI,KAAC,AAAO,QAAC,AAAC,AAAC,AAAC;AAC5B,YAAI,AAAO,UAAG,AAAI,KAAC,AAAQ,AAAE,WAAC,AAAa,cAAC,AAAQ,AAAC,AAAC;AACtD,YAAI,AAAS,YAAG,AAAI,KAAC,AAAK,MAAC,AAAI,AAAqB,OAAC,AAAS,AAAC;AAE/D,YAAI,AAAM,SAAG,AAAI,AAAe,4BAAC,AAAK,OAAE,AAAK,OAAE,AAAO,SAAE,AAAQ,UAAE,AAAS,AAAC,AAAC;AAE7E,AAAI,aAAC,AAAc,eAAC,AAAI,KAAC,AAAM,AAAC,AAAC;AAEjC,AAAI,aAAC,AAAQ,SAAC,AAAM,AAAC,AAAC,AACxB;AAAC;AAEO,AAAQ,aAAC,AAAmB;AAClC,AAAI,aAAC,AAAU,WAAC,AAAM,AAAC,AAAC;AACxB,AAAI,aAAC,AAAmB,oBAAC,AAAI,KAAC,AAAM,OAAC,AAAQ,AAAC,AAAC,AACjD;AAAC;AAED,AAAI;AACF,AAAI,aAAC,AAAQ,AAAE,WAAC,AAAQ,AAAE,AAAC;AAC3B,AAAI,aAAC,AAAmB,oBAAC,AAAG,AAAE,AAAC;AAE/B,YAAI,AAAM,SAAG,AAAI,KAAC,AAAQ,AAAE,WAAC,AAAI,AAAiB,AAAC;AAEnD,AAAM,eAAC,AAAqB,AAAE,AAAC,AACjC;AAAC;AAED,AAAQ;AACN,AAAI,aAAC,AAAI,AAAE,AAAC;AACZ,AAAI,aAAC,AAAc,eAAC,AAAG,AAAE,AAAC,AAC5B;AAAC;AAED,AAAU,eAAC,AAAsB;AAC/B,AAAI,aAAC,AAAQ,AAAE,WAAC,AAAM,OAAC,AAAM,AAAC,AAAC,AACjC;AAAC;AAED,AAAS;AACP,AAAM,eAAC,AAAM,kBAAC,AAAI,KAAC,AAAc,eAAC,AAAO,SAAE,AAAuB,AAAC,AAAC,AACtE;AAAC;AAED,AAAQ;AACN,AAAM,eAAC,AAAM,kBAAC,AAAI,KAAC,AAAmB,oBAAC,AAAO,SAAE,AAAuD,AAAC,AAAC,AAC3G;AAAC;AAED,AAAQ;AACN,AAAM,eAAC,AAAI,KAAC,AAAY,AAAC,AAC3B;AAAC;AAED,AAAK;AACH,AAAM,eAAC,AAAM,kBAAC,AAAI,KAAC,AAAU,WAAC,AAAO,SAAE,AAAmC,AAAC,AAAC,AAC9E;AAAC;AAED,AAAY;AACV,AAAM,eAAC,AAAM,kBAAC,AAAI,KAAC,AAAiB,kBAAC,AAAO,SAAE,AAAmD,AAAC,AAAC,AACrG;AAAC;AAED,AAAc;AACZ,AAAI,aAAC,AAAU,WAAC,AAAI,KAAC,AAAI,KAAC,AAAK,AAAE,QAAC,AAAK,AAAE,AAAC,AAAC,AAC7C;AAAC;AAED,AAAe,oBAAC,AAAU,aAAG,AAAK;AAChC,YAAI,AAAW,cAAG,AAAM,kBAAC,AAAI,KAAC,AAAK,AAAE,QAAC,AAAc,AAAE,kBAAE,AAA0D,AAAC,AAAC;AACpH,AAAI,aAAC,AAAU,WAAC,AAAI,KAAC,AAAU,aAAG,AAAW,YAAC,AAAK,AAAE,UAAG,AAAW,AAAC,AAAC,AACvE;AAAC;AAED,AAAgB;AACd,YAAI,AAAK,QAAG,AAAI,KAAC,AAAY,AAAE,eAAC,AAAK,AAAE,AAAC;AACxC,AAAI,aAAC,AAAiB,kBAAC,AAAI,KAAC,AAAK,AAAC,AAAC;AACnC,AAAM,eAAC,AAAK,AAAC,AACf;AAAC;AAED,AAAa,kBAAC,AAAY,MAAE,AAAmB;AAC7C,YAAI,AAAK,QAAG,AAAK,mBAAC,AAAK,MAAC,AAAI,AAAC,AAAC;AAC9B,AAAE,AAAC,YAAC,AAAU,AAAC,YAAC,AAAK,MAAC,AAAe,gBAAC,AAAI,KAAC,AAAK,AAAE,AAAC,AAAC;AACpD,AAAI,aAAC,AAAU,WAAC,AAAI,KAAC,AAAK,AAAC,AAAC;AAC5B,AAAM,eAAC,AAAK,AAAC,AACf;AAAC;AAED,AAAQ;AACN,AAAI,aAAC,AAAU,WAAC,AAAG,AAAE,AAAC,AACxB;AAAC;AAED,AAAe;AACb,AAAI,aAAC,AAAiB,kBAAC,AAAG,AAAE,AAAC,AAC/B;AAAC;AAED,AAAc,mBAAC,AAAc;AAC3B,AAAI,aAAC,AAAQ,AAAE,WAAC,AAAc,eAAC,AAAC,AAAC,AAAC,AACpC;AAAC;AAED,AAAiB;AAEjB,AAAO;AACL,AAAM,eAAC,AAAI,KAAC,AAAK,AAAE,QAAC,AAAO,AAAE,AAAC,AAChC;AAAC;AAED,AAAkB,uBAAC,AAAc;AAC/B,AAAM,eAAC,AAAI,KAAC,AAAK,AAAE,QAAC,AAAS,UAAC,AAAM,AAAC,AAAC,AACxC;AAAC;AAED,AAAa;AAEb,AAAO,YAAC,AAAa,OAAE,AAA6B;AAClD,AAAI,aAAC,AAAE,KAAG,AAAK,AAAC;AAEhB,AAAE,AAAC,YAAC,AAAU,AAAC,YAAC,AAAU,WAAC,AAAI,AAAC,AAAC;AAEjC,YAAI,AAAoC,AAAC;AAEzC,eAAO,AAAI,MAAE,AAAC;AACZ,AAAM,qBAAG,AAAI,KAAC,AAAI,AAAE,AAAC;AACrB,AAAE,AAAC,gBAAC,AAAM,OAAC,AAAI,AAAC,MAAC,AAAK,AAAC,AACzB;AAAC;AAED,AAAM,eAAC,AAAM,OAAC,AAAqB,AAAC,AACtC;AAAC;AAED,AAAI;AACF,YAAI,EAAE,AAAG,KAAE,AAAmB,qBAAE,AAAY,AAAE,iBAAG,AAAI,AAAC;AACtD,YAAI,AAAsB,AAAC;AAE3B,AAAE,AAAC,YAAC,AAAM,SAAG,AAAI,KAAC,AAAa,cAAC,AAAG,AAAC,AAAC,MAAC,AAAC;AACrC,AAAc,oCAAC,AAAQ,SAAC,AAAI,MAAE,AAAM,QAAE,AAAM,OAAC,AAAI,AAAC,AAAC;AACnD,AAAM,mBAAC,EAAE,AAAI,MAAE,AAAK,OAAE,AAAK,OAAE,AAAI,AAAE,AAAC,AACtC;AAAC;AAED,AAAM;AACJ,AAAI,kBAAE,AAAI;AACV,AAAK,mBAAE,AAAI,AAAY,2BACrB,AAAG,KACH,AAAM,kBAAC,AAAmB,oBAAC,AAAG,AAAE,OAAE,AAA+C,AAAC,kDAClF,AAAY,aAAC,AAAQ,AAAE,AACxB,AACF,AAAC,AACJ;AARS;AAQR;AAEO,AAAa,kBAAC,AAAgB;AACpC,YAAI,EAAE,AAAE,AAAE,OAAG,AAAI,AAAC;AAElB,AAAE,AAAC,YAAC,AAAE,OAAK,CAAC,AAAC,AAAC,GAAC,AAAC;AACd,AAAM,mBAAC,AAAI,AAAC,AACd;AAAC;AAED,YAAI,AAAO,UAAG,AAAG,IAAC,AAAO,AAAC;AAC1B,AAAI,aAAC,AAAE,MAAI,AAAC,AAAC;AACb,AAAM,eAAC,AAAO,QAAC,AAAM,OAAC,AAAE,AAAC,AAAC,AAC5B;AAAC;AAED,AAAc,mBAAC,AAAc;AAC3B,AAAc,gCAAC,AAAQ,SAAC,AAAI,MAAE,AAAM,QAAE,AAAM,OAAC,AAAI,AAAC,AAAC,AACrD;AAAC;AAED,AAAgB,qBAAC,AAAuB;AACtC,YAAI,AAAK,QAAG,AAAI,KAAC,AAAY,AAAE,AAAC;AAEhC,AAAG,aAAC,IAAI,AAAC,IAAC,AAAK,MAAC,AAAM,SAAG,AAAC,GAAE,AAAC,KAAE,AAAC,GAAE,AAAC,AAAE,KAAE,AAAC;AACtC,gBAAI,AAAI,OAAG,AAAI,KAAC,AAAS,UAAC,AAAS,UAAC,AAAK,MAAC,AAAC,AAAC,AAAC,AAAC;AAC9C,AAAK,kBAAC,AAAG,IAAC,AAAI,MAAE,AAAI,KAAC,AAAK,MAAC,AAAG,AAAkC,AAAC,AAAC,AACpE;AAAC,AACH;AAAC,AACF","sourcesContent":["import { Register } from '../opcodes';\nimport { Scope, DynamicScope, Environment, Opcode } from '../environment';\nimport { ElementStack } from '../builder';\nimport { Option, Destroyable, Stack, LinkedList, ListSlice, Opaque, assert, expect } from '@glimmer/util';\nimport { ReferenceIterator, PathReference, VersionedPathReference, combineSlice } from '@glimmer/reference';\nimport { CompiledDynamicProgram } from '../compiled/blocks';\nimport { LabelOpcode, JumpIfNotModifiedOpcode, DidModifyOpcode } from '../compiled/opcodes/vm';\nimport { VMState, ListBlockOpcode, TryOpcode, BlockOpcode } from './update';\nimport RenderResult from './render-result';\n\nimport {\n  APPEND_OPCODES,\n  UpdatingOpcode\n} from '../opcodes';\n\nimport {\n  Constants,\n  ConstantString\n} from '../environment/constants';\n\nexport interface PublicVM {\n  env: Environment;\n  dynamicScope(): DynamicScope;\n  getSelf(): PathReference<Opaque>;\n  newDestroyable(d: Destroyable): void;\n}\n\nexport type CapturedStack = Opaque[];\n\nexport class EvaluationStack {\n  static empty(): EvaluationStack {\n    return new this([], 0, -1);\n  }\n\n  static restore(snapshot: CapturedStack): EvaluationStack {\n    return new this(snapshot.slice(), 0, snapshot.length - 1);\n  }\n\n  constructor(private stack: Opaque[], public fp: number, public sp: number) {\n    Object.seal(this);\n  }\n\n  isEmpty() {\n    return this.sp === -1;\n  }\n\n  push(value: Opaque): void {\n    this.stack[++this.sp] = value;\n  }\n\n  dup(position = this.sp): void {\n    this.push(this.stack[position]);\n  }\n\n  pop<T>(n = 1): T {\n    let top = this.stack[this.sp] as T;\n    this.sp -= n;\n    return top;\n  }\n\n  peek<T>(): T {\n    return this.stack[this.sp] as T;\n  }\n\n  fromBase<T>(offset: number): T {\n    return this.stack[this.fp - offset] as T;\n  }\n\n  fromTop<T>(offset: number): T {\n    return this.stack[this.sp - offset] as T;\n  }\n\n  capture(items: number): CapturedStack {\n    let end = this.sp + 1;\n    let start = end - items;\n    return this.stack.slice(start, end);\n  }\n\n  toArray() {\n    return this.stack.slice(this.fp, this.sp + 1);\n  }\n}\n\nexport type IteratorResult<T> = {\n  done: false;\n  value: null;\n} | {\n  done: true;\n  value: T;\n};\n\nexport default class VM implements PublicVM {\n  private dynamicScopeStack = new Stack<DynamicScope>();\n  private scopeStack = new Stack<Scope>();\n  public updatingOpcodeStack = new Stack<LinkedList<UpdatingOpcode>>();\n  public cacheGroups = new Stack<Option<UpdatingOpcode>>();\n  public listBlockStack = new Stack<ListBlockOpcode>();\n  public constants: Constants;\n\n  public stack = EvaluationStack.empty();\n\n  /** Registers **/\n\n  private pc = -1;\n  private ra = -1;\n\n  private get fp(): number {\n    return this.stack.fp;\n  }\n\n  private set fp(fp: number) {\n    this.stack.fp = fp;\n  }\n\n  private get sp(): number {\n    return this.stack.sp;\n  }\n\n  private set sp(sp: number) {\n    this.stack.sp = sp;\n  }\n\n  public s0: any = null;\n  public s1: any = null;\n  public t0: any = null;\n  public t1: any = null;\n\n  // Fetch a value from a register onto the stack\n  fetch(register: Register) {\n    this.stack.push(this[Register[register]]);\n  }\n\n  // Load a value from the stack into a register\n  load(register: Register) {\n    this[Register[register]] = this.stack.pop();\n  }\n\n  // Fetch a value from a register\n  fetchValue<T>(register: Register): T {\n    return this[Register[register]];\n  }\n\n  // Load a value into a register\n  loadValue<T>(register: Register, value: T) {\n    this[Register[register]] = value;\n  }\n\n  // Start a new frame and save $ra and $fp on the stack\n  pushFrame() {\n    this.stack.push(this.ra);\n    this.stack.push(this.fp);\n    this.fp = this.sp - 1;\n    // this.fp = this.sp + 1;\n  }\n\n  // Restore $ra, $sp and $fp\n  popFrame() {\n    this.sp = this.fp - 1;\n    this.ra = this.stack.fromBase<number>(0);\n    this.fp = this.stack.fromBase<number>(-1);\n  }\n\n  // Jump to an address in `program`\n  goto(pc: number) {\n    this.pc = pc;\n  }\n\n  // Save $pc into $ra, then jump to a new address in `program` (jal in MIPS)\n  call(pc: number) {\n    this.ra = this.pc;\n    this.pc = pc;\n  }\n\n  // Put a specific `program` address in $ra\n  returnTo(ra: number) {\n    this.ra = ra;\n  }\n\n  // Return to the `program` address stored in $ra\n  return() {\n    this.pc = this.ra;\n  }\n\n  static initial(\n    env: Environment,\n    self: PathReference<Opaque>,\n    dynamicScope: DynamicScope,\n    elementStack: ElementStack,\n    program: CompiledDynamicProgram\n  ) {\n    let scope = Scope.root(self, program.symbolTable.symbols.length);\n    let vm = new VM(env, scope, dynamicScope, elementStack);\n    vm.pc = program.start;\n    vm.updatingOpcodeStack.push(new LinkedList<UpdatingOpcode>());\n    return vm;\n  }\n\n  constructor(\n    public env: Environment,\n    scope: Scope,\n    dynamicScope: DynamicScope,\n    private elementStack: ElementStack,\n  ) {\n    this.env = env;\n    this.constants = env.constants;\n    this.elementStack = elementStack;\n    this.scopeStack.push(scope);\n    this.dynamicScopeStack.push(dynamicScope);\n  }\n\n  capture(args: number): VMState {\n    return {\n      env: this.env,\n      scope: this.scope(),\n      dynamicScope: this.dynamicScope(),\n      stack: this.stack.capture(args)\n    };\n  }\n\n  beginCacheGroup() {\n    this.cacheGroups.push(this.updating().tail());\n  }\n\n  commitCacheGroup() {\n    //        JumpIfNotModified(END)\n    //        (head)\n    //        (....)\n    //        (tail)\n    //        DidModify\n    // END:   Noop\n\n    let END = new LabelOpcode(\"END\");\n\n    let opcodes = this.updating();\n    let marker = this.cacheGroups.pop();\n    let head = marker ? opcodes.nextNode(marker) : opcodes.head();\n    let tail = opcodes.tail();\n    let tag = combineSlice(new ListSlice(head, tail));\n\n    let guard = new JumpIfNotModifiedOpcode(tag, END);\n\n    opcodes.insertBefore(guard, head);\n    opcodes.append(new DidModifyOpcode(guard));\n    opcodes.append(END);\n  }\n\n  enter(args: number) {\n    let updating = new LinkedList<UpdatingOpcode>();\n\n    let state = this.capture(args);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    let tryOpcode = new TryOpcode(this.pc, state, tracker, updating);\n\n    this.didEnter(tryOpcode);\n  }\n\n  iterate(memo: VersionedPathReference<Opaque>, value: VersionedPathReference<Opaque>, updating = new LinkedList<UpdatingOpcode>()): TryOpcode {\n    let stack = this.stack;\n    stack.push(value);\n    stack.push(memo);\n\n    let state = this.capture(2);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    // let ip = this.ip;\n    // this.ip = end + 4;\n    // this.frames.push(ip);\n\n    return new TryOpcode(this.pc, state, tracker, updating);\n  }\n\n  enterItem(key: string, opcode: TryOpcode) {\n    this.listBlock().map[key] = opcode;\n    this.didEnter(opcode);\n  }\n\n  enterList(start: number) {\n    let updating = new LinkedList<BlockOpcode>();\n\n    let state = this.capture(0);\n    let tracker = this.elements().pushBlockList(updating);\n    let artifacts = this.stack.peek<ReferenceIterator>().artifacts;\n\n    let opcode = new ListBlockOpcode(start, state, tracker, updating, artifacts);\n\n    this.listBlockStack.push(opcode);\n\n    this.didEnter(opcode);\n  }\n\n  private didEnter(opcode: BlockOpcode) {\n    this.updateWith(opcode);\n    this.updatingOpcodeStack.push(opcode.children);\n  }\n\n  exit() {\n    this.elements().popBlock();\n    this.updatingOpcodeStack.pop();\n\n    let parent = this.updating().tail() as BlockOpcode;\n\n    parent.didInitializeChildren();\n  }\n\n  exitList() {\n    this.exit();\n    this.listBlockStack.pop();\n  }\n\n  updateWith(opcode: UpdatingOpcode) {\n    this.updating().append(opcode);\n  }\n\n  listBlock(): ListBlockOpcode {\n    return expect(this.listBlockStack.current, 'expected a list block');\n  }\n\n  updating(): LinkedList<UpdatingOpcode> {\n    return expect(this.updatingOpcodeStack.current, 'expected updating opcode on the updating opcode stack');\n  }\n\n  elements(): ElementStack {\n    return this.elementStack;\n  }\n\n  scope(): Scope {\n    return expect(this.scopeStack.current, 'expected scope on the scope stack');\n  }\n\n  dynamicScope(): DynamicScope {\n    return expect(this.dynamicScopeStack.current, 'expected dynamic scope on the dynamic scope stack');\n  }\n\n  pushChildScope() {\n    this.scopeStack.push(this.scope().child());\n  }\n\n  pushCallerScope(childScope = false) {\n    let callerScope = expect(this.scope().getCallerScope(), 'pushCallerScope is called when a caller scope is present');\n    this.scopeStack.push(childScope ? callerScope.child() : callerScope);\n  }\n\n  pushDynamicScope(): DynamicScope {\n    let child = this.dynamicScope().child();\n    this.dynamicScopeStack.push(child);\n    return child;\n  }\n\n  pushRootScope(size: number, bindCaller: boolean): Scope {\n    let scope = Scope.sized(size);\n    if (bindCaller) scope.bindCallerScope(this.scope());\n    this.scopeStack.push(scope);\n    return scope;\n  }\n\n  popScope() {\n    this.scopeStack.pop();\n  }\n\n  popDynamicScope() {\n    this.dynamicScopeStack.pop();\n  }\n\n  newDestroyable(d: Destroyable) {\n    this.elements().newDestroyable(d);\n  }\n\n  /// SCOPE HELPERS\n\n  getSelf(): PathReference<any> {\n    return this.scope().getSelf();\n  }\n\n  referenceForSymbol(symbol: number): PathReference<any> {\n    return this.scope().getSymbol(symbol);\n  }\n\n  /// EXECUTION\n\n  execute(start: number, initialize?: (vm: VM) => void): RenderResult {\n    this.pc = start;\n\n    if (initialize) initialize(this);\n\n    let result: IteratorResult<RenderResult>;\n\n    while (true) {\n      result = this.next();\n      if (result.done) break;\n    }\n\n    return result.value as RenderResult;\n  }\n\n  next(): IteratorResult<RenderResult> {\n    let { env, updatingOpcodeStack, elementStack } = this;\n    let opcode: Option<Opcode>;\n\n    if (opcode = this.nextStatement(env)) {\n      APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n      return { done: false, value: null };\n    }\n\n    return {\n      done: true,\n      value: new RenderResult(\n        env,\n        expect(updatingOpcodeStack.pop(), 'there should be a final updating opcode stack'),\n        elementStack.popBlock()\n      )\n    };\n  }\n\n  private nextStatement(env: Environment): Option<Opcode> {\n    let { pc } = this;\n\n    if (pc === -1) {\n      return null;\n    }\n\n    let program = env.program;\n    this.pc += 4;\n    return program.opcode(pc);\n  }\n\n  evaluateOpcode(opcode: Opcode) {\n    APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n  }\n\n  bindDynamicScope(names: ConstantString[]) {\n    let scope = this.dynamicScope();\n\n    for(let i=names.length - 1; i>=0; i--) {\n      let name = this.constants.getString(names[i]);\n      scope.set(name, this.stack.pop<VersionedPathReference<Opaque>>());\n    }\n  }\n}\n"]}

13

dist/commonjs/es5/lib/vm/append.js

@@ -106,3 +106,2 @@ "use strict";

}();
var i = 0;

@@ -197,5 +196,2 @@ var VM = function () {

VM.prototype.return = function _return() {
if (this.pc === this.ra + 4) {
throw "ZOMG";
}
this.pc = this.ra;

@@ -387,5 +383,2 @@ };

var opcode = void 0;
if (i++ > 100000) {
throw "zomg";
}
if (opcode = this.nextStatement(env)) {

@@ -418,4 +411,4 @@ _opcodes.APPEND_OPCODES.evaluate(this, opcode, opcode.type);

var scope = this.dynamicScope();
for (var _i = names.length - 1; _i >= 0; _i--) {
var name = this.constants.getString(names[_i]);
for (var i = names.length - 1; i >= 0; i--) {
var name = this.constants.getString(names[i]);
scope.set(name, this.stack.pop());

@@ -447,2 +440,2 @@ }

exports.default = VM;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"append.js","sourceRoot":"","sources":["append.ts"],"names":[],"mappings":"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","sourcesContent":["import { Register } from '../opcodes';\nimport { Scope, DynamicScope, Environment, Opcode } from '../environment';\nimport { ElementStack } from '../builder';\nimport { Option, Destroyable, Stack, LinkedList, ListSlice, Opaque, assert, expect } from '@glimmer/util';\nimport { ReferenceIterator, PathReference, VersionedPathReference, combineSlice } from '@glimmer/reference';\nimport { CompiledDynamicProgram } from '../compiled/blocks';\nimport { LabelOpcode, JumpIfNotModifiedOpcode, DidModifyOpcode } from '../compiled/opcodes/vm';\nimport { VMState, ListBlockOpcode, TryOpcode, BlockOpcode } from './update';\nimport RenderResult from './render-result';\n\nimport {\n  APPEND_OPCODES,\n  UpdatingOpcode\n} from '../opcodes';\n\nimport {\n  Constants,\n  ConstantString\n} from '../environment/constants';\n\nexport interface PublicVM {\n  env: Environment;\n  dynamicScope(): DynamicScope;\n  getSelf(): PathReference<Opaque>;\n  newDestroyable(d: Destroyable): void;\n}\n\nexport type CapturedStack = Opaque[];\n\nexport class EvaluationStack {\n  static empty(): EvaluationStack {\n    return new this([], 0, -1);\n  }\n\n  static restore(snapshot: CapturedStack): EvaluationStack {\n    return new this(snapshot.slice(), 0, snapshot.length - 1);\n  }\n\n  constructor(private stack: Opaque[], public fp: number, public sp: number) {\n    Object.seal(this);\n  }\n\n  isEmpty() {\n    return this.sp === -1;\n  }\n\n  push(value: Opaque): void {\n    this.stack[++this.sp] = value;\n  }\n\n  dup(position = this.sp): void {\n    this.push(this.stack[position]);\n  }\n\n  pop<T>(n = 1): T {\n    let top = this.stack[this.sp] as T;\n    this.sp -= n;\n    return top;\n  }\n\n  peek<T>(): T {\n    return this.stack[this.sp] as T;\n  }\n\n  fromBase<T>(offset: number): T {\n    return this.stack[this.fp - offset] as T;\n  }\n\n  fromTop<T>(offset: number): T {\n    return this.stack[this.sp - offset] as T;\n  }\n\n  capture(items: number): CapturedStack {\n    let end = this.sp + 1;\n    let start = end - items;\n    return this.stack.slice(start, end);\n  }\n\n  toArray() {\n    return this.stack.slice(this.fp, this.sp + 1);\n  }\n}\n\nexport type IteratorResult<T> = {\n  done: false;\n  value: null;\n} | {\n  done: true;\n  value: T;\n};\n\nlet i = 0;\n\nexport default class VM implements PublicVM {\n  private dynamicScopeStack = new Stack<DynamicScope>();\n  private scopeStack = new Stack<Scope>();\n  public updatingOpcodeStack = new Stack<LinkedList<UpdatingOpcode>>();\n  public cacheGroups = new Stack<Option<UpdatingOpcode>>();\n  public listBlockStack = new Stack<ListBlockOpcode>();\n  public constants: Constants;\n\n  public stack = EvaluationStack.empty();\n\n  /** Registers **/\n\n  private pc = -1;\n  private ra = -1;\n\n  private get fp(): number {\n    return this.stack.fp;\n  }\n\n  private set fp(fp: number) {\n    this.stack.fp = fp;\n  }\n\n  private get sp(): number {\n    return this.stack.sp;\n  }\n\n  private set sp(sp: number) {\n    this.stack.sp = sp;\n  }\n\n  public s0: any = null;\n  public s1: any = null;\n  public t0: any = null;\n  public t1: any = null;\n\n  // Fetch a value from a register onto the stack\n  fetch(register: Register) {\n    this.stack.push(this[Register[register]]);\n  }\n\n  // Load a value from the stack into a register\n  load(register: Register) {\n    this[Register[register]] = this.stack.pop();\n  }\n\n  // Fetch a value from a register\n  fetchValue<T>(register: Register): T {\n    return this[Register[register]];\n  }\n\n  // Load a value into a register\n  loadValue<T>(register: Register, value: T) {\n    this[Register[register]] = value;\n  }\n\n  // Start a new frame and save $ra and $fp on the stack\n  pushFrame() {\n    this.stack.push(this.ra);\n    this.stack.push(this.fp);\n    this.fp = this.sp - 1;\n    // this.fp = this.sp + 1;\n  }\n\n  // Restore $ra, $sp and $fp\n  popFrame() {\n    this.sp = this.fp - 1;\n    this.ra = this.stack.fromBase<number>(0);\n    this.fp = this.stack.fromBase<number>(-1);\n  }\n\n  // Jump to an address in `program`\n  goto(pc: number) {\n    this.pc = pc;\n  }\n\n  // Save $pc into $ra, then jump to a new address in `program` (jal in MIPS)\n  call(pc: number) {\n    this.ra = this.pc;\n    this.pc = pc;\n  }\n\n  // Put a specific `program` address in $ra\n  returnTo(ra: number) {\n    this.ra = ra;\n  }\n\n  // Return to the `program` address stored in $ra\n  return() {\n    if (this.pc === (this.ra + 4)) {\n      throw \"ZOMG\";\n    }\n\n    this.pc = this.ra;\n  }\n\n  static initial(\n    env: Environment,\n    self: PathReference<Opaque>,\n    dynamicScope: DynamicScope,\n    elementStack: ElementStack,\n    program: CompiledDynamicProgram\n  ) {\n    let scope = Scope.root(self, program.symbolTable.symbols.length);\n    let vm = new VM(env, scope, dynamicScope, elementStack);\n    vm.pc = program.start;\n    vm.updatingOpcodeStack.push(new LinkedList<UpdatingOpcode>());\n    return vm;\n  }\n\n  constructor(\n    public env: Environment,\n    scope: Scope,\n    dynamicScope: DynamicScope,\n    private elementStack: ElementStack,\n  ) {\n    this.env = env;\n    this.constants = env.constants;\n    this.elementStack = elementStack;\n    this.scopeStack.push(scope);\n    this.dynamicScopeStack.push(dynamicScope);\n  }\n\n  capture(args: number): VMState {\n    return {\n      env: this.env,\n      scope: this.scope(),\n      dynamicScope: this.dynamicScope(),\n      stack: this.stack.capture(args)\n    };\n  }\n\n  beginCacheGroup() {\n    this.cacheGroups.push(this.updating().tail());\n  }\n\n  commitCacheGroup() {\n    //        JumpIfNotModified(END)\n    //        (head)\n    //        (....)\n    //        (tail)\n    //        DidModify\n    // END:   Noop\n\n    let END = new LabelOpcode(\"END\");\n\n    let opcodes = this.updating();\n    let marker = this.cacheGroups.pop();\n    let head = marker ? opcodes.nextNode(marker) : opcodes.head();\n    let tail = opcodes.tail();\n    let tag = combineSlice(new ListSlice(head, tail));\n\n    let guard = new JumpIfNotModifiedOpcode(tag, END);\n\n    opcodes.insertBefore(guard, head);\n    opcodes.append(new DidModifyOpcode(guard));\n    opcodes.append(END);\n  }\n\n  enter(args: number) {\n    let updating = new LinkedList<UpdatingOpcode>();\n\n    let state = this.capture(args);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    let tryOpcode = new TryOpcode(this.pc, state, tracker, updating);\n\n    this.didEnter(tryOpcode);\n  }\n\n  iterate(memo: VersionedPathReference<Opaque>, value: VersionedPathReference<Opaque>, updating = new LinkedList<UpdatingOpcode>()): TryOpcode {\n    let stack = this.stack;\n    stack.push(value);\n    stack.push(memo);\n\n    let state = this.capture(2);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    // let ip = this.ip;\n    // this.ip = end + 4;\n    // this.frames.push(ip);\n\n    return new TryOpcode(this.pc, state, tracker, updating);\n  }\n\n  enterItem(key: string, opcode: TryOpcode) {\n    this.listBlock().map[key] = opcode;\n    this.didEnter(opcode);\n  }\n\n  enterList(start: number) {\n    let updating = new LinkedList<BlockOpcode>();\n\n    let state = this.capture(0);\n    let tracker = this.elements().pushBlockList(updating);\n    let artifacts = this.stack.peek<ReferenceIterator>().artifacts;\n\n    let opcode = new ListBlockOpcode(start, state, tracker, updating, artifacts);\n\n    this.listBlockStack.push(opcode);\n\n    this.didEnter(opcode);\n  }\n\n  private didEnter(opcode: BlockOpcode) {\n    this.updateWith(opcode);\n    this.updatingOpcodeStack.push(opcode.children);\n  }\n\n  exit() {\n    this.elements().popBlock();\n    this.updatingOpcodeStack.pop();\n\n    let parent = this.updating().tail() as BlockOpcode;\n\n    parent.didInitializeChildren();\n  }\n\n  exitList() {\n    this.exit();\n    this.listBlockStack.pop();\n  }\n\n  updateWith(opcode: UpdatingOpcode) {\n    this.updating().append(opcode);\n  }\n\n  listBlock(): ListBlockOpcode {\n    return expect(this.listBlockStack.current, 'expected a list block');\n  }\n\n  updating(): LinkedList<UpdatingOpcode> {\n    return expect(this.updatingOpcodeStack.current, 'expected updating opcode on the updating opcode stack');\n  }\n\n  elements(): ElementStack {\n    return this.elementStack;\n  }\n\n  scope(): Scope {\n    return expect(this.scopeStack.current, 'expected scope on the scope stack');\n  }\n\n  dynamicScope(): DynamicScope {\n    return expect(this.dynamicScopeStack.current, 'expected dynamic scope on the dynamic scope stack');\n  }\n\n  pushChildScope() {\n    this.scopeStack.push(this.scope().child());\n  }\n\n  pushCallerScope(childScope = false) {\n    let callerScope = expect(this.scope().getCallerScope(), 'pushCallerScope is called when a caller scope is present');\n    this.scopeStack.push(childScope ? callerScope.child() : callerScope);\n  }\n\n  pushDynamicScope(): DynamicScope {\n    let child = this.dynamicScope().child();\n    this.dynamicScopeStack.push(child);\n    return child;\n  }\n\n  pushRootScope(size: number, bindCaller: boolean): Scope {\n    let scope = Scope.sized(size);\n    if (bindCaller) scope.bindCallerScope(this.scope());\n    this.scopeStack.push(scope);\n    return scope;\n  }\n\n  popScope() {\n    this.scopeStack.pop();\n  }\n\n  popDynamicScope() {\n    this.dynamicScopeStack.pop();\n  }\n\n  newDestroyable(d: Destroyable) {\n    this.elements().newDestroyable(d);\n  }\n\n  /// SCOPE HELPERS\n\n  getSelf(): PathReference<any> {\n    return this.scope().getSelf();\n  }\n\n  referenceForSymbol(symbol: number): PathReference<any> {\n    return this.scope().getSymbol(symbol);\n  }\n\n  /// EXECUTION\n\n  execute(start: number, initialize?: (vm: VM) => void): RenderResult {\n    this.pc = start;\n\n    if (initialize) initialize(this);\n\n    let result: IteratorResult<RenderResult>;\n\n    while (true) {\n      result = this.next();\n      if (result.done) break;\n    }\n\n    return result.value as RenderResult;\n  }\n\n  next(): IteratorResult<RenderResult> {\n    let { env, updatingOpcodeStack, elementStack } = this;\n    let opcode: Option<Opcode>;\n\n    if (i++ > 100000) {\n      throw \"zomg\";\n    }\n\n    if (opcode = this.nextStatement(env)) {\n      APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n      return { done: false, value: null };\n    }\n\n    return {\n      done: true,\n      value: new RenderResult(\n        env,\n        expect(updatingOpcodeStack.pop(), 'there should be a final updating opcode stack'),\n        elementStack.popBlock()\n      )\n    };\n  }\n\n  private nextStatement(env: Environment): Option<Opcode> {\n    let { pc } = this;\n\n    if (pc === -1) {\n      return null;\n    }\n\n    let program = env.program;\n    this.pc += 4;\n    return program.opcode(pc);\n  }\n\n  evaluateOpcode(opcode: Opcode) {\n    APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n  }\n\n  bindDynamicScope(names: ConstantString[]) {\n    let scope = this.dynamicScope();\n\n    for(let i=names.length - 1; i>=0; i--) {\n      let name = this.constants.getString(names[i]);\n      scope.set(name, this.stack.pop<VersionedPathReference<Opaque>>());\n    }\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"append.js","sourceRoot":"","sources":["append.ts"],"names":[],"mappings":";;;;;;;AAAA,AAAO,AAAE,AAAQ,AAAE,AAAM,AAAY,AAAC;;AACtC,AAAO,AAAE,AAAK,AAAqC,AAAM,AAAgB,AAAC;;AAE1E,AAAO,AAAuB,AAAK,AAAE,AAAU,AAAE,AAAS,AAAkB,AAAM,AAAE,AAAM,AAAe,AAAC;;AAC1G,AAAO,AAA4D,AAAY,AAAE,AAAM,AAAoB,AAAC;;AAE5G,AAAO,AAAE,AAAW,AAAE,AAAuB,AAAE,AAAe,AAAE,AAAM,AAAwB,AAAC;;AAC/F,AAAO,AAAW,AAAe,AAAE,AAAS,AAAe,AAAM,AAAU,AAAC;;AAC5E,AAAO,AAAY,AAAM,AAAiB,AAAC,AAE3C,AAAO,AACL,AAAc,AAEf,AAAM,AAAY,AAAC,AAgBpB,AAAM;;;;;;;;;;;;;;;;;;;;;;4DASJ;6BAAoB,AAAe,OAAS,AAAU,IAAS,AAAU;8BAArD;;aAAK,QAAL,AAAK,AAAU,AAAS;aAAE,KAAF,AAAE,AAAQ,AAAS;aAAE,KAAF,AAAE,AAAQ,AACvE,AAAM;eAAC,AAAI,KATb,AAAM,AASQ,AAAI,AAAC,AAAC,AACpB,AAAC;;;oBAVM,AAAK,yBACV,AAAM;eAAC,IAAI,AAAI,KAAC,AAAE,IAAE,AAAC,GAAE,CAAC,AAAC,AAAC,AAAC,AAC7B,AAAC,AAED,AAAM;;;oBAAC,AAAO,2BAAC,AAAuB,UACpC,AAAM;eAAC,IAAI,AAAI,KAAC,AAAQ,SAAC,AAAK,AAAE,SAAE,AAAC,GAAE,AAAQ,SAAC,AAAM,SAAG,AAAC,AAAC,AAAC,AAC5D,AAAC;;;8BAMD,AAAO,6BACL,AAAM;eAAC,AAAI,KAAC,AAAE,OAAK,CAAC,AAAC,AAAC,AACxB,AAAC;;;8BAED,AAAI,qBAAC,AAAa,OAChB,AAAI;aAAC,AAAK,MAAC,EAAE,AAAI,KAAC,AAAE,AAAC,MAAG,AAAK,AAAC,AAChC,AAAC;;;8BAED,AAAG;YAAC,AAAQ,+EAAG,AAAI,KAAC,AAAE,AACpB,AAAI;;aAAC,AAAI,KAAC,AAAI,KAAC,AAAK,MAAC,AAAQ,AAAC,AAAC,AAAC,AAClC,AAAC;;;8BAED,AAAG;YAAI,AAAC,wEAAG,AAAC,AACV;;YAAI,AAAG,MAAG,AAAI,KAAC,AAAK,MAAC,AAAI,KAAC,AAAE,AAAM,AAAC,AACnC,AAAI;aAAC,AAAE,MAAI,AAAC,AAAC,AACb,AAAM;eAAC,AAAG,AAAC,AACb,AAAC;;;8BAED,AAAI,uBACF,AAAM;eAAC,AAAI,KAAC,AAAK,MAAC,AAAI,KAAC,AAAE,AAAM,AAAC,AAClC,AAAC;;;8BAED,AAAQ,6BAAI,AAAc,QACxB,AAAM;eAAC,AAAI,KAAC,AAAK,MAAC,AAAI,KAAC,AAAE,KAAG,AAAM,AAAM,AAAC,AAC3C,AAAC;;;8BAED,AAAO,2BAAI,AAAc,QACvB,AAAM;eAAC,AAAI,KAAC,AAAK,MAAC,AAAI,KAAC,AAAE,KAAG,AAAM,AAAM,AAAC,AAC3C,AAAC;;;8BAED,AAAO,2BAAC,AAAa,OACnB;YAAI,AAAG,MAAG,AAAI,KAAC,AAAE,KAAG,AAAC,AAAC,AACtB;YAAI,AAAK,QAAG,AAAG,MAAG,AAAK,AAAC,AACxB,AAAM;eAAC,AAAI,KAAC,AAAK,MAAC,AAAK,MAAC,AAAK,OAAE,AAAG,AAAC,AAAC,AACtC,AAAC;;;8BAED,AAAO,6BACL,AAAM;eAAC,AAAI,KAAC,AAAK,MAAC,AAAK,MAAC,AAAI,KAAC,AAAE,IAAE,AAAI,KAAC,AAAE,KAAG,AAAC,AAAC,AAAC,AAChD,AAAC,AACF,AAUD,AAAM,AAAC,AAAO;;;;;;qBA0GZ;gBACS,AAAgB,KACvB,AAAY,OACZ,AAA0B,cAClB,AAA0B;8BAH3B;;aAAG,MAAH,AAAG,AAAa,AAGf;aAAY,eA7Gd,AA6GE,AAAY,AAAc;aA7GX,oBAAG,AAAI,AAAK,AAAgB,AAAC,AAC9C;aAAU,aAAG,AAAI,AAAK,AAAS,AAAC,AACjC;aAAmB,sBAAG,AAAI,AAAK,AAA8B,AAAC,AAC9D;aAAW,cAAG,AAAI,AAAK,AAA0B,AAAC,AAClD;aAAc,iBAAG,AAAI,AAAK,AAAmB,AAAC,AAG9C;aAAK,QAAG,AAAe,gBAAC,AAAK,AAAE,AAAC,AAEvC,AAAiB;AAET;aAAE,KAAG,CAAC,AAAC,AAAC,AACR;aAAE,KAAG,CAAC,AAAC,AAAC,AAkBT;aAAE,KAAQ,AAAI,AAAC,AACf;aAAE,KAAQ,AAAI,AAAC,AACf;aAAE,KAAQ,AAAI,AAAC,AACf;aAAE,KAAQ,AAAI,AAAC,AA8EpB,AAAI;aAAC,AAAG,MAAG,AAAG,AAAC,AACf,AAAI;aAAC,AAAS,YAAG,AAAG,IAAC,AAAS,AAAC,AAC/B,AAAI;aAAC,AAAY,eAAG,AAAY,AAAC,AACjC,AAAI;aAAC,AAAU,WAAC,AAAI,KAAC,AAAK,AAAC,AAAC,AAC5B,AAAI;aAAC,AAAiB,kBAAC,AAAI,KArG7B,AAAY,AAAE,AAqGgB,AAAY,AAAC,AAAC,AAC5C,AAAC;AAjFD,AAA+C;;;iBAC/C,AAAK,uBAAC,AAAkB,UACtB,AAAI;aAAC,AAAK,MAAC,AAAI,KAAC,AAAI,KAAC,AAAQ,kBAAC,AAAQ,AAAC,AAAC,AAAC,AAAC,AAC5C,AAAC;AAED,AAA8C;;;;iBAC9C,AAAI,qBAAC,AAAkB,UACrB,AAAI;aAAC,AAAQ,kBAAC,AAAQ,AAAC,AAAC,aAAG,AAAI,KAAC,AAAK,MAAC,AAAG,AAAE,AAAC,AAC9C,AAAC;AAED,AAAgC;;;;iBAChC,AAAU,iCAAI,AAAkB,UAC9B,AAAM;eAAC,AAAI,KAAC,AAAQ,kBAAC,AAAQ,AAAC,AAAC,AAAC,AAClC,AAAC;AAED,AAA+B;;;;iBAC/B,AAAS,+BAAI,AAAkB,UAAE,AAAQ,OACvC,AAAI;aAAC,AAAQ,kBAAC,AAAQ,AAAC,AAAC,aAAG,AAAK,AAAC,AACnC,AAAC;AAED,AAAsD;;;;iBACtD,AAAS,iCACP,AAAI;aAAC,AAAK,MAAC,AAAI,KAAC,AAAI,KAAC,AAAE,AAAC,AAAC,AACzB,AAAI;aAAC,AAAK,MAAC,AAAI,KAAC,AAAI,KAAC,AAAE,AAAC,AAAC,AACzB,AAAI;aAAC,AAAE,KAAG,AAAI,KAAC,AAAE,KAAG,AAAC,AAAC,AACtB,AAAyB,AAC3B;AAAC;AAED,AAA2B;;;;iBAC3B,AAAQ,+BACN,AAAI;aAAC,AAAE,KAAG,AAAI,KAAC,AAAE,KAAG,AAAC,AAAC,AACtB,AAAI;aAAC,AAAE,KAAG,AAAI,KAAC,AAAK,MAAC,AAAQ,SAAS,AAAC,AAAC,AAAC,AACzC,AAAI;aAAC,AAAE,KAAG,AAAI,KAAC,AAAK,MAAC,AAAQ,SAAS,CAAC,AAAC,AAAC,AAAC,AAC5C,AAAC;AAED,AAAkC;;;;iBAClC,AAAI,qBAAC,AAAU,IACb,AAAI;aAAC,AAAE,KAAG,AAAE,AAAC,AACf,AAAC;AAED,AAA2E;;;;iBAC3E,AAAI,qBAAC,AAAU,IACb,AAAI;aAAC,AAAE,KAAG,AAAI,KAAC,AAAE,AAAC,AAClB,AAAI;aAAC,AAAE,KAAG,AAAE,AAAC,AACf,AAAC;AAED,AAA0C;;;;iBAC1C,AAAQ,6BAAC,AAAU,IACjB,AAAI;aAAC,AAAE,KAAG,AAAE,AAAC,AACf,AAAC;AAED,AAAgD;;;;iBAChD,AAAM,4BACJ,AAAI;aAAC,AAAE,KAAG,AAAI,KAAC,AAAE,AAAC,AACpB,AAAC,AAED,AAAM;;;OAAC,AAAO,2BACZ,AAAgB,KAChB,AAA2B,MAC3B,AAA0B,cAC1B,AAA0B,cAC1B,AAA+B,SAE/B;YAAI,AAAK,QAAG,AAAK,mBAAC,AAAI,KAAC,AAAI,MAAE,AAAO,QAAC,AAAW,YAAC,AAAO,QAAC,AAAM,AAAC,AAAC,AACjE;YAAI,AAAE,KAAG,IAAI,AAAE,GAAC,AAAG,KAAE,AAAK,OAAE,AAAY,cAAE,AAAY,AAAC,AAAC,AACxD,AAAE;WAAC,AAAE,KAAG,AAAO,QAAC,AAAK,AAAC,AACtB,AAAE;WAAC,AAAmB,oBAAC,AAAI,KAAC,AAAI,AAAU,AAAkB,AAAC,AAAC,AAC9D,AAAM;eAAC,AAAE,AAAC,AACZ,AAAC;;;iBAeD,AAAO,2BAAC,AAAY,MAClB,AAAM;;iBACC,AAAI,KAAC,AAAG,AACb,AAAK;mBAAE,AAAI,KAAC,AAAK,AAAE,AACnB,AAAY;0BAAE,AAAI,KAAC,AAAY,AAAE,AACjC,AAAK;mBAAE,AAAI,KAAC,AAAK,MAAC,AAAO,QAJpB,AAIqB,AAAI,AAAC,AAChC,AAAC,AACJ,AAAC;AALG,AAAG;;;iBAOP,AAAe,6CACb,AAAI;aAAC,AAAW,YAAC,AAAI,KAAC,AAAI,KAAC,AAAQ,AAAE,WAAC,AAAI,AAAE,AAAC,AAAC,AAChD,AAAC;;;iBAED,AAAgB,+CACd,AAAgC;AAChC,AAAgB;AAChB,AAAgB;AAChB,AAAgB;AAChB,AAAmB;AACnB,AAAc;AAEd;YAAI,AAAG,MAAG,AAAI,AAAW,oBAAC,AAAK,AAAC,AAAC,AAEjC;YAAI,AAAO,UAAG,AAAI,KAAC,AAAQ,AAAE,AAAC,AAC9B;YAAI,AAAM,SAAG,AAAI,KAAC,AAAW,YAAC,AAAG,AAAE,AAAC,AACpC;YAAI,AAAI,OAAG,AAAM,SAAG,AAAO,QAAC,AAAQ,SAAC,AAAM,AAAC,UAAG,AAAO,QAAC,AAAI,AAAE,AAAC,AAC9D;YAAI,AAAI,OAAG,AAAO,QAAC,AAAI,AAAE,AAAC,AAC1B;YAAI,AAAG,MAAG,AAAY,6BAAC,AAAI,AAAS,oBAAC,AAAI,MAAE,AAAI,AAAC,AAAC,AAAC,AAElD;YAAI,AAAK,QAAG,AAAI,AAAuB,gCAAC,AAAG,KAAE,AAAG,AAAC,AAAC,AAElD,AAAO;gBAAC,AAAY,aAAC,AAAK,OAAE,AAAI,AAAC,AAAC,AAClC,AAAO;gBAAC,AAAM,OAAC,AAAI,AAAe,wBAAC,AAAK,AAAC,AAAC,AAAC,AAC3C,AAAO;gBAAC,AAAM,OAAC,AAAG,AAAC,AAAC,AACtB,AAAC;;;iBAED,AAAK,uBAAC,AAAY,MAChB;YAAI,AAAQ,WAAG,AAAI,AAAU,AAAkB,AAAC,AAEhD;YAAI,AAAK,QAAG,AAAI,KAAC,AAAO,QAAC,AAAI,AAAC,AAAC,AAC/B;YAAI,AAAO,UAAG,AAAI,KAAC,AAAQ,AAAE,WAAC,AAAkB,AAAE,AAAC,AAEnD;YAAI,AAAS,YAAG,AAAI,AAAS,sBAAC,AAAI,KAAC,AAAE,IAAE,AAAK,OAAE,AAAO,SAAE,AAAQ,AAAC,AAAC,AAEjE,AAAI;aAAC,AAAQ,SAAC,AAAS,AAAC,AAAC,AAC3B,AAAC;;;iBAED,AAAO,2BAAC,AAAoC,MAAE,AAAqC;YAAE,AAAQ,+EAAG,AAAI,AAAU,AAAkB,AAC9H;;YAAI,AAAK,QAAG,AAAI,KAAC,AAAK,AAAC,AACvB,AAAK;cAAC,AAAI,KAAC,AAAK,AAAC,AAAC,AAClB,AAAK;cAAC,AAAI,KAAC,AAAI,AAAC,AAAC,AAEjB;YAAI,AAAK,QAAG,AAAI,KAAC,AAAO,QAAC,AAAC,AAAC,AAAC,AAC5B;YAAI,AAAO,UAAG,AAAI,KAAC,AAAQ,AAAE,WAAC,AAAkB,AAAE,AAAC,AAEnD,AAAoB;AACpB,AAAqB;AACrB,AAAwB;AAExB,AAAM;eAAC,AAAI,AAAS,sBAAC,AAAI,KAAC,AAAE,IAAE,AAAK,OAAE,AAAO,SAAE,AAAQ,AAAC,AAAC,AAC1D,AAAC;;;iBAED,AAAS,+BAAC,AAAW,KAAE,AAAiB,QACtC,AAAI;aAAC,AAAS,AAAE,YAAC,AAAG,IAAC,AAAG,AAAC,OAAG,AAAM,AAAC,AACnC,AAAI;aAAC,AAAQ,SAAC,AAAM,AAAC,AAAC,AACxB,AAAC;;;iBAED,AAAS,+BAAC,AAAa,OACrB;YAAI,AAAQ,WAAG,AAAI,AAAU,AAAe,AAAC,AAE7C;YAAI,AAAK,QAAG,AAAI,KAAC,AAAO,QAAC,AAAC,AAAC,AAAC,AAC5B;YAAI,AAAO,UAAG,AAAI,KAAC,AAAQ,AAAE,WAAC,AAAa,cAAC,AAAQ,AAAC,AAAC,AACtD;YAAI,AAAS,YAAG,AAAI,KAAC,AAAK,MAAC,AAAI,AAAqB,OAAC,AAAS,AAAC,AAE/D;YAAI,AAAM,SAAG,AAAI,AAAe,4BAAC,AAAK,OAAE,AAAK,OAAE,AAAO,SAAE,AAAQ,UAAE,AAAS,AAAC,AAAC,AAE7E,AAAI;aAAC,AAAc,eAAC,AAAI,KAAC,AAAM,AAAC,AAAC,AAEjC,AAAI;aAAC,AAAQ,SAAC,AAAM,AAAC,AAAC,AACxB,AAAC;;;iBAEO,AAAQ,6BAAC,AAAmB,QAClC,AAAI;aAAC,AAAU,WAAC,AAAM,AAAC,AAAC,AACxB,AAAI;aAAC,AAAmB,oBAAC,AAAI,KAAC,AAAM,OAAC,AAAQ,AAAC,AAAC,AACjD,AAAC;;;iBAED,AAAI,uBACF,AAAI;aAAC,AAAQ,AAAE,WAAC,AAAQ,AAAE,AAAC,AAC3B,AAAI;aAAC,AAAmB,oBAAC,AAAG,AAAE,AAAC,AAE/B;YAAI,AAAM,SAAG,AAAI,KAAC,AAAQ,AAAE,WAAC,AAAI,AAAiB,AAAC,AAEnD,AAAM;eAAC,AAAqB,AAAE,AAAC,AACjC,AAAC;;;iBAED,AAAQ,+BACN,AAAI;aAAC,AAAI,AAAE,AAAC,AACZ,AAAI;aAAC,AAAc,eAAC,AAAG,AAAE,AAAC,AAC5B,AAAC;;;iBAED,AAAU,iCAAC,AAAsB,QAC/B,AAAI;aAAC,AAAQ,AAAE,WAAC,AAAM,OAAC,AAAM,AAAC,AAAC,AACjC,AAAC;;;iBAED,AAAS,iCACP,AAAM;eAAC,AAAM,kBAAC,AAAI,KAAC,AAAc,eAAC,AAAO,SAAE,AAAuB,AAAC,AAAC,AACtE,AAAC;;;iBAED,AAAQ,+BACN,AAAM;eAAC,AAAM,kBAAC,AAAI,KAAC,AAAmB,oBAAC,AAAO,SAAE,AAAuD,AAAC,AAAC,AAC3G,AAAC;;;iBAED,AAAQ,+BACN,AAAM;eAAC,AAAI,KAAC,AAAY,AAAC,AAC3B,AAAC;;;iBAED,AAAK,yBACH,AAAM;eAAC,AAAM,kBAAC,AAAI,KAAC,AAAU,WAAC,AAAO,SAAE,AAAmC,AAAC,AAAC,AAC9E,AAAC;;;iBAED,AAAY,uCACV,AAAM;eAAC,AAAM,kBAAC,AAAI,KAAC,AAAiB,kBAAC,AAAO,SAAE,AAAmD,AAAC,AAAC,AACrG,AAAC;;;iBAED,AAAc,2CACZ,AAAI;aAAC,AAAU,WAAC,AAAI,KAAC,AAAI,KAAC,AAAK,AAAE,QAAC,AAAK,AAAE,AAAC,AAAC,AAC7C,AAAC;;;iBAED,AAAe;YAAC,AAAU,iFAAG,AAAK,AAChC;;YAAI,AAAW,cAAG,AAAM,kBAAC,AAAI,KAAC,AAAK,AAAE,QAAC,AAAc,AAAE,kBAAE,AAA0D,AAAC,AAAC,AACpH,AAAI;aAAC,AAAU,WAAC,AAAI,KAAC,AAAU,aAAG,AAAW,YAAC,AAAK,AAAE,UAAG,AAAW,AAAC,AAAC,AACvE,AAAC;;;iBAED,AAAgB,+CACd;YAAI,AAAK,QAAG,AAAI,KAAC,AAAY,AAAE,eAAC,AAAK,AAAE,AAAC,AACxC,AAAI;aAAC,AAAiB,kBAAC,AAAI,KAAC,AAAK,AAAC,AAAC,AACnC,AAAM;eAAC,AAAK,AAAC,AACf,AAAC;;;iBAED,AAAa,uCAAC,AAAY,MAAE,AAAmB,YAC7C;YAAI,AAAK,QAAG,AAAK,mBAAC,AAAK,MAAC,AAAI,AAAC,AAAC,AAC9B,AAAE,AAAC;YAAC,AAAU,AAAC,YAAC,AAAK,MAAC,AAAe,gBAAC,AAAI,KAAC,AAAK,AAAE,AAAC,AAAC,AACpD,AAAI;aAAC,AAAU,WAAC,AAAI,KAAC,AAAK,AAAC,AAAC,AAC5B,AAAM;eAAC,AAAK,AAAC,AACf,AAAC;;;iBAED,AAAQ,+BACN,AAAI;aAAC,AAAU,WAAC,AAAG,AAAE,AAAC,AACxB,AAAC;;;iBAED,AAAe,6CACb,AAAI;aAAC,AAAiB,kBAAC,AAAG,AAAE,AAAC,AAC/B,AAAC;;;iBAED,AAAc,yCAAC,AAAc,GAC3B,AAAI;aAAC,AAAQ,AAAE,WAAC,AAAc,eAAC,AAAC,AAAC,AAAC,AACpC,AAAC;AAED,AAAiB;;;;iBAEjB,AAAO,6BACL,AAAM;eAAC,AAAI,KAAC,AAAK,AAAE,QAAC,AAAO,AAAE,AAAC,AAChC,AAAC;;;iBAED,AAAkB,iDAAC,AAAc,QAC/B,AAAM;eAAC,AAAI,KAAC,AAAK,AAAE,QAAC,AAAS,UAAC,AAAM,AAAC,AAAC,AACxC,AAAC;AAED,AAAa;;;;iBAEb,AAAO,2BAAC,AAAa,OAAE,AAA6B,YAClD,AAAI;aAAC,AAAE,KAAG,AAAK,AAAC,AAEhB,AAAE,AAAC;YAAC,AAAU,AAAC,YAAC,AAAU,WAAC,AAAI,AAAC,AAAC,AAEjC;YAAI,AAAoC,AAAC,cAEzC;eAAO,AAAI,MAAE,AAAC,AACZ,AAAM;qBAAG,AAAI,KAAC,AAAI,AAAE,AAAC,AACrB,AAAE,AAAC;gBAAC,AAAM,OAAC,AAAI,AAAC,MAAC,AAAK,AAAC,AACzB,AAAC;AAED,AAAM;eAAC,AAAM,OAAC,AAAqB,AAAC,AACtC,AAAC;;;iBAED,AAAI,uBACF,AAAI;YAAE,AAAG,MAAwC,AAAI,AAAC;YAA3C,AAAmB;YAAE,AAAY,AAAE,oBAC9C;;YAAI,AAAsB,AAAC,cAE3B,AAAE,AAAC;YAAC,AAAM,SAAG,AAAI,KAAC,AAAa,cAAC,AAAG,AAAC,AAAC,MAAC,AAAC,AACrC,AAAc;oCAAC,AAAQ,SAAC,AAAI,MAAE,AAAM,QAAE,AAAM,OAAC,AAAI,AAAC,AAAC,AACnD,AAAM;mBAAC,EAAE,AAAI,MAAE,AAAK,OAAE,AAAK,OAAE,AAAI,AAAE,AAAC,AACtC,AAAC;AAED,AAAM;;kBACE,AAAI,AACV,AAAK;mBAAE,AAAI,AAAY,2BACrB,AAAG,KACH,AAAM,kBAAC,AAAmB,oBAAC,AAAG,AAAE,OAAE,AAA+C,AAAC,kDAClF,AAAY,aALT,AAKU,AAAQ,AAAE,AACxB,AACF,AAAC,AACJ,AAAC;AAPG,AAAI;;;iBASA,AAAa,uCAAC,AAAgB,KACpC,AAAI;YAAE,AAAE,AAAE,KAAG,AAAI,AAAC,KAElB,AAAE,AAAC;;YAAC,AAAE,OAAK,CAAC,AAAC,AAAC,GAAC,AAAC,AACd,AAAM;mBAAC,AAAI,AAAC,AACd,AAAC;AAED;YAAI,AAAO,UAAG,AAAG,IAAC,AAAO,AAAC,AAC1B,AAAI;aAAC,AAAE,MAAI,AAAC,AAAC,AACb,AAAM;eAAC,AAAO,QAAC,AAAM,OAAC,AAAE,AAAC,AAAC,AAC5B,AAAC;;;iBAED,AAAc,yCAAC,AAAc,QAC3B,AAAc;gCAAC,AAAQ,SAAC,AAAI,MAAE,AAAM,QAAE,AAAM,OAAC,AAAI,AAAC,AAAC,AACrD,AAAC;;;iBAED,AAAgB,6CAAC,AAAuB,OACtC;YAAI,AAAK,QAAG,AAAI,KAAC,AAAY,AAAE,AAAC,AAEhC,AAAG;aAAC,IAAI,AAAC,IAAC,AAAK,MAAC,AAAM,SAAG,AAAC,GAAE,AAAC,KAAE,AAAC,GAAE,AAAC,AAAE,KAAE,AAAC,AACtC;gBAAI,AAAI,OAAG,AAAI,KAAC,AAAS,UAAC,AAAS,UAAC,AAAK,MAAC,AAAC,AAAC,AAAC,AAAC,AAC9C,AAAK;kBAAC,AAAG,IAAC,AAAI,MAAE,AAAI,KAAC,AAAK,MAAC,AAAG,AAAkC,AAAC,AAAC,AACpE,AAAC,AACH;AAAC,AACF;;;;;yBA3UG,AAAM;mBAAC,AAAI,KAAC,AAAK,MAAC,AAAE,AAAC,AACvB,AAAC,AAED,AAAY,AAAE;;uBAAC,AAAU,IACvB,AAAI;iBAAC,AAAK,MAAC,AAAE,KAAG,AAAE,AAAC,AACrB,AAAC,AAED,AAAY,AAAE;;;;yBACZ,AAAM;mBAAC,AAAI,KAAC,AAAK,MAAC,AAAE,AAAC,AACvB,AAAC,AAED,AAAY,AAAE;;uBAAC,AAAU,IACvB,AAAI;iBAAC,AAAK,MAAC,AAAE,KAAG,AAAE,AAAC,AACrB,AAAC","sourcesContent":["import { Register } from '../opcodes';\nimport { Scope, DynamicScope, Environment, Opcode } from '../environment';\nimport { ElementStack } from '../builder';\nimport { Option, Destroyable, Stack, LinkedList, ListSlice, Opaque, assert, expect } from '@glimmer/util';\nimport { ReferenceIterator, PathReference, VersionedPathReference, combineSlice } from '@glimmer/reference';\nimport { CompiledDynamicProgram } from '../compiled/blocks';\nimport { LabelOpcode, JumpIfNotModifiedOpcode, DidModifyOpcode } from '../compiled/opcodes/vm';\nimport { VMState, ListBlockOpcode, TryOpcode, BlockOpcode } from './update';\nimport RenderResult from './render-result';\n\nimport {\n  APPEND_OPCODES,\n  UpdatingOpcode\n} from '../opcodes';\n\nimport {\n  Constants,\n  ConstantString\n} from '../environment/constants';\n\nexport interface PublicVM {\n  env: Environment;\n  dynamicScope(): DynamicScope;\n  getSelf(): PathReference<Opaque>;\n  newDestroyable(d: Destroyable): void;\n}\n\nexport type CapturedStack = Opaque[];\n\nexport class EvaluationStack {\n  static empty(): EvaluationStack {\n    return new this([], 0, -1);\n  }\n\n  static restore(snapshot: CapturedStack): EvaluationStack {\n    return new this(snapshot.slice(), 0, snapshot.length - 1);\n  }\n\n  constructor(private stack: Opaque[], public fp: number, public sp: number) {\n    Object.seal(this);\n  }\n\n  isEmpty() {\n    return this.sp === -1;\n  }\n\n  push(value: Opaque): void {\n    this.stack[++this.sp] = value;\n  }\n\n  dup(position = this.sp): void {\n    this.push(this.stack[position]);\n  }\n\n  pop<T>(n = 1): T {\n    let top = this.stack[this.sp] as T;\n    this.sp -= n;\n    return top;\n  }\n\n  peek<T>(): T {\n    return this.stack[this.sp] as T;\n  }\n\n  fromBase<T>(offset: number): T {\n    return this.stack[this.fp - offset] as T;\n  }\n\n  fromTop<T>(offset: number): T {\n    return this.stack[this.sp - offset] as T;\n  }\n\n  capture(items: number): CapturedStack {\n    let end = this.sp + 1;\n    let start = end - items;\n    return this.stack.slice(start, end);\n  }\n\n  toArray() {\n    return this.stack.slice(this.fp, this.sp + 1);\n  }\n}\n\nexport type IteratorResult<T> = {\n  done: false;\n  value: null;\n} | {\n  done: true;\n  value: T;\n};\n\nexport default class VM implements PublicVM {\n  private dynamicScopeStack = new Stack<DynamicScope>();\n  private scopeStack = new Stack<Scope>();\n  public updatingOpcodeStack = new Stack<LinkedList<UpdatingOpcode>>();\n  public cacheGroups = new Stack<Option<UpdatingOpcode>>();\n  public listBlockStack = new Stack<ListBlockOpcode>();\n  public constants: Constants;\n\n  public stack = EvaluationStack.empty();\n\n  /** Registers **/\n\n  private pc = -1;\n  private ra = -1;\n\n  private get fp(): number {\n    return this.stack.fp;\n  }\n\n  private set fp(fp: number) {\n    this.stack.fp = fp;\n  }\n\n  private get sp(): number {\n    return this.stack.sp;\n  }\n\n  private set sp(sp: number) {\n    this.stack.sp = sp;\n  }\n\n  public s0: any = null;\n  public s1: any = null;\n  public t0: any = null;\n  public t1: any = null;\n\n  // Fetch a value from a register onto the stack\n  fetch(register: Register) {\n    this.stack.push(this[Register[register]]);\n  }\n\n  // Load a value from the stack into a register\n  load(register: Register) {\n    this[Register[register]] = this.stack.pop();\n  }\n\n  // Fetch a value from a register\n  fetchValue<T>(register: Register): T {\n    return this[Register[register]];\n  }\n\n  // Load a value into a register\n  loadValue<T>(register: Register, value: T) {\n    this[Register[register]] = value;\n  }\n\n  // Start a new frame and save $ra and $fp on the stack\n  pushFrame() {\n    this.stack.push(this.ra);\n    this.stack.push(this.fp);\n    this.fp = this.sp - 1;\n    // this.fp = this.sp + 1;\n  }\n\n  // Restore $ra, $sp and $fp\n  popFrame() {\n    this.sp = this.fp - 1;\n    this.ra = this.stack.fromBase<number>(0);\n    this.fp = this.stack.fromBase<number>(-1);\n  }\n\n  // Jump to an address in `program`\n  goto(pc: number) {\n    this.pc = pc;\n  }\n\n  // Save $pc into $ra, then jump to a new address in `program` (jal in MIPS)\n  call(pc: number) {\n    this.ra = this.pc;\n    this.pc = pc;\n  }\n\n  // Put a specific `program` address in $ra\n  returnTo(ra: number) {\n    this.ra = ra;\n  }\n\n  // Return to the `program` address stored in $ra\n  return() {\n    this.pc = this.ra;\n  }\n\n  static initial(\n    env: Environment,\n    self: PathReference<Opaque>,\n    dynamicScope: DynamicScope,\n    elementStack: ElementStack,\n    program: CompiledDynamicProgram\n  ) {\n    let scope = Scope.root(self, program.symbolTable.symbols.length);\n    let vm = new VM(env, scope, dynamicScope, elementStack);\n    vm.pc = program.start;\n    vm.updatingOpcodeStack.push(new LinkedList<UpdatingOpcode>());\n    return vm;\n  }\n\n  constructor(\n    public env: Environment,\n    scope: Scope,\n    dynamicScope: DynamicScope,\n    private elementStack: ElementStack,\n  ) {\n    this.env = env;\n    this.constants = env.constants;\n    this.elementStack = elementStack;\n    this.scopeStack.push(scope);\n    this.dynamicScopeStack.push(dynamicScope);\n  }\n\n  capture(args: number): VMState {\n    return {\n      env: this.env,\n      scope: this.scope(),\n      dynamicScope: this.dynamicScope(),\n      stack: this.stack.capture(args)\n    };\n  }\n\n  beginCacheGroup() {\n    this.cacheGroups.push(this.updating().tail());\n  }\n\n  commitCacheGroup() {\n    //        JumpIfNotModified(END)\n    //        (head)\n    //        (....)\n    //        (tail)\n    //        DidModify\n    // END:   Noop\n\n    let END = new LabelOpcode(\"END\");\n\n    let opcodes = this.updating();\n    let marker = this.cacheGroups.pop();\n    let head = marker ? opcodes.nextNode(marker) : opcodes.head();\n    let tail = opcodes.tail();\n    let tag = combineSlice(new ListSlice(head, tail));\n\n    let guard = new JumpIfNotModifiedOpcode(tag, END);\n\n    opcodes.insertBefore(guard, head);\n    opcodes.append(new DidModifyOpcode(guard));\n    opcodes.append(END);\n  }\n\n  enter(args: number) {\n    let updating = new LinkedList<UpdatingOpcode>();\n\n    let state = this.capture(args);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    let tryOpcode = new TryOpcode(this.pc, state, tracker, updating);\n\n    this.didEnter(tryOpcode);\n  }\n\n  iterate(memo: VersionedPathReference<Opaque>, value: VersionedPathReference<Opaque>, updating = new LinkedList<UpdatingOpcode>()): TryOpcode {\n    let stack = this.stack;\n    stack.push(value);\n    stack.push(memo);\n\n    let state = this.capture(2);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    // let ip = this.ip;\n    // this.ip = end + 4;\n    // this.frames.push(ip);\n\n    return new TryOpcode(this.pc, state, tracker, updating);\n  }\n\n  enterItem(key: string, opcode: TryOpcode) {\n    this.listBlock().map[key] = opcode;\n    this.didEnter(opcode);\n  }\n\n  enterList(start: number) {\n    let updating = new LinkedList<BlockOpcode>();\n\n    let state = this.capture(0);\n    let tracker = this.elements().pushBlockList(updating);\n    let artifacts = this.stack.peek<ReferenceIterator>().artifacts;\n\n    let opcode = new ListBlockOpcode(start, state, tracker, updating, artifacts);\n\n    this.listBlockStack.push(opcode);\n\n    this.didEnter(opcode);\n  }\n\n  private didEnter(opcode: BlockOpcode) {\n    this.updateWith(opcode);\n    this.updatingOpcodeStack.push(opcode.children);\n  }\n\n  exit() {\n    this.elements().popBlock();\n    this.updatingOpcodeStack.pop();\n\n    let parent = this.updating().tail() as BlockOpcode;\n\n    parent.didInitializeChildren();\n  }\n\n  exitList() {\n    this.exit();\n    this.listBlockStack.pop();\n  }\n\n  updateWith(opcode: UpdatingOpcode) {\n    this.updating().append(opcode);\n  }\n\n  listBlock(): ListBlockOpcode {\n    return expect(this.listBlockStack.current, 'expected a list block');\n  }\n\n  updating(): LinkedList<UpdatingOpcode> {\n    return expect(this.updatingOpcodeStack.current, 'expected updating opcode on the updating opcode stack');\n  }\n\n  elements(): ElementStack {\n    return this.elementStack;\n  }\n\n  scope(): Scope {\n    return expect(this.scopeStack.current, 'expected scope on the scope stack');\n  }\n\n  dynamicScope(): DynamicScope {\n    return expect(this.dynamicScopeStack.current, 'expected dynamic scope on the dynamic scope stack');\n  }\n\n  pushChildScope() {\n    this.scopeStack.push(this.scope().child());\n  }\n\n  pushCallerScope(childScope = false) {\n    let callerScope = expect(this.scope().getCallerScope(), 'pushCallerScope is called when a caller scope is present');\n    this.scopeStack.push(childScope ? callerScope.child() : callerScope);\n  }\n\n  pushDynamicScope(): DynamicScope {\n    let child = this.dynamicScope().child();\n    this.dynamicScopeStack.push(child);\n    return child;\n  }\n\n  pushRootScope(size: number, bindCaller: boolean): Scope {\n    let scope = Scope.sized(size);\n    if (bindCaller) scope.bindCallerScope(this.scope());\n    this.scopeStack.push(scope);\n    return scope;\n  }\n\n  popScope() {\n    this.scopeStack.pop();\n  }\n\n  popDynamicScope() {\n    this.dynamicScopeStack.pop();\n  }\n\n  newDestroyable(d: Destroyable) {\n    this.elements().newDestroyable(d);\n  }\n\n  /// SCOPE HELPERS\n\n  getSelf(): PathReference<any> {\n    return this.scope().getSelf();\n  }\n\n  referenceForSymbol(symbol: number): PathReference<any> {\n    return this.scope().getSymbol(symbol);\n  }\n\n  /// EXECUTION\n\n  execute(start: number, initialize?: (vm: VM) => void): RenderResult {\n    this.pc = start;\n\n    if (initialize) initialize(this);\n\n    let result: IteratorResult<RenderResult>;\n\n    while (true) {\n      result = this.next();\n      if (result.done) break;\n    }\n\n    return result.value as RenderResult;\n  }\n\n  next(): IteratorResult<RenderResult> {\n    let { env, updatingOpcodeStack, elementStack } = this;\n    let opcode: Option<Opcode>;\n\n    if (opcode = this.nextStatement(env)) {\n      APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n      return { done: false, value: null };\n    }\n\n    return {\n      done: true,\n      value: new RenderResult(\n        env,\n        expect(updatingOpcodeStack.pop(), 'there should be a final updating opcode stack'),\n        elementStack.popBlock()\n      )\n    };\n  }\n\n  private nextStatement(env: Environment): Option<Opcode> {\n    let { pc } = this;\n\n    if (pc === -1) {\n      return null;\n    }\n\n    let program = env.program;\n    this.pc += 4;\n    return program.opcode(pc);\n  }\n\n  evaluateOpcode(opcode: Opcode) {\n    APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n  }\n\n  bindDynamicScope(names: ConstantString[]) {\n    let scope = this.dynamicScope();\n\n    for(let i=names.length - 1; i>=0; i--) {\n      let name = this.constants.getString(names[i]);\n      scope.set(name, this.stack.pop<VersionedPathReference<Opaque>>());\n    }\n  }\n}\n"]}

@@ -54,3 +54,2 @@ import { Register } from '../opcodes';

}
let i = 0;
export default class VM {

@@ -135,5 +134,2 @@ constructor(env, scope, dynamicScope, elementStack) {

return() {
if (this.pc === (this.ra + 4)) {
throw "ZOMG";
}
this.pc = this.ra;

@@ -291,5 +287,2 @@ }

let opcode;
if (i++ > 100000) {
throw "zomg";
}
if (opcode = this.nextStatement(env)) {

@@ -324,2 +317,2 @@ APPEND_OPCODES.evaluate(this, opcode, opcode.type);

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"append.js","sourceRoot":"","sources":["append.ts"],"names":[],"mappings":"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","sourcesContent":["import { Register } from '../opcodes';\nimport { Scope, DynamicScope, Environment, Opcode } from '../environment';\nimport { ElementStack } from '../builder';\nimport { Option, Destroyable, Stack, LinkedList, ListSlice, Opaque, assert, expect } from '@glimmer/util';\nimport { ReferenceIterator, PathReference, VersionedPathReference, combineSlice } from '@glimmer/reference';\nimport { CompiledDynamicProgram } from '../compiled/blocks';\nimport { LabelOpcode, JumpIfNotModifiedOpcode, DidModifyOpcode } from '../compiled/opcodes/vm';\nimport { VMState, ListBlockOpcode, TryOpcode, BlockOpcode } from './update';\nimport RenderResult from './render-result';\n\nimport {\n  APPEND_OPCODES,\n  UpdatingOpcode\n} from '../opcodes';\n\nimport {\n  Constants,\n  ConstantString\n} from '../environment/constants';\n\nexport interface PublicVM {\n  env: Environment;\n  dynamicScope(): DynamicScope;\n  getSelf(): PathReference<Opaque>;\n  newDestroyable(d: Destroyable): void;\n}\n\nexport type CapturedStack = Opaque[];\n\nexport class EvaluationStack {\n  static empty(): EvaluationStack {\n    return new this([], 0, -1);\n  }\n\n  static restore(snapshot: CapturedStack): EvaluationStack {\n    return new this(snapshot.slice(), 0, snapshot.length - 1);\n  }\n\n  constructor(private stack: Opaque[], public fp: number, public sp: number) {\n    Object.seal(this);\n  }\n\n  isEmpty() {\n    return this.sp === -1;\n  }\n\n  push(value: Opaque): void {\n    this.stack[++this.sp] = value;\n  }\n\n  dup(position = this.sp): void {\n    this.push(this.stack[position]);\n  }\n\n  pop<T>(n = 1): T {\n    let top = this.stack[this.sp] as T;\n    this.sp -= n;\n    return top;\n  }\n\n  peek<T>(): T {\n    return this.stack[this.sp] as T;\n  }\n\n  fromBase<T>(offset: number): T {\n    return this.stack[this.fp - offset] as T;\n  }\n\n  fromTop<T>(offset: number): T {\n    return this.stack[this.sp - offset] as T;\n  }\n\n  capture(items: number): CapturedStack {\n    let end = this.sp + 1;\n    let start = end - items;\n    return this.stack.slice(start, end);\n  }\n\n  toArray() {\n    return this.stack.slice(this.fp, this.sp + 1);\n  }\n}\n\nexport type IteratorResult<T> = {\n  done: false;\n  value: null;\n} | {\n  done: true;\n  value: T;\n};\n\nlet i = 0;\n\nexport default class VM implements PublicVM {\n  private dynamicScopeStack = new Stack<DynamicScope>();\n  private scopeStack = new Stack<Scope>();\n  public updatingOpcodeStack = new Stack<LinkedList<UpdatingOpcode>>();\n  public cacheGroups = new Stack<Option<UpdatingOpcode>>();\n  public listBlockStack = new Stack<ListBlockOpcode>();\n  public constants: Constants;\n\n  public stack = EvaluationStack.empty();\n\n  /** Registers **/\n\n  private pc = -1;\n  private ra = -1;\n\n  private get fp(): number {\n    return this.stack.fp;\n  }\n\n  private set fp(fp: number) {\n    this.stack.fp = fp;\n  }\n\n  private get sp(): number {\n    return this.stack.sp;\n  }\n\n  private set sp(sp: number) {\n    this.stack.sp = sp;\n  }\n\n  public s0: any = null;\n  public s1: any = null;\n  public t0: any = null;\n  public t1: any = null;\n\n  // Fetch a value from a register onto the stack\n  fetch(register: Register) {\n    this.stack.push(this[Register[register]]);\n  }\n\n  // Load a value from the stack into a register\n  load(register: Register) {\n    this[Register[register]] = this.stack.pop();\n  }\n\n  // Fetch a value from a register\n  fetchValue<T>(register: Register): T {\n    return this[Register[register]];\n  }\n\n  // Load a value into a register\n  loadValue<T>(register: Register, value: T) {\n    this[Register[register]] = value;\n  }\n\n  // Start a new frame and save $ra and $fp on the stack\n  pushFrame() {\n    this.stack.push(this.ra);\n    this.stack.push(this.fp);\n    this.fp = this.sp - 1;\n    // this.fp = this.sp + 1;\n  }\n\n  // Restore $ra, $sp and $fp\n  popFrame() {\n    this.sp = this.fp - 1;\n    this.ra = this.stack.fromBase<number>(0);\n    this.fp = this.stack.fromBase<number>(-1);\n  }\n\n  // Jump to an address in `program`\n  goto(pc: number) {\n    this.pc = pc;\n  }\n\n  // Save $pc into $ra, then jump to a new address in `program` (jal in MIPS)\n  call(pc: number) {\n    this.ra = this.pc;\n    this.pc = pc;\n  }\n\n  // Put a specific `program` address in $ra\n  returnTo(ra: number) {\n    this.ra = ra;\n  }\n\n  // Return to the `program` address stored in $ra\n  return() {\n    if (this.pc === (this.ra + 4)) {\n      throw \"ZOMG\";\n    }\n\n    this.pc = this.ra;\n  }\n\n  static initial(\n    env: Environment,\n    self: PathReference<Opaque>,\n    dynamicScope: DynamicScope,\n    elementStack: ElementStack,\n    program: CompiledDynamicProgram\n  ) {\n    let scope = Scope.root(self, program.symbolTable.symbols.length);\n    let vm = new VM(env, scope, dynamicScope, elementStack);\n    vm.pc = program.start;\n    vm.updatingOpcodeStack.push(new LinkedList<UpdatingOpcode>());\n    return vm;\n  }\n\n  constructor(\n    public env: Environment,\n    scope: Scope,\n    dynamicScope: DynamicScope,\n    private elementStack: ElementStack,\n  ) {\n    this.env = env;\n    this.constants = env.constants;\n    this.elementStack = elementStack;\n    this.scopeStack.push(scope);\n    this.dynamicScopeStack.push(dynamicScope);\n  }\n\n  capture(args: number): VMState {\n    return {\n      env: this.env,\n      scope: this.scope(),\n      dynamicScope: this.dynamicScope(),\n      stack: this.stack.capture(args)\n    };\n  }\n\n  beginCacheGroup() {\n    this.cacheGroups.push(this.updating().tail());\n  }\n\n  commitCacheGroup() {\n    //        JumpIfNotModified(END)\n    //        (head)\n    //        (....)\n    //        (tail)\n    //        DidModify\n    // END:   Noop\n\n    let END = new LabelOpcode(\"END\");\n\n    let opcodes = this.updating();\n    let marker = this.cacheGroups.pop();\n    let head = marker ? opcodes.nextNode(marker) : opcodes.head();\n    let tail = opcodes.tail();\n    let tag = combineSlice(new ListSlice(head, tail));\n\n    let guard = new JumpIfNotModifiedOpcode(tag, END);\n\n    opcodes.insertBefore(guard, head);\n    opcodes.append(new DidModifyOpcode(guard));\n    opcodes.append(END);\n  }\n\n  enter(args: number) {\n    let updating = new LinkedList<UpdatingOpcode>();\n\n    let state = this.capture(args);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    let tryOpcode = new TryOpcode(this.pc, state, tracker, updating);\n\n    this.didEnter(tryOpcode);\n  }\n\n  iterate(memo: VersionedPathReference<Opaque>, value: VersionedPathReference<Opaque>, updating = new LinkedList<UpdatingOpcode>()): TryOpcode {\n    let stack = this.stack;\n    stack.push(value);\n    stack.push(memo);\n\n    let state = this.capture(2);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    // let ip = this.ip;\n    // this.ip = end + 4;\n    // this.frames.push(ip);\n\n    return new TryOpcode(this.pc, state, tracker, updating);\n  }\n\n  enterItem(key: string, opcode: TryOpcode) {\n    this.listBlock().map[key] = opcode;\n    this.didEnter(opcode);\n  }\n\n  enterList(start: number) {\n    let updating = new LinkedList<BlockOpcode>();\n\n    let state = this.capture(0);\n    let tracker = this.elements().pushBlockList(updating);\n    let artifacts = this.stack.peek<ReferenceIterator>().artifacts;\n\n    let opcode = new ListBlockOpcode(start, state, tracker, updating, artifacts);\n\n    this.listBlockStack.push(opcode);\n\n    this.didEnter(opcode);\n  }\n\n  private didEnter(opcode: BlockOpcode) {\n    this.updateWith(opcode);\n    this.updatingOpcodeStack.push(opcode.children);\n  }\n\n  exit() {\n    this.elements().popBlock();\n    this.updatingOpcodeStack.pop();\n\n    let parent = this.updating().tail() as BlockOpcode;\n\n    parent.didInitializeChildren();\n  }\n\n  exitList() {\n    this.exit();\n    this.listBlockStack.pop();\n  }\n\n  updateWith(opcode: UpdatingOpcode) {\n    this.updating().append(opcode);\n  }\n\n  listBlock(): ListBlockOpcode {\n    return expect(this.listBlockStack.current, 'expected a list block');\n  }\n\n  updating(): LinkedList<UpdatingOpcode> {\n    return expect(this.updatingOpcodeStack.current, 'expected updating opcode on the updating opcode stack');\n  }\n\n  elements(): ElementStack {\n    return this.elementStack;\n  }\n\n  scope(): Scope {\n    return expect(this.scopeStack.current, 'expected scope on the scope stack');\n  }\n\n  dynamicScope(): DynamicScope {\n    return expect(this.dynamicScopeStack.current, 'expected dynamic scope on the dynamic scope stack');\n  }\n\n  pushChildScope() {\n    this.scopeStack.push(this.scope().child());\n  }\n\n  pushCallerScope(childScope = false) {\n    let callerScope = expect(this.scope().getCallerScope(), 'pushCallerScope is called when a caller scope is present');\n    this.scopeStack.push(childScope ? callerScope.child() : callerScope);\n  }\n\n  pushDynamicScope(): DynamicScope {\n    let child = this.dynamicScope().child();\n    this.dynamicScopeStack.push(child);\n    return child;\n  }\n\n  pushRootScope(size: number, bindCaller: boolean): Scope {\n    let scope = Scope.sized(size);\n    if (bindCaller) scope.bindCallerScope(this.scope());\n    this.scopeStack.push(scope);\n    return scope;\n  }\n\n  popScope() {\n    this.scopeStack.pop();\n  }\n\n  popDynamicScope() {\n    this.dynamicScopeStack.pop();\n  }\n\n  newDestroyable(d: Destroyable) {\n    this.elements().newDestroyable(d);\n  }\n\n  /// SCOPE HELPERS\n\n  getSelf(): PathReference<any> {\n    return this.scope().getSelf();\n  }\n\n  referenceForSymbol(symbol: number): PathReference<any> {\n    return this.scope().getSymbol(symbol);\n  }\n\n  /// EXECUTION\n\n  execute(start: number, initialize?: (vm: VM) => void): RenderResult {\n    this.pc = start;\n\n    if (initialize) initialize(this);\n\n    let result: IteratorResult<RenderResult>;\n\n    while (true) {\n      result = this.next();\n      if (result.done) break;\n    }\n\n    return result.value as RenderResult;\n  }\n\n  next(): IteratorResult<RenderResult> {\n    let { env, updatingOpcodeStack, elementStack } = this;\n    let opcode: Option<Opcode>;\n\n    if (i++ > 100000) {\n      throw \"zomg\";\n    }\n\n    if (opcode = this.nextStatement(env)) {\n      APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n      return { done: false, value: null };\n    }\n\n    return {\n      done: true,\n      value: new RenderResult(\n        env,\n        expect(updatingOpcodeStack.pop(), 'there should be a final updating opcode stack'),\n        elementStack.popBlock()\n      )\n    };\n  }\n\n  private nextStatement(env: Environment): Option<Opcode> {\n    let { pc } = this;\n\n    if (pc === -1) {\n      return null;\n    }\n\n    let program = env.program;\n    this.pc += 4;\n    return program.opcode(pc);\n  }\n\n  evaluateOpcode(opcode: Opcode) {\n    APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n  }\n\n  bindDynamicScope(names: ConstantString[]) {\n    let scope = this.dynamicScope();\n\n    for(let i=names.length - 1; i>=0; i--) {\n      let name = this.constants.getString(names[i]);\n      scope.set(name, this.stack.pop<VersionedPathReference<Opaque>>());\n    }\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"append.js","sourceRoot":"","sources":["append.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,KAAK,EAAqC,MAAM,gBAAgB,CAAC;AAE1E,OAAO,EAAuB,KAAK,EAAE,UAAU,EAAE,SAAS,EAAkB,MAAM,EAAE,MAAM,eAAe,CAAC;AAC1G,OAAO,EAA4D,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAE5G,OAAO,EAAE,WAAW,EAAE,uBAAuB,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAC/F,OAAO,EAAW,eAAe,EAAE,SAAS,EAAe,MAAM,UAAU,CAAC;AAC5E,OAAO,YAAY,MAAM,iBAAiB,CAAC;AAE3C,OAAO,EACL,cAAc,EAEf,MAAM,YAAY,CAAC;AAgBpB,MAAM;IASJ,YAAoB,KAAe,EAAS,EAAU,EAAS,EAAU;QAArD,UAAK,GAAL,KAAK,CAAU;QAAS,OAAE,GAAF,EAAE,CAAQ;QAAS,OAAE,GAAF,EAAE,CAAQ;QACvE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpB,CAAC;IAVD,MAAM,CAAC,KAAK;QACV,MAAM,CAAC,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC7B,CAAC;IAED,MAAM,CAAC,OAAO,CAAC,QAAuB;QACpC,MAAM,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,EAAE,CAAC,EAAE,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAC5D,CAAC;IAMD,OAAO;QACL,MAAM,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC;IACxB,CAAC;IAED,IAAI,CAAC,KAAa;QAChB,IAAI,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC;IAChC,CAAC;IAED,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC,EAAE;QACpB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC;IAClC,CAAC;IAED,GAAG,CAAI,CAAC,GAAG,CAAC;QACV,IAAI,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAM,CAAC;QACnC,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;QACb,MAAM,CAAC,GAAG,CAAC;IACb,CAAC;IAED,IAAI;QACF,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAM,CAAC;IAClC,CAAC;IAED,QAAQ,CAAI,MAAc;QACxB,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,GAAG,MAAM,CAAM,CAAC;IAC3C,CAAC;IAED,OAAO,CAAI,MAAc;QACvB,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,GAAG,MAAM,CAAM,CAAC;IAC3C,CAAC;IAED,OAAO,CAAC,KAAa;QACnB,IAAI,GAAG,GAAG,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;QACtB,IAAI,KAAK,GAAG,GAAG,GAAG,KAAK,CAAC;QACxB,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACtC,CAAC;IAED,OAAO;QACL,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;IAChD,CAAC;CACF;AAUD,MAAM,CAAC,OAAO;IA0GZ,YACS,GAAgB,EACvB,KAAY,EACZ,YAA0B,EAClB,YAA0B;QAH3B,QAAG,GAAH,GAAG,CAAa;QAGf,iBAAY,GAAZ,YAAY,CAAc;QA7G5B,sBAAiB,GAAG,IAAI,KAAK,EAAgB,CAAC;QAC9C,eAAU,GAAG,IAAI,KAAK,EAAS,CAAC;QACjC,wBAAmB,GAAG,IAAI,KAAK,EAA8B,CAAC;QAC9D,gBAAW,GAAG,IAAI,KAAK,EAA0B,CAAC;QAClD,mBAAc,GAAG,IAAI,KAAK,EAAmB,CAAC;QAG9C,UAAK,GAAG,eAAe,CAAC,KAAK,EAAE,CAAC;QAEvC,iBAAiB;QAET,OAAE,GAAG,CAAC,CAAC,CAAC;QACR,OAAE,GAAG,CAAC,CAAC,CAAC;QAkBT,OAAE,GAAQ,IAAI,CAAC;QACf,OAAE,GAAQ,IAAI,CAAC;QACf,OAAE,GAAQ,IAAI,CAAC;QACf,OAAE,GAAQ,IAAI,CAAC;QA8EpB,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;QACf,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC,SAAS,CAAC;QAC/B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC5C,CAAC;IAtGD,IAAY,EAAE;QACZ,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;IACvB,CAAC;IAED,IAAY,EAAE,CAAC,EAAU;QACvB,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,IAAY,EAAE;QACZ,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;IACvB,CAAC;IAED,IAAY,EAAE,CAAC,EAAU;QACvB,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,CAAC;IACrB,CAAC;IAOD,+CAA+C;IAC/C,KAAK,CAAC,QAAkB;QACtB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC;IAED,8CAA8C;IAC9C,IAAI,CAAC,QAAkB;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;IAC9C,CAAC;IAED,gCAAgC;IAChC,UAAU,CAAI,QAAkB;QAC9B,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;IAClC,CAAC;IAED,+BAA+B;IAC/B,SAAS,CAAI,QAAkB,EAAE,KAAQ;QACvC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,GAAG,KAAK,CAAC;IACnC,CAAC;IAED,sDAAsD;IACtD,SAAS;QACP,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACzB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACzB,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;QACtB,yBAAyB;IAC3B,CAAC;IAED,2BAA2B;IAC3B,QAAQ;QACN,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;QACtB,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAS,CAAC,CAAC,CAAC;QACzC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAS,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC;IAED,kCAAkC;IAClC,IAAI,CAAC,EAAU;QACb,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;IACf,CAAC;IAED,2EAA2E;IAC3E,IAAI,CAAC,EAAU;QACb,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;QAClB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;IACf,CAAC;IAED,0CAA0C;IAC1C,QAAQ,CAAC,EAAU;QACjB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;IACf,CAAC;IAED,gDAAgD;IAChD,MAAM;QACJ,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;IACpB,CAAC;IAED,MAAM,CAAC,OAAO,CACZ,GAAgB,EAChB,IAA2B,EAC3B,YAA0B,EAC1B,YAA0B,EAC1B,OAA+B;QAE/B,IAAI,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACjE,IAAI,EAAE,GAAG,IAAI,EAAE,CAAC,GAAG,EAAE,KAAK,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC;QACxD,EAAE,CAAC,EAAE,GAAG,OAAO,CAAC,KAAK,CAAC;QACtB,EAAE,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,UAAU,EAAkB,CAAC,CAAC;QAC9D,MAAM,CAAC,EAAE,CAAC;IACZ,CAAC;IAeD,OAAO,CAAC,IAAY;QAClB,MAAM,CAAC;YACL,GAAG,EAAE,IAAI,CAAC,GAAG;YACb,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE;YACnB,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE;YACjC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;SAChC,CAAC;IACJ,CAAC;IAED,eAAe;QACb,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;IAChD,CAAC;IAED,gBAAgB;QACd,gCAAgC;QAChC,gBAAgB;QAChB,gBAAgB;QAChB,gBAAgB;QAChB,mBAAmB;QACnB,cAAc;QAEd,IAAI,GAAG,GAAG,IAAI,WAAW,CAAC,KAAK,CAAC,CAAC;QAEjC,IAAI,OAAO,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC9B,IAAI,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC;QACpC,IAAI,IAAI,GAAG,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;QAC9D,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;QAC1B,IAAI,GAAG,GAAG,YAAY,CAAC,IAAI,SAAS,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;QAElD,IAAI,KAAK,GAAG,IAAI,uBAAuB,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAElD,OAAO,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAClC,OAAO,CAAC,MAAM,CAAC,IAAI,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC;QAC3C,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACtB,CAAC;IAED,KAAK,CAAC,IAAY;QAChB,IAAI,QAAQ,GAAG,IAAI,UAAU,EAAkB,CAAC;QAEhD,IAAI,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC/B,IAAI,OAAO,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,kBAAkB,EAAE,CAAC;QAEnD,IAAI,SAAS,GAAG,IAAI,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;QAEjE,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;IAC3B,CAAC;IAED,OAAO,CAAC,IAAoC,EAAE,KAAqC,EAAE,QAAQ,GAAG,IAAI,UAAU,EAAkB;QAC9H,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACvB,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClB,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEjB,IAAI,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAC5B,IAAI,OAAO,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,kBAAkB,EAAE,CAAC;QAEnD,oBAAoB;QACpB,qBAAqB;QACrB,wBAAwB;QAExB,MAAM,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;IAC1D,CAAC;IAED,SAAS,CAAC,GAAW,EAAE,MAAiB;QACtC,IAAI,CAAC,SAAS,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC;QACnC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IACxB,CAAC;IAED,SAAS,CAAC,KAAa;QACrB,IAAI,QAAQ,GAAG,IAAI,UAAU,EAAe,CAAC;QAE7C,IAAI,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAC5B,IAAI,OAAO,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QACtD,IAAI,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,EAAqB,CAAC,SAAS,CAAC;QAE/D,IAAI,MAAM,GAAG,IAAI,eAAe,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;QAE7E,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEjC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IACxB,CAAC;IAEO,QAAQ,CAAC,MAAmB;QAClC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QACxB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACjD,CAAC;IAED,IAAI;QACF,IAAI,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE,CAAC;QAC3B,IAAI,CAAC,mBAAmB,CAAC,GAAG,EAAE,CAAC;QAE/B,IAAI,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAiB,CAAC;QAEnD,MAAM,CAAC,qBAAqB,EAAE,CAAC;IACjC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,EAAE,CAAC;QACZ,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE,CAAC;IAC5B,CAAC;IAED,UAAU,CAAC,MAAsB;QAC/B,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACjC,CAAC;IAED,SAAS;QACP,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,uBAAuB,CAAC,CAAC;IACtE,CAAC;IAED,QAAQ;QACN,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,uDAAuD,CAAC,CAAC;IAC3G,CAAC;IAED,QAAQ;QACN,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,KAAK;QACH,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,mCAAmC,CAAC,CAAC;IAC9E,CAAC;IAED,YAAY;QACV,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,mDAAmD,CAAC,CAAC;IACrG,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC;IAC7C,CAAC;IAED,eAAe,CAAC,UAAU,GAAG,KAAK;QAChC,IAAI,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,cAAc,EAAE,EAAE,0DAA0D,CAAC,CAAC;QACpH,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,GAAG,WAAW,CAAC,KAAK,EAAE,GAAG,WAAW,CAAC,CAAC;IACvE,CAAC;IAED,gBAAgB;QACd,IAAI,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC,KAAK,EAAE,CAAC;QACxC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACnC,MAAM,CAAC,KAAK,CAAC;IACf,CAAC;IAED,aAAa,CAAC,IAAY,EAAE,UAAmB;QAC7C,IAAI,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC9B,EAAE,CAAC,CAAC,UAAU,CAAC;YAAC,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QACpD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5B,MAAM,CAAC,KAAK,CAAC;IACf,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC;IACxB,CAAC;IAED,eAAe;QACb,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE,CAAC;IAC/B,CAAC;IAED,cAAc,CAAC,CAAc;QAC3B,IAAI,CAAC,QAAQ,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;IACpC,CAAC;IAED,iBAAiB;IAEjB,OAAO;QACL,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,OAAO,EAAE,CAAC;IAChC,CAAC;IAED,kBAAkB,CAAC,MAAc;QAC/B,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IACxC,CAAC;IAED,aAAa;IAEb,OAAO,CAAC,KAAa,EAAE,UAA6B;QAClD,IAAI,CAAC,EAAE,GAAG,KAAK,CAAC;QAEhB,EAAE,CAAC,CAAC,UAAU,CAAC;YAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAEjC,IAAI,MAAoC,CAAC;QAEzC,OAAO,IAAI,EAAE,CAAC;YACZ,MAAM,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;YACrB,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC;gBAAC,KAAK,CAAC;QACzB,CAAC;QAED,MAAM,CAAC,MAAM,CAAC,KAAqB,CAAC;IACtC,CAAC;IAED,IAAI;QACF,IAAI,EAAE,GAAG,EAAE,mBAAmB,EAAE,YAAY,EAAE,GAAG,IAAI,CAAC;QACtD,IAAI,MAAsB,CAAC;QAE3B,EAAE,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACrC,cAAc,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;YACnD,MAAM,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;QACtC,CAAC;QAED,MAAM,CAAC;YACL,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,IAAI,YAAY,CACrB,GAAG,EACH,MAAM,CAAC,mBAAmB,CAAC,GAAG,EAAE,EAAE,+CAA+C,CAAC,EAClF,YAAY,CAAC,QAAQ,EAAE,CACxB;SACF,CAAC;IACJ,CAAC;IAEO,aAAa,CAAC,GAAgB;QACpC,IAAI,EAAE,EAAE,EAAE,GAAG,IAAI,CAAC;QAElB,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;YACd,MAAM,CAAC,IAAI,CAAC;QACd,CAAC;QAED,IAAI,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC;QAC1B,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;QACb,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAC5B,CAAC;IAED,cAAc,CAAC,MAAc;QAC3B,cAAc,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;IACrD,CAAC;IAED,gBAAgB,CAAC,KAAuB;QACtC,IAAI,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAEhC,GAAG,CAAA,CAAC,IAAI,CAAC,GAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YACtC,IAAI,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;YAC9C,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,EAAkC,CAAC,CAAC;QACpE,CAAC;IACH,CAAC;CACF","sourcesContent":["import { Register } from '../opcodes';\nimport { Scope, DynamicScope, Environment, Opcode } from '../environment';\nimport { ElementStack } from '../builder';\nimport { Option, Destroyable, Stack, LinkedList, ListSlice, Opaque, assert, expect } from '@glimmer/util';\nimport { ReferenceIterator, PathReference, VersionedPathReference, combineSlice } from '@glimmer/reference';\nimport { CompiledDynamicProgram } from '../compiled/blocks';\nimport { LabelOpcode, JumpIfNotModifiedOpcode, DidModifyOpcode } from '../compiled/opcodes/vm';\nimport { VMState, ListBlockOpcode, TryOpcode, BlockOpcode } from './update';\nimport RenderResult from './render-result';\n\nimport {\n  APPEND_OPCODES,\n  UpdatingOpcode\n} from '../opcodes';\n\nimport {\n  Constants,\n  ConstantString\n} from '../environment/constants';\n\nexport interface PublicVM {\n  env: Environment;\n  dynamicScope(): DynamicScope;\n  getSelf(): PathReference<Opaque>;\n  newDestroyable(d: Destroyable): void;\n}\n\nexport type CapturedStack = Opaque[];\n\nexport class EvaluationStack {\n  static empty(): EvaluationStack {\n    return new this([], 0, -1);\n  }\n\n  static restore(snapshot: CapturedStack): EvaluationStack {\n    return new this(snapshot.slice(), 0, snapshot.length - 1);\n  }\n\n  constructor(private stack: Opaque[], public fp: number, public sp: number) {\n    Object.seal(this);\n  }\n\n  isEmpty() {\n    return this.sp === -1;\n  }\n\n  push(value: Opaque): void {\n    this.stack[++this.sp] = value;\n  }\n\n  dup(position = this.sp): void {\n    this.push(this.stack[position]);\n  }\n\n  pop<T>(n = 1): T {\n    let top = this.stack[this.sp] as T;\n    this.sp -= n;\n    return top;\n  }\n\n  peek<T>(): T {\n    return this.stack[this.sp] as T;\n  }\n\n  fromBase<T>(offset: number): T {\n    return this.stack[this.fp - offset] as T;\n  }\n\n  fromTop<T>(offset: number): T {\n    return this.stack[this.sp - offset] as T;\n  }\n\n  capture(items: number): CapturedStack {\n    let end = this.sp + 1;\n    let start = end - items;\n    return this.stack.slice(start, end);\n  }\n\n  toArray() {\n    return this.stack.slice(this.fp, this.sp + 1);\n  }\n}\n\nexport type IteratorResult<T> = {\n  done: false;\n  value: null;\n} | {\n  done: true;\n  value: T;\n};\n\nexport default class VM implements PublicVM {\n  private dynamicScopeStack = new Stack<DynamicScope>();\n  private scopeStack = new Stack<Scope>();\n  public updatingOpcodeStack = new Stack<LinkedList<UpdatingOpcode>>();\n  public cacheGroups = new Stack<Option<UpdatingOpcode>>();\n  public listBlockStack = new Stack<ListBlockOpcode>();\n  public constants: Constants;\n\n  public stack = EvaluationStack.empty();\n\n  /** Registers **/\n\n  private pc = -1;\n  private ra = -1;\n\n  private get fp(): number {\n    return this.stack.fp;\n  }\n\n  private set fp(fp: number) {\n    this.stack.fp = fp;\n  }\n\n  private get sp(): number {\n    return this.stack.sp;\n  }\n\n  private set sp(sp: number) {\n    this.stack.sp = sp;\n  }\n\n  public s0: any = null;\n  public s1: any = null;\n  public t0: any = null;\n  public t1: any = null;\n\n  // Fetch a value from a register onto the stack\n  fetch(register: Register) {\n    this.stack.push(this[Register[register]]);\n  }\n\n  // Load a value from the stack into a register\n  load(register: Register) {\n    this[Register[register]] = this.stack.pop();\n  }\n\n  // Fetch a value from a register\n  fetchValue<T>(register: Register): T {\n    return this[Register[register]];\n  }\n\n  // Load a value into a register\n  loadValue<T>(register: Register, value: T) {\n    this[Register[register]] = value;\n  }\n\n  // Start a new frame and save $ra and $fp on the stack\n  pushFrame() {\n    this.stack.push(this.ra);\n    this.stack.push(this.fp);\n    this.fp = this.sp - 1;\n    // this.fp = this.sp + 1;\n  }\n\n  // Restore $ra, $sp and $fp\n  popFrame() {\n    this.sp = this.fp - 1;\n    this.ra = this.stack.fromBase<number>(0);\n    this.fp = this.stack.fromBase<number>(-1);\n  }\n\n  // Jump to an address in `program`\n  goto(pc: number) {\n    this.pc = pc;\n  }\n\n  // Save $pc into $ra, then jump to a new address in `program` (jal in MIPS)\n  call(pc: number) {\n    this.ra = this.pc;\n    this.pc = pc;\n  }\n\n  // Put a specific `program` address in $ra\n  returnTo(ra: number) {\n    this.ra = ra;\n  }\n\n  // Return to the `program` address stored in $ra\n  return() {\n    this.pc = this.ra;\n  }\n\n  static initial(\n    env: Environment,\n    self: PathReference<Opaque>,\n    dynamicScope: DynamicScope,\n    elementStack: ElementStack,\n    program: CompiledDynamicProgram\n  ) {\n    let scope = Scope.root(self, program.symbolTable.symbols.length);\n    let vm = new VM(env, scope, dynamicScope, elementStack);\n    vm.pc = program.start;\n    vm.updatingOpcodeStack.push(new LinkedList<UpdatingOpcode>());\n    return vm;\n  }\n\n  constructor(\n    public env: Environment,\n    scope: Scope,\n    dynamicScope: DynamicScope,\n    private elementStack: ElementStack,\n  ) {\n    this.env = env;\n    this.constants = env.constants;\n    this.elementStack = elementStack;\n    this.scopeStack.push(scope);\n    this.dynamicScopeStack.push(dynamicScope);\n  }\n\n  capture(args: number): VMState {\n    return {\n      env: this.env,\n      scope: this.scope(),\n      dynamicScope: this.dynamicScope(),\n      stack: this.stack.capture(args)\n    };\n  }\n\n  beginCacheGroup() {\n    this.cacheGroups.push(this.updating().tail());\n  }\n\n  commitCacheGroup() {\n    //        JumpIfNotModified(END)\n    //        (head)\n    //        (....)\n    //        (tail)\n    //        DidModify\n    // END:   Noop\n\n    let END = new LabelOpcode(\"END\");\n\n    let opcodes = this.updating();\n    let marker = this.cacheGroups.pop();\n    let head = marker ? opcodes.nextNode(marker) : opcodes.head();\n    let tail = opcodes.tail();\n    let tag = combineSlice(new ListSlice(head, tail));\n\n    let guard = new JumpIfNotModifiedOpcode(tag, END);\n\n    opcodes.insertBefore(guard, head);\n    opcodes.append(new DidModifyOpcode(guard));\n    opcodes.append(END);\n  }\n\n  enter(args: number) {\n    let updating = new LinkedList<UpdatingOpcode>();\n\n    let state = this.capture(args);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    let tryOpcode = new TryOpcode(this.pc, state, tracker, updating);\n\n    this.didEnter(tryOpcode);\n  }\n\n  iterate(memo: VersionedPathReference<Opaque>, value: VersionedPathReference<Opaque>, updating = new LinkedList<UpdatingOpcode>()): TryOpcode {\n    let stack = this.stack;\n    stack.push(value);\n    stack.push(memo);\n\n    let state = this.capture(2);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    // let ip = this.ip;\n    // this.ip = end + 4;\n    // this.frames.push(ip);\n\n    return new TryOpcode(this.pc, state, tracker, updating);\n  }\n\n  enterItem(key: string, opcode: TryOpcode) {\n    this.listBlock().map[key] = opcode;\n    this.didEnter(opcode);\n  }\n\n  enterList(start: number) {\n    let updating = new LinkedList<BlockOpcode>();\n\n    let state = this.capture(0);\n    let tracker = this.elements().pushBlockList(updating);\n    let artifacts = this.stack.peek<ReferenceIterator>().artifacts;\n\n    let opcode = new ListBlockOpcode(start, state, tracker, updating, artifacts);\n\n    this.listBlockStack.push(opcode);\n\n    this.didEnter(opcode);\n  }\n\n  private didEnter(opcode: BlockOpcode) {\n    this.updateWith(opcode);\n    this.updatingOpcodeStack.push(opcode.children);\n  }\n\n  exit() {\n    this.elements().popBlock();\n    this.updatingOpcodeStack.pop();\n\n    let parent = this.updating().tail() as BlockOpcode;\n\n    parent.didInitializeChildren();\n  }\n\n  exitList() {\n    this.exit();\n    this.listBlockStack.pop();\n  }\n\n  updateWith(opcode: UpdatingOpcode) {\n    this.updating().append(opcode);\n  }\n\n  listBlock(): ListBlockOpcode {\n    return expect(this.listBlockStack.current, 'expected a list block');\n  }\n\n  updating(): LinkedList<UpdatingOpcode> {\n    return expect(this.updatingOpcodeStack.current, 'expected updating opcode on the updating opcode stack');\n  }\n\n  elements(): ElementStack {\n    return this.elementStack;\n  }\n\n  scope(): Scope {\n    return expect(this.scopeStack.current, 'expected scope on the scope stack');\n  }\n\n  dynamicScope(): DynamicScope {\n    return expect(this.dynamicScopeStack.current, 'expected dynamic scope on the dynamic scope stack');\n  }\n\n  pushChildScope() {\n    this.scopeStack.push(this.scope().child());\n  }\n\n  pushCallerScope(childScope = false) {\n    let callerScope = expect(this.scope().getCallerScope(), 'pushCallerScope is called when a caller scope is present');\n    this.scopeStack.push(childScope ? callerScope.child() : callerScope);\n  }\n\n  pushDynamicScope(): DynamicScope {\n    let child = this.dynamicScope().child();\n    this.dynamicScopeStack.push(child);\n    return child;\n  }\n\n  pushRootScope(size: number, bindCaller: boolean): Scope {\n    let scope = Scope.sized(size);\n    if (bindCaller) scope.bindCallerScope(this.scope());\n    this.scopeStack.push(scope);\n    return scope;\n  }\n\n  popScope() {\n    this.scopeStack.pop();\n  }\n\n  popDynamicScope() {\n    this.dynamicScopeStack.pop();\n  }\n\n  newDestroyable(d: Destroyable) {\n    this.elements().newDestroyable(d);\n  }\n\n  /// SCOPE HELPERS\n\n  getSelf(): PathReference<any> {\n    return this.scope().getSelf();\n  }\n\n  referenceForSymbol(symbol: number): PathReference<any> {\n    return this.scope().getSymbol(symbol);\n  }\n\n  /// EXECUTION\n\n  execute(start: number, initialize?: (vm: VM) => void): RenderResult {\n    this.pc = start;\n\n    if (initialize) initialize(this);\n\n    let result: IteratorResult<RenderResult>;\n\n    while (true) {\n      result = this.next();\n      if (result.done) break;\n    }\n\n    return result.value as RenderResult;\n  }\n\n  next(): IteratorResult<RenderResult> {\n    let { env, updatingOpcodeStack, elementStack } = this;\n    let opcode: Option<Opcode>;\n\n    if (opcode = this.nextStatement(env)) {\n      APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n      return { done: false, value: null };\n    }\n\n    return {\n      done: true,\n      value: new RenderResult(\n        env,\n        expect(updatingOpcodeStack.pop(), 'there should be a final updating opcode stack'),\n        elementStack.popBlock()\n      )\n    };\n  }\n\n  private nextStatement(env: Environment): Option<Opcode> {\n    let { pc } = this;\n\n    if (pc === -1) {\n      return null;\n    }\n\n    let program = env.program;\n    this.pc += 4;\n    return program.opcode(pc);\n  }\n\n  evaluateOpcode(opcode: Opcode) {\n    APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n  }\n\n  bindDynamicScope(names: ConstantString[]) {\n    let scope = this.dynamicScope();\n\n    for(let i=names.length - 1; i>=0; i--) {\n      let name = this.constants.getString(names[i]);\n      scope.set(name, this.stack.pop<VersionedPathReference<Opaque>>());\n    }\n  }\n}\n"]}

@@ -77,3 +77,2 @@ var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();

}();
var i = 0;

@@ -168,5 +167,2 @@ var VM = function () {

VM.prototype.return = function _return() {
if (this.pc === this.ra + 4) {
throw "ZOMG";
}
this.pc = this.ra;

@@ -358,5 +354,2 @@ };

var opcode = void 0;
if (i++ > 100000) {
throw "zomg";
}
if (opcode = this.nextStatement(env)) {

@@ -389,4 +382,4 @@ APPEND_OPCODES.evaluate(this, opcode, opcode.type);

var scope = this.dynamicScope();
for (var _i = names.length - 1; _i >= 0; _i--) {
var name = this.constants.getString(names[_i]);
for (var i = names.length - 1; i >= 0; i--) {
var name = this.constants.getString(names[i]);
scope.set(name, this.stack.pop());

@@ -418,2 +411,2 @@ }

export default VM;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"append.js","sourceRoot":"","sources":["append.ts"],"names":[],"mappings":"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","sourcesContent":["import { Register } from '../opcodes';\nimport { Scope, DynamicScope, Environment, Opcode } from '../environment';\nimport { ElementStack } from '../builder';\nimport { Option, Destroyable, Stack, LinkedList, ListSlice, Opaque, assert, expect } from '@glimmer/util';\nimport { ReferenceIterator, PathReference, VersionedPathReference, combineSlice } from '@glimmer/reference';\nimport { CompiledDynamicProgram } from '../compiled/blocks';\nimport { LabelOpcode, JumpIfNotModifiedOpcode, DidModifyOpcode } from '../compiled/opcodes/vm';\nimport { VMState, ListBlockOpcode, TryOpcode, BlockOpcode } from './update';\nimport RenderResult from './render-result';\n\nimport {\n  APPEND_OPCODES,\n  UpdatingOpcode\n} from '../opcodes';\n\nimport {\n  Constants,\n  ConstantString\n} from '../environment/constants';\n\nexport interface PublicVM {\n  env: Environment;\n  dynamicScope(): DynamicScope;\n  getSelf(): PathReference<Opaque>;\n  newDestroyable(d: Destroyable): void;\n}\n\nexport type CapturedStack = Opaque[];\n\nexport class EvaluationStack {\n  static empty(): EvaluationStack {\n    return new this([], 0, -1);\n  }\n\n  static restore(snapshot: CapturedStack): EvaluationStack {\n    return new this(snapshot.slice(), 0, snapshot.length - 1);\n  }\n\n  constructor(private stack: Opaque[], public fp: number, public sp: number) {\n    Object.seal(this);\n  }\n\n  isEmpty() {\n    return this.sp === -1;\n  }\n\n  push(value: Opaque): void {\n    this.stack[++this.sp] = value;\n  }\n\n  dup(position = this.sp): void {\n    this.push(this.stack[position]);\n  }\n\n  pop<T>(n = 1): T {\n    let top = this.stack[this.sp] as T;\n    this.sp -= n;\n    return top;\n  }\n\n  peek<T>(): T {\n    return this.stack[this.sp] as T;\n  }\n\n  fromBase<T>(offset: number): T {\n    return this.stack[this.fp - offset] as T;\n  }\n\n  fromTop<T>(offset: number): T {\n    return this.stack[this.sp - offset] as T;\n  }\n\n  capture(items: number): CapturedStack {\n    let end = this.sp + 1;\n    let start = end - items;\n    return this.stack.slice(start, end);\n  }\n\n  toArray() {\n    return this.stack.slice(this.fp, this.sp + 1);\n  }\n}\n\nexport type IteratorResult<T> = {\n  done: false;\n  value: null;\n} | {\n  done: true;\n  value: T;\n};\n\nlet i = 0;\n\nexport default class VM implements PublicVM {\n  private dynamicScopeStack = new Stack<DynamicScope>();\n  private scopeStack = new Stack<Scope>();\n  public updatingOpcodeStack = new Stack<LinkedList<UpdatingOpcode>>();\n  public cacheGroups = new Stack<Option<UpdatingOpcode>>();\n  public listBlockStack = new Stack<ListBlockOpcode>();\n  public constants: Constants;\n\n  public stack = EvaluationStack.empty();\n\n  /** Registers **/\n\n  private pc = -1;\n  private ra = -1;\n\n  private get fp(): number {\n    return this.stack.fp;\n  }\n\n  private set fp(fp: number) {\n    this.stack.fp = fp;\n  }\n\n  private get sp(): number {\n    return this.stack.sp;\n  }\n\n  private set sp(sp: number) {\n    this.stack.sp = sp;\n  }\n\n  public s0: any = null;\n  public s1: any = null;\n  public t0: any = null;\n  public t1: any = null;\n\n  // Fetch a value from a register onto the stack\n  fetch(register: Register) {\n    this.stack.push(this[Register[register]]);\n  }\n\n  // Load a value from the stack into a register\n  load(register: Register) {\n    this[Register[register]] = this.stack.pop();\n  }\n\n  // Fetch a value from a register\n  fetchValue<T>(register: Register): T {\n    return this[Register[register]];\n  }\n\n  // Load a value into a register\n  loadValue<T>(register: Register, value: T) {\n    this[Register[register]] = value;\n  }\n\n  // Start a new frame and save $ra and $fp on the stack\n  pushFrame() {\n    this.stack.push(this.ra);\n    this.stack.push(this.fp);\n    this.fp = this.sp - 1;\n    // this.fp = this.sp + 1;\n  }\n\n  // Restore $ra, $sp and $fp\n  popFrame() {\n    this.sp = this.fp - 1;\n    this.ra = this.stack.fromBase<number>(0);\n    this.fp = this.stack.fromBase<number>(-1);\n  }\n\n  // Jump to an address in `program`\n  goto(pc: number) {\n    this.pc = pc;\n  }\n\n  // Save $pc into $ra, then jump to a new address in `program` (jal in MIPS)\n  call(pc: number) {\n    this.ra = this.pc;\n    this.pc = pc;\n  }\n\n  // Put a specific `program` address in $ra\n  returnTo(ra: number) {\n    this.ra = ra;\n  }\n\n  // Return to the `program` address stored in $ra\n  return() {\n    if (this.pc === (this.ra + 4)) {\n      throw \"ZOMG\";\n    }\n\n    this.pc = this.ra;\n  }\n\n  static initial(\n    env: Environment,\n    self: PathReference<Opaque>,\n    dynamicScope: DynamicScope,\n    elementStack: ElementStack,\n    program: CompiledDynamicProgram\n  ) {\n    let scope = Scope.root(self, program.symbolTable.symbols.length);\n    let vm = new VM(env, scope, dynamicScope, elementStack);\n    vm.pc = program.start;\n    vm.updatingOpcodeStack.push(new LinkedList<UpdatingOpcode>());\n    return vm;\n  }\n\n  constructor(\n    public env: Environment,\n    scope: Scope,\n    dynamicScope: DynamicScope,\n    private elementStack: ElementStack,\n  ) {\n    this.env = env;\n    this.constants = env.constants;\n    this.elementStack = elementStack;\n    this.scopeStack.push(scope);\n    this.dynamicScopeStack.push(dynamicScope);\n  }\n\n  capture(args: number): VMState {\n    return {\n      env: this.env,\n      scope: this.scope(),\n      dynamicScope: this.dynamicScope(),\n      stack: this.stack.capture(args)\n    };\n  }\n\n  beginCacheGroup() {\n    this.cacheGroups.push(this.updating().tail());\n  }\n\n  commitCacheGroup() {\n    //        JumpIfNotModified(END)\n    //        (head)\n    //        (....)\n    //        (tail)\n    //        DidModify\n    // END:   Noop\n\n    let END = new LabelOpcode(\"END\");\n\n    let opcodes = this.updating();\n    let marker = this.cacheGroups.pop();\n    let head = marker ? opcodes.nextNode(marker) : opcodes.head();\n    let tail = opcodes.tail();\n    let tag = combineSlice(new ListSlice(head, tail));\n\n    let guard = new JumpIfNotModifiedOpcode(tag, END);\n\n    opcodes.insertBefore(guard, head);\n    opcodes.append(new DidModifyOpcode(guard));\n    opcodes.append(END);\n  }\n\n  enter(args: number) {\n    let updating = new LinkedList<UpdatingOpcode>();\n\n    let state = this.capture(args);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    let tryOpcode = new TryOpcode(this.pc, state, tracker, updating);\n\n    this.didEnter(tryOpcode);\n  }\n\n  iterate(memo: VersionedPathReference<Opaque>, value: VersionedPathReference<Opaque>, updating = new LinkedList<UpdatingOpcode>()): TryOpcode {\n    let stack = this.stack;\n    stack.push(value);\n    stack.push(memo);\n\n    let state = this.capture(2);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    // let ip = this.ip;\n    // this.ip = end + 4;\n    // this.frames.push(ip);\n\n    return new TryOpcode(this.pc, state, tracker, updating);\n  }\n\n  enterItem(key: string, opcode: TryOpcode) {\n    this.listBlock().map[key] = opcode;\n    this.didEnter(opcode);\n  }\n\n  enterList(start: number) {\n    let updating = new LinkedList<BlockOpcode>();\n\n    let state = this.capture(0);\n    let tracker = this.elements().pushBlockList(updating);\n    let artifacts = this.stack.peek<ReferenceIterator>().artifacts;\n\n    let opcode = new ListBlockOpcode(start, state, tracker, updating, artifacts);\n\n    this.listBlockStack.push(opcode);\n\n    this.didEnter(opcode);\n  }\n\n  private didEnter(opcode: BlockOpcode) {\n    this.updateWith(opcode);\n    this.updatingOpcodeStack.push(opcode.children);\n  }\n\n  exit() {\n    this.elements().popBlock();\n    this.updatingOpcodeStack.pop();\n\n    let parent = this.updating().tail() as BlockOpcode;\n\n    parent.didInitializeChildren();\n  }\n\n  exitList() {\n    this.exit();\n    this.listBlockStack.pop();\n  }\n\n  updateWith(opcode: UpdatingOpcode) {\n    this.updating().append(opcode);\n  }\n\n  listBlock(): ListBlockOpcode {\n    return expect(this.listBlockStack.current, 'expected a list block');\n  }\n\n  updating(): LinkedList<UpdatingOpcode> {\n    return expect(this.updatingOpcodeStack.current, 'expected updating opcode on the updating opcode stack');\n  }\n\n  elements(): ElementStack {\n    return this.elementStack;\n  }\n\n  scope(): Scope {\n    return expect(this.scopeStack.current, 'expected scope on the scope stack');\n  }\n\n  dynamicScope(): DynamicScope {\n    return expect(this.dynamicScopeStack.current, 'expected dynamic scope on the dynamic scope stack');\n  }\n\n  pushChildScope() {\n    this.scopeStack.push(this.scope().child());\n  }\n\n  pushCallerScope(childScope = false) {\n    let callerScope = expect(this.scope().getCallerScope(), 'pushCallerScope is called when a caller scope is present');\n    this.scopeStack.push(childScope ? callerScope.child() : callerScope);\n  }\n\n  pushDynamicScope(): DynamicScope {\n    let child = this.dynamicScope().child();\n    this.dynamicScopeStack.push(child);\n    return child;\n  }\n\n  pushRootScope(size: number, bindCaller: boolean): Scope {\n    let scope = Scope.sized(size);\n    if (bindCaller) scope.bindCallerScope(this.scope());\n    this.scopeStack.push(scope);\n    return scope;\n  }\n\n  popScope() {\n    this.scopeStack.pop();\n  }\n\n  popDynamicScope() {\n    this.dynamicScopeStack.pop();\n  }\n\n  newDestroyable(d: Destroyable) {\n    this.elements().newDestroyable(d);\n  }\n\n  /// SCOPE HELPERS\n\n  getSelf(): PathReference<any> {\n    return this.scope().getSelf();\n  }\n\n  referenceForSymbol(symbol: number): PathReference<any> {\n    return this.scope().getSymbol(symbol);\n  }\n\n  /// EXECUTION\n\n  execute(start: number, initialize?: (vm: VM) => void): RenderResult {\n    this.pc = start;\n\n    if (initialize) initialize(this);\n\n    let result: IteratorResult<RenderResult>;\n\n    while (true) {\n      result = this.next();\n      if (result.done) break;\n    }\n\n    return result.value as RenderResult;\n  }\n\n  next(): IteratorResult<RenderResult> {\n    let { env, updatingOpcodeStack, elementStack } = this;\n    let opcode: Option<Opcode>;\n\n    if (i++ > 100000) {\n      throw \"zomg\";\n    }\n\n    if (opcode = this.nextStatement(env)) {\n      APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n      return { done: false, value: null };\n    }\n\n    return {\n      done: true,\n      value: new RenderResult(\n        env,\n        expect(updatingOpcodeStack.pop(), 'there should be a final updating opcode stack'),\n        elementStack.popBlock()\n      )\n    };\n  }\n\n  private nextStatement(env: Environment): Option<Opcode> {\n    let { pc } = this;\n\n    if (pc === -1) {\n      return null;\n    }\n\n    let program = env.program;\n    this.pc += 4;\n    return program.opcode(pc);\n  }\n\n  evaluateOpcode(opcode: Opcode) {\n    APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n  }\n\n  bindDynamicScope(names: ConstantString[]) {\n    let scope = this.dynamicScope();\n\n    for(let i=names.length - 1; i>=0; i--) {\n      let name = this.constants.getString(names[i]);\n      scope.set(name, this.stack.pop<VersionedPathReference<Opaque>>());\n    }\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"append.js","sourceRoot":"","sources":["append.ts"],"names":[],"mappings":"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","sourcesContent":["import { Register } from '../opcodes';\nimport { Scope, DynamicScope, Environment, Opcode } from '../environment';\nimport { ElementStack } from '../builder';\nimport { Option, Destroyable, Stack, LinkedList, ListSlice, Opaque, assert, expect } from '@glimmer/util';\nimport { ReferenceIterator, PathReference, VersionedPathReference, combineSlice } from '@glimmer/reference';\nimport { CompiledDynamicProgram } from '../compiled/blocks';\nimport { LabelOpcode, JumpIfNotModifiedOpcode, DidModifyOpcode } from '../compiled/opcodes/vm';\nimport { VMState, ListBlockOpcode, TryOpcode, BlockOpcode } from './update';\nimport RenderResult from './render-result';\n\nimport {\n  APPEND_OPCODES,\n  UpdatingOpcode\n} from '../opcodes';\n\nimport {\n  Constants,\n  ConstantString\n} from '../environment/constants';\n\nexport interface PublicVM {\n  env: Environment;\n  dynamicScope(): DynamicScope;\n  getSelf(): PathReference<Opaque>;\n  newDestroyable(d: Destroyable): void;\n}\n\nexport type CapturedStack = Opaque[];\n\nexport class EvaluationStack {\n  static empty(): EvaluationStack {\n    return new this([], 0, -1);\n  }\n\n  static restore(snapshot: CapturedStack): EvaluationStack {\n    return new this(snapshot.slice(), 0, snapshot.length - 1);\n  }\n\n  constructor(private stack: Opaque[], public fp: number, public sp: number) {\n    Object.seal(this);\n  }\n\n  isEmpty() {\n    return this.sp === -1;\n  }\n\n  push(value: Opaque): void {\n    this.stack[++this.sp] = value;\n  }\n\n  dup(position = this.sp): void {\n    this.push(this.stack[position]);\n  }\n\n  pop<T>(n = 1): T {\n    let top = this.stack[this.sp] as T;\n    this.sp -= n;\n    return top;\n  }\n\n  peek<T>(): T {\n    return this.stack[this.sp] as T;\n  }\n\n  fromBase<T>(offset: number): T {\n    return this.stack[this.fp - offset] as T;\n  }\n\n  fromTop<T>(offset: number): T {\n    return this.stack[this.sp - offset] as T;\n  }\n\n  capture(items: number): CapturedStack {\n    let end = this.sp + 1;\n    let start = end - items;\n    return this.stack.slice(start, end);\n  }\n\n  toArray() {\n    return this.stack.slice(this.fp, this.sp + 1);\n  }\n}\n\nexport type IteratorResult<T> = {\n  done: false;\n  value: null;\n} | {\n  done: true;\n  value: T;\n};\n\nexport default class VM implements PublicVM {\n  private dynamicScopeStack = new Stack<DynamicScope>();\n  private scopeStack = new Stack<Scope>();\n  public updatingOpcodeStack = new Stack<LinkedList<UpdatingOpcode>>();\n  public cacheGroups = new Stack<Option<UpdatingOpcode>>();\n  public listBlockStack = new Stack<ListBlockOpcode>();\n  public constants: Constants;\n\n  public stack = EvaluationStack.empty();\n\n  /** Registers **/\n\n  private pc = -1;\n  private ra = -1;\n\n  private get fp(): number {\n    return this.stack.fp;\n  }\n\n  private set fp(fp: number) {\n    this.stack.fp = fp;\n  }\n\n  private get sp(): number {\n    return this.stack.sp;\n  }\n\n  private set sp(sp: number) {\n    this.stack.sp = sp;\n  }\n\n  public s0: any = null;\n  public s1: any = null;\n  public t0: any = null;\n  public t1: any = null;\n\n  // Fetch a value from a register onto the stack\n  fetch(register: Register) {\n    this.stack.push(this[Register[register]]);\n  }\n\n  // Load a value from the stack into a register\n  load(register: Register) {\n    this[Register[register]] = this.stack.pop();\n  }\n\n  // Fetch a value from a register\n  fetchValue<T>(register: Register): T {\n    return this[Register[register]];\n  }\n\n  // Load a value into a register\n  loadValue<T>(register: Register, value: T) {\n    this[Register[register]] = value;\n  }\n\n  // Start a new frame and save $ra and $fp on the stack\n  pushFrame() {\n    this.stack.push(this.ra);\n    this.stack.push(this.fp);\n    this.fp = this.sp - 1;\n    // this.fp = this.sp + 1;\n  }\n\n  // Restore $ra, $sp and $fp\n  popFrame() {\n    this.sp = this.fp - 1;\n    this.ra = this.stack.fromBase<number>(0);\n    this.fp = this.stack.fromBase<number>(-1);\n  }\n\n  // Jump to an address in `program`\n  goto(pc: number) {\n    this.pc = pc;\n  }\n\n  // Save $pc into $ra, then jump to a new address in `program` (jal in MIPS)\n  call(pc: number) {\n    this.ra = this.pc;\n    this.pc = pc;\n  }\n\n  // Put a specific `program` address in $ra\n  returnTo(ra: number) {\n    this.ra = ra;\n  }\n\n  // Return to the `program` address stored in $ra\n  return() {\n    this.pc = this.ra;\n  }\n\n  static initial(\n    env: Environment,\n    self: PathReference<Opaque>,\n    dynamicScope: DynamicScope,\n    elementStack: ElementStack,\n    program: CompiledDynamicProgram\n  ) {\n    let scope = Scope.root(self, program.symbolTable.symbols.length);\n    let vm = new VM(env, scope, dynamicScope, elementStack);\n    vm.pc = program.start;\n    vm.updatingOpcodeStack.push(new LinkedList<UpdatingOpcode>());\n    return vm;\n  }\n\n  constructor(\n    public env: Environment,\n    scope: Scope,\n    dynamicScope: DynamicScope,\n    private elementStack: ElementStack,\n  ) {\n    this.env = env;\n    this.constants = env.constants;\n    this.elementStack = elementStack;\n    this.scopeStack.push(scope);\n    this.dynamicScopeStack.push(dynamicScope);\n  }\n\n  capture(args: number): VMState {\n    return {\n      env: this.env,\n      scope: this.scope(),\n      dynamicScope: this.dynamicScope(),\n      stack: this.stack.capture(args)\n    };\n  }\n\n  beginCacheGroup() {\n    this.cacheGroups.push(this.updating().tail());\n  }\n\n  commitCacheGroup() {\n    //        JumpIfNotModified(END)\n    //        (head)\n    //        (....)\n    //        (tail)\n    //        DidModify\n    // END:   Noop\n\n    let END = new LabelOpcode(\"END\");\n\n    let opcodes = this.updating();\n    let marker = this.cacheGroups.pop();\n    let head = marker ? opcodes.nextNode(marker) : opcodes.head();\n    let tail = opcodes.tail();\n    let tag = combineSlice(new ListSlice(head, tail));\n\n    let guard = new JumpIfNotModifiedOpcode(tag, END);\n\n    opcodes.insertBefore(guard, head);\n    opcodes.append(new DidModifyOpcode(guard));\n    opcodes.append(END);\n  }\n\n  enter(args: number) {\n    let updating = new LinkedList<UpdatingOpcode>();\n\n    let state = this.capture(args);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    let tryOpcode = new TryOpcode(this.pc, state, tracker, updating);\n\n    this.didEnter(tryOpcode);\n  }\n\n  iterate(memo: VersionedPathReference<Opaque>, value: VersionedPathReference<Opaque>, updating = new LinkedList<UpdatingOpcode>()): TryOpcode {\n    let stack = this.stack;\n    stack.push(value);\n    stack.push(memo);\n\n    let state = this.capture(2);\n    let tracker = this.elements().pushUpdatableBlock();\n\n    // let ip = this.ip;\n    // this.ip = end + 4;\n    // this.frames.push(ip);\n\n    return new TryOpcode(this.pc, state, tracker, updating);\n  }\n\n  enterItem(key: string, opcode: TryOpcode) {\n    this.listBlock().map[key] = opcode;\n    this.didEnter(opcode);\n  }\n\n  enterList(start: number) {\n    let updating = new LinkedList<BlockOpcode>();\n\n    let state = this.capture(0);\n    let tracker = this.elements().pushBlockList(updating);\n    let artifacts = this.stack.peek<ReferenceIterator>().artifacts;\n\n    let opcode = new ListBlockOpcode(start, state, tracker, updating, artifacts);\n\n    this.listBlockStack.push(opcode);\n\n    this.didEnter(opcode);\n  }\n\n  private didEnter(opcode: BlockOpcode) {\n    this.updateWith(opcode);\n    this.updatingOpcodeStack.push(opcode.children);\n  }\n\n  exit() {\n    this.elements().popBlock();\n    this.updatingOpcodeStack.pop();\n\n    let parent = this.updating().tail() as BlockOpcode;\n\n    parent.didInitializeChildren();\n  }\n\n  exitList() {\n    this.exit();\n    this.listBlockStack.pop();\n  }\n\n  updateWith(opcode: UpdatingOpcode) {\n    this.updating().append(opcode);\n  }\n\n  listBlock(): ListBlockOpcode {\n    return expect(this.listBlockStack.current, 'expected a list block');\n  }\n\n  updating(): LinkedList<UpdatingOpcode> {\n    return expect(this.updatingOpcodeStack.current, 'expected updating opcode on the updating opcode stack');\n  }\n\n  elements(): ElementStack {\n    return this.elementStack;\n  }\n\n  scope(): Scope {\n    return expect(this.scopeStack.current, 'expected scope on the scope stack');\n  }\n\n  dynamicScope(): DynamicScope {\n    return expect(this.dynamicScopeStack.current, 'expected dynamic scope on the dynamic scope stack');\n  }\n\n  pushChildScope() {\n    this.scopeStack.push(this.scope().child());\n  }\n\n  pushCallerScope(childScope = false) {\n    let callerScope = expect(this.scope().getCallerScope(), 'pushCallerScope is called when a caller scope is present');\n    this.scopeStack.push(childScope ? callerScope.child() : callerScope);\n  }\n\n  pushDynamicScope(): DynamicScope {\n    let child = this.dynamicScope().child();\n    this.dynamicScopeStack.push(child);\n    return child;\n  }\n\n  pushRootScope(size: number, bindCaller: boolean): Scope {\n    let scope = Scope.sized(size);\n    if (bindCaller) scope.bindCallerScope(this.scope());\n    this.scopeStack.push(scope);\n    return scope;\n  }\n\n  popScope() {\n    this.scopeStack.pop();\n  }\n\n  popDynamicScope() {\n    this.dynamicScopeStack.pop();\n  }\n\n  newDestroyable(d: Destroyable) {\n    this.elements().newDestroyable(d);\n  }\n\n  /// SCOPE HELPERS\n\n  getSelf(): PathReference<any> {\n    return this.scope().getSelf();\n  }\n\n  referenceForSymbol(symbol: number): PathReference<any> {\n    return this.scope().getSymbol(symbol);\n  }\n\n  /// EXECUTION\n\n  execute(start: number, initialize?: (vm: VM) => void): RenderResult {\n    this.pc = start;\n\n    if (initialize) initialize(this);\n\n    let result: IteratorResult<RenderResult>;\n\n    while (true) {\n      result = this.next();\n      if (result.done) break;\n    }\n\n    return result.value as RenderResult;\n  }\n\n  next(): IteratorResult<RenderResult> {\n    let { env, updatingOpcodeStack, elementStack } = this;\n    let opcode: Option<Opcode>;\n\n    if (opcode = this.nextStatement(env)) {\n      APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n      return { done: false, value: null };\n    }\n\n    return {\n      done: true,\n      value: new RenderResult(\n        env,\n        expect(updatingOpcodeStack.pop(), 'there should be a final updating opcode stack'),\n        elementStack.popBlock()\n      )\n    };\n  }\n\n  private nextStatement(env: Environment): Option<Opcode> {\n    let { pc } = this;\n\n    if (pc === -1) {\n      return null;\n    }\n\n    let program = env.program;\n    this.pc += 4;\n    return program.opcode(pc);\n  }\n\n  evaluateOpcode(opcode: Opcode) {\n    APPEND_OPCODES.evaluate(this, opcode, opcode.type);\n  }\n\n  bindDynamicScope(names: ConstantString[]) {\n    let scope = this.dynamicScope();\n\n    for(let i=names.length - 1; i>=0; i--) {\n      let name = this.constants.getString(names[i]);\n      scope.set(name, this.stack.pop<VersionedPathReference<Opaque>>());\n    }\n  }\n}\n"]}
{
"name": "@glimmer/runtime",
"version": "0.23.0-alpha.9",
"version": "0.23.0-alpha.10",
"description": "Minimal runtime needed to render Glimmer templates",

@@ -8,8 +8,8 @@ "repository": "https://github.com/tildeio/glimmer/tree/master/packages/@glimmer/runtime",

"dependencies": {
"@glimmer/util": "^0.23.0-alpha.9",
"@glimmer/reference": "^0.23.0-alpha.9",
"@glimmer/object": "^0.23.0-alpha.9",
"@glimmer/object-reference": "^0.23.0-alpha.9",
"@glimmer/wire-format": "^0.23.0-alpha.9",
"@glimmer/interfaces": "^0.23.0-alpha.9"
"@glimmer/util": "^0.23.0-alpha.10",
"@glimmer/reference": "^0.23.0-alpha.10",
"@glimmer/object": "^0.23.0-alpha.10",
"@glimmer/object-reference": "^0.23.0-alpha.10",
"@glimmer/wire-format": "^0.23.0-alpha.10",
"@glimmer/interfaces": "^0.23.0-alpha.10"
},

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

Sorry, the diff of this file is too big to display

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