ad4e8a2796
There were a couple of issues with it: - interpreter is not supported - the source position was just accidentally correct for full-codegen - the eval origin could have been cached Also fixes a few other places to use AbstractCode. R=mstarzinger@chromium.org Committed: https://crrev.com/2f3a171adc9e620c2235bf0562145b9d4eaba66d Cr-Commit-Position: refs/heads/master@{#35257} Review URL: https://codereview.chromium.org/1854713002 Cr-Commit-Position: refs/heads/master@{#35481}
141 lines
3.0 KiB
Plaintext
141 lines
3.0 KiB
Plaintext
#
|
|
# Autogenerated by generate-bytecode-expectations.
|
|
#
|
|
|
|
---
|
|
pool type: string
|
|
execute: yes
|
|
wrap: yes
|
|
|
|
---
|
|
snippet: "
|
|
eval('var x = 10;'); return x;
|
|
"
|
|
frame size: 9
|
|
parameter count: 1
|
|
bytecode array length: 67
|
|
bytecodes: [
|
|
B(CallRuntime), U16(Runtime::kNewFunctionContext), R(closure), U8(1),
|
|
B(PushContext), R(0),
|
|
B(Ldar), R(this),
|
|
B(StaContextSlot), R(context), U8(4),
|
|
B(CreateMappedArguments),
|
|
B(StaContextSlot), R(context), U8(5),
|
|
B(Ldar), R(new_target),
|
|
B(StaContextSlot), R(context), U8(6),
|
|
B(StackCheck),
|
|
B(LdaConstant), U8(0),
|
|
B(Star), R(3),
|
|
B(CallRuntimeForPair), U16(Runtime::kLoadLookupSlotForCall), R(3), U8(1), R(1),
|
|
B(LdaConstant), U8(1),
|
|
B(Star), R(3),
|
|
B(Mov), R(1), R(4),
|
|
B(Mov), R(3), R(5),
|
|
B(Mov), R(closure), R(6),
|
|
B(LdaZero),
|
|
B(Star), R(7),
|
|
B(LdaSmi), U8(34),
|
|
B(Star), R(8),
|
|
B(CallRuntime), U16(Runtime::kResolvePossiblyDirectEval), R(4), U8(5),
|
|
B(Star), R(1),
|
|
B(Call), R(1), R(2), U8(2), U8(0),
|
|
B(LdaLookupSlot), U8(2),
|
|
B(Return),
|
|
]
|
|
constant pool: [
|
|
"eval",
|
|
"var x = 10;",
|
|
"x",
|
|
]
|
|
handlers: [
|
|
]
|
|
|
|
---
|
|
snippet: "
|
|
eval('var x = 10;'); return typeof x;
|
|
"
|
|
frame size: 9
|
|
parameter count: 1
|
|
bytecode array length: 68
|
|
bytecodes: [
|
|
B(CallRuntime), U16(Runtime::kNewFunctionContext), R(closure), U8(1),
|
|
B(PushContext), R(0),
|
|
B(Ldar), R(this),
|
|
B(StaContextSlot), R(context), U8(4),
|
|
B(CreateMappedArguments),
|
|
B(StaContextSlot), R(context), U8(5),
|
|
B(Ldar), R(new_target),
|
|
B(StaContextSlot), R(context), U8(6),
|
|
B(StackCheck),
|
|
B(LdaConstant), U8(0),
|
|
B(Star), R(3),
|
|
B(CallRuntimeForPair), U16(Runtime::kLoadLookupSlotForCall), R(3), U8(1), R(1),
|
|
B(LdaConstant), U8(1),
|
|
B(Star), R(3),
|
|
B(Mov), R(1), R(4),
|
|
B(Mov), R(3), R(5),
|
|
B(Mov), R(closure), R(6),
|
|
B(LdaZero),
|
|
B(Star), R(7),
|
|
B(LdaSmi), U8(34),
|
|
B(Star), R(8),
|
|
B(CallRuntime), U16(Runtime::kResolvePossiblyDirectEval), R(4), U8(5),
|
|
B(Star), R(1),
|
|
B(Call), R(1), R(2), U8(2), U8(0),
|
|
B(LdaLookupSlotInsideTypeof), U8(2),
|
|
B(TypeOf),
|
|
B(Return),
|
|
]
|
|
constant pool: [
|
|
"eval",
|
|
"var x = 10;",
|
|
"x",
|
|
]
|
|
handlers: [
|
|
]
|
|
|
|
---
|
|
snippet: "
|
|
x = 20; return eval('');
|
|
"
|
|
frame size: 9
|
|
parameter count: 1
|
|
bytecode array length: 69
|
|
bytecodes: [
|
|
B(CallRuntime), U16(Runtime::kNewFunctionContext), R(closure), U8(1),
|
|
B(PushContext), R(0),
|
|
B(Ldar), R(this),
|
|
B(StaContextSlot), R(context), U8(4),
|
|
B(CreateMappedArguments),
|
|
B(StaContextSlot), R(context), U8(5),
|
|
B(Ldar), R(new_target),
|
|
B(StaContextSlot), R(context), U8(6),
|
|
B(StackCheck),
|
|
B(LdaSmi), U8(20),
|
|
B(StaLookupSlotSloppy), U8(0),
|
|
B(LdaConstant), U8(1),
|
|
B(Star), R(3),
|
|
B(CallRuntimeForPair), U16(Runtime::kLoadLookupSlotForCall), R(3), U8(1), R(1),
|
|
B(LdaConstant), U8(2),
|
|
B(Star), R(3),
|
|
B(Mov), R(1), R(4),
|
|
B(Mov), R(3), R(5),
|
|
B(Mov), R(closure), R(6),
|
|
B(LdaZero),
|
|
B(Star), R(7),
|
|
B(LdaSmi), U8(49),
|
|
B(Star), R(8),
|
|
B(CallRuntime), U16(Runtime::kResolvePossiblyDirectEval), R(4), U8(5),
|
|
B(Star), R(1),
|
|
B(Call), R(1), R(2), U8(2), U8(0),
|
|
B(Return),
|
|
]
|
|
constant pool: [
|
|
"x",
|
|
"eval",
|
|
"",
|
|
]
|
|
handlers: [
|
|
]
|
|
|