Socket
Socket
Sign inDemoInstall

@glimmer/vm

Package Overview
Dependencies
Maintainers
10
Versions
245
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@glimmer/vm - npm Package Compare versions

Comparing version 0.29.10 to 0.30.0

2

dist/commonjs/es2017/lib/opcodes.js
"use strict";
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"opcodes.js","sourceRoot":"","sources":["../../../../packages/@glimmer/vm/lib/opcodes.ts"],"names":[],"mappings":"","sourcesContent":["export const enum Op {\n  /*\n    Documentation TODO:\n\n    Document the local variable layout in the stack\n    diagram before-and-after.\n\n    Document updating opcodes emitting from unreachable\n    append opcode.\n\n    Document the element stack, block stack and List\n    block stack.\n   */\n\n  /**\n   * This opcode should never be reached.\n   */\n  Bug,\n\n  /// EXPRESSIONS\n\n  /**\n   * Operation: Evaluate a Helper.\n   * Format:\n   *   (Helper helper:#Function)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments →\n   *   ..., VersionedPathReference\n   */\n  Helper,\n\n  /**\n   * Operation:\n   *   Bind the variable represented by a symbol from\n   *   the value at the top of the stack.\n   * Format:\n   *   (SetVariable symbol:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  SetVariable,\n\n  /**\n   * Operation:\n   *   Bind the block at the top of the stack.\n   * Format:\n   *   (SetBlock symbol:u32)\n   * Operand Stack:\n   *   ..., SymbolTable, Handle →\n   *   ...\n   */\n  SetBlock,\n\n  /**\n   * Operation:\n   *   Push the contents of the variable represented by\n   *   a symbol (a positional or named argument) onto\n   *   the stack.\n   * Format:\n   *   (PushSymbol symbol:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetVariable,\n\n  /**\n   * Operation:\n   *   Pop a VersionedPathReference from the top of the\n   *   stack, and push a VersionedPathReference constructed\n   *   by `.get(property)`.\n   * Format:\n   *   (GetProperty property:#string)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ..., VersionedPathReference\n   */\n  GetProperty,\n\n  /**\n   * Operation: Push the specified bound block onto the stack.\n   * Format:\n   *   (GetBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., InlineBlock\n   */\n  GetBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound and FALSE if it is not.\n   * Format:\n   *   (HasBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., boolean\n   */\n  HasBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound *and* has at least one specified formal\n   *   parameter, and FALSE otherwise.\n   * Format:\n   *   (HasBlockParams block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference (boolean)\n   */\n  HasBlockParams,\n\n  /**\n   * Operation:\n   *   Pop count `VersionedPathReference`s off the stack and\n   *   construct a new ConcatReference from them (in reverse\n   *   order).\n   * Format:\n   *   (Concat count:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ..., ConcatReference\n   */\n  Concat,\n\n  /**\n   * Operation:\n   *   Push an Object constant onto the stack that is not\n   *   a JavaScript primitive.\n   * Format:\n   *   (PushConstant constant:#Object)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Constant,\n\n  /**\n   * Operation:\n   *   Wrap a JavaScript primitive in a reference and push it\n   *   onto the stack.\n   * Format:\n   *   (PushPrimitive constant:#Primitive)\n   * Operand Stack:\n   *   ... →\n   *   ..., Primitive\n   * Description:\n   *   The two high bits of the constant reference describe\n   *   the kind of primitive:\n   *\n   *   00: number\n   *   01: string\n   *   10: true | false | null | undefined\n   */\n  Primitive,\n\n  /**\n   * Operation: Convert the top of the stack into a primitive reference.\n   *\n   * Format:\n   *   (PrimitiveReference)\n   * Operand Stack:\n   *   ..., Primitive →\n   *   ..., VersionedPathReference<Primitive>\n   */\n  PrimitiveReference,\n\n  /**\n   * Operation: Duplicate and push item from an offset in the stack.\n   * Format:\n   *   (Dup register:u32, offset:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ..., Opaque, Opaque\n   */\n  Dup,\n\n  /**\n   * Operation: Pop N items off the stack and throw away the value.\n   * Format:\n   *   (Pop)\n   * Operand Stack:\n   *   ..., Opaque, ..., Opaque →\n   *   ...\n   */\n  Pop,\n\n  /**\n   * Operation: Load a value into a register\n   * Format:\n   *   (Load register:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ...\n   */\n  Load,\n\n  /**\n   * Operation: Fetch a value from a register\n   * Format:\n   *   (Fetch register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Fetch,\n\n  /// PRELUDE & EXIT\n\n  /**\n   * Operation: Push a new root scope onto the scope stack.\n   *\n   * Format:\n   *   (RootScope symbols:u32 bindCallerScope:bool)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A root scope has no parent scope, and therefore inherits no lexical\n   *   variables. If `bindCallerScope` is `true`, the current scope remembers\n   *   the caller scope (for yielding blocks).\n   */\n  RootScope,\n\n  /**\n   * Operation: Push a new child scope onto the scope stack.\n   *\n   * Format:\n   *   (ChildScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A child scope inherits from the current parent scope, and therefore\n   *   shares its lexical variables.\n   */\n  ChildScope,\n\n  /**\n   * Operation: Pop the current scope from the scope stack.\n   * Format:\n   *   (PopScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PopScope,\n\n  /**\n   * Operation: Return to the previous frame.\n   * Format:\n   *   (Return)\n   * Operand Stack:\n   *   ..., address:number →\n   *   ...\n   */\n  Return,\n\n  /**\n   * Operation: Return to a place in the program given an offset\n   * Format:\n   *  (ReturnTo offset:i32)\n   * Operand Stack:\n   *    ... →\n   */\n  ReturnTo,\n\n  /// HTML\n\n  /**\n   * Operation: Append a Text node with value `contents`\n   * Format:\n   *   (Text contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Text,\n\n  /**\n   * Operation: Append a Comment node with value `contents`\n   * Format:\n   *   (Comment contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Comment,\n\n  /**\n   * Operation: Append a Dynamic node based on .\n   * Format:\n   *   (DynamicContent isTrusting:boolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  DynamicContent,\n\n  /**\n   * Operation: Open a new Element named `tag`.\n   * Format:\n   *   (OpenElement tag:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  OpenElement,\n\n  /**\n   * Operation:\n   *   Open a new Element named `tag` with special operations provided\n   *   on the stack.\n   * Format:\n   *   (OpenElementWithOperations tag:#string)\n   * Operand Stack:\n   *   ..., ElementOperations →\n   *   ...\n   */\n  OpenElementWithOperations,\n\n  /**\n   * Operation:\n   *   Open a new Element with a name on the stack and with special\n   *   operations provided on the stack.\n   * Format:\n   *   (OpenDynamicElement)\n   * Operand Stack:\n   *   ..., string, ElementOperations →\n   *   ...\n   */\n  OpenDynamicElement,\n\n  /**\n   * Operation: Add an attribute to the current Element.\n   * Format:\n   *   (StaticAttr name:#string value:#string namespace:Option<#string>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  StaticAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (DynamicAttr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   * Description:\n   *   If `trusting` is false, the host may sanitize the attribute\n   *   based upon known risks.\n   */\n  DynamicAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (ComponentAtr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  ComponentAttr,\n\n  /**\n   * Operation: Finish setting attributes on the current element.\n   *\n   * Format:\n   *   (FlushElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  FlushElement,\n\n  /**\n   * Operation: Close the current element.\n   *\n   * Format:\n   *   (CloseElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CloseElement,\n\n  /// MODIFIER\n  Modifier,                  // (ConstantString, ConstantOther<ModifierManager>, ConstantExpression)\n\n  /// WORMHOLE\n  PushRemoteElement,         // ()\n  PopRemoteElement,          // ()\n\n  /// DYNAMIC SCOPE\n\n  /**\n   * Operation: Bind stack values as dynamic variables.\n   * Format:\n   *   (BindDynamicScope names:#Array<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ...\n   * Description:\n   *   This is used to expose `-with-dynamic-vars`, and is a\n   *   niche feature.\n   */\n  BindDynamicScope,\n\n  PushDynamicScope,          // ()\n  PopDynamicScope,           // ()\n\n  /// VM\n\n  /**\n   * Operation: Compile the InlineBlock at the top of the stack.\n   * Format:\n   *   (CompileBlock)\n   * Operand Stack:\n   *   ..., CompilableBlock →\n   *   ..., Handle\n   */\n  CompileBlock,\n\n  /**\n   * Operation: Push a scope onto the stack.\n   * Format:\n   *   (PushBlockScope #Scope)\n   * Operand Stack:\n   *   ..., →\n   *   ..., Scope\n   */\n  PushBlockScope,\n\n  /**\n   * Operation: Push a symbol table onto the stack.\n   * Format:\n   *   (PushSymbolTable #SymbolTable)\n   * Operand Stack:\n   *   ..., →\n   *   ..., SymbolTable\n   */\n  PushSymbolTable,\n\n  /**\n   * Operation: Evaluate the handle at the top of the stack.\n   * Format:\n   *   (InvokeVirtual)\n   * Operand Stack:\n   *   ..., Handle, →\n   *   ...\n   */\n  InvokeVirtual,\n\n  /**\n   * Operation: Evaluate the handle.\n   * Format:\n   *   (InvokeStatic handle:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  InvokeStatic,\n\n  /**\n   * Operation: Yield to a block.\n   * Format:\n   *   (InvokeYield)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments, SymbolTable, Handle →\n   *   ...\n   */\n  InvokeYield,\n\n  /**\n   * Operation: Jump to the specified offset.\n   *\n   * Format:\n   *   (Jump to:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Jump,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is true.\n   *\n   * Format:\n   *   (JumpIf to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpIf,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is false.\n   *\n   * Format:\n   *   (JumpUnless to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpUnless,\n\n  /**\n   * Operation: Push a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   ... →\n   *   $ra, $fp\n   */\n  PushFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   $ra, $fp →\n   *   ...\n   */\n  PopFrame,\n\n  /**\n   * Operation:\n   *   Start tracking a new output block that could change\n   *   if one of its inputs changes.\n   *\n   * Format:\n   *   (Enter args:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   Soon after this opcode, one of Jump, JumpIf,\n   *   or JumpUnless will produce an updating assertion.\n   *   If that assertion fails, the appending VM will\n   *   be re-entered, and the instructions from `from`\n   *   to `to` will be executed.\n   *\n   *   TODO: Save and restore.\n   */\n  Enter,\n\n  /**\n   * Operation:\n   *   Finish tracking the current block.\n   *\n   * Format:\n   *   (Exit)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   This finalizes the validators that the updating\n   *   block must check to determine whether it's safe to\n   *   skip running the contents.\n   */\n  Exit,\n\n  /**\n   * Operation: Convert the top of the stack into a boolean reference.\n   *\n   * Format:\n   *   (ToBoolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<bool>\n   */\n  ToBoolean,\n\n  /// LISTS\n\n  /**\n   * Operation: Enter a list.\n   *\n   * Format:\n   *   (EnterList address:u32)\n   * Operand Stack:\n   *   ..., Iterator →\n   *   ...\n   */\n  EnterList,\n\n  /**\n   * Operation: Exit the current list.\n   *\n   * Format:\n   *   (ExitList)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  ExitList,\n\n  /**\n   * Operation:\n   *   Convert an operand and key into an iterator and\n   *   presence reference.\n   *\n   * Format:\n   *   (PutIterator)\n   * Operand Stack:\n   *   ..., key:string, list:VersionedPathReference →\n   *   ..., iterator:ReferenceIterator, present:PresenceReference\n   */\n  PutIterator,\n\n  /**\n   * Operation:\n   *   Set up the stack for iterating for a given key,\n   *   or jump to `end` if there is nothing left to\n   *   iterate.\n   *\n   * Format:\n   *   (Iterate end:u32)\n   * Operand Stack:\n   *   Form 1: (something to iterate)\n   *   ... →\n   *   ..., VersionedPathReference, VersionedPathReference, string\n   *   Form 2: (nothing left to iterate)\n   *   ... →\n   *   ...\n   * Description:\n   *   In Form 1, the stack will have (in reverse order):\n   *\n   *   - the key, as a string\n   *   - the current iterated value\n   *   - the memoized iterated value\n   */\n  Iterate,\n\n  /// COMPONENTS\n\n  /**\n   * Operation: Test whether a reference contains a component definition.\n   *\n   * Format:\n   *   (IsComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<boolean>\n   */\n  IsComponent,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, TemplateMeta, CapturedArguments }\n   */\n  CurryComponent,\n\n  /**\n   * Operation: Push an appropriate component manager onto the stack.\n   *\n   * Format:\n   *   (PushComponentManager #ComponentSpec)\n   * Operand Stack:\n   *   ... →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushComponentDefinition,\n\n  /**\n   * Operation:\n   *   Push an appropriate component manager onto the stack from\n   *   a runtime-resolved component definition.\n   *\n   * Format:\n   *   (PushDynamicComponentManager templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushDynamicComponentManager,\n\n  /**\n   * Operation: Push a user representation of args onto the stack.\n   *\n   * Format:\n   *   (PushArgs names:#Array<#string> positionalCount:u32 synthetic:#boolean)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...]  →\n   *   ..., [VersionedPathReference ...], Arguments\n   *\n   * Description:\n   *   This arguments object is only necessary when calling into\n   *   user-specified hooks. It is meant to be implemented as a\n   *   transient proxy that reads into the stack as needed.\n   *   Holding onto the Arguments after the call has completed is\n   *   illegal.\n   */\n  PushArgs,\n\n  /**\n   * Operation: Pops Arguments from the stack and clears the next N args.\n   *\n   * Format:\n   *   (PopArgs)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments  →\n   *   ...\n   *\n   * Description:\n   * The arguments object contains the information of how many user\n   * supplied args the component was invoked with. To clear them from\n   * the stack we must pop it from the stack and call `clear` on it\n   * to remove the argument values from the stack.\n   */\n  PopArgs,\n\n  /**\n   * Operation: ...\n   * Format:\n   *   (PrepareArgs state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PrepareArgs,\n\n  /**\n   * Operation: Create the component and push it onto the stack.\n   * Format:\n   *   (CreateComponent flags:u32 state:u32)\n   *   ... →\n   *   ...\n   * Description:\n   * Operand Stack:\n   *   Flags:\n   *\n   *   * 0b001: Has a default block\n   *   * 0b010: Has an inverse block\n   */\n  CreateComponent,\n\n  /**\n   * Operation: Register a destructor for the current component\n   *\n   * Format:\n   *   (RegisterComponentDestructor state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  RegisterComponentDestructor,\n\n  /**\n   * Operation: Push a new ElementOperations for the current component.\n   *\n   * Format:\n   *   (PutComponentOperations)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PutComponentOperations,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentSelf state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetComponentSelf,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentTagName state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., Option<string>\n   */\n  GetComponentTagName,\n\n  /**\n   * Operation: Get the component layout from the manager.\n   *\n   * Format:\n   *   (GetComponentLayout state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., ProgramSymbolTable, Handle\n   */\n  GetComponentLayout,\n\n  /**\n   * Operation: Invoke the layout returned by the manager.\n   *\n   * Format:\n   *   (InvokeComponentLayout)\n   * Operand Stack:\n   *   ..., ProgramSymbolTable, Handle →\n   *   ...\n   */\n  InvokeComponentLayout,\n\n  /**\n   * Operation: Begin a new cache group\n   *\n   * Format:\n   *   (BeginComponentTransaction)\n   * Operand Stack:\n   *   ..., ComponentManager<T>, T →\n   *   ..., ComponentManager<T>, T\n   */\n  BeginComponentTransaction,\n\n  /**\n   * Operation: Commit the current cache group\n   *\n   * Format:\n   *   (CommitComponentTransaction)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CommitComponentTransaction,\n\n  /**\n   * Operation: Invoke didCreateElement on the current component manager\n   *\n   * Format:\n   *   (DidCreateElement state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  DidCreateElement,\n\n  /**\n   * Operation: Invoke didRenderLayout on the current component manager\n   *\n   * Format:\n   *   (DidRenderLayout state:u32)\n   * Operand Stack:\n   *   ..., →\n   *   ...\n   */\n  DidRenderLayout,\n\n  /// PARTIALS\n\n  /**\n   * Operation: Lookup and invoke a partial template.\n   *\n   * Format:\n   *   (InvokePartial templateMeta:#TemplateMeta symbols:#Array<#string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  InvokePartial,\n\n  /**\n   * Operation:\n   *   Resolve {{foo}} inside a partial, which could be either a self-lookup\n   *   or a local variable that is in-scope for the caller.\n   *\n   * Format:\n   *   (ResolveMaybeLocal local:#string)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  ResolveMaybeLocal,\n\n  /// DEBUGGER\n\n  /**\n   * Operation: Activate the debugger\n   *\n   * Format:\n   *   (Debugger symbols:#Array<string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Debugger,\n\n  /** The size of the opcode list */\n  Size\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"opcodes.js","sourceRoot":"","sources":["../../../../packages/@glimmer/vm/lib/opcodes.ts"],"names":[],"mappings":"","sourcesContent":["export const enum Op {\n  /*\n    Documentation TODO:\n\n    Document the local variable layout in the stack\n    diagram before-and-after.\n\n    Document updating opcodes emitting from unreachable\n    append opcode.\n\n    Document the element stack, block stack and List\n    block stack.\n   */\n\n  /**\n   * This opcode should never be reached.\n   */\n  Bug,\n\n  /// EXPRESSIONS\n\n  /**\n   * Operation: Evaluate a Helper.\n   * Format:\n   *   (Helper helper:#Function)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments →\n   *   ..., VersionedPathReference\n   */\n  Helper,\n\n  /**\n   * Operation:\n   *   Bind the variable represented by a symbol from\n   *   the value at the top of the stack.\n   * Format:\n   *   (SetVariable symbol:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  SetVariable,\n\n  /**\n   * Operation:\n   *   Bind the block at the top of the stack.\n   * Format:\n   *   (SetBlock symbol:u32)\n   * Operand Stack:\n   *   ..., SymbolTable, Handle →\n   *   ...\n   */\n  SetBlock,\n\n  /**\n   * Operation:\n   *   Push the contents of the variable represented by\n   *   a symbol (a positional or named argument) onto\n   *   the stack.\n   * Format:\n   *   (PushSymbol symbol:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetVariable,\n\n  /**\n   * Operation:\n   *   Pop a VersionedPathReference from the top of the\n   *   stack, and push a VersionedPathReference constructed\n   *   by `.get(property)`.\n   * Format:\n   *   (GetProperty property:#string)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ..., VersionedPathReference\n   */\n  GetProperty,\n\n  /**\n   * Operation: Push the specified bound block onto the stack.\n   * Format:\n   *   (GetBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., InlineBlock\n   */\n  GetBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound and FALSE if it is not.\n   * Format:\n   *   (HasBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., boolean\n   */\n  HasBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound *and* has at least one specified formal\n   *   parameter, and FALSE otherwise.\n   * Format:\n   *   (HasBlockParams block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference (boolean)\n   */\n  HasBlockParams,\n\n  /**\n   * Operation:\n   *   Pop count `VersionedPathReference`s off the stack and\n   *   construct a new ConcatReference from them (in reverse\n   *   order).\n   * Format:\n   *   (Concat count:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ..., ConcatReference\n   */\n  Concat,\n\n  /**\n   * Operation:\n   *   Push an Object constant onto the stack that is not\n   *   a JavaScript primitive.\n   * Format:\n   *   (PushConstant constant:#Object)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Constant,\n\n  /**\n   * Operation:\n   *   Wrap a JavaScript primitive in a reference and push it\n   *   onto the stack.\n   * Format:\n   *   (PushPrimitive constant:#Primitive)\n   * Operand Stack:\n   *   ... →\n   *   ..., Primitive\n   * Description:\n   *   The two high bits of the constant reference describe\n   *   the kind of primitive:\n   *\n   *   00: number\n   *   01: string\n   *   10: true | false | null | undefined\n   */\n  Primitive,\n\n  /**\n   * Operation: Convert the top of the stack into a primitive reference.\n   *\n   * Format:\n   *   (PrimitiveReference)\n   * Operand Stack:\n   *   ..., Primitive →\n   *   ..., VersionedPathReference<Primitive>\n   */\n  PrimitiveReference,\n\n  /**\n   * Operation: Duplicate and push item from an offset in the stack.\n   * Format:\n   *   (Dup register:u32, offset:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ..., Opaque, Opaque\n   */\n  Dup,\n\n  /**\n   * Operation: Pop N items off the stack and throw away the value.\n   * Format:\n   *   (Pop)\n   * Operand Stack:\n   *   ..., Opaque, ..., Opaque →\n   *   ...\n   */\n  Pop,\n\n  /**\n   * Operation: Load a value into a register\n   * Format:\n   *   (Load register:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ...\n   */\n  Load,\n\n  /**\n   * Operation: Fetch a value from a register\n   * Format:\n   *   (Fetch register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Fetch,\n\n  /// PRELUDE & EXIT\n\n  /**\n   * Operation: Push a new root scope onto the scope stack.\n   *\n   * Format:\n   *   (RootScope symbols:u32 bindCallerScope:bool)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A root scope has no parent scope, and therefore inherits no lexical\n   *   variables. If `bindCallerScope` is `true`, the current scope remembers\n   *   the caller scope (for yielding blocks).\n   */\n  RootScope,\n\n  /**\n   * Operation: Push a new child scope onto the scope stack.\n   *\n   * Format:\n   *   (ChildScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A child scope inherits from the current parent scope, and therefore\n   *   shares its lexical variables.\n   */\n  ChildScope,\n\n  /**\n   * Operation: Pop the current scope from the scope stack.\n   * Format:\n   *   (PopScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PopScope,\n\n  /**\n   * Operation: Return to the previous frame.\n   * Format:\n   *   (Return)\n   * Operand Stack:\n   *   ..., address:number →\n   *   ...\n   */\n  Return,\n\n  /**\n   * Operation: Return to a place in the program given an offset\n   * Format:\n   *  (ReturnTo offset:i32)\n   * Operand Stack:\n   *    ... →\n   */\n  ReturnTo,\n\n  /// HTML\n\n  /**\n   * Operation: Append a Text node with value `contents`\n   * Format:\n   *   (Text contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Text,\n\n  /**\n   * Operation: Append a Comment node with value `contents`\n   * Format:\n   *   (Comment contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Comment,\n\n  /**\n   * Operation: Append a Dynamic node based on .\n   * Format:\n   *   (DynamicContent isTrusting:boolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  DynamicContent,\n\n  /**\n   * Operation: Open a new Element named `tag`.\n   * Format:\n   *   (OpenElement tag:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  OpenElement,\n\n  /**\n   * Operation:\n   *   Open a new Element named `tag` with special operations provided\n   *   on the stack.\n   * Format:\n   *   (OpenElementWithOperations tag:#string)\n   * Operand Stack:\n   *   ..., ElementOperations →\n   *   ...\n   */\n  OpenElementWithOperations,\n\n  /**\n   * Operation:\n   *   Open a new Element with a name on the stack and with special\n   *   operations provided on the stack.\n   * Format:\n   *   (OpenDynamicElement)\n   * Operand Stack:\n   *   ..., string, ElementOperations →\n   *   ...\n   */\n  OpenDynamicElement,\n\n  /**\n   * Operation: Add an attribute to the current Element.\n   * Format:\n   *   (StaticAttr name:#string value:#string namespace:Option<#string>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  StaticAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (DynamicAttr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   * Description:\n   *   If `trusting` is false, the host may sanitize the attribute\n   *   based upon known risks.\n   */\n  DynamicAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (ComponentAtr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  ComponentAttr,\n\n  /**\n   * Operation: Finish setting attributes on the current element.\n   *\n   * Format:\n   *   (FlushElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  FlushElement,\n\n  /**\n   * Operation: Close the current element.\n   *\n   * Format:\n   *   (CloseElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CloseElement,\n\n  /// MODIFIER\n  Modifier,                  // (ConstantString, ConstantOther<ModifierManager>, ConstantExpression)\n\n  /// WORMHOLE\n  PushRemoteElement,         // ()\n  PopRemoteElement,          // ()\n\n  /// DYNAMIC SCOPE\n\n  /**\n   * Operation: Bind stack values as dynamic variables.\n   * Format:\n   *   (BindDynamicScope names:#Array<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ...\n   * Description:\n   *   This is used to expose `-with-dynamic-vars`, and is a\n   *   niche feature.\n   */\n  BindDynamicScope,\n\n  PushDynamicScope,          // ()\n  PopDynamicScope,           // ()\n\n  /// VM\n\n  /**\n   * Operation: Compile the InlineBlock at the top of the stack.\n   * Format:\n   *   (CompileBlock)\n   * Operand Stack:\n   *   ..., CompilableBlock →\n   *   ..., Handle\n   */\n  CompileBlock,\n\n  /**\n   * Operation: Push a scope onto the stack.\n   * Format:\n   *   (PushBlockScope #Scope)\n   * Operand Stack:\n   *   ..., →\n   *   ..., Scope\n   */\n  PushBlockScope,\n\n  /**\n   * Operation: Push a symbol table onto the stack.\n   * Format:\n   *   (PushSymbolTable #SymbolTable)\n   * Operand Stack:\n   *   ..., →\n   *   ..., SymbolTable\n   */\n  PushSymbolTable,\n\n  /**\n   * Operation: Evaluate the handle at the top of the stack.\n   * Format:\n   *   (InvokeVirtual)\n   * Operand Stack:\n   *   ..., Handle, →\n   *   ...\n   */\n  InvokeVirtual,\n\n  /**\n   * Operation: Evaluate the handle.\n   * Format:\n   *   (InvokeStatic handle:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  InvokeStatic,\n\n  /**\n   * Operation: Yield to a block.\n   * Format:\n   *   (InvokeYield)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments, SymbolTable, Handle →\n   *   ...\n   */\n  InvokeYield,\n\n  /**\n   * Operation: Jump to the specified offset.\n   *\n   * Format:\n   *   (Jump to:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Jump,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is true.\n   *\n   * Format:\n   *   (JumpIf to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpIf,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is false.\n   *\n   * Format:\n   *   (JumpUnless to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpUnless,\n\n  /**\n   * Operation: Push a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   ... →\n   *   $ra, $fp\n   */\n  PushFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   $ra, $fp →\n   *   ...\n   */\n  PopFrame,\n\n  /**\n   * Operation:\n   *   Start tracking a new output block that could change\n   *   if one of its inputs changes.\n   *\n   * Format:\n   *   (Enter args:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   Soon after this opcode, one of Jump, JumpIf,\n   *   or JumpUnless will produce an updating assertion.\n   *   If that assertion fails, the appending VM will\n   *   be re-entered, and the instructions from `from`\n   *   to `to` will be executed.\n   *\n   *   TODO: Save and restore.\n   */\n  Enter,\n\n  /**\n   * Operation:\n   *   Finish tracking the current block.\n   *\n   * Format:\n   *   (Exit)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   This finalizes the validators that the updating\n   *   block must check to determine whether it's safe to\n   *   skip running the contents.\n   */\n  Exit,\n\n  /**\n   * Operation: Convert the top of the stack into a boolean reference.\n   *\n   * Format:\n   *   (ToBoolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<bool>\n   */\n  ToBoolean,\n\n  /// LISTS\n\n  /**\n   * Operation: Enter a list.\n   *\n   * Format:\n   *   (EnterList address:u32)\n   * Operand Stack:\n   *   ..., Iterator →\n   *   ...\n   */\n  EnterList,\n\n  /**\n   * Operation: Exit the current list.\n   *\n   * Format:\n   *   (ExitList)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  ExitList,\n\n  /**\n   * Operation:\n   *   Convert an operand and key into an iterator and\n   *   presence reference.\n   *\n   * Format:\n   *   (PutIterator)\n   * Operand Stack:\n   *   ..., key:string, list:VersionedPathReference →\n   *   ..., iterator:ReferenceIterator, present:PresenceReference\n   */\n  PutIterator,\n\n  /**\n   * Operation:\n   *   Set up the stack for iterating for a given key,\n   *   or jump to `end` if there is nothing left to\n   *   iterate.\n   *\n   * Format:\n   *   (Iterate end:u32)\n   * Operand Stack:\n   *   Form 1: (something to iterate)\n   *   ... →\n   *   ..., VersionedPathReference, VersionedPathReference, string\n   *   Form 2: (nothing left to iterate)\n   *   ... →\n   *   ...\n   * Description:\n   *   In Form 1, the stack will have (in reverse order):\n   *\n   *   - the key, as a string\n   *   - the current iterated value\n   *   - the memoized iterated value\n   */\n  Iterate,\n\n  /// COMPONENTS\n\n  /**\n   * Operation: Test whether a reference contains a component definition.\n   *\n   * Format:\n   *   (Main state:register)\n   * Operand Stack:\n   *   ..., Invocation, ComponentDefinition →\n   *   ...\n   */\n  Main,\n\n  /**\n   * Operation: Test whether a reference contains a component definition.\n   *\n   * Format:\n   *   (IsComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<boolean>\n   */\n  IsComponent,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, TemplateMeta, CapturedArguments }\n   */\n  CurryComponent,\n\n  /**\n   * Operation: Push an appropriate component manager onto the stack.\n   *\n   * Format:\n   *   (PushComponentManager #ComponentSpec)\n   * Operand Stack:\n   *   ... →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushComponentDefinition,\n\n  /**\n   * Operation:\n   *   Push an appropriate component manager onto the stack from\n   *   a runtime-resolved component definition.\n   *\n   * Format:\n   *   (PushDynamicComponentManager templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushDynamicComponentManager,\n\n  /**\n   * Operation: Push a user representation of args onto the stack.\n   *\n   * Format:\n   *   (PushArgs names:#Array<#string> positionalCount:u32 synthetic:#boolean)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...]  →\n   *   ..., [VersionedPathReference ...], Arguments\n   *\n   * Description:\n   *   This arguments object is only necessary when calling into\n   *   user-specified hooks. It is meant to be implemented as a\n   *   transient proxy that reads into the stack as needed.\n   *   Holding onto the Arguments after the call has completed is\n   *   illegal.\n   */\n  PushArgs,\n\n  /**\n   * Operation: Pops Arguments from the stack and clears the next N args.\n   *\n   * Format:\n   *   (PopArgs)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments  →\n   *   ...\n   *\n   * Description:\n   * The arguments object contains the information of how many user\n   * supplied args the component was invoked with. To clear them from\n   * the stack we must pop it from the stack and call `clear` on it\n   * to remove the argument values from the stack.\n   */\n  PopArgs,\n\n  /**\n   * Operation: ...\n   * Format:\n   *   (PrepareArgs state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PrepareArgs,\n\n  /**\n   * Operation: Create the component and push it onto the stack.\n   * Format:\n   *   (CreateComponent flags:u32 state:register)\n   *   ... →\n   *   ...\n   * Description:\n   * Operand Stack:\n   *   Flags:\n   *\n   *   * 0b001: Has a default block\n   *   * 0b010: Has an inverse block\n   */\n  CreateComponent,\n\n  /**\n   * Operation: Register a destructor for the current component\n   *\n   * Format:\n   *   (RegisterComponentDestructor state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  RegisterComponentDestructor,\n\n  /**\n   * Operation: Push a new ElementOperations for the current component.\n   *\n   * Format:\n   *   (PutComponentOperations)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PutComponentOperations,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentSelf state:register)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetComponentSelf,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentTagName state:register)\n   * Operand Stack:\n   *   ... →\n   *   ..., Option<string>\n   */\n  GetComponentTagName,\n\n  /**\n   * Operation: Get the component layout from the manager.\n   *\n   * Format:\n   *   (GetComponentLayout state:register)\n   * Operand Stack:\n   *   ... →\n   *   ..., ProgramSymbolTable, Handle\n   */\n  GetComponentLayout,\n\n  /**\n   * Operation:\n   *   Populate the state register with the layout currently\n   *   on the stack.\n   *\n   * Format:\n   *   (PopulateLayout state:register)\n   * Operand Stack:\n   *   ..., ProgramSymbolTable, Handle →\n   *   ...\n   */\n  PopulateLayout,\n\n  /**\n   * Operation: Invoke the layout returned by the manager.\n   *\n   * Format:\n   *   (InvokeComponentLayout state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  InvokeComponentLayout,\n\n  /**\n   * Operation: Begin a new cache group\n   *\n   * Format:\n   *   (BeginComponentTransaction)\n   * Operand Stack:\n   *   ..., ComponentManager<T>, T →\n   *   ..., ComponentManager<T>, T\n   */\n  BeginComponentTransaction,\n\n  /**\n   * Operation: Commit the current cache group\n   *\n   * Format:\n   *   (CommitComponentTransaction)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CommitComponentTransaction,\n\n  /**\n   * Operation: Invoke didCreateElement on the current component manager\n   *\n   * Format:\n   *   (DidCreateElement state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  DidCreateElement,\n\n  /**\n   * Operation: Invoke didRenderLayout on the current component manager\n   *\n   * Format:\n   *   (DidRenderLayout state:register)\n   * Operand Stack:\n   *   ..., →\n   *   ...\n   */\n  DidRenderLayout,\n\n  /// PARTIALS\n\n  /**\n   * Operation: Lookup and invoke a partial template.\n   *\n   * Format:\n   *   (InvokePartial templateMeta:#TemplateMeta symbols:#Array<#string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  InvokePartial,\n\n  /**\n   * Operation:\n   *   Resolve {{foo}} inside a partial, which could be either a self-lookup\n   *   or a local variable that is in-scope for the caller.\n   *\n   * Format:\n   *   (ResolveMaybeLocal local:#string)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  ResolveMaybeLocal,\n\n  /// DEBUGGER\n\n  /**\n   * Operation: Activate the debugger\n   *\n   * Format:\n   *   (Debugger symbols:#Array<string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Debugger,\n\n  /** The size of the opcode list */\n  Size\n}\n"]}
"use strict";
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"opcodes.js","sourceRoot":"","sources":["../../../../packages/@glimmer/vm/lib/opcodes.ts"],"names":[],"mappings":"","sourcesContent":["export const enum Op {\n  /*\n    Documentation TODO:\n\n    Document the local variable layout in the stack\n    diagram before-and-after.\n\n    Document updating opcodes emitting from unreachable\n    append opcode.\n\n    Document the element stack, block stack and List\n    block stack.\n   */\n\n  /**\n   * This opcode should never be reached.\n   */\n  Bug,\n\n  /// EXPRESSIONS\n\n  /**\n   * Operation: Evaluate a Helper.\n   * Format:\n   *   (Helper helper:#Function)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments →\n   *   ..., VersionedPathReference\n   */\n  Helper,\n\n  /**\n   * Operation:\n   *   Bind the variable represented by a symbol from\n   *   the value at the top of the stack.\n   * Format:\n   *   (SetVariable symbol:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  SetVariable,\n\n  /**\n   * Operation:\n   *   Bind the block at the top of the stack.\n   * Format:\n   *   (SetBlock symbol:u32)\n   * Operand Stack:\n   *   ..., SymbolTable, Handle →\n   *   ...\n   */\n  SetBlock,\n\n  /**\n   * Operation:\n   *   Push the contents of the variable represented by\n   *   a symbol (a positional or named argument) onto\n   *   the stack.\n   * Format:\n   *   (PushSymbol symbol:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetVariable,\n\n  /**\n   * Operation:\n   *   Pop a VersionedPathReference from the top of the\n   *   stack, and push a VersionedPathReference constructed\n   *   by `.get(property)`.\n   * Format:\n   *   (GetProperty property:#string)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ..., VersionedPathReference\n   */\n  GetProperty,\n\n  /**\n   * Operation: Push the specified bound block onto the stack.\n   * Format:\n   *   (GetBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., InlineBlock\n   */\n  GetBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound and FALSE if it is not.\n   * Format:\n   *   (HasBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., boolean\n   */\n  HasBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound *and* has at least one specified formal\n   *   parameter, and FALSE otherwise.\n   * Format:\n   *   (HasBlockParams block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference (boolean)\n   */\n  HasBlockParams,\n\n  /**\n   * Operation:\n   *   Pop count `VersionedPathReference`s off the stack and\n   *   construct a new ConcatReference from them (in reverse\n   *   order).\n   * Format:\n   *   (Concat count:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ..., ConcatReference\n   */\n  Concat,\n\n  /**\n   * Operation:\n   *   Push an Object constant onto the stack that is not\n   *   a JavaScript primitive.\n   * Format:\n   *   (PushConstant constant:#Object)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Constant,\n\n  /**\n   * Operation:\n   *   Wrap a JavaScript primitive in a reference and push it\n   *   onto the stack.\n   * Format:\n   *   (PushPrimitive constant:#Primitive)\n   * Operand Stack:\n   *   ... →\n   *   ..., Primitive\n   * Description:\n   *   The two high bits of the constant reference describe\n   *   the kind of primitive:\n   *\n   *   00: number\n   *   01: string\n   *   10: true | false | null | undefined\n   */\n  Primitive,\n\n  /**\n   * Operation: Convert the top of the stack into a primitive reference.\n   *\n   * Format:\n   *   (PrimitiveReference)\n   * Operand Stack:\n   *   ..., Primitive →\n   *   ..., VersionedPathReference<Primitive>\n   */\n  PrimitiveReference,\n\n  /**\n   * Operation: Duplicate and push item from an offset in the stack.\n   * Format:\n   *   (Dup register:u32, offset:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ..., Opaque, Opaque\n   */\n  Dup,\n\n  /**\n   * Operation: Pop N items off the stack and throw away the value.\n   * Format:\n   *   (Pop)\n   * Operand Stack:\n   *   ..., Opaque, ..., Opaque →\n   *   ...\n   */\n  Pop,\n\n  /**\n   * Operation: Load a value into a register\n   * Format:\n   *   (Load register:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ...\n   */\n  Load,\n\n  /**\n   * Operation: Fetch a value from a register\n   * Format:\n   *   (Fetch register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Fetch,\n\n  /// PRELUDE & EXIT\n\n  /**\n   * Operation: Push a new root scope onto the scope stack.\n   *\n   * Format:\n   *   (RootScope symbols:u32 bindCallerScope:bool)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A root scope has no parent scope, and therefore inherits no lexical\n   *   variables. If `bindCallerScope` is `true`, the current scope remembers\n   *   the caller scope (for yielding blocks).\n   */\n  RootScope,\n\n  /**\n   * Operation: Push a new child scope onto the scope stack.\n   *\n   * Format:\n   *   (ChildScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A child scope inherits from the current parent scope, and therefore\n   *   shares its lexical variables.\n   */\n  ChildScope,\n\n  /**\n   * Operation: Pop the current scope from the scope stack.\n   * Format:\n   *   (PopScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PopScope,\n\n  /**\n   * Operation: Return to the previous frame.\n   * Format:\n   *   (Return)\n   * Operand Stack:\n   *   ..., address:number →\n   *   ...\n   */\n  Return,\n\n  /**\n   * Operation: Return to a place in the program given an offset\n   * Format:\n   *  (ReturnTo offset:i32)\n   * Operand Stack:\n   *    ... →\n   */\n  ReturnTo,\n\n  /// HTML\n\n  /**\n   * Operation: Append a Text node with value `contents`\n   * Format:\n   *   (Text contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Text,\n\n  /**\n   * Operation: Append a Comment node with value `contents`\n   * Format:\n   *   (Comment contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Comment,\n\n  /**\n   * Operation: Append a Dynamic node based on .\n   * Format:\n   *   (DynamicContent isTrusting:boolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  DynamicContent,\n\n  /**\n   * Operation: Open a new Element named `tag`.\n   * Format:\n   *   (OpenElement tag:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  OpenElement,\n\n  /**\n   * Operation:\n   *   Open a new Element named `tag` with special operations provided\n   *   on the stack.\n   * Format:\n   *   (OpenElementWithOperations tag:#string)\n   * Operand Stack:\n   *   ..., ElementOperations →\n   *   ...\n   */\n  OpenElementWithOperations,\n\n  /**\n   * Operation:\n   *   Open a new Element with a name on the stack and with special\n   *   operations provided on the stack.\n   * Format:\n   *   (OpenDynamicElement)\n   * Operand Stack:\n   *   ..., string, ElementOperations →\n   *   ...\n   */\n  OpenDynamicElement,\n\n  /**\n   * Operation: Add an attribute to the current Element.\n   * Format:\n   *   (StaticAttr name:#string value:#string namespace:Option<#string>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  StaticAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (DynamicAttr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   * Description:\n   *   If `trusting` is false, the host may sanitize the attribute\n   *   based upon known risks.\n   */\n  DynamicAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (ComponentAtr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  ComponentAttr,\n\n  /**\n   * Operation: Finish setting attributes on the current element.\n   *\n   * Format:\n   *   (FlushElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  FlushElement,\n\n  /**\n   * Operation: Close the current element.\n   *\n   * Format:\n   *   (CloseElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CloseElement,\n\n  /// MODIFIER\n  Modifier,                  // (ConstantString, ConstantOther<ModifierManager>, ConstantExpression)\n\n  /// WORMHOLE\n  PushRemoteElement,         // ()\n  PopRemoteElement,          // ()\n\n  /// DYNAMIC SCOPE\n\n  /**\n   * Operation: Bind stack values as dynamic variables.\n   * Format:\n   *   (BindDynamicScope names:#Array<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ...\n   * Description:\n   *   This is used to expose `-with-dynamic-vars`, and is a\n   *   niche feature.\n   */\n  BindDynamicScope,\n\n  PushDynamicScope,          // ()\n  PopDynamicScope,           // ()\n\n  /// VM\n\n  /**\n   * Operation: Compile the InlineBlock at the top of the stack.\n   * Format:\n   *   (CompileBlock)\n   * Operand Stack:\n   *   ..., CompilableBlock →\n   *   ..., Handle\n   */\n  CompileBlock,\n\n  /**\n   * Operation: Push a scope onto the stack.\n   * Format:\n   *   (PushBlockScope #Scope)\n   * Operand Stack:\n   *   ..., →\n   *   ..., Scope\n   */\n  PushBlockScope,\n\n  /**\n   * Operation: Push a symbol table onto the stack.\n   * Format:\n   *   (PushSymbolTable #SymbolTable)\n   * Operand Stack:\n   *   ..., →\n   *   ..., SymbolTable\n   */\n  PushSymbolTable,\n\n  /**\n   * Operation: Evaluate the handle at the top of the stack.\n   * Format:\n   *   (InvokeVirtual)\n   * Operand Stack:\n   *   ..., Handle, →\n   *   ...\n   */\n  InvokeVirtual,\n\n  /**\n   * Operation: Evaluate the handle.\n   * Format:\n   *   (InvokeStatic handle:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  InvokeStatic,\n\n  /**\n   * Operation: Yield to a block.\n   * Format:\n   *   (InvokeYield)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments, SymbolTable, Handle →\n   *   ...\n   */\n  InvokeYield,\n\n  /**\n   * Operation: Jump to the specified offset.\n   *\n   * Format:\n   *   (Jump to:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Jump,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is true.\n   *\n   * Format:\n   *   (JumpIf to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpIf,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is false.\n   *\n   * Format:\n   *   (JumpUnless to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpUnless,\n\n  /**\n   * Operation: Push a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   ... →\n   *   $ra, $fp\n   */\n  PushFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   $ra, $fp →\n   *   ...\n   */\n  PopFrame,\n\n  /**\n   * Operation:\n   *   Start tracking a new output block that could change\n   *   if one of its inputs changes.\n   *\n   * Format:\n   *   (Enter args:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   Soon after this opcode, one of Jump, JumpIf,\n   *   or JumpUnless will produce an updating assertion.\n   *   If that assertion fails, the appending VM will\n   *   be re-entered, and the instructions from `from`\n   *   to `to` will be executed.\n   *\n   *   TODO: Save and restore.\n   */\n  Enter,\n\n  /**\n   * Operation:\n   *   Finish tracking the current block.\n   *\n   * Format:\n   *   (Exit)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   This finalizes the validators that the updating\n   *   block must check to determine whether it's safe to\n   *   skip running the contents.\n   */\n  Exit,\n\n  /**\n   * Operation: Convert the top of the stack into a boolean reference.\n   *\n   * Format:\n   *   (ToBoolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<bool>\n   */\n  ToBoolean,\n\n  /// LISTS\n\n  /**\n   * Operation: Enter a list.\n   *\n   * Format:\n   *   (EnterList address:u32)\n   * Operand Stack:\n   *   ..., Iterator →\n   *   ...\n   */\n  EnterList,\n\n  /**\n   * Operation: Exit the current list.\n   *\n   * Format:\n   *   (ExitList)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  ExitList,\n\n  /**\n   * Operation:\n   *   Convert an operand and key into an iterator and\n   *   presence reference.\n   *\n   * Format:\n   *   (PutIterator)\n   * Operand Stack:\n   *   ..., key:string, list:VersionedPathReference →\n   *   ..., iterator:ReferenceIterator, present:PresenceReference\n   */\n  PutIterator,\n\n  /**\n   * Operation:\n   *   Set up the stack for iterating for a given key,\n   *   or jump to `end` if there is nothing left to\n   *   iterate.\n   *\n   * Format:\n   *   (Iterate end:u32)\n   * Operand Stack:\n   *   Form 1: (something to iterate)\n   *   ... →\n   *   ..., VersionedPathReference, VersionedPathReference, string\n   *   Form 2: (nothing left to iterate)\n   *   ... →\n   *   ...\n   * Description:\n   *   In Form 1, the stack will have (in reverse order):\n   *\n   *   - the key, as a string\n   *   - the current iterated value\n   *   - the memoized iterated value\n   */\n  Iterate,\n\n  /// COMPONENTS\n\n  /**\n   * Operation: Test whether a reference contains a component definition.\n   *\n   * Format:\n   *   (IsComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<boolean>\n   */\n  IsComponent,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, TemplateMeta, CapturedArguments }\n   */\n  CurryComponent,\n\n  /**\n   * Operation: Push an appropriate component manager onto the stack.\n   *\n   * Format:\n   *   (PushComponentManager #ComponentSpec)\n   * Operand Stack:\n   *   ... →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushComponentDefinition,\n\n  /**\n   * Operation:\n   *   Push an appropriate component manager onto the stack from\n   *   a runtime-resolved component definition.\n   *\n   * Format:\n   *   (PushDynamicComponentManager templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushDynamicComponentManager,\n\n  /**\n   * Operation: Push a user representation of args onto the stack.\n   *\n   * Format:\n   *   (PushArgs names:#Array<#string> positionalCount:u32 synthetic:#boolean)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...]  →\n   *   ..., [VersionedPathReference ...], Arguments\n   *\n   * Description:\n   *   This arguments object is only necessary when calling into\n   *   user-specified hooks. It is meant to be implemented as a\n   *   transient proxy that reads into the stack as needed.\n   *   Holding onto the Arguments after the call has completed is\n   *   illegal.\n   */\n  PushArgs,\n\n  /**\n   * Operation: Pops Arguments from the stack and clears the next N args.\n   *\n   * Format:\n   *   (PopArgs)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments  →\n   *   ...\n   *\n   * Description:\n   * The arguments object contains the information of how many user\n   * supplied args the component was invoked with. To clear them from\n   * the stack we must pop it from the stack and call `clear` on it\n   * to remove the argument values from the stack.\n   */\n  PopArgs,\n\n  /**\n   * Operation: ...\n   * Format:\n   *   (PrepareArgs state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PrepareArgs,\n\n  /**\n   * Operation: Create the component and push it onto the stack.\n   * Format:\n   *   (CreateComponent flags:u32 state:u32)\n   *   ... →\n   *   ...\n   * Description:\n   * Operand Stack:\n   *   Flags:\n   *\n   *   * 0b001: Has a default block\n   *   * 0b010: Has an inverse block\n   */\n  CreateComponent,\n\n  /**\n   * Operation: Register a destructor for the current component\n   *\n   * Format:\n   *   (RegisterComponentDestructor state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  RegisterComponentDestructor,\n\n  /**\n   * Operation: Push a new ElementOperations for the current component.\n   *\n   * Format:\n   *   (PutComponentOperations)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PutComponentOperations,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentSelf state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetComponentSelf,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentTagName state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., Option<string>\n   */\n  GetComponentTagName,\n\n  /**\n   * Operation: Get the component layout from the manager.\n   *\n   * Format:\n   *   (GetComponentLayout state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., ProgramSymbolTable, Handle\n   */\n  GetComponentLayout,\n\n  /**\n   * Operation: Invoke the layout returned by the manager.\n   *\n   * Format:\n   *   (InvokeComponentLayout)\n   * Operand Stack:\n   *   ..., ProgramSymbolTable, Handle →\n   *   ...\n   */\n  InvokeComponentLayout,\n\n  /**\n   * Operation: Begin a new cache group\n   *\n   * Format:\n   *   (BeginComponentTransaction)\n   * Operand Stack:\n   *   ..., ComponentManager<T>, T →\n   *   ..., ComponentManager<T>, T\n   */\n  BeginComponentTransaction,\n\n  /**\n   * Operation: Commit the current cache group\n   *\n   * Format:\n   *   (CommitComponentTransaction)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CommitComponentTransaction,\n\n  /**\n   * Operation: Invoke didCreateElement on the current component manager\n   *\n   * Format:\n   *   (DidCreateElement state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  DidCreateElement,\n\n  /**\n   * Operation: Invoke didRenderLayout on the current component manager\n   *\n   * Format:\n   *   (DidRenderLayout state:u32)\n   * Operand Stack:\n   *   ..., →\n   *   ...\n   */\n  DidRenderLayout,\n\n  /// PARTIALS\n\n  /**\n   * Operation: Lookup and invoke a partial template.\n   *\n   * Format:\n   *   (InvokePartial templateMeta:#TemplateMeta symbols:#Array<#string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  InvokePartial,\n\n  /**\n   * Operation:\n   *   Resolve {{foo}} inside a partial, which could be either a self-lookup\n   *   or a local variable that is in-scope for the caller.\n   *\n   * Format:\n   *   (ResolveMaybeLocal local:#string)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  ResolveMaybeLocal,\n\n  /// DEBUGGER\n\n  /**\n   * Operation: Activate the debugger\n   *\n   * Format:\n   *   (Debugger symbols:#Array<string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Debugger,\n\n  /** The size of the opcode list */\n  Size\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"opcodes.js","sourceRoot":"","sources":["../../../../packages/@glimmer/vm/lib/opcodes.ts"],"names":[],"mappings":"","sourcesContent":["export const enum Op {\n  /*\n    Documentation TODO:\n\n    Document the local variable layout in the stack\n    diagram before-and-after.\n\n    Document updating opcodes emitting from unreachable\n    append opcode.\n\n    Document the element stack, block stack and List\n    block stack.\n   */\n\n  /**\n   * This opcode should never be reached.\n   */\n  Bug,\n\n  /// EXPRESSIONS\n\n  /**\n   * Operation: Evaluate a Helper.\n   * Format:\n   *   (Helper helper:#Function)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments →\n   *   ..., VersionedPathReference\n   */\n  Helper,\n\n  /**\n   * Operation:\n   *   Bind the variable represented by a symbol from\n   *   the value at the top of the stack.\n   * Format:\n   *   (SetVariable symbol:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  SetVariable,\n\n  /**\n   * Operation:\n   *   Bind the block at the top of the stack.\n   * Format:\n   *   (SetBlock symbol:u32)\n   * Operand Stack:\n   *   ..., SymbolTable, Handle →\n   *   ...\n   */\n  SetBlock,\n\n  /**\n   * Operation:\n   *   Push the contents of the variable represented by\n   *   a symbol (a positional or named argument) onto\n   *   the stack.\n   * Format:\n   *   (PushSymbol symbol:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetVariable,\n\n  /**\n   * Operation:\n   *   Pop a VersionedPathReference from the top of the\n   *   stack, and push a VersionedPathReference constructed\n   *   by `.get(property)`.\n   * Format:\n   *   (GetProperty property:#string)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ..., VersionedPathReference\n   */\n  GetProperty,\n\n  /**\n   * Operation: Push the specified bound block onto the stack.\n   * Format:\n   *   (GetBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., InlineBlock\n   */\n  GetBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound and FALSE if it is not.\n   * Format:\n   *   (HasBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., boolean\n   */\n  HasBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound *and* has at least one specified formal\n   *   parameter, and FALSE otherwise.\n   * Format:\n   *   (HasBlockParams block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference (boolean)\n   */\n  HasBlockParams,\n\n  /**\n   * Operation:\n   *   Pop count `VersionedPathReference`s off the stack and\n   *   construct a new ConcatReference from them (in reverse\n   *   order).\n   * Format:\n   *   (Concat count:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ..., ConcatReference\n   */\n  Concat,\n\n  /**\n   * Operation:\n   *   Push an Object constant onto the stack that is not\n   *   a JavaScript primitive.\n   * Format:\n   *   (PushConstant constant:#Object)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Constant,\n\n  /**\n   * Operation:\n   *   Wrap a JavaScript primitive in a reference and push it\n   *   onto the stack.\n   * Format:\n   *   (PushPrimitive constant:#Primitive)\n   * Operand Stack:\n   *   ... →\n   *   ..., Primitive\n   * Description:\n   *   The two high bits of the constant reference describe\n   *   the kind of primitive:\n   *\n   *   00: number\n   *   01: string\n   *   10: true | false | null | undefined\n   */\n  Primitive,\n\n  /**\n   * Operation: Convert the top of the stack into a primitive reference.\n   *\n   * Format:\n   *   (PrimitiveReference)\n   * Operand Stack:\n   *   ..., Primitive →\n   *   ..., VersionedPathReference<Primitive>\n   */\n  PrimitiveReference,\n\n  /**\n   * Operation: Duplicate and push item from an offset in the stack.\n   * Format:\n   *   (Dup register:u32, offset:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ..., Opaque, Opaque\n   */\n  Dup,\n\n  /**\n   * Operation: Pop N items off the stack and throw away the value.\n   * Format:\n   *   (Pop)\n   * Operand Stack:\n   *   ..., Opaque, ..., Opaque →\n   *   ...\n   */\n  Pop,\n\n  /**\n   * Operation: Load a value into a register\n   * Format:\n   *   (Load register:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ...\n   */\n  Load,\n\n  /**\n   * Operation: Fetch a value from a register\n   * Format:\n   *   (Fetch register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Fetch,\n\n  /// PRELUDE & EXIT\n\n  /**\n   * Operation: Push a new root scope onto the scope stack.\n   *\n   * Format:\n   *   (RootScope symbols:u32 bindCallerScope:bool)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A root scope has no parent scope, and therefore inherits no lexical\n   *   variables. If `bindCallerScope` is `true`, the current scope remembers\n   *   the caller scope (for yielding blocks).\n   */\n  RootScope,\n\n  /**\n   * Operation: Push a new child scope onto the scope stack.\n   *\n   * Format:\n   *   (ChildScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A child scope inherits from the current parent scope, and therefore\n   *   shares its lexical variables.\n   */\n  ChildScope,\n\n  /**\n   * Operation: Pop the current scope from the scope stack.\n   * Format:\n   *   (PopScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PopScope,\n\n  /**\n   * Operation: Return to the previous frame.\n   * Format:\n   *   (Return)\n   * Operand Stack:\n   *   ..., address:number →\n   *   ...\n   */\n  Return,\n\n  /**\n   * Operation: Return to a place in the program given an offset\n   * Format:\n   *  (ReturnTo offset:i32)\n   * Operand Stack:\n   *    ... →\n   */\n  ReturnTo,\n\n  /// HTML\n\n  /**\n   * Operation: Append a Text node with value `contents`\n   * Format:\n   *   (Text contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Text,\n\n  /**\n   * Operation: Append a Comment node with value `contents`\n   * Format:\n   *   (Comment contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Comment,\n\n  /**\n   * Operation: Append a Dynamic node based on .\n   * Format:\n   *   (DynamicContent isTrusting:boolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  DynamicContent,\n\n  /**\n   * Operation: Open a new Element named `tag`.\n   * Format:\n   *   (OpenElement tag:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  OpenElement,\n\n  /**\n   * Operation:\n   *   Open a new Element named `tag` with special operations provided\n   *   on the stack.\n   * Format:\n   *   (OpenElementWithOperations tag:#string)\n   * Operand Stack:\n   *   ..., ElementOperations →\n   *   ...\n   */\n  OpenElementWithOperations,\n\n  /**\n   * Operation:\n   *   Open a new Element with a name on the stack and with special\n   *   operations provided on the stack.\n   * Format:\n   *   (OpenDynamicElement)\n   * Operand Stack:\n   *   ..., string, ElementOperations →\n   *   ...\n   */\n  OpenDynamicElement,\n\n  /**\n   * Operation: Add an attribute to the current Element.\n   * Format:\n   *   (StaticAttr name:#string value:#string namespace:Option<#string>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  StaticAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (DynamicAttr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   * Description:\n   *   If `trusting` is false, the host may sanitize the attribute\n   *   based upon known risks.\n   */\n  DynamicAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (ComponentAtr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  ComponentAttr,\n\n  /**\n   * Operation: Finish setting attributes on the current element.\n   *\n   * Format:\n   *   (FlushElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  FlushElement,\n\n  /**\n   * Operation: Close the current element.\n   *\n   * Format:\n   *   (CloseElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CloseElement,\n\n  /// MODIFIER\n  Modifier,                  // (ConstantString, ConstantOther<ModifierManager>, ConstantExpression)\n\n  /// WORMHOLE\n  PushRemoteElement,         // ()\n  PopRemoteElement,          // ()\n\n  /// DYNAMIC SCOPE\n\n  /**\n   * Operation: Bind stack values as dynamic variables.\n   * Format:\n   *   (BindDynamicScope names:#Array<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ...\n   * Description:\n   *   This is used to expose `-with-dynamic-vars`, and is a\n   *   niche feature.\n   */\n  BindDynamicScope,\n\n  PushDynamicScope,          // ()\n  PopDynamicScope,           // ()\n\n  /// VM\n\n  /**\n   * Operation: Compile the InlineBlock at the top of the stack.\n   * Format:\n   *   (CompileBlock)\n   * Operand Stack:\n   *   ..., CompilableBlock →\n   *   ..., Handle\n   */\n  CompileBlock,\n\n  /**\n   * Operation: Push a scope onto the stack.\n   * Format:\n   *   (PushBlockScope #Scope)\n   * Operand Stack:\n   *   ..., →\n   *   ..., Scope\n   */\n  PushBlockScope,\n\n  /**\n   * Operation: Push a symbol table onto the stack.\n   * Format:\n   *   (PushSymbolTable #SymbolTable)\n   * Operand Stack:\n   *   ..., →\n   *   ..., SymbolTable\n   */\n  PushSymbolTable,\n\n  /**\n   * Operation: Evaluate the handle at the top of the stack.\n   * Format:\n   *   (InvokeVirtual)\n   * Operand Stack:\n   *   ..., Handle, →\n   *   ...\n   */\n  InvokeVirtual,\n\n  /**\n   * Operation: Evaluate the handle.\n   * Format:\n   *   (InvokeStatic handle:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  InvokeStatic,\n\n  /**\n   * Operation: Yield to a block.\n   * Format:\n   *   (InvokeYield)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments, SymbolTable, Handle →\n   *   ...\n   */\n  InvokeYield,\n\n  /**\n   * Operation: Jump to the specified offset.\n   *\n   * Format:\n   *   (Jump to:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Jump,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is true.\n   *\n   * Format:\n   *   (JumpIf to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpIf,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is false.\n   *\n   * Format:\n   *   (JumpUnless to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpUnless,\n\n  /**\n   * Operation: Push a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   ... →\n   *   $ra, $fp\n   */\n  PushFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   $ra, $fp →\n   *   ...\n   */\n  PopFrame,\n\n  /**\n   * Operation:\n   *   Start tracking a new output block that could change\n   *   if one of its inputs changes.\n   *\n   * Format:\n   *   (Enter args:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   Soon after this opcode, one of Jump, JumpIf,\n   *   or JumpUnless will produce an updating assertion.\n   *   If that assertion fails, the appending VM will\n   *   be re-entered, and the instructions from `from`\n   *   to `to` will be executed.\n   *\n   *   TODO: Save and restore.\n   */\n  Enter,\n\n  /**\n   * Operation:\n   *   Finish tracking the current block.\n   *\n   * Format:\n   *   (Exit)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   This finalizes the validators that the updating\n   *   block must check to determine whether it's safe to\n   *   skip running the contents.\n   */\n  Exit,\n\n  /**\n   * Operation: Convert the top of the stack into a boolean reference.\n   *\n   * Format:\n   *   (ToBoolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<bool>\n   */\n  ToBoolean,\n\n  /// LISTS\n\n  /**\n   * Operation: Enter a list.\n   *\n   * Format:\n   *   (EnterList address:u32)\n   * Operand Stack:\n   *   ..., Iterator →\n   *   ...\n   */\n  EnterList,\n\n  /**\n   * Operation: Exit the current list.\n   *\n   * Format:\n   *   (ExitList)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  ExitList,\n\n  /**\n   * Operation:\n   *   Convert an operand and key into an iterator and\n   *   presence reference.\n   *\n   * Format:\n   *   (PutIterator)\n   * Operand Stack:\n   *   ..., key:string, list:VersionedPathReference →\n   *   ..., iterator:ReferenceIterator, present:PresenceReference\n   */\n  PutIterator,\n\n  /**\n   * Operation:\n   *   Set up the stack for iterating for a given key,\n   *   or jump to `end` if there is nothing left to\n   *   iterate.\n   *\n   * Format:\n   *   (Iterate end:u32)\n   * Operand Stack:\n   *   Form 1: (something to iterate)\n   *   ... →\n   *   ..., VersionedPathReference, VersionedPathReference, string\n   *   Form 2: (nothing left to iterate)\n   *   ... →\n   *   ...\n   * Description:\n   *   In Form 1, the stack will have (in reverse order):\n   *\n   *   - the key, as a string\n   *   - the current iterated value\n   *   - the memoized iterated value\n   */\n  Iterate,\n\n  /// COMPONENTS\n\n  /**\n   * Operation: Test whether a reference contains a component definition.\n   *\n   * Format:\n   *   (Main state:register)\n   * Operand Stack:\n   *   ..., Invocation, ComponentDefinition →\n   *   ...\n   */\n  Main,\n\n  /**\n   * Operation: Test whether a reference contains a component definition.\n   *\n   * Format:\n   *   (IsComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<boolean>\n   */\n  IsComponent,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, TemplateMeta, CapturedArguments }\n   */\n  CurryComponent,\n\n  /**\n   * Operation: Push an appropriate component manager onto the stack.\n   *\n   * Format:\n   *   (PushComponentManager #ComponentSpec)\n   * Operand Stack:\n   *   ... →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushComponentDefinition,\n\n  /**\n   * Operation:\n   *   Push an appropriate component manager onto the stack from\n   *   a runtime-resolved component definition.\n   *\n   * Format:\n   *   (PushDynamicComponentManager templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushDynamicComponentManager,\n\n  /**\n   * Operation: Push a user representation of args onto the stack.\n   *\n   * Format:\n   *   (PushArgs names:#Array<#string> positionalCount:u32 synthetic:#boolean)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...]  →\n   *   ..., [VersionedPathReference ...], Arguments\n   *\n   * Description:\n   *   This arguments object is only necessary when calling into\n   *   user-specified hooks. It is meant to be implemented as a\n   *   transient proxy that reads into the stack as needed.\n   *   Holding onto the Arguments after the call has completed is\n   *   illegal.\n   */\n  PushArgs,\n\n  /**\n   * Operation: Pops Arguments from the stack and clears the next N args.\n   *\n   * Format:\n   *   (PopArgs)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments  →\n   *   ...\n   *\n   * Description:\n   * The arguments object contains the information of how many user\n   * supplied args the component was invoked with. To clear them from\n   * the stack we must pop it from the stack and call `clear` on it\n   * to remove the argument values from the stack.\n   */\n  PopArgs,\n\n  /**\n   * Operation: ...\n   * Format:\n   *   (PrepareArgs state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PrepareArgs,\n\n  /**\n   * Operation: Create the component and push it onto the stack.\n   * Format:\n   *   (CreateComponent flags:u32 state:register)\n   *   ... →\n   *   ...\n   * Description:\n   * Operand Stack:\n   *   Flags:\n   *\n   *   * 0b001: Has a default block\n   *   * 0b010: Has an inverse block\n   */\n  CreateComponent,\n\n  /**\n   * Operation: Register a destructor for the current component\n   *\n   * Format:\n   *   (RegisterComponentDestructor state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  RegisterComponentDestructor,\n\n  /**\n   * Operation: Push a new ElementOperations for the current component.\n   *\n   * Format:\n   *   (PutComponentOperations)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PutComponentOperations,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentSelf state:register)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetComponentSelf,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentTagName state:register)\n   * Operand Stack:\n   *   ... →\n   *   ..., Option<string>\n   */\n  GetComponentTagName,\n\n  /**\n   * Operation: Get the component layout from the manager.\n   *\n   * Format:\n   *   (GetComponentLayout state:register)\n   * Operand Stack:\n   *   ... →\n   *   ..., ProgramSymbolTable, Handle\n   */\n  GetComponentLayout,\n\n  /**\n   * Operation:\n   *   Populate the state register with the layout currently\n   *   on the stack.\n   *\n   * Format:\n   *   (PopulateLayout state:register)\n   * Operand Stack:\n   *   ..., ProgramSymbolTable, Handle →\n   *   ...\n   */\n  PopulateLayout,\n\n  /**\n   * Operation: Invoke the layout returned by the manager.\n   *\n   * Format:\n   *   (InvokeComponentLayout state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  InvokeComponentLayout,\n\n  /**\n   * Operation: Begin a new cache group\n   *\n   * Format:\n   *   (BeginComponentTransaction)\n   * Operand Stack:\n   *   ..., ComponentManager<T>, T →\n   *   ..., ComponentManager<T>, T\n   */\n  BeginComponentTransaction,\n\n  /**\n   * Operation: Commit the current cache group\n   *\n   * Format:\n   *   (CommitComponentTransaction)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CommitComponentTransaction,\n\n  /**\n   * Operation: Invoke didCreateElement on the current component manager\n   *\n   * Format:\n   *   (DidCreateElement state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  DidCreateElement,\n\n  /**\n   * Operation: Invoke didRenderLayout on the current component manager\n   *\n   * Format:\n   *   (DidRenderLayout state:register)\n   * Operand Stack:\n   *   ..., →\n   *   ...\n   */\n  DidRenderLayout,\n\n  /// PARTIALS\n\n  /**\n   * Operation: Lookup and invoke a partial template.\n   *\n   * Format:\n   *   (InvokePartial templateMeta:#TemplateMeta symbols:#Array<#string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  InvokePartial,\n\n  /**\n   * Operation:\n   *   Resolve {{foo}} inside a partial, which could be either a self-lookup\n   *   or a local variable that is in-scope for the caller.\n   *\n   * Format:\n   *   (ResolveMaybeLocal local:#string)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  ResolveMaybeLocal,\n\n  /// DEBUGGER\n\n  /**\n   * Operation: Activate the debugger\n   *\n   * Format:\n   *   (Debugger symbols:#Array<string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Debugger,\n\n  /** The size of the opcode list */\n  Size\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"opcodes.js","sourceRoot":"","sources":["../../../../packages/@glimmer/vm/lib/opcodes.ts"],"names":[],"mappings":"","sourcesContent":["export const enum Op {\n  /*\n    Documentation TODO:\n\n    Document the local variable layout in the stack\n    diagram before-and-after.\n\n    Document updating opcodes emitting from unreachable\n    append opcode.\n\n    Document the element stack, block stack and List\n    block stack.\n   */\n\n  /**\n   * This opcode should never be reached.\n   */\n  Bug,\n\n  /// EXPRESSIONS\n\n  /**\n   * Operation: Evaluate a Helper.\n   * Format:\n   *   (Helper helper:#Function)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments →\n   *   ..., VersionedPathReference\n   */\n  Helper,\n\n  /**\n   * Operation:\n   *   Bind the variable represented by a symbol from\n   *   the value at the top of the stack.\n   * Format:\n   *   (SetVariable symbol:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  SetVariable,\n\n  /**\n   * Operation:\n   *   Bind the block at the top of the stack.\n   * Format:\n   *   (SetBlock symbol:u32)\n   * Operand Stack:\n   *   ..., SymbolTable, Handle →\n   *   ...\n   */\n  SetBlock,\n\n  /**\n   * Operation:\n   *   Push the contents of the variable represented by\n   *   a symbol (a positional or named argument) onto\n   *   the stack.\n   * Format:\n   *   (PushSymbol symbol:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetVariable,\n\n  /**\n   * Operation:\n   *   Pop a VersionedPathReference from the top of the\n   *   stack, and push a VersionedPathReference constructed\n   *   by `.get(property)`.\n   * Format:\n   *   (GetProperty property:#string)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ..., VersionedPathReference\n   */\n  GetProperty,\n\n  /**\n   * Operation: Push the specified bound block onto the stack.\n   * Format:\n   *   (GetBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., InlineBlock\n   */\n  GetBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound and FALSE if it is not.\n   * Format:\n   *   (HasBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., boolean\n   */\n  HasBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound *and* has at least one specified formal\n   *   parameter, and FALSE otherwise.\n   * Format:\n   *   (HasBlockParams block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference (boolean)\n   */\n  HasBlockParams,\n\n  /**\n   * Operation:\n   *   Pop count `VersionedPathReference`s off the stack and\n   *   construct a new ConcatReference from them (in reverse\n   *   order).\n   * Format:\n   *   (Concat count:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ..., ConcatReference\n   */\n  Concat,\n\n  /**\n   * Operation:\n   *   Push an Object constant onto the stack that is not\n   *   a JavaScript primitive.\n   * Format:\n   *   (PushConstant constant:#Object)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Constant,\n\n  /**\n   * Operation:\n   *   Wrap a JavaScript primitive in a reference and push it\n   *   onto the stack.\n   * Format:\n   *   (PushPrimitive constant:#Primitive)\n   * Operand Stack:\n   *   ... →\n   *   ..., Primitive\n   * Description:\n   *   The two high bits of the constant reference describe\n   *   the kind of primitive:\n   *\n   *   00: number\n   *   01: string\n   *   10: true | false | null | undefined\n   */\n  Primitive,\n\n  /**\n   * Operation: Convert the top of the stack into a primitive reference.\n   *\n   * Format:\n   *   (PrimitiveReference)\n   * Operand Stack:\n   *   ..., Primitive →\n   *   ..., VersionedPathReference<Primitive>\n   */\n  PrimitiveReference,\n\n  /**\n   * Operation: Duplicate and push item from an offset in the stack.\n   * Format:\n   *   (Dup register:u32, offset:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ..., Opaque, Opaque\n   */\n  Dup,\n\n  /**\n   * Operation: Pop N items off the stack and throw away the value.\n   * Format:\n   *   (Pop)\n   * Operand Stack:\n   *   ..., Opaque, ..., Opaque →\n   *   ...\n   */\n  Pop,\n\n  /**\n   * Operation: Load a value into a register\n   * Format:\n   *   (Load register:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ...\n   */\n  Load,\n\n  /**\n   * Operation: Fetch a value from a register\n   * Format:\n   *   (Fetch register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Fetch,\n\n  /// PRELUDE & EXIT\n\n  /**\n   * Operation: Push a new root scope onto the scope stack.\n   *\n   * Format:\n   *   (RootScope symbols:u32 bindCallerScope:bool)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A root scope has no parent scope, and therefore inherits no lexical\n   *   variables. If `bindCallerScope` is `true`, the current scope remembers\n   *   the caller scope (for yielding blocks).\n   */\n  RootScope,\n\n  /**\n   * Operation: Push a new child scope onto the scope stack.\n   *\n   * Format:\n   *   (ChildScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A child scope inherits from the current parent scope, and therefore\n   *   shares its lexical variables.\n   */\n  ChildScope,\n\n  /**\n   * Operation: Pop the current scope from the scope stack.\n   * Format:\n   *   (PopScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PopScope,\n\n  /**\n   * Operation: Return to the previous frame.\n   * Format:\n   *   (Return)\n   * Operand Stack:\n   *   ..., address:number →\n   *   ...\n   */\n  Return,\n\n  /**\n   * Operation: Return to a place in the program given an offset\n   * Format:\n   *  (ReturnTo offset:i32)\n   * Operand Stack:\n   *    ... →\n   */\n  ReturnTo,\n\n  /// HTML\n\n  /**\n   * Operation: Append a Text node with value `contents`\n   * Format:\n   *   (Text contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Text,\n\n  /**\n   * Operation: Append a Comment node with value `contents`\n   * Format:\n   *   (Comment contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Comment,\n\n  /**\n   * Operation: Append a Dynamic node based on .\n   * Format:\n   *   (DynamicContent isTrusting:boolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  DynamicContent,\n\n  /**\n   * Operation: Open a new Element named `tag`.\n   * Format:\n   *   (OpenElement tag:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  OpenElement,\n\n  /**\n   * Operation:\n   *   Open a new Element named `tag` with special operations provided\n   *   on the stack.\n   * Format:\n   *   (OpenElementWithOperations tag:#string)\n   * Operand Stack:\n   *   ..., ElementOperations →\n   *   ...\n   */\n  OpenElementWithOperations,\n\n  /**\n   * Operation:\n   *   Open a new Element with a name on the stack and with special\n   *   operations provided on the stack.\n   * Format:\n   *   (OpenDynamicElement)\n   * Operand Stack:\n   *   ..., string, ElementOperations →\n   *   ...\n   */\n  OpenDynamicElement,\n\n  /**\n   * Operation: Add an attribute to the current Element.\n   * Format:\n   *   (StaticAttr name:#string value:#string namespace:Option<#string>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  StaticAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (DynamicAttr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   * Description:\n   *   If `trusting` is false, the host may sanitize the attribute\n   *   based upon known risks.\n   */\n  DynamicAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (ComponentAtr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  ComponentAttr,\n\n  /**\n   * Operation: Finish setting attributes on the current element.\n   *\n   * Format:\n   *   (FlushElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  FlushElement,\n\n  /**\n   * Operation: Close the current element.\n   *\n   * Format:\n   *   (CloseElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CloseElement,\n\n  /// MODIFIER\n  Modifier,                  // (ConstantString, ConstantOther<ModifierManager>, ConstantExpression)\n\n  /// WORMHOLE\n  PushRemoteElement,         // ()\n  PopRemoteElement,          // ()\n\n  /// DYNAMIC SCOPE\n\n  /**\n   * Operation: Bind stack values as dynamic variables.\n   * Format:\n   *   (BindDynamicScope names:#Array<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ...\n   * Description:\n   *   This is used to expose `-with-dynamic-vars`, and is a\n   *   niche feature.\n   */\n  BindDynamicScope,\n\n  PushDynamicScope,          // ()\n  PopDynamicScope,           // ()\n\n  /// VM\n\n  /**\n   * Operation: Compile the InlineBlock at the top of the stack.\n   * Format:\n   *   (CompileBlock)\n   * Operand Stack:\n   *   ..., CompilableBlock →\n   *   ..., Handle\n   */\n  CompileBlock,\n\n  /**\n   * Operation: Push a scope onto the stack.\n   * Format:\n   *   (PushBlockScope #Scope)\n   * Operand Stack:\n   *   ..., →\n   *   ..., Scope\n   */\n  PushBlockScope,\n\n  /**\n   * Operation: Push a symbol table onto the stack.\n   * Format:\n   *   (PushSymbolTable #SymbolTable)\n   * Operand Stack:\n   *   ..., →\n   *   ..., SymbolTable\n   */\n  PushSymbolTable,\n\n  /**\n   * Operation: Evaluate the handle at the top of the stack.\n   * Format:\n   *   (InvokeVirtual)\n   * Operand Stack:\n   *   ..., Handle, →\n   *   ...\n   */\n  InvokeVirtual,\n\n  /**\n   * Operation: Evaluate the handle.\n   * Format:\n   *   (InvokeStatic handle:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  InvokeStatic,\n\n  /**\n   * Operation: Yield to a block.\n   * Format:\n   *   (InvokeYield)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments, SymbolTable, Handle →\n   *   ...\n   */\n  InvokeYield,\n\n  /**\n   * Operation: Jump to the specified offset.\n   *\n   * Format:\n   *   (Jump to:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Jump,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is true.\n   *\n   * Format:\n   *   (JumpIf to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpIf,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is false.\n   *\n   * Format:\n   *   (JumpUnless to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpUnless,\n\n  /**\n   * Operation: Push a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   ... →\n   *   $ra, $fp\n   */\n  PushFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   $ra, $fp →\n   *   ...\n   */\n  PopFrame,\n\n  /**\n   * Operation:\n   *   Start tracking a new output block that could change\n   *   if one of its inputs changes.\n   *\n   * Format:\n   *   (Enter args:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   Soon after this opcode, one of Jump, JumpIf,\n   *   or JumpUnless will produce an updating assertion.\n   *   If that assertion fails, the appending VM will\n   *   be re-entered, and the instructions from `from`\n   *   to `to` will be executed.\n   *\n   *   TODO: Save and restore.\n   */\n  Enter,\n\n  /**\n   * Operation:\n   *   Finish tracking the current block.\n   *\n   * Format:\n   *   (Exit)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   This finalizes the validators that the updating\n   *   block must check to determine whether it's safe to\n   *   skip running the contents.\n   */\n  Exit,\n\n  /**\n   * Operation: Convert the top of the stack into a boolean reference.\n   *\n   * Format:\n   *   (ToBoolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<bool>\n   */\n  ToBoolean,\n\n  /// LISTS\n\n  /**\n   * Operation: Enter a list.\n   *\n   * Format:\n   *   (EnterList address:u32)\n   * Operand Stack:\n   *   ..., Iterator →\n   *   ...\n   */\n  EnterList,\n\n  /**\n   * Operation: Exit the current list.\n   *\n   * Format:\n   *   (ExitList)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  ExitList,\n\n  /**\n   * Operation:\n   *   Convert an operand and key into an iterator and\n   *   presence reference.\n   *\n   * Format:\n   *   (PutIterator)\n   * Operand Stack:\n   *   ..., key:string, list:VersionedPathReference →\n   *   ..., iterator:ReferenceIterator, present:PresenceReference\n   */\n  PutIterator,\n\n  /**\n   * Operation:\n   *   Set up the stack for iterating for a given key,\n   *   or jump to `end` if there is nothing left to\n   *   iterate.\n   *\n   * Format:\n   *   (Iterate end:u32)\n   * Operand Stack:\n   *   Form 1: (something to iterate)\n   *   ... →\n   *   ..., VersionedPathReference, VersionedPathReference, string\n   *   Form 2: (nothing left to iterate)\n   *   ... →\n   *   ...\n   * Description:\n   *   In Form 1, the stack will have (in reverse order):\n   *\n   *   - the key, as a string\n   *   - the current iterated value\n   *   - the memoized iterated value\n   */\n  Iterate,\n\n  /// COMPONENTS\n\n  /**\n   * Operation: Test whether a reference contains a component definition.\n   *\n   * Format:\n   *   (IsComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<boolean>\n   */\n  IsComponent,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, TemplateMeta, CapturedArguments }\n   */\n  CurryComponent,\n\n  /**\n   * Operation: Push an appropriate component manager onto the stack.\n   *\n   * Format:\n   *   (PushComponentManager #ComponentSpec)\n   * Operand Stack:\n   *   ... →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushComponentDefinition,\n\n  /**\n   * Operation:\n   *   Push an appropriate component manager onto the stack from\n   *   a runtime-resolved component definition.\n   *\n   * Format:\n   *   (PushDynamicComponentManager templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushDynamicComponentManager,\n\n  /**\n   * Operation: Push a user representation of args onto the stack.\n   *\n   * Format:\n   *   (PushArgs names:#Array<#string> positionalCount:u32 synthetic:#boolean)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...]  →\n   *   ..., [VersionedPathReference ...], Arguments\n   *\n   * Description:\n   *   This arguments object is only necessary when calling into\n   *   user-specified hooks. It is meant to be implemented as a\n   *   transient proxy that reads into the stack as needed.\n   *   Holding onto the Arguments after the call has completed is\n   *   illegal.\n   */\n  PushArgs,\n\n  /**\n   * Operation: Pops Arguments from the stack and clears the next N args.\n   *\n   * Format:\n   *   (PopArgs)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments  →\n   *   ...\n   *\n   * Description:\n   * The arguments object contains the information of how many user\n   * supplied args the component was invoked with. To clear them from\n   * the stack we must pop it from the stack and call `clear` on it\n   * to remove the argument values from the stack.\n   */\n  PopArgs,\n\n  /**\n   * Operation: ...\n   * Format:\n   *   (PrepareArgs state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PrepareArgs,\n\n  /**\n   * Operation: Create the component and push it onto the stack.\n   * Format:\n   *   (CreateComponent flags:u32 state:u32)\n   *   ... →\n   *   ...\n   * Description:\n   * Operand Stack:\n   *   Flags:\n   *\n   *   * 0b001: Has a default block\n   *   * 0b010: Has an inverse block\n   */\n  CreateComponent,\n\n  /**\n   * Operation: Register a destructor for the current component\n   *\n   * Format:\n   *   (RegisterComponentDestructor state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  RegisterComponentDestructor,\n\n  /**\n   * Operation: Push a new ElementOperations for the current component.\n   *\n   * Format:\n   *   (PutComponentOperations)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PutComponentOperations,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentSelf state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetComponentSelf,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentTagName state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., Option<string>\n   */\n  GetComponentTagName,\n\n  /**\n   * Operation: Get the component layout from the manager.\n   *\n   * Format:\n   *   (GetComponentLayout state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., ProgramSymbolTable, Handle\n   */\n  GetComponentLayout,\n\n  /**\n   * Operation: Invoke the layout returned by the manager.\n   *\n   * Format:\n   *   (InvokeComponentLayout)\n   * Operand Stack:\n   *   ..., ProgramSymbolTable, Handle →\n   *   ...\n   */\n  InvokeComponentLayout,\n\n  /**\n   * Operation: Begin a new cache group\n   *\n   * Format:\n   *   (BeginComponentTransaction)\n   * Operand Stack:\n   *   ..., ComponentManager<T>, T →\n   *   ..., ComponentManager<T>, T\n   */\n  BeginComponentTransaction,\n\n  /**\n   * Operation: Commit the current cache group\n   *\n   * Format:\n   *   (CommitComponentTransaction)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CommitComponentTransaction,\n\n  /**\n   * Operation: Invoke didCreateElement on the current component manager\n   *\n   * Format:\n   *   (DidCreateElement state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  DidCreateElement,\n\n  /**\n   * Operation: Invoke didRenderLayout on the current component manager\n   *\n   * Format:\n   *   (DidRenderLayout state:u32)\n   * Operand Stack:\n   *   ..., →\n   *   ...\n   */\n  DidRenderLayout,\n\n  /// PARTIALS\n\n  /**\n   * Operation: Lookup and invoke a partial template.\n   *\n   * Format:\n   *   (InvokePartial templateMeta:#TemplateMeta symbols:#Array<#string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  InvokePartial,\n\n  /**\n   * Operation:\n   *   Resolve {{foo}} inside a partial, which could be either a self-lookup\n   *   or a local variable that is in-scope for the caller.\n   *\n   * Format:\n   *   (ResolveMaybeLocal local:#string)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  ResolveMaybeLocal,\n\n  /// DEBUGGER\n\n  /**\n   * Operation: Activate the debugger\n   *\n   * Format:\n   *   (Debugger symbols:#Array<string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Debugger,\n\n  /** The size of the opcode list */\n  Size\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"opcodes.js","sourceRoot":"","sources":["../../../../packages/@glimmer/vm/lib/opcodes.ts"],"names":[],"mappings":"","sourcesContent":["export const enum Op {\n  /*\n    Documentation TODO:\n\n    Document the local variable layout in the stack\n    diagram before-and-after.\n\n    Document updating opcodes emitting from unreachable\n    append opcode.\n\n    Document the element stack, block stack and List\n    block stack.\n   */\n\n  /**\n   * This opcode should never be reached.\n   */\n  Bug,\n\n  /// EXPRESSIONS\n\n  /**\n   * Operation: Evaluate a Helper.\n   * Format:\n   *   (Helper helper:#Function)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments →\n   *   ..., VersionedPathReference\n   */\n  Helper,\n\n  /**\n   * Operation:\n   *   Bind the variable represented by a symbol from\n   *   the value at the top of the stack.\n   * Format:\n   *   (SetVariable symbol:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  SetVariable,\n\n  /**\n   * Operation:\n   *   Bind the block at the top of the stack.\n   * Format:\n   *   (SetBlock symbol:u32)\n   * Operand Stack:\n   *   ..., SymbolTable, Handle →\n   *   ...\n   */\n  SetBlock,\n\n  /**\n   * Operation:\n   *   Push the contents of the variable represented by\n   *   a symbol (a positional or named argument) onto\n   *   the stack.\n   * Format:\n   *   (PushSymbol symbol:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetVariable,\n\n  /**\n   * Operation:\n   *   Pop a VersionedPathReference from the top of the\n   *   stack, and push a VersionedPathReference constructed\n   *   by `.get(property)`.\n   * Format:\n   *   (GetProperty property:#string)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ..., VersionedPathReference\n   */\n  GetProperty,\n\n  /**\n   * Operation: Push the specified bound block onto the stack.\n   * Format:\n   *   (GetBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., InlineBlock\n   */\n  GetBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound and FALSE if it is not.\n   * Format:\n   *   (HasBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., boolean\n   */\n  HasBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound *and* has at least one specified formal\n   *   parameter, and FALSE otherwise.\n   * Format:\n   *   (HasBlockParams block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference (boolean)\n   */\n  HasBlockParams,\n\n  /**\n   * Operation:\n   *   Pop count `VersionedPathReference`s off the stack and\n   *   construct a new ConcatReference from them (in reverse\n   *   order).\n   * Format:\n   *   (Concat count:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ..., ConcatReference\n   */\n  Concat,\n\n  /**\n   * Operation:\n   *   Push an Object constant onto the stack that is not\n   *   a JavaScript primitive.\n   * Format:\n   *   (PushConstant constant:#Object)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Constant,\n\n  /**\n   * Operation:\n   *   Wrap a JavaScript primitive in a reference and push it\n   *   onto the stack.\n   * Format:\n   *   (PushPrimitive constant:#Primitive)\n   * Operand Stack:\n   *   ... →\n   *   ..., Primitive\n   * Description:\n   *   The two high bits of the constant reference describe\n   *   the kind of primitive:\n   *\n   *   00: number\n   *   01: string\n   *   10: true | false | null | undefined\n   */\n  Primitive,\n\n  /**\n   * Operation: Convert the top of the stack into a primitive reference.\n   *\n   * Format:\n   *   (PrimitiveReference)\n   * Operand Stack:\n   *   ..., Primitive →\n   *   ..., VersionedPathReference<Primitive>\n   */\n  PrimitiveReference,\n\n  /**\n   * Operation: Duplicate and push item from an offset in the stack.\n   * Format:\n   *   (Dup register:u32, offset:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ..., Opaque, Opaque\n   */\n  Dup,\n\n  /**\n   * Operation: Pop N items off the stack and throw away the value.\n   * Format:\n   *   (Pop)\n   * Operand Stack:\n   *   ..., Opaque, ..., Opaque →\n   *   ...\n   */\n  Pop,\n\n  /**\n   * Operation: Load a value into a register\n   * Format:\n   *   (Load register:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ...\n   */\n  Load,\n\n  /**\n   * Operation: Fetch a value from a register\n   * Format:\n   *   (Fetch register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Fetch,\n\n  /// PRELUDE & EXIT\n\n  /**\n   * Operation: Push a new root scope onto the scope stack.\n   *\n   * Format:\n   *   (RootScope symbols:u32 bindCallerScope:bool)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A root scope has no parent scope, and therefore inherits no lexical\n   *   variables. If `bindCallerScope` is `true`, the current scope remembers\n   *   the caller scope (for yielding blocks).\n   */\n  RootScope,\n\n  /**\n   * Operation: Push a new child scope onto the scope stack.\n   *\n   * Format:\n   *   (ChildScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A child scope inherits from the current parent scope, and therefore\n   *   shares its lexical variables.\n   */\n  ChildScope,\n\n  /**\n   * Operation: Pop the current scope from the scope stack.\n   * Format:\n   *   (PopScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PopScope,\n\n  /**\n   * Operation: Return to the previous frame.\n   * Format:\n   *   (Return)\n   * Operand Stack:\n   *   ..., address:number →\n   *   ...\n   */\n  Return,\n\n  /**\n   * Operation: Return to a place in the program given an offset\n   * Format:\n   *  (ReturnTo offset:i32)\n   * Operand Stack:\n   *    ... →\n   */\n  ReturnTo,\n\n  /// HTML\n\n  /**\n   * Operation: Append a Text node with value `contents`\n   * Format:\n   *   (Text contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Text,\n\n  /**\n   * Operation: Append a Comment node with value `contents`\n   * Format:\n   *   (Comment contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Comment,\n\n  /**\n   * Operation: Append a Dynamic node based on .\n   * Format:\n   *   (DynamicContent isTrusting:boolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  DynamicContent,\n\n  /**\n   * Operation: Open a new Element named `tag`.\n   * Format:\n   *   (OpenElement tag:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  OpenElement,\n\n  /**\n   * Operation:\n   *   Open a new Element named `tag` with special operations provided\n   *   on the stack.\n   * Format:\n   *   (OpenElementWithOperations tag:#string)\n   * Operand Stack:\n   *   ..., ElementOperations →\n   *   ...\n   */\n  OpenElementWithOperations,\n\n  /**\n   * Operation:\n   *   Open a new Element with a name on the stack and with special\n   *   operations provided on the stack.\n   * Format:\n   *   (OpenDynamicElement)\n   * Operand Stack:\n   *   ..., string, ElementOperations →\n   *   ...\n   */\n  OpenDynamicElement,\n\n  /**\n   * Operation: Add an attribute to the current Element.\n   * Format:\n   *   (StaticAttr name:#string value:#string namespace:Option<#string>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  StaticAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (DynamicAttr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   * Description:\n   *   If `trusting` is false, the host may sanitize the attribute\n   *   based upon known risks.\n   */\n  DynamicAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (ComponentAtr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  ComponentAttr,\n\n  /**\n   * Operation: Finish setting attributes on the current element.\n   *\n   * Format:\n   *   (FlushElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  FlushElement,\n\n  /**\n   * Operation: Close the current element.\n   *\n   * Format:\n   *   (CloseElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CloseElement,\n\n  /// MODIFIER\n  Modifier,                  // (ConstantString, ConstantOther<ModifierManager>, ConstantExpression)\n\n  /// WORMHOLE\n  PushRemoteElement,         // ()\n  PopRemoteElement,          // ()\n\n  /// DYNAMIC SCOPE\n\n  /**\n   * Operation: Bind stack values as dynamic variables.\n   * Format:\n   *   (BindDynamicScope names:#Array<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ...\n   * Description:\n   *   This is used to expose `-with-dynamic-vars`, and is a\n   *   niche feature.\n   */\n  BindDynamicScope,\n\n  PushDynamicScope,          // ()\n  PopDynamicScope,           // ()\n\n  /// VM\n\n  /**\n   * Operation: Compile the InlineBlock at the top of the stack.\n   * Format:\n   *   (CompileBlock)\n   * Operand Stack:\n   *   ..., CompilableBlock →\n   *   ..., Handle\n   */\n  CompileBlock,\n\n  /**\n   * Operation: Push a scope onto the stack.\n   * Format:\n   *   (PushBlockScope #Scope)\n   * Operand Stack:\n   *   ..., →\n   *   ..., Scope\n   */\n  PushBlockScope,\n\n  /**\n   * Operation: Push a symbol table onto the stack.\n   * Format:\n   *   (PushSymbolTable #SymbolTable)\n   * Operand Stack:\n   *   ..., →\n   *   ..., SymbolTable\n   */\n  PushSymbolTable,\n\n  /**\n   * Operation: Evaluate the handle at the top of the stack.\n   * Format:\n   *   (InvokeVirtual)\n   * Operand Stack:\n   *   ..., Handle, →\n   *   ...\n   */\n  InvokeVirtual,\n\n  /**\n   * Operation: Evaluate the handle.\n   * Format:\n   *   (InvokeStatic handle:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  InvokeStatic,\n\n  /**\n   * Operation: Yield to a block.\n   * Format:\n   *   (InvokeYield)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments, SymbolTable, Handle →\n   *   ...\n   */\n  InvokeYield,\n\n  /**\n   * Operation: Jump to the specified offset.\n   *\n   * Format:\n   *   (Jump to:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Jump,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is true.\n   *\n   * Format:\n   *   (JumpIf to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpIf,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is false.\n   *\n   * Format:\n   *   (JumpUnless to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpUnless,\n\n  /**\n   * Operation: Push a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   ... →\n   *   $ra, $fp\n   */\n  PushFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   $ra, $fp →\n   *   ...\n   */\n  PopFrame,\n\n  /**\n   * Operation:\n   *   Start tracking a new output block that could change\n   *   if one of its inputs changes.\n   *\n   * Format:\n   *   (Enter args:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   Soon after this opcode, one of Jump, JumpIf,\n   *   or JumpUnless will produce an updating assertion.\n   *   If that assertion fails, the appending VM will\n   *   be re-entered, and the instructions from `from`\n   *   to `to` will be executed.\n   *\n   *   TODO: Save and restore.\n   */\n  Enter,\n\n  /**\n   * Operation:\n   *   Finish tracking the current block.\n   *\n   * Format:\n   *   (Exit)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   This finalizes the validators that the updating\n   *   block must check to determine whether it's safe to\n   *   skip running the contents.\n   */\n  Exit,\n\n  /**\n   * Operation: Convert the top of the stack into a boolean reference.\n   *\n   * Format:\n   *   (ToBoolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<bool>\n   */\n  ToBoolean,\n\n  /// LISTS\n\n  /**\n   * Operation: Enter a list.\n   *\n   * Format:\n   *   (EnterList address:u32)\n   * Operand Stack:\n   *   ..., Iterator →\n   *   ...\n   */\n  EnterList,\n\n  /**\n   * Operation: Exit the current list.\n   *\n   * Format:\n   *   (ExitList)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  ExitList,\n\n  /**\n   * Operation:\n   *   Convert an operand and key into an iterator and\n   *   presence reference.\n   *\n   * Format:\n   *   (PutIterator)\n   * Operand Stack:\n   *   ..., key:string, list:VersionedPathReference →\n   *   ..., iterator:ReferenceIterator, present:PresenceReference\n   */\n  PutIterator,\n\n  /**\n   * Operation:\n   *   Set up the stack for iterating for a given key,\n   *   or jump to `end` if there is nothing left to\n   *   iterate.\n   *\n   * Format:\n   *   (Iterate end:u32)\n   * Operand Stack:\n   *   Form 1: (something to iterate)\n   *   ... →\n   *   ..., VersionedPathReference, VersionedPathReference, string\n   *   Form 2: (nothing left to iterate)\n   *   ... →\n   *   ...\n   * Description:\n   *   In Form 1, the stack will have (in reverse order):\n   *\n   *   - the key, as a string\n   *   - the current iterated value\n   *   - the memoized iterated value\n   */\n  Iterate,\n\n  /// COMPONENTS\n\n  /**\n   * Operation: Test whether a reference contains a component definition.\n   *\n   * Format:\n   *   (Main state:register)\n   * Operand Stack:\n   *   ..., Invocation, ComponentDefinition →\n   *   ...\n   */\n  Main,\n\n  /**\n   * Operation: Test whether a reference contains a component definition.\n   *\n   * Format:\n   *   (IsComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<boolean>\n   */\n  IsComponent,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, TemplateMeta, CapturedArguments }\n   */\n  CurryComponent,\n\n  /**\n   * Operation: Push an appropriate component manager onto the stack.\n   *\n   * Format:\n   *   (PushComponentManager #ComponentSpec)\n   * Operand Stack:\n   *   ... →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushComponentDefinition,\n\n  /**\n   * Operation:\n   *   Push an appropriate component manager onto the stack from\n   *   a runtime-resolved component definition.\n   *\n   * Format:\n   *   (PushDynamicComponentManager templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushDynamicComponentManager,\n\n  /**\n   * Operation: Push a user representation of args onto the stack.\n   *\n   * Format:\n   *   (PushArgs names:#Array<#string> positionalCount:u32 synthetic:#boolean)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...]  →\n   *   ..., [VersionedPathReference ...], Arguments\n   *\n   * Description:\n   *   This arguments object is only necessary when calling into\n   *   user-specified hooks. It is meant to be implemented as a\n   *   transient proxy that reads into the stack as needed.\n   *   Holding onto the Arguments after the call has completed is\n   *   illegal.\n   */\n  PushArgs,\n\n  /**\n   * Operation: Pops Arguments from the stack and clears the next N args.\n   *\n   * Format:\n   *   (PopArgs)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments  →\n   *   ...\n   *\n   * Description:\n   * The arguments object contains the information of how many user\n   * supplied args the component was invoked with. To clear them from\n   * the stack we must pop it from the stack and call `clear` on it\n   * to remove the argument values from the stack.\n   */\n  PopArgs,\n\n  /**\n   * Operation: ...\n   * Format:\n   *   (PrepareArgs state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PrepareArgs,\n\n  /**\n   * Operation: Create the component and push it onto the stack.\n   * Format:\n   *   (CreateComponent flags:u32 state:register)\n   *   ... →\n   *   ...\n   * Description:\n   * Operand Stack:\n   *   Flags:\n   *\n   *   * 0b001: Has a default block\n   *   * 0b010: Has an inverse block\n   */\n  CreateComponent,\n\n  /**\n   * Operation: Register a destructor for the current component\n   *\n   * Format:\n   *   (RegisterComponentDestructor state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  RegisterComponentDestructor,\n\n  /**\n   * Operation: Push a new ElementOperations for the current component.\n   *\n   * Format:\n   *   (PutComponentOperations)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PutComponentOperations,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentSelf state:register)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetComponentSelf,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentTagName state:register)\n   * Operand Stack:\n   *   ... →\n   *   ..., Option<string>\n   */\n  GetComponentTagName,\n\n  /**\n   * Operation: Get the component layout from the manager.\n   *\n   * Format:\n   *   (GetComponentLayout state:register)\n   * Operand Stack:\n   *   ... →\n   *   ..., ProgramSymbolTable, Handle\n   */\n  GetComponentLayout,\n\n  /**\n   * Operation:\n   *   Populate the state register with the layout currently\n   *   on the stack.\n   *\n   * Format:\n   *   (PopulateLayout state:register)\n   * Operand Stack:\n   *   ..., ProgramSymbolTable, Handle →\n   *   ...\n   */\n  PopulateLayout,\n\n  /**\n   * Operation: Invoke the layout returned by the manager.\n   *\n   * Format:\n   *   (InvokeComponentLayout state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  InvokeComponentLayout,\n\n  /**\n   * Operation: Begin a new cache group\n   *\n   * Format:\n   *   (BeginComponentTransaction)\n   * Operand Stack:\n   *   ..., ComponentManager<T>, T →\n   *   ..., ComponentManager<T>, T\n   */\n  BeginComponentTransaction,\n\n  /**\n   * Operation: Commit the current cache group\n   *\n   * Format:\n   *   (CommitComponentTransaction)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CommitComponentTransaction,\n\n  /**\n   * Operation: Invoke didCreateElement on the current component manager\n   *\n   * Format:\n   *   (DidCreateElement state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  DidCreateElement,\n\n  /**\n   * Operation: Invoke didRenderLayout on the current component manager\n   *\n   * Format:\n   *   (DidRenderLayout state:register)\n   * Operand Stack:\n   *   ..., →\n   *   ...\n   */\n  DidRenderLayout,\n\n  /// PARTIALS\n\n  /**\n   * Operation: Lookup and invoke a partial template.\n   *\n   * Format:\n   *   (InvokePartial templateMeta:#TemplateMeta symbols:#Array<#string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  InvokePartial,\n\n  /**\n   * Operation:\n   *   Resolve {{foo}} inside a partial, which could be either a self-lookup\n   *   or a local variable that is in-scope for the caller.\n   *\n   * Format:\n   *   (ResolveMaybeLocal local:#string)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  ResolveMaybeLocal,\n\n  /// DEBUGGER\n\n  /**\n   * Operation: Activate the debugger\n   *\n   * Format:\n   *   (Debugger symbols:#Array<string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Debugger,\n\n  /** The size of the opcode list */\n  Size\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"opcodes.js","sourceRoot":"","sources":["../../../../packages/@glimmer/vm/lib/opcodes.ts"],"names":[],"mappings":"","sourcesContent":["export const enum Op {\n  /*\n    Documentation TODO:\n\n    Document the local variable layout in the stack\n    diagram before-and-after.\n\n    Document updating opcodes emitting from unreachable\n    append opcode.\n\n    Document the element stack, block stack and List\n    block stack.\n   */\n\n  /**\n   * This opcode should never be reached.\n   */\n  Bug,\n\n  /// EXPRESSIONS\n\n  /**\n   * Operation: Evaluate a Helper.\n   * Format:\n   *   (Helper helper:#Function)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments →\n   *   ..., VersionedPathReference\n   */\n  Helper,\n\n  /**\n   * Operation:\n   *   Bind the variable represented by a symbol from\n   *   the value at the top of the stack.\n   * Format:\n   *   (SetVariable symbol:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  SetVariable,\n\n  /**\n   * Operation:\n   *   Bind the block at the top of the stack.\n   * Format:\n   *   (SetBlock symbol:u32)\n   * Operand Stack:\n   *   ..., SymbolTable, Handle →\n   *   ...\n   */\n  SetBlock,\n\n  /**\n   * Operation:\n   *   Push the contents of the variable represented by\n   *   a symbol (a positional or named argument) onto\n   *   the stack.\n   * Format:\n   *   (PushSymbol symbol:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetVariable,\n\n  /**\n   * Operation:\n   *   Pop a VersionedPathReference from the top of the\n   *   stack, and push a VersionedPathReference constructed\n   *   by `.get(property)`.\n   * Format:\n   *   (GetProperty property:#string)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ..., VersionedPathReference\n   */\n  GetProperty,\n\n  /**\n   * Operation: Push the specified bound block onto the stack.\n   * Format:\n   *   (GetBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., InlineBlock\n   */\n  GetBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound and FALSE if it is not.\n   * Format:\n   *   (HasBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., boolean\n   */\n  HasBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound *and* has at least one specified formal\n   *   parameter, and FALSE otherwise.\n   * Format:\n   *   (HasBlockParams block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference (boolean)\n   */\n  HasBlockParams,\n\n  /**\n   * Operation:\n   *   Pop count `VersionedPathReference`s off the stack and\n   *   construct a new ConcatReference from them (in reverse\n   *   order).\n   * Format:\n   *   (Concat count:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ..., ConcatReference\n   */\n  Concat,\n\n  /**\n   * Operation:\n   *   Push an Object constant onto the stack that is not\n   *   a JavaScript primitive.\n   * Format:\n   *   (PushConstant constant:#Object)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Constant,\n\n  /**\n   * Operation:\n   *   Wrap a JavaScript primitive in a reference and push it\n   *   onto the stack.\n   * Format:\n   *   (PushPrimitive constant:#Primitive)\n   * Operand Stack:\n   *   ... →\n   *   ..., Primitive\n   * Description:\n   *   The two high bits of the constant reference describe\n   *   the kind of primitive:\n   *\n   *   00: number\n   *   01: string\n   *   10: true | false | null | undefined\n   */\n  Primitive,\n\n  /**\n   * Operation: Convert the top of the stack into a primitive reference.\n   *\n   * Format:\n   *   (PrimitiveReference)\n   * Operand Stack:\n   *   ..., Primitive →\n   *   ..., VersionedPathReference<Primitive>\n   */\n  PrimitiveReference,\n\n  /**\n   * Operation: Duplicate and push item from an offset in the stack.\n   * Format:\n   *   (Dup register:u32, offset:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ..., Opaque, Opaque\n   */\n  Dup,\n\n  /**\n   * Operation: Pop N items off the stack and throw away the value.\n   * Format:\n   *   (Pop)\n   * Operand Stack:\n   *   ..., Opaque, ..., Opaque →\n   *   ...\n   */\n  Pop,\n\n  /**\n   * Operation: Load a value into a register\n   * Format:\n   *   (Load register:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ...\n   */\n  Load,\n\n  /**\n   * Operation: Fetch a value from a register\n   * Format:\n   *   (Fetch register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Fetch,\n\n  /// PRELUDE & EXIT\n\n  /**\n   * Operation: Push a new root scope onto the scope stack.\n   *\n   * Format:\n   *   (RootScope symbols:u32 bindCallerScope:bool)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A root scope has no parent scope, and therefore inherits no lexical\n   *   variables. If `bindCallerScope` is `true`, the current scope remembers\n   *   the caller scope (for yielding blocks).\n   */\n  RootScope,\n\n  /**\n   * Operation: Push a new child scope onto the scope stack.\n   *\n   * Format:\n   *   (ChildScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A child scope inherits from the current parent scope, and therefore\n   *   shares its lexical variables.\n   */\n  ChildScope,\n\n  /**\n   * Operation: Pop the current scope from the scope stack.\n   * Format:\n   *   (PopScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PopScope,\n\n  /**\n   * Operation: Return to the previous frame.\n   * Format:\n   *   (Return)\n   * Operand Stack:\n   *   ..., address:number →\n   *   ...\n   */\n  Return,\n\n  /**\n   * Operation: Return to a place in the program given an offset\n   * Format:\n   *  (ReturnTo offset:i32)\n   * Operand Stack:\n   *    ... →\n   */\n  ReturnTo,\n\n  /// HTML\n\n  /**\n   * Operation: Append a Text node with value `contents`\n   * Format:\n   *   (Text contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Text,\n\n  /**\n   * Operation: Append a Comment node with value `contents`\n   * Format:\n   *   (Comment contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Comment,\n\n  /**\n   * Operation: Append a Dynamic node based on .\n   * Format:\n   *   (DynamicContent isTrusting:boolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  DynamicContent,\n\n  /**\n   * Operation: Open a new Element named `tag`.\n   * Format:\n   *   (OpenElement tag:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  OpenElement,\n\n  /**\n   * Operation:\n   *   Open a new Element named `tag` with special operations provided\n   *   on the stack.\n   * Format:\n   *   (OpenElementWithOperations tag:#string)\n   * Operand Stack:\n   *   ..., ElementOperations →\n   *   ...\n   */\n  OpenElementWithOperations,\n\n  /**\n   * Operation:\n   *   Open a new Element with a name on the stack and with special\n   *   operations provided on the stack.\n   * Format:\n   *   (OpenDynamicElement)\n   * Operand Stack:\n   *   ..., string, ElementOperations →\n   *   ...\n   */\n  OpenDynamicElement,\n\n  /**\n   * Operation: Add an attribute to the current Element.\n   * Format:\n   *   (StaticAttr name:#string value:#string namespace:Option<#string>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  StaticAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (DynamicAttr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   * Description:\n   *   If `trusting` is false, the host may sanitize the attribute\n   *   based upon known risks.\n   */\n  DynamicAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (ComponentAtr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  ComponentAttr,\n\n  /**\n   * Operation: Finish setting attributes on the current element.\n   *\n   * Format:\n   *   (FlushElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  FlushElement,\n\n  /**\n   * Operation: Close the current element.\n   *\n   * Format:\n   *   (CloseElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CloseElement,\n\n  /// MODIFIER\n  Modifier,                  // (ConstantString, ConstantOther<ModifierManager>, ConstantExpression)\n\n  /// WORMHOLE\n  PushRemoteElement,         // ()\n  PopRemoteElement,          // ()\n\n  /// DYNAMIC SCOPE\n\n  /**\n   * Operation: Bind stack values as dynamic variables.\n   * Format:\n   *   (BindDynamicScope names:#Array<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ...\n   * Description:\n   *   This is used to expose `-with-dynamic-vars`, and is a\n   *   niche feature.\n   */\n  BindDynamicScope,\n\n  PushDynamicScope,          // ()\n  PopDynamicScope,           // ()\n\n  /// VM\n\n  /**\n   * Operation: Compile the InlineBlock at the top of the stack.\n   * Format:\n   *   (CompileBlock)\n   * Operand Stack:\n   *   ..., CompilableBlock →\n   *   ..., Handle\n   */\n  CompileBlock,\n\n  /**\n   * Operation: Push a scope onto the stack.\n   * Format:\n   *   (PushBlockScope #Scope)\n   * Operand Stack:\n   *   ..., →\n   *   ..., Scope\n   */\n  PushBlockScope,\n\n  /**\n   * Operation: Push a symbol table onto the stack.\n   * Format:\n   *   (PushSymbolTable #SymbolTable)\n   * Operand Stack:\n   *   ..., →\n   *   ..., SymbolTable\n   */\n  PushSymbolTable,\n\n  /**\n   * Operation: Evaluate the handle at the top of the stack.\n   * Format:\n   *   (InvokeVirtual)\n   * Operand Stack:\n   *   ..., Handle, →\n   *   ...\n   */\n  InvokeVirtual,\n\n  /**\n   * Operation: Evaluate the handle.\n   * Format:\n   *   (InvokeStatic handle:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  InvokeStatic,\n\n  /**\n   * Operation: Yield to a block.\n   * Format:\n   *   (InvokeYield)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments, SymbolTable, Handle →\n   *   ...\n   */\n  InvokeYield,\n\n  /**\n   * Operation: Jump to the specified offset.\n   *\n   * Format:\n   *   (Jump to:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Jump,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is true.\n   *\n   * Format:\n   *   (JumpIf to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpIf,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is false.\n   *\n   * Format:\n   *   (JumpUnless to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpUnless,\n\n  /**\n   * Operation: Push a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   ... →\n   *   $ra, $fp\n   */\n  PushFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   $ra, $fp →\n   *   ...\n   */\n  PopFrame,\n\n  /**\n   * Operation:\n   *   Start tracking a new output block that could change\n   *   if one of its inputs changes.\n   *\n   * Format:\n   *   (Enter args:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   Soon after this opcode, one of Jump, JumpIf,\n   *   or JumpUnless will produce an updating assertion.\n   *   If that assertion fails, the appending VM will\n   *   be re-entered, and the instructions from `from`\n   *   to `to` will be executed.\n   *\n   *   TODO: Save and restore.\n   */\n  Enter,\n\n  /**\n   * Operation:\n   *   Finish tracking the current block.\n   *\n   * Format:\n   *   (Exit)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   This finalizes the validators that the updating\n   *   block must check to determine whether it's safe to\n   *   skip running the contents.\n   */\n  Exit,\n\n  /**\n   * Operation: Convert the top of the stack into a boolean reference.\n   *\n   * Format:\n   *   (ToBoolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<bool>\n   */\n  ToBoolean,\n\n  /// LISTS\n\n  /**\n   * Operation: Enter a list.\n   *\n   * Format:\n   *   (EnterList address:u32)\n   * Operand Stack:\n   *   ..., Iterator →\n   *   ...\n   */\n  EnterList,\n\n  /**\n   * Operation: Exit the current list.\n   *\n   * Format:\n   *   (ExitList)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  ExitList,\n\n  /**\n   * Operation:\n   *   Convert an operand and key into an iterator and\n   *   presence reference.\n   *\n   * Format:\n   *   (PutIterator)\n   * Operand Stack:\n   *   ..., key:string, list:VersionedPathReference →\n   *   ..., iterator:ReferenceIterator, present:PresenceReference\n   */\n  PutIterator,\n\n  /**\n   * Operation:\n   *   Set up the stack for iterating for a given key,\n   *   or jump to `end` if there is nothing left to\n   *   iterate.\n   *\n   * Format:\n   *   (Iterate end:u32)\n   * Operand Stack:\n   *   Form 1: (something to iterate)\n   *   ... →\n   *   ..., VersionedPathReference, VersionedPathReference, string\n   *   Form 2: (nothing left to iterate)\n   *   ... →\n   *   ...\n   * Description:\n   *   In Form 1, the stack will have (in reverse order):\n   *\n   *   - the key, as a string\n   *   - the current iterated value\n   *   - the memoized iterated value\n   */\n  Iterate,\n\n  /// COMPONENTS\n\n  /**\n   * Operation: Test whether a reference contains a component definition.\n   *\n   * Format:\n   *   (IsComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<boolean>\n   */\n  IsComponent,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, TemplateMeta, CapturedArguments }\n   */\n  CurryComponent,\n\n  /**\n   * Operation: Push an appropriate component manager onto the stack.\n   *\n   * Format:\n   *   (PushComponentManager #ComponentSpec)\n   * Operand Stack:\n   *   ... →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushComponentDefinition,\n\n  /**\n   * Operation:\n   *   Push an appropriate component manager onto the stack from\n   *   a runtime-resolved component definition.\n   *\n   * Format:\n   *   (PushDynamicComponentManager templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushDynamicComponentManager,\n\n  /**\n   * Operation: Push a user representation of args onto the stack.\n   *\n   * Format:\n   *   (PushArgs names:#Array<#string> positionalCount:u32 synthetic:#boolean)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...]  →\n   *   ..., [VersionedPathReference ...], Arguments\n   *\n   * Description:\n   *   This arguments object is only necessary when calling into\n   *   user-specified hooks. It is meant to be implemented as a\n   *   transient proxy that reads into the stack as needed.\n   *   Holding onto the Arguments after the call has completed is\n   *   illegal.\n   */\n  PushArgs,\n\n  /**\n   * Operation: Pops Arguments from the stack and clears the next N args.\n   *\n   * Format:\n   *   (PopArgs)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments  →\n   *   ...\n   *\n   * Description:\n   * The arguments object contains the information of how many user\n   * supplied args the component was invoked with. To clear them from\n   * the stack we must pop it from the stack and call `clear` on it\n   * to remove the argument values from the stack.\n   */\n  PopArgs,\n\n  /**\n   * Operation: ...\n   * Format:\n   *   (PrepareArgs state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PrepareArgs,\n\n  /**\n   * Operation: Create the component and push it onto the stack.\n   * Format:\n   *   (CreateComponent flags:u32 state:u32)\n   *   ... →\n   *   ...\n   * Description:\n   * Operand Stack:\n   *   Flags:\n   *\n   *   * 0b001: Has a default block\n   *   * 0b010: Has an inverse block\n   */\n  CreateComponent,\n\n  /**\n   * Operation: Register a destructor for the current component\n   *\n   * Format:\n   *   (RegisterComponentDestructor state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  RegisterComponentDestructor,\n\n  /**\n   * Operation: Push a new ElementOperations for the current component.\n   *\n   * Format:\n   *   (PutComponentOperations)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PutComponentOperations,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentSelf state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetComponentSelf,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentTagName state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., Option<string>\n   */\n  GetComponentTagName,\n\n  /**\n   * Operation: Get the component layout from the manager.\n   *\n   * Format:\n   *   (GetComponentLayout state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., ProgramSymbolTable, Handle\n   */\n  GetComponentLayout,\n\n  /**\n   * Operation: Invoke the layout returned by the manager.\n   *\n   * Format:\n   *   (InvokeComponentLayout)\n   * Operand Stack:\n   *   ..., ProgramSymbolTable, Handle →\n   *   ...\n   */\n  InvokeComponentLayout,\n\n  /**\n   * Operation: Begin a new cache group\n   *\n   * Format:\n   *   (BeginComponentTransaction)\n   * Operand Stack:\n   *   ..., ComponentManager<T>, T →\n   *   ..., ComponentManager<T>, T\n   */\n  BeginComponentTransaction,\n\n  /**\n   * Operation: Commit the current cache group\n   *\n   * Format:\n   *   (CommitComponentTransaction)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CommitComponentTransaction,\n\n  /**\n   * Operation: Invoke didCreateElement on the current component manager\n   *\n   * Format:\n   *   (DidCreateElement state:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  DidCreateElement,\n\n  /**\n   * Operation: Invoke didRenderLayout on the current component manager\n   *\n   * Format:\n   *   (DidRenderLayout state:u32)\n   * Operand Stack:\n   *   ..., →\n   *   ...\n   */\n  DidRenderLayout,\n\n  /// PARTIALS\n\n  /**\n   * Operation: Lookup and invoke a partial template.\n   *\n   * Format:\n   *   (InvokePartial templateMeta:#TemplateMeta symbols:#Array<#string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  InvokePartial,\n\n  /**\n   * Operation:\n   *   Resolve {{foo}} inside a partial, which could be either a self-lookup\n   *   or a local variable that is in-scope for the caller.\n   *\n   * Format:\n   *   (ResolveMaybeLocal local:#string)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  ResolveMaybeLocal,\n\n  /// DEBUGGER\n\n  /**\n   * Operation: Activate the debugger\n   *\n   * Format:\n   *   (Debugger symbols:#Array<string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Debugger,\n\n  /** The size of the opcode list */\n  Size\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"opcodes.js","sourceRoot":"","sources":["../../../../packages/@glimmer/vm/lib/opcodes.ts"],"names":[],"mappings":"","sourcesContent":["export const enum Op {\n  /*\n    Documentation TODO:\n\n    Document the local variable layout in the stack\n    diagram before-and-after.\n\n    Document updating opcodes emitting from unreachable\n    append opcode.\n\n    Document the element stack, block stack and List\n    block stack.\n   */\n\n  /**\n   * This opcode should never be reached.\n   */\n  Bug,\n\n  /// EXPRESSIONS\n\n  /**\n   * Operation: Evaluate a Helper.\n   * Format:\n   *   (Helper helper:#Function)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments →\n   *   ..., VersionedPathReference\n   */\n  Helper,\n\n  /**\n   * Operation:\n   *   Bind the variable represented by a symbol from\n   *   the value at the top of the stack.\n   * Format:\n   *   (SetVariable symbol:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  SetVariable,\n\n  /**\n   * Operation:\n   *   Bind the block at the top of the stack.\n   * Format:\n   *   (SetBlock symbol:u32)\n   * Operand Stack:\n   *   ..., SymbolTable, Handle →\n   *   ...\n   */\n  SetBlock,\n\n  /**\n   * Operation:\n   *   Push the contents of the variable represented by\n   *   a symbol (a positional or named argument) onto\n   *   the stack.\n   * Format:\n   *   (PushSymbol symbol:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetVariable,\n\n  /**\n   * Operation:\n   *   Pop a VersionedPathReference from the top of the\n   *   stack, and push a VersionedPathReference constructed\n   *   by `.get(property)`.\n   * Format:\n   *   (GetProperty property:#string)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ..., VersionedPathReference\n   */\n  GetProperty,\n\n  /**\n   * Operation: Push the specified bound block onto the stack.\n   * Format:\n   *   (GetBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., InlineBlock\n   */\n  GetBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound and FALSE if it is not.\n   * Format:\n   *   (HasBlock block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., boolean\n   */\n  HasBlock,\n\n  /**\n   * Operation:\n   *   Push TRUE onto the stack if the specified block\n   *   is bound *and* has at least one specified formal\n   *   parameter, and FALSE otherwise.\n   * Format:\n   *   (HasBlockParams block:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference (boolean)\n   */\n  HasBlockParams,\n\n  /**\n   * Operation:\n   *   Pop count `VersionedPathReference`s off the stack and\n   *   construct a new ConcatReference from them (in reverse\n   *   order).\n   * Format:\n   *   (Concat count:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ..., ConcatReference\n   */\n  Concat,\n\n  /**\n   * Operation:\n   *   Push an Object constant onto the stack that is not\n   *   a JavaScript primitive.\n   * Format:\n   *   (PushConstant constant:#Object)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Constant,\n\n  /**\n   * Operation:\n   *   Wrap a JavaScript primitive in a reference and push it\n   *   onto the stack.\n   * Format:\n   *   (PushPrimitive constant:#Primitive)\n   * Operand Stack:\n   *   ... →\n   *   ..., Primitive\n   * Description:\n   *   The two high bits of the constant reference describe\n   *   the kind of primitive:\n   *\n   *   00: number\n   *   01: string\n   *   10: true | false | null | undefined\n   */\n  Primitive,\n\n  /**\n   * Operation: Convert the top of the stack into a primitive reference.\n   *\n   * Format:\n   *   (PrimitiveReference)\n   * Operand Stack:\n   *   ..., Primitive →\n   *   ..., VersionedPathReference<Primitive>\n   */\n  PrimitiveReference,\n\n  /**\n   * Operation: Duplicate and push item from an offset in the stack.\n   * Format:\n   *   (Dup register:u32, offset:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ..., Opaque, Opaque\n   */\n  Dup,\n\n  /**\n   * Operation: Pop N items off the stack and throw away the value.\n   * Format:\n   *   (Pop)\n   * Operand Stack:\n   *   ..., Opaque, ..., Opaque →\n   *   ...\n   */\n  Pop,\n\n  /**\n   * Operation: Load a value into a register\n   * Format:\n   *   (Load register:u32)\n   * Operand Stack:\n   *   ..., Opaque →\n   *   ...\n   */\n  Load,\n\n  /**\n   * Operation: Fetch a value from a register\n   * Format:\n   *   (Fetch register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ..., Opaque\n   */\n  Fetch,\n\n  /// PRELUDE & EXIT\n\n  /**\n   * Operation: Push a new root scope onto the scope stack.\n   *\n   * Format:\n   *   (RootScope symbols:u32 bindCallerScope:bool)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A root scope has no parent scope, and therefore inherits no lexical\n   *   variables. If `bindCallerScope` is `true`, the current scope remembers\n   *   the caller scope (for yielding blocks).\n   */\n  RootScope,\n\n  /**\n   * Operation: Push a new child scope onto the scope stack.\n   *\n   * Format:\n   *   (ChildScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   A child scope inherits from the current parent scope, and therefore\n   *   shares its lexical variables.\n   */\n  ChildScope,\n\n  /**\n   * Operation: Pop the current scope from the scope stack.\n   * Format:\n   *   (PopScope)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PopScope,\n\n  /**\n   * Operation: Return to the previous frame.\n   * Format:\n   *   (Return)\n   * Operand Stack:\n   *   ..., address:number →\n   *   ...\n   */\n  Return,\n\n  /**\n   * Operation: Return to a place in the program given an offset\n   * Format:\n   *  (ReturnTo offset:i32)\n   * Operand Stack:\n   *    ... →\n   */\n  ReturnTo,\n\n  /// HTML\n\n  /**\n   * Operation: Append a Text node with value `contents`\n   * Format:\n   *   (Text contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Text,\n\n  /**\n   * Operation: Append a Comment node with value `contents`\n   * Format:\n   *   (Comment contents:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Comment,\n\n  /**\n   * Operation: Append a Dynamic node based on .\n   * Format:\n   *   (DynamicContent isTrusting:boolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  DynamicContent,\n\n  /**\n   * Operation: Open a new Element named `tag`.\n   * Format:\n   *   (OpenElement tag:#string)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  OpenElement,\n\n  /**\n   * Operation:\n   *   Open a new Element named `tag` with special operations provided\n   *   on the stack.\n   * Format:\n   *   (OpenElementWithOperations tag:#string)\n   * Operand Stack:\n   *   ..., ElementOperations →\n   *   ...\n   */\n  OpenElementWithOperations,\n\n  /**\n   * Operation:\n   *   Open a new Element with a name on the stack and with special\n   *   operations provided on the stack.\n   * Format:\n   *   (OpenDynamicElement)\n   * Operand Stack:\n   *   ..., string, ElementOperations →\n   *   ...\n   */\n  OpenDynamicElement,\n\n  /**\n   * Operation: Add an attribute to the current Element.\n   * Format:\n   *   (StaticAttr name:#string value:#string namespace:Option<#string>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  StaticAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (DynamicAttr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   * Description:\n   *   If `trusting` is false, the host may sanitize the attribute\n   *   based upon known risks.\n   */\n  DynamicAttr,\n\n  /**\n   * Operation:\n   *   Add an attribute to the current element using the value\n   *   at the top of the stack.\n   *\n   * Format:\n   *   (ComponentAtr name:#string trusting:boolean namespace:Option<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  ComponentAttr,\n\n  /**\n   * Operation: Finish setting attributes on the current element.\n   *\n   * Format:\n   *   (FlushElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  FlushElement,\n\n  /**\n   * Operation: Close the current element.\n   *\n   * Format:\n   *   (CloseElement)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CloseElement,\n\n  /// MODIFIER\n  Modifier,                  // (ConstantString, ConstantOther<ModifierManager>, ConstantExpression)\n\n  /// WORMHOLE\n  PushRemoteElement,         // ()\n  PopRemoteElement,          // ()\n\n  /// DYNAMIC SCOPE\n\n  /**\n   * Operation: Bind stack values as dynamic variables.\n   * Format:\n   *   (BindDynamicScope names:#Array<#string>)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...] →\n   *   ...\n   * Description:\n   *   This is used to expose `-with-dynamic-vars`, and is a\n   *   niche feature.\n   */\n  BindDynamicScope,\n\n  PushDynamicScope,          // ()\n  PopDynamicScope,           // ()\n\n  /// VM\n\n  /**\n   * Operation: Compile the InlineBlock at the top of the stack.\n   * Format:\n   *   (CompileBlock)\n   * Operand Stack:\n   *   ..., CompilableBlock →\n   *   ..., Handle\n   */\n  CompileBlock,\n\n  /**\n   * Operation: Push a scope onto the stack.\n   * Format:\n   *   (PushBlockScope #Scope)\n   * Operand Stack:\n   *   ..., →\n   *   ..., Scope\n   */\n  PushBlockScope,\n\n  /**\n   * Operation: Push a symbol table onto the stack.\n   * Format:\n   *   (PushSymbolTable #SymbolTable)\n   * Operand Stack:\n   *   ..., →\n   *   ..., SymbolTable\n   */\n  PushSymbolTable,\n\n  /**\n   * Operation: Evaluate the handle at the top of the stack.\n   * Format:\n   *   (InvokeVirtual)\n   * Operand Stack:\n   *   ..., Handle, →\n   *   ...\n   */\n  InvokeVirtual,\n\n  /**\n   * Operation: Evaluate the handle.\n   * Format:\n   *   (InvokeStatic handle:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  InvokeStatic,\n\n  /**\n   * Operation: Yield to a block.\n   * Format:\n   *   (InvokeYield)\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments, SymbolTable, Handle →\n   *   ...\n   */\n  InvokeYield,\n\n  /**\n   * Operation: Jump to the specified offset.\n   *\n   * Format:\n   *   (Jump to:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Jump,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is true.\n   *\n   * Format:\n   *   (JumpIf to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpIf,\n\n  /**\n   * Operation:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is false.\n   *\n   * Format:\n   *   (JumpUnless to:u32)\n   * Operand Stack:\n   *   ..., VersionedPathReference →\n   *   ...\n   */\n  JumpUnless,\n\n  /**\n   * Operation: Push a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   ... →\n   *   $ra, $fp\n   */\n  PushFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PushFrame)\n   * Operand Stack:\n   *   $ra, $fp →\n   *   ...\n   */\n  PopFrame,\n\n  /**\n   * Operation:\n   *   Start tracking a new output block that could change\n   *   if one of its inputs changes.\n   *\n   * Format:\n   *   (Enter args:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   Soon after this opcode, one of Jump, JumpIf,\n   *   or JumpUnless will produce an updating assertion.\n   *   If that assertion fails, the appending VM will\n   *   be re-entered, and the instructions from `from`\n   *   to `to` will be executed.\n   *\n   *   TODO: Save and restore.\n   */\n  Enter,\n\n  /**\n   * Operation:\n   *   Finish tracking the current block.\n   *\n   * Format:\n   *   (Exit)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   This finalizes the validators that the updating\n   *   block must check to determine whether it's safe to\n   *   skip running the contents.\n   */\n  Exit,\n\n  /**\n   * Operation: Convert the top of the stack into a boolean reference.\n   *\n   * Format:\n   *   (ToBoolean)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<bool>\n   */\n  ToBoolean,\n\n  /// LISTS\n\n  /**\n   * Operation: Enter a list.\n   *\n   * Format:\n   *   (EnterList address:u32)\n   * Operand Stack:\n   *   ..., Iterator →\n   *   ...\n   */\n  EnterList,\n\n  /**\n   * Operation: Exit the current list.\n   *\n   * Format:\n   *   (ExitList)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  ExitList,\n\n  /**\n   * Operation:\n   *   Convert an operand and key into an iterator and\n   *   presence reference.\n   *\n   * Format:\n   *   (PutIterator)\n   * Operand Stack:\n   *   ..., key:string, list:VersionedPathReference →\n   *   ..., iterator:ReferenceIterator, present:PresenceReference\n   */\n  PutIterator,\n\n  /**\n   * Operation:\n   *   Set up the stack for iterating for a given key,\n   *   or jump to `end` if there is nothing left to\n   *   iterate.\n   *\n   * Format:\n   *   (Iterate end:u32)\n   * Operand Stack:\n   *   Form 1: (something to iterate)\n   *   ... →\n   *   ..., VersionedPathReference, VersionedPathReference, string\n   *   Form 2: (nothing left to iterate)\n   *   ... →\n   *   ...\n   * Description:\n   *   In Form 1, the stack will have (in reverse order):\n   *\n   *   - the key, as a string\n   *   - the current iterated value\n   *   - the memoized iterated value\n   */\n  Iterate,\n\n  /// COMPONENTS\n\n  /**\n   * Operation: Test whether a reference contains a component definition.\n   *\n   * Format:\n   *   (Main state:register)\n   * Operand Stack:\n   *   ..., Invocation, ComponentDefinition →\n   *   ...\n   */\n  Main,\n\n  /**\n   * Operation: Test whether a reference contains a component definition.\n   *\n   * Format:\n   *   (IsComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<boolean>\n   */\n  IsComponent,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, TemplateMeta, CapturedArguments }\n   */\n  CurryComponent,\n\n  /**\n   * Operation: Push an appropriate component manager onto the stack.\n   *\n   * Format:\n   *   (PushComponentManager #ComponentSpec)\n   * Operand Stack:\n   *   ... →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushComponentDefinition,\n\n  /**\n   * Operation:\n   *   Push an appropriate component manager onto the stack from\n   *   a runtime-resolved component definition.\n   *\n   * Format:\n   *   (PushDynamicComponentManager templateMeta:#TemplateMeta)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., { ComponentDefinition, ComponentManager }\n   */\n  PushDynamicComponentManager,\n\n  /**\n   * Operation: Push a user representation of args onto the stack.\n   *\n   * Format:\n   *   (PushArgs names:#Array<#string> positionalCount:u32 synthetic:#boolean)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...]  →\n   *   ..., [VersionedPathReference ...], Arguments\n   *\n   * Description:\n   *   This arguments object is only necessary when calling into\n   *   user-specified hooks. It is meant to be implemented as a\n   *   transient proxy that reads into the stack as needed.\n   *   Holding onto the Arguments after the call has completed is\n   *   illegal.\n   */\n  PushArgs,\n\n  /**\n   * Operation: Pops Arguments from the stack and clears the next N args.\n   *\n   * Format:\n   *   (PopArgs)\n   *\n   * Operand Stack:\n   *   ..., [VersionedPathReference ...], Arguments  →\n   *   ...\n   *\n   * Description:\n   * The arguments object contains the information of how many user\n   * supplied args the component was invoked with. To clear them from\n   * the stack we must pop it from the stack and call `clear` on it\n   * to remove the argument values from the stack.\n   */\n  PopArgs,\n\n  /**\n   * Operation: ...\n   * Format:\n   *   (PrepareArgs state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PrepareArgs,\n\n  /**\n   * Operation: Create the component and push it onto the stack.\n   * Format:\n   *   (CreateComponent flags:u32 state:register)\n   *   ... →\n   *   ...\n   * Description:\n   * Operand Stack:\n   *   Flags:\n   *\n   *   * 0b001: Has a default block\n   *   * 0b010: Has an inverse block\n   */\n  CreateComponent,\n\n  /**\n   * Operation: Register a destructor for the current component\n   *\n   * Format:\n   *   (RegisterComponentDestructor state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  RegisterComponentDestructor,\n\n  /**\n   * Operation: Push a new ElementOperations for the current component.\n   *\n   * Format:\n   *   (PutComponentOperations)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  PutComponentOperations,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentSelf state:register)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  GetComponentSelf,\n\n  /**\n   * Operation: Push the component's `self` onto the stack.\n   *\n   * Format:\n   *   (GetComponentTagName state:register)\n   * Operand Stack:\n   *   ... →\n   *   ..., Option<string>\n   */\n  GetComponentTagName,\n\n  /**\n   * Operation: Get the component layout from the manager.\n   *\n   * Format:\n   *   (GetComponentLayout state:register)\n   * Operand Stack:\n   *   ... →\n   *   ..., ProgramSymbolTable, Handle\n   */\n  GetComponentLayout,\n\n  /**\n   * Operation:\n   *   Populate the state register with the layout currently\n   *   on the stack.\n   *\n   * Format:\n   *   (PopulateLayout state:register)\n   * Operand Stack:\n   *   ..., ProgramSymbolTable, Handle →\n   *   ...\n   */\n  PopulateLayout,\n\n  /**\n   * Operation: Invoke the layout returned by the manager.\n   *\n   * Format:\n   *   (InvokeComponentLayout state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  InvokeComponentLayout,\n\n  /**\n   * Operation: Begin a new cache group\n   *\n   * Format:\n   *   (BeginComponentTransaction)\n   * Operand Stack:\n   *   ..., ComponentManager<T>, T →\n   *   ..., ComponentManager<T>, T\n   */\n  BeginComponentTransaction,\n\n  /**\n   * Operation: Commit the current cache group\n   *\n   * Format:\n   *   (CommitComponentTransaction)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  CommitComponentTransaction,\n\n  /**\n   * Operation: Invoke didCreateElement on the current component manager\n   *\n   * Format:\n   *   (DidCreateElement state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  DidCreateElement,\n\n  /**\n   * Operation: Invoke didRenderLayout on the current component manager\n   *\n   * Format:\n   *   (DidRenderLayout state:register)\n   * Operand Stack:\n   *   ..., →\n   *   ...\n   */\n  DidRenderLayout,\n\n  /// PARTIALS\n\n  /**\n   * Operation: Lookup and invoke a partial template.\n   *\n   * Format:\n   *   (InvokePartial templateMeta:#TemplateMeta symbols:#Array<#string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  InvokePartial,\n\n  /**\n   * Operation:\n   *   Resolve {{foo}} inside a partial, which could be either a self-lookup\n   *   or a local variable that is in-scope for the caller.\n   *\n   * Format:\n   *   (ResolveMaybeLocal local:#string)\n   * Operand Stack:\n   *   ... →\n   *   ..., VersionedPathReference\n   */\n  ResolveMaybeLocal,\n\n  /// DEBUGGER\n\n  /**\n   * Operation: Activate the debugger\n   *\n   * Format:\n   *   (Debugger symbols:#Array<string> evalInfo:#Array<number>)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  Debugger,\n\n  /** The size of the opcode list */\n  Size\n}\n"]}

@@ -575,2 +575,12 @@ export declare const enum Op {

* Format:
* (Main state:register)
* Operand Stack:
* ..., Invocation, ComponentDefinition →
* ...
*/
Main = 57,
/**
* Operation: Test whether a reference contains a component definition.
*
* Format:
* (IsComponent)

@@ -581,3 +591,3 @@ * Operand Stack:

*/
IsComponent = 57,
IsComponent = 58,
/**

@@ -592,3 +602,3 @@ * Operation: Curry a component definition for a later invocation.

*/
CurryComponent = 58,
CurryComponent = 59,
/**

@@ -603,3 +613,3 @@ * Operation: Push an appropriate component manager onto the stack.

*/
PushComponentDefinition = 59,
PushComponentDefinition = 60,
/**

@@ -616,3 +626,3 @@ * Operation:

*/
PushDynamicComponentManager = 60,
PushDynamicComponentManager = 61,
/**

@@ -635,3 +645,3 @@ * Operation: Push a user representation of args onto the stack.

*/
PushArgs = 61,
PushArgs = 62,
/**

@@ -653,7 +663,7 @@ * Operation: Pops Arguments from the stack and clears the next N args.

*/
PopArgs = 62,
PopArgs = 63,
/**
* Operation: ...
* Format:
* (PrepareArgs state:u32)
* (PrepareArgs state:register)
* Operand Stack:

@@ -663,7 +673,7 @@ * ... →

*/
PrepareArgs = 63,
PrepareArgs = 64,
/**
* Operation: Create the component and push it onto the stack.
* Format:
* (CreateComponent flags:u32 state:u32)
* (CreateComponent flags:u32 state:register)
* ... →

@@ -678,3 +688,3 @@ * ...

*/
CreateComponent = 64,
CreateComponent = 65,
/**

@@ -684,3 +694,3 @@ * Operation: Register a destructor for the current component

* Format:
* (RegisterComponentDestructor state:u32)
* (RegisterComponentDestructor state:register)
* Operand Stack:

@@ -690,3 +700,3 @@ * ... →

*/
RegisterComponentDestructor = 65,
RegisterComponentDestructor = 66,
/**

@@ -701,3 +711,3 @@ * Operation: Push a new ElementOperations for the current component.

*/
PutComponentOperations = 66,
PutComponentOperations = 67,
/**

@@ -707,3 +717,3 @@ * Operation: Push the component's `self` onto the stack.

* Format:
* (GetComponentSelf state:u32)
* (GetComponentSelf state:register)
* Operand Stack:

@@ -713,3 +723,3 @@ * ... →

*/
GetComponentSelf = 67,
GetComponentSelf = 68,
/**

@@ -719,3 +729,3 @@ * Operation: Push the component's `self` onto the stack.

* Format:
* (GetComponentTagName state:u32)
* (GetComponentTagName state:register)
* Operand Stack:

@@ -725,3 +735,3 @@ * ... →

*/
GetComponentTagName = 68,
GetComponentTagName = 69,
/**

@@ -731,3 +741,3 @@ * Operation: Get the component layout from the manager.

* Format:
* (GetComponentLayout state:u32)
* (GetComponentLayout state:register)
* Operand Stack:

@@ -737,8 +747,10 @@ * ... →

*/
GetComponentLayout = 69,
GetComponentLayout = 70,
/**
* Operation: Invoke the layout returned by the manager.
* Operation:
* Populate the state register with the layout currently
* on the stack.
*
* Format:
* (InvokeComponentLayout)
* (PopulateLayout state:register)
* Operand Stack:

@@ -748,4 +760,14 @@ * ..., ProgramSymbolTable, Handle →

*/
InvokeComponentLayout = 70,
PopulateLayout = 71,
/**
* Operation: Invoke the layout returned by the manager.
*
* Format:
* (InvokeComponentLayout state:register)
* Operand Stack:
* ... →
* ...
*/
InvokeComponentLayout = 72,
/**
* Operation: Begin a new cache group

@@ -759,3 +781,3 @@ *

*/
BeginComponentTransaction = 71,
BeginComponentTransaction = 73,
/**

@@ -770,3 +792,3 @@ * Operation: Commit the current cache group

*/
CommitComponentTransaction = 72,
CommitComponentTransaction = 74,
/**

@@ -776,3 +798,3 @@ * Operation: Invoke didCreateElement on the current component manager

* Format:
* (DidCreateElement state:u32)
* (DidCreateElement state:register)
* Operand Stack:

@@ -782,3 +804,3 @@ * ... →

*/
DidCreateElement = 73,
DidCreateElement = 75,
/**

@@ -788,3 +810,3 @@ * Operation: Invoke didRenderLayout on the current component manager

* Format:
* (DidRenderLayout state:u32)
* (DidRenderLayout state:register)
* Operand Stack:

@@ -794,3 +816,3 @@ * ..., →

*/
DidRenderLayout = 74,
DidRenderLayout = 76,
/**

@@ -805,3 +827,3 @@ * Operation: Lookup and invoke a partial template.

*/
InvokePartial = 75,
InvokePartial = 77,
/**

@@ -818,3 +840,3 @@ * Operation:

*/
ResolveMaybeLocal = 76,
ResolveMaybeLocal = 78,
/**

@@ -829,5 +851,5 @@ * Operation: Activate the debugger

*/
Debugger = 77,
Debugger = 79,
/** The size of the opcode list */
Size = 78,
Size = 80,
}
{
"name": "@glimmer/vm",
"version": "0.29.10",
"version": "0.30.0",
"repository": "https://github.com/glimmerjs/glimmer-vm/tree/master/packages/@glimmer/vm",
"dependencies": {
"@glimmer/util": "^0.29.10",
"@glimmer/interfaces": "^0.29.10",
"@glimmer/program": "^0.29.10"
"@glimmer/util": "^0.30.0",
"@glimmer/interfaces": "^0.30.0",
"@glimmer/program": "^0.30.0"
},
"devDependencies": {
"@glimmer/debug": "^0.29.10",
"@glimmer/debug": "^0.30.0",
"@types/qunit": "^2.0.31",

@@ -13,0 +13,0 @@ "typescript": "^2.2.0"

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