mirror of
https://github.com/jerryscript-project/jerryscript.git
synced 2025-12-15 16:29:21 +00:00
The work is based on PR #4843, only fixed some conflicts and cppcheck errors. Co-authored-by: Robert Fancsik robert.fancsik@h-lab.eu JerryScript-DCO-1.0-Signed-off-by: Gergo Csizi gergocs@inf.u-szeged.hu
436 lines
16 KiB
C
436 lines
16 KiB
C
/* Copyright JS Foundation and other contributors, http://js.foundation
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#ifndef VM_H
|
|
#define VM_H
|
|
|
|
#include "ecma-globals.h"
|
|
#include "ecma-module.h"
|
|
|
|
#include "jrt.h"
|
|
#include "vm-defines.h"
|
|
|
|
/** \addtogroup vm Virtual machine
|
|
* @{
|
|
*
|
|
* \addtogroup vm_executor Executor
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* Each CBC opcode is transformed to three vm opcodes:
|
|
*
|
|
* - first opcode is a "get arguments" opcode which specifies
|
|
* the type (register, literal, stack, etc.) and number
|
|
* (from 0 to 2) of input arguments
|
|
* - second opcode is a "group" opcode which specifies
|
|
* the actual operation (add, increment, call, etc.)
|
|
* - third opcode is a "put result" opcode which specifies
|
|
* the destination where the result is stored (register,
|
|
* stack, etc.)
|
|
*/
|
|
|
|
/**
|
|
* If VM_OC_GET_ARGS_INDEX(opcode) == VM_OC_GET_BRANCH,
|
|
* this flag signals that the branch is a backward branch.
|
|
*/
|
|
#define VM_OC_BACKWARD_BRANCH (1 << 15)
|
|
|
|
/**
|
|
* Position of "get arguments" opcode.
|
|
*/
|
|
#define VM_OC_GET_ARGS_SHIFT 8
|
|
|
|
/**
|
|
* Mask of "get arguments" opcode.
|
|
*/
|
|
#define VM_OC_GET_ARGS_MASK 0x7
|
|
|
|
/**
|
|
* Generate the binary representation of a "get arguments" opcode.
|
|
*/
|
|
#define VM_OC_GET_ARGS_CREATE_INDEX(V) (((V) &VM_OC_GET_ARGS_MASK) << VM_OC_GET_ARGS_SHIFT)
|
|
|
|
/**
|
|
* Extract the "get arguments" opcode.
|
|
*/
|
|
#define VM_OC_GET_ARGS_INDEX(O) ((O) & (VM_OC_GET_ARGS_MASK << VM_OC_GET_ARGS_SHIFT))
|
|
|
|
/**
|
|
* Checks whether the result is stored somewhere.
|
|
*/
|
|
#define VM_OC_HAS_GET_ARGS(V) ((V) & (VM_OC_GET_ARGS_MASK << VM_OC_GET_ARGS_SHIFT))
|
|
|
|
/**
|
|
* Argument getters that are part of the opcodes.
|
|
*/
|
|
typedef enum
|
|
{
|
|
VM_OC_GET_NONE = VM_OC_GET_ARGS_CREATE_INDEX (0), /**< do nothing */
|
|
VM_OC_GET_BRANCH = VM_OC_GET_ARGS_CREATE_INDEX (1), /**< branch argument */
|
|
VM_OC_GET_STACK = VM_OC_GET_ARGS_CREATE_INDEX (2), /**< pop one element from the stack */
|
|
VM_OC_GET_STACK_STACK = VM_OC_GET_ARGS_CREATE_INDEX (3), /**< pop two elements from the stack */
|
|
|
|
VM_OC_GET_LITERAL = VM_OC_GET_ARGS_CREATE_INDEX (4), /**< resolve literal */
|
|
VM_OC_GET_LITERAL_LITERAL = VM_OC_GET_ARGS_CREATE_INDEX (5), /**< resolve two literals */
|
|
VM_OC_GET_STACK_LITERAL = VM_OC_GET_ARGS_CREATE_INDEX (6), /**< pop one element from the stack
|
|
* and resolve a literal */
|
|
VM_OC_GET_THIS_LITERAL = VM_OC_GET_ARGS_CREATE_INDEX (7), /**< get this and resolve a literal */
|
|
} vm_oc_get_types;
|
|
|
|
/**
|
|
* Mask of "group" opcode.
|
|
*/
|
|
#define VM_OC_GROUP_MASK 0xff
|
|
|
|
/**
|
|
* Extract the "group" opcode.
|
|
*/
|
|
#define VM_OC_GROUP_GET_INDEX(O) ((O) &VM_OC_GROUP_MASK)
|
|
|
|
/**
|
|
* Opcodes.
|
|
*/
|
|
typedef enum
|
|
{
|
|
VM_OC_POP, /**< pop from stack */
|
|
VM_OC_POP_BLOCK, /**< pop block */
|
|
VM_OC_PUSH, /**< push one literal */
|
|
VM_OC_PUSH_TWO, /**< push two literals */
|
|
VM_OC_PUSH_THREE, /**< push three literals */
|
|
VM_OC_PUSH_UNDEFINED, /**< push undefined value */
|
|
VM_OC_PUSH_TRUE, /**< push true value */
|
|
VM_OC_PUSH_FALSE, /**< push false value */
|
|
VM_OC_PUSH_NULL, /**< push null value */
|
|
VM_OC_PUSH_THIS, /**< push this */
|
|
VM_OC_PUSH_0, /**< push number zero */
|
|
VM_OC_PUSH_POS_BYTE, /**< push number between 1 and 256 */
|
|
VM_OC_PUSH_NEG_BYTE, /**< push number between -1 and -256 */
|
|
VM_OC_PUSH_LIT_0, /**< push literal and number zero */
|
|
VM_OC_PUSH_LIT_POS_BYTE, /**< push literal and number between 1 and 256 */
|
|
VM_OC_PUSH_LIT_NEG_BYTE, /**< push literal and number between -1 and -256 */
|
|
VM_OC_PUSH_OBJECT, /**< push object */
|
|
VM_OC_PUSH_NAMED_FUNC_EXPR, /**< push named function expression */
|
|
VM_OC_SET_PROPERTY, /**< set property */
|
|
|
|
VM_OC_SET_GETTER, /**< set getter */
|
|
VM_OC_SET_SETTER, /**< set setter */
|
|
VM_OC_PUSH_ARRAY, /**< push array */
|
|
VM_OC_PUSH_ELISON, /**< push elison */
|
|
VM_OC_APPEND_ARRAY, /**< append array */
|
|
VM_OC_IDENT_REFERENCE, /**< ident reference */
|
|
VM_OC_PROP_REFERENCE, /**< prop reference */
|
|
VM_OC_PROP_GET, /**< prop get */
|
|
|
|
/* These eight opcodes must be in this order. */
|
|
VM_OC_PROP_PRE_INCR, /**< prefix increment of a property */
|
|
VM_OC_PROP_PRE_DECR, /**< prop prefix decrement of a property */
|
|
VM_OC_PROP_POST_INCR, /**< prop postfix increment of a property */
|
|
VM_OC_PROP_POST_DECR, /**< prop postfix decrement of a property */
|
|
VM_OC_PRE_INCR, /**< prefix increment */
|
|
VM_OC_PRE_DECR, /**< prefix decrement */
|
|
VM_OC_POST_INCR, /**< postfix increment */
|
|
VM_OC_POST_DECR, /**< postfix decrement */
|
|
|
|
VM_OC_PROP_DELETE, /**< delete property */
|
|
VM_OC_DELETE, /**< delete */
|
|
|
|
VM_OC_MOV_IDENT, /**< move identifier register reference */
|
|
VM_OC_ASSIGN, /**< assign */
|
|
VM_OC_ASSIGN_PROP, /**< assign property */
|
|
VM_OC_ASSIGN_PROP_THIS, /**< assign prop this */
|
|
|
|
VM_OC_RETURN, /**< return */
|
|
VM_OC_RETURN_FUNCTION_END, /**< return at the end of a function/script */
|
|
VM_OC_THROW, /**< throw */
|
|
VM_OC_THROW_REFERENCE_ERROR, /**< throw reference error */
|
|
|
|
VM_OC_EVAL, /**< eval */
|
|
VM_OC_CALL, /**< call */
|
|
VM_OC_NEW, /**< new */
|
|
VM_OC_RESOLVE_BASE_FOR_CALL, /**< resolve base value before call */
|
|
VM_OC_ERROR, /**< error while the vm_loop is suspended */
|
|
|
|
VM_OC_JUMP, /**< jump */
|
|
VM_OC_BRANCH_IF_NULLISH, /** branch if undefined or null */
|
|
VM_OC_BRANCH_OPTIONAL_CHAIN, /** branch if undefined or null and adjust stack */
|
|
VM_OC_POP_REFERENCE, /** prop identifier or property reference from the stack */
|
|
VM_OC_BRANCH_IF_STRICT_EQUAL, /**< branch if strict equal */
|
|
|
|
/* These four opcodes must be in this order. */
|
|
VM_OC_BRANCH_IF_TRUE, /**< branch if true */
|
|
VM_OC_BRANCH_IF_FALSE, /**< branch if false */
|
|
VM_OC_BRANCH_IF_LOGICAL_TRUE, /**< branch if logical true */
|
|
VM_OC_BRANCH_IF_LOGICAL_FALSE, /**< branch if logical false */
|
|
|
|
VM_OC_PLUS, /**< unary plus */
|
|
VM_OC_MINUS, /**< unary minus */
|
|
VM_OC_NOT, /**< not */
|
|
VM_OC_BIT_NOT, /**< bitwise not */
|
|
VM_OC_VOID, /**< void */
|
|
VM_OC_TYPEOF_IDENT, /**< typeof identifier */
|
|
VM_OC_TYPEOF, /**< typeof */
|
|
|
|
VM_OC_ADD, /**< binary add */
|
|
VM_OC_SUB, /**< binary sub */
|
|
VM_OC_MUL, /**< mul */
|
|
VM_OC_DIV, /**< div */
|
|
VM_OC_MOD, /**< mod */
|
|
VM_OC_EXP, /**< exponentiation */
|
|
|
|
VM_OC_EQUAL, /**< equal */
|
|
VM_OC_NOT_EQUAL, /**< not equal */
|
|
VM_OC_STRICT_EQUAL, /**< strict equal */
|
|
VM_OC_STRICT_NOT_EQUAL, /**< strict not equal */
|
|
VM_OC_LESS, /**< less */
|
|
VM_OC_GREATER, /**< greater */
|
|
VM_OC_LESS_EQUAL, /**< less equal */
|
|
VM_OC_GREATER_EQUAL, /**< greater equal */
|
|
VM_OC_IN, /**< in */
|
|
VM_OC_INSTANCEOF, /**< instanceof */
|
|
|
|
VM_OC_BIT_OR, /**< bitwise or */
|
|
VM_OC_BIT_XOR, /**< bitwise xor */
|
|
VM_OC_BIT_AND, /**< bitwise and */
|
|
VM_OC_LEFT_SHIFT, /**< left shift */
|
|
VM_OC_RIGHT_SHIFT, /**< right shift */
|
|
VM_OC_UNS_RIGHT_SHIFT, /**< unsigned right shift */
|
|
|
|
VM_OC_BLOCK_CREATE_CONTEXT, /**< create lexical environment for blocks enclosed in braces */
|
|
VM_OC_WITH, /**< with */
|
|
VM_OC_FOR_IN_INIT, /**< for-in init context */
|
|
VM_OC_FOR_IN_GET_NEXT, /**< get next */
|
|
VM_OC_FOR_IN_HAS_NEXT, /**< has next */
|
|
|
|
VM_OC_TRY, /**< try */
|
|
VM_OC_CATCH, /**< catch */
|
|
VM_OC_FINALLY, /**< finally */
|
|
VM_OC_CONTEXT_END, /**< context end */
|
|
VM_OC_JUMP_AND_EXIT_CONTEXT, /**< jump and exit context */
|
|
|
|
VM_OC_CREATE_BINDING, /**< create variables */
|
|
VM_OC_CREATE_ARGUMENTS, /**< create arguments object */
|
|
VM_OC_SET_BYTECODE_PTR, /**< setting bytecode pointer */
|
|
VM_OC_VAR_EVAL, /**< variable and function evaluation */
|
|
VM_OC_EXT_VAR_EVAL, /**< variable and function evaluation for
|
|
* functions with separate argument context */
|
|
VM_OC_INIT_ARG_OR_FUNC, /**< create and init a function or argument binding */
|
|
|
|
#if JERRY_DEBUGGER
|
|
VM_OC_BREAKPOINT_ENABLED, /**< enabled breakpoint for debugger */
|
|
VM_OC_BREAKPOINT_DISABLED, /**< disabled breakpoint for debugger */
|
|
#endif /* JERRY_DEBUGGER */
|
|
VM_OC_CLASS_CALL_STATIC_BLOCK, /**< call the class static block */
|
|
VM_OC_DEFINE_FIELD, /**< define class field */
|
|
VM_OC_PRIVATE_PROP_REFERENCE, /**< reference to class private method */
|
|
VM_OC_ASSIGN_PRIVATE, /**< assign to private field */
|
|
VM_OC_PRIVATE_FIELD_ADD, /**< add private field */
|
|
VM_OC_PRIVATE_PROP_GET, /**< get private field */
|
|
VM_OC_PRIVATE_IN, /**< 'in' opcode handler for private identifiers */
|
|
VM_OC_COLLECT_PRIVATE_PROPERTY, /**< collect private properties */
|
|
VM_OC_CHECK_VAR, /**< check redeclared vars in the global scope */
|
|
VM_OC_CHECK_LET, /**< check redeclared lets in the global scope */
|
|
VM_OC_ASSIGN_LET_CONST, /**< assign values to let/const declarations */
|
|
VM_OC_INIT_BINDING, /**< create and intialize a binding */
|
|
VM_OC_THROW_CONST_ERROR, /**< throw invalid assignment to const variable error */
|
|
VM_OC_COPY_TO_GLOBAL, /**< copy value to global lex env */
|
|
VM_OC_COPY_FROM_ARG, /**< copy value from arg lex env */
|
|
VM_OC_CLONE_CONTEXT, /**< clone lexical environment with let/const declarations */
|
|
VM_OC_COPY_DATA_PROPERTIES, /**< copy data properties of an object */
|
|
VM_OC_SET_COMPUTED_PROPERTY, /**< set computed property */
|
|
|
|
VM_OC_FOR_OF_INIT, /**< for-of init context */
|
|
VM_OC_FOR_OF_GET_NEXT, /**< for-of get next */
|
|
VM_OC_FOR_OF_HAS_NEXT, /**< for-of has next */
|
|
VM_OC_FOR_AWAIT_OF_INIT, /**< for-await-of init context */
|
|
VM_OC_FOR_AWAIT_OF_HAS_NEXT, /**< for-await-of has next */
|
|
|
|
VM_OC_LOCAL_EVAL, /**< eval in local context */
|
|
VM_OC_SUPER_CALL, /**< call the 'super' constructor */
|
|
VM_OC_PUSH_CLASS_ENVIRONMENT, /**< push class environment */
|
|
VM_OC_PUSH_IMPLICIT_CTOR, /**< create implicit class constructor */
|
|
VM_OC_INIT_CLASS, /**< initialize class */
|
|
VM_OC_FINALIZE_CLASS, /**< finalize class */
|
|
VM_OC_SET_FIELD_INIT, /**< store the class field initializer function */
|
|
VM_OC_SET_STATIC_FIELD_INIT, /**< store the static class field initializer function */
|
|
VM_OC_RUN_FIELD_INIT, /**< run the class field initializer function */
|
|
VM_OC_RUN_STATIC_FIELD_INIT, /**< run the static class field initializer function */
|
|
VM_OC_SET_NEXT_COMPUTED_FIELD, /**< set the next computed field of a class */
|
|
VM_OC_PUSH_SUPER_CONSTRUCTOR, /**< getSuperConstructor operation */
|
|
VM_OC_RESOLVE_LEXICAL_THIS, /**< resolve this_binding from from the lexical environment */
|
|
VM_OC_SUPER_REFERENCE, /**< push super reference */
|
|
VM_OC_SET_HOME_OBJECT, /**< set the [[HomeObject]] environment in an object literal */
|
|
VM_OC_OBJECT_LITERAL_HOME_ENV, /**< create/destroy [[HomeObject]] environment of an object literal */
|
|
VM_OC_SET_FUNCTION_NAME, /**< set function name property */
|
|
|
|
VM_OC_PUSH_SPREAD_ELEMENT, /**< push spread element */
|
|
VM_OC_PUSH_REST_OBJECT, /**< push rest object */
|
|
VM_OC_ITERATOR_CONTEXT_CREATE, /**< create iterator conext */
|
|
VM_OC_ITERATOR_CONTEXT_END, /**< finalize iterator cotnext */
|
|
VM_OC_ITERATOR_STEP, /**< IteratorStep abstract operation */
|
|
VM_OC_OBJ_INIT_CONTEXT_CREATE, /**< create object initializer context */
|
|
VM_OC_OBJ_INIT_CONTEXT_END, /**< finalize object initializer context */
|
|
VM_OC_OBJ_INIT_PUSH_REST, /**< push the object with the rest properties */
|
|
VM_OC_INITIALIZER_PUSH_NAME, /**< append string to name list array and push the string */
|
|
VM_OC_DEFAULT_INITIALIZER, /**< default initializer inside a pattern */
|
|
VM_OC_REST_INITIALIZER, /**< create rest object inside an array pattern */
|
|
VM_OC_INITIALIZER_PUSH_PROP, /**< push property for object initializer */
|
|
VM_OC_SPREAD_ARGUMENTS, /**< perform function call/construct with spreaded arguments */
|
|
VM_OC_CREATE_GENERATOR, /**< create a generator object */
|
|
VM_OC_YIELD, /**< yield operation */
|
|
VM_OC_ASYNC_YIELD, /**< async yield operation */
|
|
VM_OC_ASYNC_YIELD_ITERATOR, /**< async yield iterator operation */
|
|
VM_OC_AWAIT, /**< await operation */
|
|
VM_OC_GENERATOR_AWAIT, /**< generator await operation */
|
|
VM_OC_EXT_RETURN, /**< return which also clears the stack */
|
|
VM_OC_ASYNC_EXIT, /**< return from async function */
|
|
VM_OC_STRING_CONCAT, /**< string concatenation */
|
|
VM_OC_GET_TEMPLATE_OBJECT, /**< GetTemplateObject operation */
|
|
VM_OC_PUSH_NEW_TARGET, /**< push new.target onto the stack */
|
|
VM_OC_REQUIRE_OBJECT_COERCIBLE, /**< RequireObjectCoercible opretaion */
|
|
VM_OC_ASSIGN_SUPER, /**< assign super reference */
|
|
VM_OC_SET__PROTO__, /**< set prototype when __proto__: form is used */
|
|
VM_OC_PUSH_STATIC_FIELD_FUNC, /**< push static field initializer function */
|
|
VM_OC_ADD_COMPUTED_FIELD, /**< add computed field name */
|
|
#if JERRY_MODULE_SYSTEM
|
|
VM_OC_MODULE_IMPORT, /**< module dynamic import */
|
|
VM_OC_MODULE_IMPORT_META, /**< module import.meta */
|
|
#endif /* JERRY_MODULE_SYSTEM */
|
|
|
|
VM_OC_NONE, /**< a special opcode for unsupported byte codes */
|
|
} vm_oc_types;
|
|
|
|
/**
|
|
* Unused opcodes, but required by byte-code types.
|
|
*/
|
|
typedef enum
|
|
{
|
|
#if !JERRY_DEBUGGER
|
|
VM_OC_BREAKPOINT_ENABLED = VM_OC_NONE, /**< enabled breakpoint for debugger is unused */
|
|
VM_OC_BREAKPOINT_DISABLED = VM_OC_NONE, /**< disabled breakpoint for debugger is unused */
|
|
#endif /* !JERRY_DEBUGGER */
|
|
#if !JERRY_MODULE_SYSTEM
|
|
VM_OC_MODULE_IMPORT = VM_OC_NONE, /**< module dynamic import */
|
|
VM_OC_MODULE_IMPORT_META = VM_OC_NONE, /**< module import.meta */
|
|
#endif /* JERRY_MODULE_SYSTEM */
|
|
|
|
VM_OC_UNUSED = VM_OC_NONE /**< placeholder if the list is empty */
|
|
} vm_oc_unused_types;
|
|
|
|
/**
|
|
* Decrement operator.
|
|
*/
|
|
#define VM_OC_DECREMENT_OPERATOR_FLAG 0x1
|
|
|
|
/**
|
|
* Postfix increment/decrement operator.
|
|
*/
|
|
#define VM_OC_POST_INCR_DECR_OPERATOR_FLAG 0x2
|
|
|
|
/**
|
|
* An named variable is updated by the increment/decrement operator.
|
|
*/
|
|
#define VM_OC_IDENT_INCR_DECR_OPERATOR_FLAG 0x4
|
|
|
|
/**
|
|
* Jump to target offset if input value is logical false.
|
|
*/
|
|
#define VM_OC_BRANCH_IF_FALSE_FLAG 0x1
|
|
|
|
/**
|
|
* Branch optimized for logical and/or opcodes.
|
|
*/
|
|
#define VM_OC_LOGICAL_BRANCH_FLAG 0x2
|
|
|
|
/**
|
|
* Bit index shift for non-static property initializers.
|
|
*/
|
|
#define VM_OC_NON_STATIC_SHIFT 15
|
|
|
|
/**
|
|
* This flag is set for static property initializers.
|
|
*/
|
|
#define VM_OC_NON_STATIC_FLAG (0x1 << VM_OC_NON_STATIC_SHIFT)
|
|
|
|
/**
|
|
* Position of "put result" opcode.
|
|
*/
|
|
#define VM_OC_PUT_RESULT_SHIFT 11
|
|
|
|
/**
|
|
* Mask of "put result" opcode.
|
|
*/
|
|
#define VM_OC_PUT_RESULT_MASK 0xf
|
|
|
|
/**
|
|
* Generate a "put result" opcode flag bit.
|
|
*/
|
|
#define VM_OC_PUT_RESULT_CREATE_FLAG(V) (((V) &VM_OC_PUT_RESULT_MASK) << VM_OC_PUT_RESULT_SHIFT)
|
|
|
|
/**
|
|
* Checks whether the result is stored somewhere.
|
|
*/
|
|
#define VM_OC_HAS_PUT_RESULT(V) ((V) & (VM_OC_PUT_RESULT_MASK << VM_OC_PUT_RESULT_SHIFT))
|
|
|
|
/**
|
|
* Specify where the result is stored
|
|
*/
|
|
typedef enum
|
|
{
|
|
VM_OC_PUT_IDENT = VM_OC_PUT_RESULT_CREATE_FLAG (0x1),
|
|
VM_OC_PUT_REFERENCE = VM_OC_PUT_RESULT_CREATE_FLAG (0x2),
|
|
VM_OC_PUT_STACK = VM_OC_PUT_RESULT_CREATE_FLAG (0x4),
|
|
VM_OC_PUT_BLOCK = VM_OC_PUT_RESULT_CREATE_FLAG (0x8),
|
|
} vm_oc_put_types;
|
|
|
|
/**
|
|
* Non-recursive vm_loop: the vm_loop can be suspended
|
|
* to execute a call /construct operation. These return
|
|
* types of the vm_loop tells whether a call operation
|
|
* is in progress or the vm_loop is finished.
|
|
*/
|
|
typedef enum
|
|
{
|
|
VM_NO_EXEC_OP, /**< do nothing */
|
|
VM_EXEC_CALL, /**< invoke a function */
|
|
VM_EXEC_SUPER_CALL, /**< invoke a function through 'super' keyword */
|
|
VM_EXEC_SPREAD_OP, /**< call/construct operation with spreaded argument list */
|
|
VM_EXEC_RETURN, /**< return with the completion value without freeing registers */
|
|
VM_EXEC_CONSTRUCT, /**< construct a new object */
|
|
} vm_call_operation;
|
|
|
|
ecma_value_t vm_run_global (const ecma_compiled_code_t *bytecode_p, ecma_object_t *function_object_p);
|
|
ecma_value_t vm_run_eval (ecma_compiled_code_t *bytecode_data_p, uint32_t parse_opts);
|
|
|
|
#if JERRY_MODULE_SYSTEM
|
|
ecma_value_t vm_run_module (ecma_module_t *module_p);
|
|
ecma_value_t vm_init_module_scope (ecma_module_t *module_p);
|
|
#endif /* JERRY_MODULE_SYSTEM */
|
|
|
|
ecma_value_t vm_run (vm_frame_ctx_shared_t *shared_p, ecma_value_t this_binding_value, ecma_object_t *lex_env_p);
|
|
ecma_value_t vm_execute (vm_frame_ctx_t *frame_ctx_p);
|
|
|
|
bool vm_is_strict_mode (void);
|
|
bool vm_is_direct_eval_form_call (void);
|
|
|
|
ecma_value_t vm_get_backtrace (uint32_t max_depth);
|
|
|
|
/**
|
|
* @}
|
|
* @}
|
|
*/
|
|
|
|
#endif /* !VM_H */
|