New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@glimmer/vm

Package Overview
Dependencies
Maintainers
11
Versions
255
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.34.8 to 0.35.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 named arguments in the Arguments to the symbols\n   *   specified by the symbol table in the component state at register.\n   * Format:\n   *   (SetNamedVariables register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetNamedVariables,\n\n  /**\n   * Operation:\n   *   Bind the blocks in the Arguments to the symbols specified by the\n   *   symbol table in the component state at register.\n   * Format:\n   *   (SetBlocks register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetBlocks,\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: Convert the top of the stack into a number.\n   *\n   * Format:\n   *   (ReifyU32)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>, u32\n   */\n  ReifyU32,\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 root scope onto the scope stack.\n   *\n   * Format:\n   *   (VirtualRootScope register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   The symbol count is determined by the component state in\n   *   the specified register.\n   */\n  VirtualRootScope,\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 content as HTML.\n   * Format:\n   *   (AppendHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendHTML,\n\n  /**\n   * Operation: Append SafeHTML as HTML.\n   * Format:\n   *   (AppendSafeHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<SafeHTML> →\n   *   ...\n   */\n  AppendSafeHTML,\n\n  /**\n   * Operation: Append DocumentFragment.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<DocumentFragment> →\n   *   ...\n   */\n  AppendDocumentFragment,\n\n  /**\n   * Operation: Append Node.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Node> →\n   *   ...\n   */\n  AppendNode,\n\n  /**\n   * Operation: Append content as text.\n   * Format:\n   *   (AppendText)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendText,\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 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:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is the same as the\n   *   comparison.\n   *\n   * Format:\n   *   (JumpEq to:i32 comparison:i32)\n   * Operand Stack:\n   *   ..., u32 →\n   *   ..., u32\n   */\n  JumpEq,\n\n  /**\n   * Operation:\n   *   Validate that the value at the top of the stack\n   *   hasn't changed.\n   *\n   * Format:\n   *   (AssertSame)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>\n   */\n  AssertSame,\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: Push a small stack frame\n   *\n   * Format:\n   *   (PushSmallFrame)\n   * Operand Stack:\n   *   ... →\n   *   $fp\n   */\n  PushSmallFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PopSmallFrame)\n   * Operand Stack:\n   *   $fp →\n   *   ...\n   */\n  PopSmallFrame,\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   *   JumpUnless, or JumpEq will produce an updating\n   *   assertion. If that assertion fails, the appending\n   *   VM will 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: Push the content type onto the stack.\n   *\n   * Format:\n   *   (ContentType)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<Opaque>, VersionedPathReference<ContentType>\n   */\n  ContentType,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, Locator, 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   *   Pushes the ComponentInstance onto the stack that is\n   *   used during the invoke.\n   *\n   * Format:\n   *   (PushDynamicComponentInstance)\n   * Operand Stack:\n   *   ..., ComponentDefinition →\n   *   ..., { ComponentDefinition, manager: null, layout: null, state: null, handle: null, table: null }\n   */\n\n  PushDynamicComponentInstance,\n\n  /**\n   * Operation:\n   *   Pushes a curried component definition on to the stack\n   *\n   * Format:\n   *   (PushCurriedComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  PushCurriedComponent,\n\n  /**\n   * Operation:\n   *   Push a resolved component definition onto the stack\n   *\n   * Format:\n   *   (ResolveDynamicComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  ResolveDynamicComponent,\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: Push empty args onto the stack\n   *\n   * Format:\n   *   (EmptyArgs)\n   *\n   * OperandStack:\n   *   ... →\n   *   ..., Arguments\n   */\n  PushEmptyArgs,\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: Replaces Arguments on the stack with CapturedArguments\n   * Format:\n   *   (CaptureArgs)\n   *\n   * Operand Stack:\n   *   ..., Arguments  →\n   *   ..., CapturedArguments\n   *\n   * Description:\n   * The Arguments object is mutated in place because it is usually consumed immediately\n   * after being pushed on to the stack. In some situations, such as with curried components,\n   * information about more than one Argument may need to exist on the stack at once. In those\n   * cases, the CaptureArgs instruction pops an Arguments object off the stack and replaces it\n   * with the immutable CapturedArgs snapshot.\n   */\n  CaptureArgs,\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: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  SetupForEval,\n\n  /**\n   * Operation: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  BindEvalScope,\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:#Locator 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 named arguments in the Arguments to the symbols\n   *   specified by the symbol table in the component state at register.\n   * Format:\n   *   (SetNamedVariables register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetNamedVariables,\n\n  /**\n   * Operation:\n   *   Bind the blocks in the Arguments to the symbols specified by the\n   *   symbol table in the component state at register.\n   * Format:\n   *   (SetBlocks register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetBlocks,\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: Convert the top of the stack into a number.\n   *\n   * Format:\n   *   (ReifyU32)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>, u32\n   */\n  ReifyU32,\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 root scope onto the scope stack.\n   *\n   * Format:\n   *   (VirtualRootScope register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   The symbol count is determined by the component state in\n   *   the specified register.\n   */\n  VirtualRootScope,\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 content as HTML.\n   * Format:\n   *   (AppendHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendHTML,\n\n  /**\n   * Operation: Append SafeHTML as HTML.\n   * Format:\n   *   (AppendSafeHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<SafeHTML> →\n   *   ...\n   */\n  AppendSafeHTML,\n\n  /**\n   * Operation: Append DocumentFragment.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<DocumentFragment> →\n   *   ...\n   */\n  AppendDocumentFragment,\n\n  /**\n   * Operation: Append Node.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Node> →\n   *   ...\n   */\n  AppendNode,\n\n  /**\n   * Operation: Append content as text.\n   * Format:\n   *   (AppendText)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendText,\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 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:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is the same as the\n   *   comparison.\n   *\n   * Format:\n   *   (JumpEq to:i32 comparison:i32)\n   * Operand Stack:\n   *   ..., u32 →\n   *   ..., u32\n   */\n  JumpEq,\n\n  /**\n   * Operation:\n   *   Validate that the value at the top of the stack\n   *   hasn't changed.\n   *\n   * Format:\n   *   (AssertSame)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>\n   */\n  AssertSame,\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: Push a small stack frame\n   *\n   * Format:\n   *   (PushSmallFrame)\n   * Operand Stack:\n   *   ... →\n   *   $fp\n   */\n  PushSmallFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PopSmallFrame)\n   * Operand Stack:\n   *   $fp →\n   *   ...\n   */\n  PopSmallFrame,\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   *   JumpUnless, or JumpEq will produce an updating\n   *   assertion. If that assertion fails, the appending\n   *   VM will 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: Push the content type onto the stack.\n   *\n   * Format:\n   *   (ContentType)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<Opaque>, VersionedPathReference<ContentType>\n   */\n  ContentType,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, Locator, 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   *   Pushes the ComponentInstance onto the stack that is\n   *   used during the invoke.\n   *\n   * Format:\n   *   (PushDynamicComponentInstance)\n   * Operand Stack:\n   *   ..., ComponentDefinition →\n   *   ..., { ComponentDefinition, manager: null, layout: null, state: null, handle: null, table: null }\n   */\n\n  PushDynamicComponentInstance,\n\n  /**\n   * Operation:\n   *   Pushes a curried component definition on to the stack\n   *\n   * Format:\n   *   (PushCurriedComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  PushCurriedComponent,\n\n  /**\n   * Operation:\n   *   Push a resolved component definition onto the stack\n   *\n   * Format:\n   *   (ResolveDynamicComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  ResolveDynamicComponent,\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: Push empty args onto the stack\n   *\n   * Format:\n   *   (EmptyArgs)\n   *\n   * OperandStack:\n   *   ... →\n   *   ..., Arguments\n   */\n  PushEmptyArgs,\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: Replaces Arguments on the stack with CapturedArguments\n   * Format:\n   *   (CaptureArgs)\n   *\n   * Operand Stack:\n   *   ..., Arguments  →\n   *   ..., CapturedArguments\n   *\n   * Description:\n   * The Arguments object is mutated in place because it is usually consumed immediately\n   * after being pushed on to the stack. In some situations, such as with curried components,\n   * information about more than one Argument may need to exist on the stack at once. In those\n   * cases, the CaptureArgs instruction pops an Arguments object off the stack and replaces it\n   * with the immutable CapturedArgs snapshot.\n   */\n  CaptureArgs,\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 `tagName` 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: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  SetupForEval,\n\n  /**\n   * Operation: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  BindEvalScope,\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:#Locator 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 named arguments in the Arguments to the symbols\n   *   specified by the symbol table in the component state at register.\n   * Format:\n   *   (SetNamedVariables register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetNamedVariables,\n\n  /**\n   * Operation:\n   *   Bind the blocks in the Arguments to the symbols specified by the\n   *   symbol table in the component state at register.\n   * Format:\n   *   (SetBlocks register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetBlocks,\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: Convert the top of the stack into a number.\n   *\n   * Format:\n   *   (ReifyU32)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>, u32\n   */\n  ReifyU32,\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 root scope onto the scope stack.\n   *\n   * Format:\n   *   (VirtualRootScope register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   The symbol count is determined by the component state in\n   *   the specified register.\n   */\n  VirtualRootScope,\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 content as HTML.\n   * Format:\n   *   (AppendHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendHTML,\n\n  /**\n   * Operation: Append SafeHTML as HTML.\n   * Format:\n   *   (AppendSafeHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<SafeHTML> →\n   *   ...\n   */\n  AppendSafeHTML,\n\n  /**\n   * Operation: Append DocumentFragment.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<DocumentFragment> →\n   *   ...\n   */\n  AppendDocumentFragment,\n\n  /**\n   * Operation: Append Node.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Node> →\n   *   ...\n   */\n  AppendNode,\n\n  /**\n   * Operation: Append content as text.\n   * Format:\n   *   (AppendText)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendText,\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 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:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is the same as the\n   *   comparison.\n   *\n   * Format:\n   *   (JumpEq to:i32 comparison:i32)\n   * Operand Stack:\n   *   ..., u32 →\n   *   ..., u32\n   */\n  JumpEq,\n\n  /**\n   * Operation:\n   *   Validate that the value at the top of the stack\n   *   hasn't changed.\n   *\n   * Format:\n   *   (AssertSame)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>\n   */\n  AssertSame,\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: Push a small stack frame\n   *\n   * Format:\n   *   (PushSmallFrame)\n   * Operand Stack:\n   *   ... →\n   *   $fp\n   */\n  PushSmallFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PopSmallFrame)\n   * Operand Stack:\n   *   $fp →\n   *   ...\n   */\n  PopSmallFrame,\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   *   JumpUnless, or JumpEq will produce an updating\n   *   assertion. If that assertion fails, the appending\n   *   VM will 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: Push the content type onto the stack.\n   *\n   * Format:\n   *   (ContentType)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<Opaque>, VersionedPathReference<ContentType>\n   */\n  ContentType,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, Locator, 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   *   Pushes the ComponentInstance onto the stack that is\n   *   used during the invoke.\n   *\n   * Format:\n   *   (PushDynamicComponentInstance)\n   * Operand Stack:\n   *   ..., ComponentDefinition →\n   *   ..., { ComponentDefinition, manager: null, layout: null, state: null, handle: null, table: null }\n   */\n\n  PushDynamicComponentInstance,\n\n  /**\n   * Operation:\n   *   Pushes a curried component definition on to the stack\n   *\n   * Format:\n   *   (PushCurriedComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  PushCurriedComponent,\n\n  /**\n   * Operation:\n   *   Push a resolved component definition onto the stack\n   *\n   * Format:\n   *   (ResolveDynamicComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  ResolveDynamicComponent,\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: Push empty args onto the stack\n   *\n   * Format:\n   *   (EmptyArgs)\n   *\n   * OperandStack:\n   *   ... →\n   *   ..., Arguments\n   */\n  PushEmptyArgs,\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: Replaces Arguments on the stack with CapturedArguments\n   * Format:\n   *   (CaptureArgs)\n   *\n   * Operand Stack:\n   *   ..., Arguments  →\n   *   ..., CapturedArguments\n   *\n   * Description:\n   * The Arguments object is mutated in place because it is usually consumed immediately\n   * after being pushed on to the stack. In some situations, such as with curried components,\n   * information about more than one Argument may need to exist on the stack at once. In those\n   * cases, the CaptureArgs instruction pops an Arguments object off the stack and replaces it\n   * with the immutable CapturedArgs snapshot.\n   */\n  CaptureArgs,\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: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  SetupForEval,\n\n  /**\n   * Operation: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  BindEvalScope,\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:#Locator 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 named arguments in the Arguments to the symbols\n   *   specified by the symbol table in the component state at register.\n   * Format:\n   *   (SetNamedVariables register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetNamedVariables,\n\n  /**\n   * Operation:\n   *   Bind the blocks in the Arguments to the symbols specified by the\n   *   symbol table in the component state at register.\n   * Format:\n   *   (SetBlocks register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetBlocks,\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: Convert the top of the stack into a number.\n   *\n   * Format:\n   *   (ReifyU32)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>, u32\n   */\n  ReifyU32,\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 root scope onto the scope stack.\n   *\n   * Format:\n   *   (VirtualRootScope register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   The symbol count is determined by the component state in\n   *   the specified register.\n   */\n  VirtualRootScope,\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 content as HTML.\n   * Format:\n   *   (AppendHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendHTML,\n\n  /**\n   * Operation: Append SafeHTML as HTML.\n   * Format:\n   *   (AppendSafeHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<SafeHTML> →\n   *   ...\n   */\n  AppendSafeHTML,\n\n  /**\n   * Operation: Append DocumentFragment.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<DocumentFragment> →\n   *   ...\n   */\n  AppendDocumentFragment,\n\n  /**\n   * Operation: Append Node.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Node> →\n   *   ...\n   */\n  AppendNode,\n\n  /**\n   * Operation: Append content as text.\n   * Format:\n   *   (AppendText)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendText,\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 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:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is the same as the\n   *   comparison.\n   *\n   * Format:\n   *   (JumpEq to:i32 comparison:i32)\n   * Operand Stack:\n   *   ..., u32 →\n   *   ..., u32\n   */\n  JumpEq,\n\n  /**\n   * Operation:\n   *   Validate that the value at the top of the stack\n   *   hasn't changed.\n   *\n   * Format:\n   *   (AssertSame)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>\n   */\n  AssertSame,\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: Push a small stack frame\n   *\n   * Format:\n   *   (PushSmallFrame)\n   * Operand Stack:\n   *   ... →\n   *   $fp\n   */\n  PushSmallFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PopSmallFrame)\n   * Operand Stack:\n   *   $fp →\n   *   ...\n   */\n  PopSmallFrame,\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   *   JumpUnless, or JumpEq will produce an updating\n   *   assertion. If that assertion fails, the appending\n   *   VM will 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: Push the content type onto the stack.\n   *\n   * Format:\n   *   (ContentType)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<Opaque>, VersionedPathReference<ContentType>\n   */\n  ContentType,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, Locator, 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   *   Pushes the ComponentInstance onto the stack that is\n   *   used during the invoke.\n   *\n   * Format:\n   *   (PushDynamicComponentInstance)\n   * Operand Stack:\n   *   ..., ComponentDefinition →\n   *   ..., { ComponentDefinition, manager: null, layout: null, state: null, handle: null, table: null }\n   */\n\n  PushDynamicComponentInstance,\n\n  /**\n   * Operation:\n   *   Pushes a curried component definition on to the stack\n   *\n   * Format:\n   *   (PushCurriedComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  PushCurriedComponent,\n\n  /**\n   * Operation:\n   *   Push a resolved component definition onto the stack\n   *\n   * Format:\n   *   (ResolveDynamicComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  ResolveDynamicComponent,\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: Push empty args onto the stack\n   *\n   * Format:\n   *   (EmptyArgs)\n   *\n   * OperandStack:\n   *   ... →\n   *   ..., Arguments\n   */\n  PushEmptyArgs,\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: Replaces Arguments on the stack with CapturedArguments\n   * Format:\n   *   (CaptureArgs)\n   *\n   * Operand Stack:\n   *   ..., Arguments  →\n   *   ..., CapturedArguments\n   *\n   * Description:\n   * The Arguments object is mutated in place because it is usually consumed immediately\n   * after being pushed on to the stack. In some situations, such as with curried components,\n   * information about more than one Argument may need to exist on the stack at once. In those\n   * cases, the CaptureArgs instruction pops an Arguments object off the stack and replaces it\n   * with the immutable CapturedArgs snapshot.\n   */\n  CaptureArgs,\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 `tagName` 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: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  SetupForEval,\n\n  /**\n   * Operation: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  BindEvalScope,\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:#Locator 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 named arguments in the Arguments to the symbols\n   *   specified by the symbol table in the component state at register.\n   * Format:\n   *   (SetNamedVariables register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetNamedVariables,\n\n  /**\n   * Operation:\n   *   Bind the blocks in the Arguments to the symbols specified by the\n   *   symbol table in the component state at register.\n   * Format:\n   *   (SetBlocks register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetBlocks,\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: Convert the top of the stack into a number.\n   *\n   * Format:\n   *   (ReifyU32)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>, u32\n   */\n  ReifyU32,\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 root scope onto the scope stack.\n   *\n   * Format:\n   *   (VirtualRootScope register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   The symbol count is determined by the component state in\n   *   the specified register.\n   */\n  VirtualRootScope,\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 content as HTML.\n   * Format:\n   *   (AppendHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendHTML,\n\n  /**\n   * Operation: Append SafeHTML as HTML.\n   * Format:\n   *   (AppendSafeHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<SafeHTML> →\n   *   ...\n   */\n  AppendSafeHTML,\n\n  /**\n   * Operation: Append DocumentFragment.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<DocumentFragment> →\n   *   ...\n   */\n  AppendDocumentFragment,\n\n  /**\n   * Operation: Append Node.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Node> →\n   *   ...\n   */\n  AppendNode,\n\n  /**\n   * Operation: Append content as text.\n   * Format:\n   *   (AppendText)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendText,\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 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:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is the same as the\n   *   comparison.\n   *\n   * Format:\n   *   (JumpEq to:i32 comparison:i32)\n   * Operand Stack:\n   *   ..., u32 →\n   *   ..., u32\n   */\n  JumpEq,\n\n  /**\n   * Operation:\n   *   Validate that the value at the top of the stack\n   *   hasn't changed.\n   *\n   * Format:\n   *   (AssertSame)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>\n   */\n  AssertSame,\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: Push a small stack frame\n   *\n   * Format:\n   *   (PushSmallFrame)\n   * Operand Stack:\n   *   ... →\n   *   $fp\n   */\n  PushSmallFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PopSmallFrame)\n   * Operand Stack:\n   *   $fp →\n   *   ...\n   */\n  PopSmallFrame,\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   *   JumpUnless, or JumpEq will produce an updating\n   *   assertion. If that assertion fails, the appending\n   *   VM will 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: Push the content type onto the stack.\n   *\n   * Format:\n   *   (ContentType)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<Opaque>, VersionedPathReference<ContentType>\n   */\n  ContentType,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, Locator, 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   *   Pushes the ComponentInstance onto the stack that is\n   *   used during the invoke.\n   *\n   * Format:\n   *   (PushDynamicComponentInstance)\n   * Operand Stack:\n   *   ..., ComponentDefinition →\n   *   ..., { ComponentDefinition, manager: null, layout: null, state: null, handle: null, table: null }\n   */\n\n  PushDynamicComponentInstance,\n\n  /**\n   * Operation:\n   *   Pushes a curried component definition on to the stack\n   *\n   * Format:\n   *   (PushCurriedComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  PushCurriedComponent,\n\n  /**\n   * Operation:\n   *   Push a resolved component definition onto the stack\n   *\n   * Format:\n   *   (ResolveDynamicComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  ResolveDynamicComponent,\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: Push empty args onto the stack\n   *\n   * Format:\n   *   (EmptyArgs)\n   *\n   * OperandStack:\n   *   ... →\n   *   ..., Arguments\n   */\n  PushEmptyArgs,\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: Replaces Arguments on the stack with CapturedArguments\n   * Format:\n   *   (CaptureArgs)\n   *\n   * Operand Stack:\n   *   ..., Arguments  →\n   *   ..., CapturedArguments\n   *\n   * Description:\n   * The Arguments object is mutated in place because it is usually consumed immediately\n   * after being pushed on to the stack. In some situations, such as with curried components,\n   * information about more than one Argument may need to exist on the stack at once. In those\n   * cases, the CaptureArgs instruction pops an Arguments object off the stack and replaces it\n   * with the immutable CapturedArgs snapshot.\n   */\n  CaptureArgs,\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: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  SetupForEval,\n\n  /**\n   * Operation: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  BindEvalScope,\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:#Locator 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 named arguments in the Arguments to the symbols\n   *   specified by the symbol table in the component state at register.\n   * Format:\n   *   (SetNamedVariables register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetNamedVariables,\n\n  /**\n   * Operation:\n   *   Bind the blocks in the Arguments to the symbols specified by the\n   *   symbol table in the component state at register.\n   * Format:\n   *   (SetBlocks register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetBlocks,\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: Convert the top of the stack into a number.\n   *\n   * Format:\n   *   (ReifyU32)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>, u32\n   */\n  ReifyU32,\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 root scope onto the scope stack.\n   *\n   * Format:\n   *   (VirtualRootScope register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   The symbol count is determined by the component state in\n   *   the specified register.\n   */\n  VirtualRootScope,\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 content as HTML.\n   * Format:\n   *   (AppendHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendHTML,\n\n  /**\n   * Operation: Append SafeHTML as HTML.\n   * Format:\n   *   (AppendSafeHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<SafeHTML> →\n   *   ...\n   */\n  AppendSafeHTML,\n\n  /**\n   * Operation: Append DocumentFragment.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<DocumentFragment> →\n   *   ...\n   */\n  AppendDocumentFragment,\n\n  /**\n   * Operation: Append Node.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Node> →\n   *   ...\n   */\n  AppendNode,\n\n  /**\n   * Operation: Append content as text.\n   * Format:\n   *   (AppendText)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendText,\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 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:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is the same as the\n   *   comparison.\n   *\n   * Format:\n   *   (JumpEq to:i32 comparison:i32)\n   * Operand Stack:\n   *   ..., u32 →\n   *   ..., u32\n   */\n  JumpEq,\n\n  /**\n   * Operation:\n   *   Validate that the value at the top of the stack\n   *   hasn't changed.\n   *\n   * Format:\n   *   (AssertSame)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>\n   */\n  AssertSame,\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: Push a small stack frame\n   *\n   * Format:\n   *   (PushSmallFrame)\n   * Operand Stack:\n   *   ... →\n   *   $fp\n   */\n  PushSmallFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PopSmallFrame)\n   * Operand Stack:\n   *   $fp →\n   *   ...\n   */\n  PopSmallFrame,\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   *   JumpUnless, or JumpEq will produce an updating\n   *   assertion. If that assertion fails, the appending\n   *   VM will 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: Push the content type onto the stack.\n   *\n   * Format:\n   *   (ContentType)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<Opaque>, VersionedPathReference<ContentType>\n   */\n  ContentType,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, Locator, 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   *   Pushes the ComponentInstance onto the stack that is\n   *   used during the invoke.\n   *\n   * Format:\n   *   (PushDynamicComponentInstance)\n   * Operand Stack:\n   *   ..., ComponentDefinition →\n   *   ..., { ComponentDefinition, manager: null, layout: null, state: null, handle: null, table: null }\n   */\n\n  PushDynamicComponentInstance,\n\n  /**\n   * Operation:\n   *   Pushes a curried component definition on to the stack\n   *\n   * Format:\n   *   (PushCurriedComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  PushCurriedComponent,\n\n  /**\n   * Operation:\n   *   Push a resolved component definition onto the stack\n   *\n   * Format:\n   *   (ResolveDynamicComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  ResolveDynamicComponent,\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: Push empty args onto the stack\n   *\n   * Format:\n   *   (EmptyArgs)\n   *\n   * OperandStack:\n   *   ... →\n   *   ..., Arguments\n   */\n  PushEmptyArgs,\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: Replaces Arguments on the stack with CapturedArguments\n   * Format:\n   *   (CaptureArgs)\n   *\n   * Operand Stack:\n   *   ..., Arguments  →\n   *   ..., CapturedArguments\n   *\n   * Description:\n   * The Arguments object is mutated in place because it is usually consumed immediately\n   * after being pushed on to the stack. In some situations, such as with curried components,\n   * information about more than one Argument may need to exist on the stack at once. In those\n   * cases, the CaptureArgs instruction pops an Arguments object off the stack and replaces it\n   * with the immutable CapturedArgs snapshot.\n   */\n  CaptureArgs,\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 `tagName` 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: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  SetupForEval,\n\n  /**\n   * Operation: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  BindEvalScope,\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:#Locator 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 named arguments in the Arguments to the symbols\n   *   specified by the symbol table in the component state at register.\n   * Format:\n   *   (SetNamedVariables register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetNamedVariables,\n\n  /**\n   * Operation:\n   *   Bind the blocks in the Arguments to the symbols specified by the\n   *   symbol table in the component state at register.\n   * Format:\n   *   (SetBlocks register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetBlocks,\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: Convert the top of the stack into a number.\n   *\n   * Format:\n   *   (ReifyU32)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>, u32\n   */\n  ReifyU32,\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 root scope onto the scope stack.\n   *\n   * Format:\n   *   (VirtualRootScope register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   The symbol count is determined by the component state in\n   *   the specified register.\n   */\n  VirtualRootScope,\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 content as HTML.\n   * Format:\n   *   (AppendHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendHTML,\n\n  /**\n   * Operation: Append SafeHTML as HTML.\n   * Format:\n   *   (AppendSafeHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<SafeHTML> →\n   *   ...\n   */\n  AppendSafeHTML,\n\n  /**\n   * Operation: Append DocumentFragment.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<DocumentFragment> →\n   *   ...\n   */\n  AppendDocumentFragment,\n\n  /**\n   * Operation: Append Node.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Node> →\n   *   ...\n   */\n  AppendNode,\n\n  /**\n   * Operation: Append content as text.\n   * Format:\n   *   (AppendText)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendText,\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 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:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is the same as the\n   *   comparison.\n   *\n   * Format:\n   *   (JumpEq to:i32 comparison:i32)\n   * Operand Stack:\n   *   ..., u32 →\n   *   ..., u32\n   */\n  JumpEq,\n\n  /**\n   * Operation:\n   *   Validate that the value at the top of the stack\n   *   hasn't changed.\n   *\n   * Format:\n   *   (AssertSame)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>\n   */\n  AssertSame,\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: Push a small stack frame\n   *\n   * Format:\n   *   (PushSmallFrame)\n   * Operand Stack:\n   *   ... →\n   *   $fp\n   */\n  PushSmallFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PopSmallFrame)\n   * Operand Stack:\n   *   $fp →\n   *   ...\n   */\n  PopSmallFrame,\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   *   JumpUnless, or JumpEq will produce an updating\n   *   assertion. If that assertion fails, the appending\n   *   VM will 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: Push the content type onto the stack.\n   *\n   * Format:\n   *   (ContentType)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<Opaque>, VersionedPathReference<ContentType>\n   */\n  ContentType,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, Locator, 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   *   Pushes the ComponentInstance onto the stack that is\n   *   used during the invoke.\n   *\n   * Format:\n   *   (PushDynamicComponentInstance)\n   * Operand Stack:\n   *   ..., ComponentDefinition →\n   *   ..., { ComponentDefinition, manager: null, layout: null, state: null, handle: null, table: null }\n   */\n\n  PushDynamicComponentInstance,\n\n  /**\n   * Operation:\n   *   Pushes a curried component definition on to the stack\n   *\n   * Format:\n   *   (PushCurriedComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  PushCurriedComponent,\n\n  /**\n   * Operation:\n   *   Push a resolved component definition onto the stack\n   *\n   * Format:\n   *   (ResolveDynamicComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  ResolveDynamicComponent,\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: Push empty args onto the stack\n   *\n   * Format:\n   *   (EmptyArgs)\n   *\n   * OperandStack:\n   *   ... →\n   *   ..., Arguments\n   */\n  PushEmptyArgs,\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: Replaces Arguments on the stack with CapturedArguments\n   * Format:\n   *   (CaptureArgs)\n   *\n   * Operand Stack:\n   *   ..., Arguments  →\n   *   ..., CapturedArguments\n   *\n   * Description:\n   * The Arguments object is mutated in place because it is usually consumed immediately\n   * after being pushed on to the stack. In some situations, such as with curried components,\n   * information about more than one Argument may need to exist on the stack at once. In those\n   * cases, the CaptureArgs instruction pops an Arguments object off the stack and replaces it\n   * with the immutable CapturedArgs snapshot.\n   */\n  CaptureArgs,\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: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  SetupForEval,\n\n  /**\n   * Operation: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  BindEvalScope,\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:#Locator 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 named arguments in the Arguments to the symbols\n   *   specified by the symbol table in the component state at register.\n   * Format:\n   *   (SetNamedVariables register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetNamedVariables,\n\n  /**\n   * Operation:\n   *   Bind the blocks in the Arguments to the symbols specified by the\n   *   symbol table in the component state at register.\n   * Format:\n   *   (SetBlocks register:u32)\n   * Operand Stack:\n   *   ..., Arguments →\n   *   ...\n   */\n  SetBlocks,\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: Convert the top of the stack into a number.\n   *\n   * Format:\n   *   (ReifyU32)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>, u32\n   */\n  ReifyU32,\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 root scope onto the scope stack.\n   *\n   * Format:\n   *   (VirtualRootScope register:u32)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   * Description:\n   *   The symbol count is determined by the component state in\n   *   the specified register.\n   */\n  VirtualRootScope,\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 content as HTML.\n   * Format:\n   *   (AppendHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendHTML,\n\n  /**\n   * Operation: Append SafeHTML as HTML.\n   * Format:\n   *   (AppendSafeHTML)\n   * Operand Stack:\n   *   ..., VersionedPathReference<SafeHTML> →\n   *   ...\n   */\n  AppendSafeHTML,\n\n  /**\n   * Operation: Append DocumentFragment.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<DocumentFragment> →\n   *   ...\n   */\n  AppendDocumentFragment,\n\n  /**\n   * Operation: Append Node.\n   * Format:\n   *   (AppendFragment)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Node> →\n   *   ...\n   */\n  AppendNode,\n\n  /**\n   * Operation: Append content as text.\n   * Format:\n   *   (AppendText)\n   * Operand Stack:\n   *   ..., VersionedPathReference<string> →\n   *   ...\n   */\n  AppendText,\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 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:\n   *   Jump to the specified offset if the value at\n   *   the top of the stack is the same as the\n   *   comparison.\n   *\n   * Format:\n   *   (JumpEq to:i32 comparison:i32)\n   * Operand Stack:\n   *   ..., u32 →\n   *   ..., u32\n   */\n  JumpEq,\n\n  /**\n   * Operation:\n   *   Validate that the value at the top of the stack\n   *   hasn't changed.\n   *\n   * Format:\n   *   (AssertSame)\n   * Operand Stack:\n   *   ..., VersionedPathReference<u32> →\n   *   ..., VersionedPathReference<u32>\n   */\n  AssertSame,\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: Push a small stack frame\n   *\n   * Format:\n   *   (PushSmallFrame)\n   * Operand Stack:\n   *   ... →\n   *   $fp\n   */\n  PushSmallFrame,\n\n  /**\n   * Operation: Pop a stack frame\n   *\n   * Format:\n   *   (PopSmallFrame)\n   * Operand Stack:\n   *   $fp →\n   *   ...\n   */\n  PopSmallFrame,\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   *   JumpUnless, or JumpEq will produce an updating\n   *   assertion. If that assertion fails, the appending\n   *   VM will 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: Push the content type onto the stack.\n   *\n   * Format:\n   *   (ContentType)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., VersionedPathReference<Opaque>, VersionedPathReference<ContentType>\n   */\n  ContentType,\n\n  /**\n   * Operation: Curry a component definition for a later invocation.\n   *\n   * Format:\n   *   (CurryComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference, [VersionedPathReference ...], Arguments →\n   *   ..., { VersionedPathReference, Locator, 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   *   Pushes the ComponentInstance onto the stack that is\n   *   used during the invoke.\n   *\n   * Format:\n   *   (PushDynamicComponentInstance)\n   * Operand Stack:\n   *   ..., ComponentDefinition →\n   *   ..., { ComponentDefinition, manager: null, layout: null, state: null, handle: null, table: null }\n   */\n\n  PushDynamicComponentInstance,\n\n  /**\n   * Operation:\n   *   Pushes a curried component definition on to the stack\n   *\n   * Format:\n   *   (PushCurriedComponent)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  PushCurriedComponent,\n\n  /**\n   * Operation:\n   *   Push a resolved component definition onto the stack\n   *\n   * Format:\n   *   (ResolveDynamicComponent templateMeta:#Locator)\n   * Operand Stack:\n   *   ..., VersionedPathReference<Opaque> →\n   *   ..., ComponentDefinition\n   */\n  ResolveDynamicComponent,\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: Push empty args onto the stack\n   *\n   * Format:\n   *   (EmptyArgs)\n   *\n   * OperandStack:\n   *   ... →\n   *   ..., Arguments\n   */\n  PushEmptyArgs,\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: Replaces Arguments on the stack with CapturedArguments\n   * Format:\n   *   (CaptureArgs)\n   *\n   * Operand Stack:\n   *   ..., Arguments  →\n   *   ..., CapturedArguments\n   *\n   * Description:\n   * The Arguments object is mutated in place because it is usually consumed immediately\n   * after being pushed on to the stack. In some situations, such as with curried components,\n   * information about more than one Argument may need to exist on the stack at once. In those\n   * cases, the CaptureArgs instruction pops an Arguments object off the stack and replaces it\n   * with the immutable CapturedArgs snapshot.\n   */\n  CaptureArgs,\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 `tagName` 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: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  SetupForEval,\n\n  /**\n   * Operation: Populate the eval lookup if necessary.\n   *\n   * Format:\n   *   (SetupForEval state:register)\n   * Operand Stack:\n   *   ... →\n   *   ...\n   */\n  BindEvalScope,\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:#Locator 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"]}

@@ -887,3 +887,3 @@ export declare const enum Op {

/**
* Operation: Push the component's `self` onto the stack.
* Operation: Push the component's `tagName` onto the stack.
*

@@ -890,0 +890,0 @@ * Format:

{
"name": "@glimmer/vm",
"version": "0.34.8",
"version": "0.35.0",
"repository": "https://github.com/glimmerjs/glimmer-vm/tree/master/packages/@glimmer/vm",
"dependencies": {
"@glimmer/util": "^0.34.8",
"@glimmer/interfaces": "^0.34.8",
"@glimmer/program": "^0.34.8"
"@glimmer/util": "^0.35.0",
"@glimmer/interfaces": "^0.35.0",
"@glimmer/program": "^0.35.0"
},
"devDependencies": {
"@glimmer/debug": "^0.34.8",
"@glimmer/debug": "^0.35.0",
"@types/qunit": "^2.0.31",

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

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