| Index: test/cctest/interpreter/bytecode_expectations/ForOf.golden
|
| diff --git a/test/cctest/interpreter/bytecode_expectations/ForOf.golden b/test/cctest/interpreter/bytecode_expectations/ForOf.golden
|
| index a5f7f6e683067db1b0dc710b291266300581c73c..5fc593a1b96bed862abb217b3dcd53de77bcb4a2 100644
|
| --- a/test/cctest/interpreter/bytecode_expectations/ForOf.golden
|
| +++ b/test/cctest/interpreter/bytecode_expectations/ForOf.golden
|
| @@ -9,7 +9,7 @@ wrap: yes
|
| snippet: "
|
| for (var p of [0, 1, 2]) {}
|
| "
|
| -frame size: 15
|
| +frame size: 16
|
| parameter count: 1
|
| bytecode array length: 272
|
| bytecodes: [
|
| @@ -18,25 +18,25 @@ bytecodes: [
|
| B(Star), R(4),
|
| B(Mov), R(context), R(11),
|
| B(Mov), R(context), R(12),
|
| - /* 48 S> */ B(CreateArrayLiteral), U8(0), U8(2), U8(9),
|
| - B(Star), R(13),
|
| - B(LdaNamedProperty), R(13), U8(1), U8(3),
|
| + /* 48 S> */ B(CreateArrayLiteral), U8(0), U8(4), U8(9),
|
| B(Star), R(14),
|
| - B(CallProperty), R(14), R(13), U8(1), U8(5),
|
| + B(LdaNamedProperty), R(14), U8(1), U8(5),
|
| + B(Star), R(15),
|
| + B(CallProperty), R(15), R(14), U8(1), U8(7),
|
| B(JumpIfJSReceiver), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowSymbolIteratorInvalid), R(0), U8(0),
|
| B(Star), R(2),
|
| - /* 45 S> */ B(LdaNamedProperty), R(2), U8(2), U8(9),
|
| - B(Star), R(13),
|
| - /* 45 E> */ B(CallProperty), R(13), R(2), U8(1), U8(7),
|
| + /* 45 S> */ B(LdaNamedProperty), R(2), U8(2), U8(13),
|
| + B(Star), R(14),
|
| + /* 45 E> */ B(CallProperty), R(14), R(2), U8(1), U8(11),
|
| B(Star), R(3),
|
| /* 45 E> */ B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(3), U8(1),
|
| B(ToBooleanLogicalNot),
|
| B(JumpIfFalse), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(3), U8(1),
|
| - B(LdaNamedProperty), R(3), U8(3), U8(11),
|
| + B(LdaNamedProperty), R(3), U8(3), U8(17),
|
| B(JumpIfToBooleanTrue), U8(25),
|
| - B(LdaNamedProperty), R(3), U8(4), U8(13),
|
| + B(LdaNamedProperty), R(3), U8(4), U8(19),
|
| B(Star), R(5),
|
| B(LdaSmi), I8(2),
|
| B(Star), R(4),
|
| @@ -53,7 +53,7 @@ bytecodes: [
|
| B(Star), R(12),
|
| B(PushContext), R(8),
|
| B(LdaSmi), I8(2),
|
| - B(TestEqualStrict), R(4), U8(15),
|
| + B(TestEqualStrict), R(4), U8(31),
|
| B(JumpIfFalse), U8(6),
|
| B(LdaSmi), I8(1),
|
| B(Star), R(4),
|
| @@ -71,21 +71,21 @@ bytecodes: [
|
| B(SetPendingMessage),
|
| B(Star), R(11),
|
| B(LdaZero),
|
| - B(TestEqualStrict), R(4), U8(16),
|
| + B(TestEqualStrict), R(4), U8(34),
|
| B(JumpIfTrue), U8(111),
|
| - B(LdaNamedProperty), R(2), U8(7), U8(17),
|
| + B(LdaNamedProperty), R(2), U8(7), U8(35),
|
| B(Star), R(6),
|
| B(TestUndetectable), R(6),
|
| B(JumpIfFalse), U8(4),
|
| B(Jump), U8(99),
|
| B(LdaSmi), I8(1),
|
| - B(TestEqualStrict), R(4), U8(20),
|
| + B(TestEqualStrict), R(4), U8(40),
|
| B(JumpIfFalse), U8(67),
|
| B(Ldar), R(6),
|
| B(TypeOf),
|
| B(Star), R(12),
|
| B(LdaConstant), U8(8),
|
| - B(TestEqualStrict), R(12), U8(21),
|
| + B(TestEqualStrict), R(12), U8(41),
|
| B(JumpIfFalse), U8(4),
|
| B(Jump), U8(18),
|
| B(Wide), B(LdaSmi), I16(130),
|
| @@ -109,9 +109,9 @@ bytecodes: [
|
| B(PushContext), R(8),
|
| B(PopContext), R(8),
|
| B(Jump), U8(27),
|
| - B(Mov), R(6), R(12),
|
| - B(Mov), R(2), R(13),
|
| - B(InvokeIntrinsic), U8(Runtime::k_Call), R(12), U8(2),
|
| + B(Mov), R(6), R(13),
|
| + B(Mov), R(2), R(14),
|
| + B(InvokeIntrinsic), U8(Runtime::k_Call), R(13), U8(2),
|
| B(Star), R(7),
|
| B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(7), U8(1),
|
| B(JumpIfToBooleanFalse), U8(4),
|
| @@ -152,7 +152,7 @@ snippet: "
|
| var x = 'potatoes';
|
| for (var p of x) { return p; }
|
| "
|
| -frame size: 16
|
| +frame size: 17
|
| parameter count: 1
|
| bytecode array length: 286
|
| bytecodes: [
|
| @@ -163,24 +163,24 @@ bytecodes: [
|
| B(Star), R(5),
|
| B(Mov), R(context), R(12),
|
| B(Mov), R(context), R(13),
|
| - /* 68 S> */ B(LdaNamedProperty), R(0), U8(1), U8(2),
|
| - B(Star), R(15),
|
| - B(CallProperty), R(15), R(0), U8(1), U8(4),
|
| - B(Mov), R(0), R(14),
|
| + /* 68 S> */ B(LdaNamedProperty), R(0), U8(1), U8(6),
|
| + B(Star), R(16),
|
| + B(CallProperty), R(16), R(0), U8(1), U8(8),
|
| + B(Mov), R(0), R(15),
|
| B(JumpIfJSReceiver), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowSymbolIteratorInvalid), R(0), U8(0),
|
| B(Star), R(3),
|
| - /* 65 S> */ B(LdaNamedProperty), R(3), U8(2), U8(8),
|
| - B(Star), R(14),
|
| - /* 65 E> */ B(CallProperty), R(14), R(3), U8(1), U8(6),
|
| + /* 65 S> */ B(LdaNamedProperty), R(3), U8(2), U8(14),
|
| + B(Star), R(15),
|
| + /* 65 E> */ B(CallProperty), R(15), R(3), U8(1), U8(12),
|
| B(Star), R(4),
|
| /* 65 E> */ B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(4), U8(1),
|
| B(ToBooleanLogicalNot),
|
| B(JumpIfFalse), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(4), U8(1),
|
| - B(LdaNamedProperty), R(4), U8(3), U8(10),
|
| + B(LdaNamedProperty), R(4), U8(3), U8(18),
|
| B(JumpIfToBooleanTrue), U8(27),
|
| - B(LdaNamedProperty), R(4), U8(4), U8(12),
|
| + B(LdaNamedProperty), R(4), U8(4), U8(20),
|
| B(Star), R(6),
|
| B(LdaSmi), I8(2),
|
| B(Star), R(5),
|
| @@ -198,7 +198,7 @@ bytecodes: [
|
| B(Star), R(13),
|
| B(PushContext), R(9),
|
| B(LdaSmi), I8(2),
|
| - B(TestEqualStrict), R(5), U8(14),
|
| + B(TestEqualStrict), R(5), U8(32),
|
| B(JumpIfFalse), U8(6),
|
| B(LdaSmi), I8(1),
|
| B(Star), R(5),
|
| @@ -216,21 +216,21 @@ bytecodes: [
|
| B(SetPendingMessage),
|
| B(Star), R(12),
|
| B(LdaZero),
|
| - B(TestEqualStrict), R(5), U8(15),
|
| + B(TestEqualStrict), R(5), U8(35),
|
| B(JumpIfTrue), U8(111),
|
| - B(LdaNamedProperty), R(3), U8(7), U8(16),
|
| + B(LdaNamedProperty), R(3), U8(7), U8(36),
|
| B(Star), R(7),
|
| B(TestUndetectable), R(7),
|
| B(JumpIfFalse), U8(4),
|
| B(Jump), U8(99),
|
| B(LdaSmi), I8(1),
|
| - B(TestEqualStrict), R(5), U8(19),
|
| + B(TestEqualStrict), R(5), U8(41),
|
| B(JumpIfFalse), U8(67),
|
| B(Ldar), R(7),
|
| B(TypeOf),
|
| B(Star), R(13),
|
| B(LdaConstant), U8(8),
|
| - B(TestEqualStrict), R(13), U8(20),
|
| + B(TestEqualStrict), R(13), U8(42),
|
| B(JumpIfFalse), U8(4),
|
| B(Jump), U8(18),
|
| B(Wide), B(LdaSmi), I16(130),
|
| @@ -254,9 +254,9 @@ bytecodes: [
|
| B(PushContext), R(9),
|
| B(PopContext), R(9),
|
| B(Jump), U8(27),
|
| - B(Mov), R(7), R(13),
|
| - B(Mov), R(3), R(14),
|
| - B(InvokeIntrinsic), U8(Runtime::k_Call), R(13), U8(2),
|
| + B(Mov), R(7), R(14),
|
| + B(Mov), R(3), R(15),
|
| + B(InvokeIntrinsic), U8(Runtime::k_Call), R(14), U8(2),
|
| B(Star), R(8),
|
| B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(8), U8(1),
|
| B(JumpIfToBooleanFalse), U8(4),
|
| @@ -304,7 +304,7 @@ snippet: "
|
| if (x == 20) break;
|
| }
|
| "
|
| -frame size: 15
|
| +frame size: 16
|
| parameter count: 1
|
| bytecode array length: 290
|
| bytecodes: [
|
| @@ -313,25 +313,25 @@ bytecodes: [
|
| B(Star), R(4),
|
| B(Mov), R(context), R(11),
|
| B(Mov), R(context), R(12),
|
| - /* 48 S> */ B(CreateArrayLiteral), U8(0), U8(2), U8(9),
|
| - B(Star), R(13),
|
| - B(LdaNamedProperty), R(13), U8(1), U8(3),
|
| + /* 48 S> */ B(CreateArrayLiteral), U8(0), U8(4), U8(9),
|
| B(Star), R(14),
|
| - B(CallProperty), R(14), R(13), U8(1), U8(5),
|
| + B(LdaNamedProperty), R(14), U8(1), U8(5),
|
| + B(Star), R(15),
|
| + B(CallProperty), R(15), R(14), U8(1), U8(7),
|
| B(JumpIfJSReceiver), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowSymbolIteratorInvalid), R(0), U8(0),
|
| B(Star), R(2),
|
| - /* 45 S> */ B(LdaNamedProperty), R(2), U8(2), U8(9),
|
| - B(Star), R(13),
|
| - /* 45 E> */ B(CallProperty), R(13), R(2), U8(1), U8(7),
|
| + /* 45 S> */ B(LdaNamedProperty), R(2), U8(2), U8(13),
|
| + B(Star), R(14),
|
| + /* 45 E> */ B(CallProperty), R(14), R(2), U8(1), U8(11),
|
| B(Star), R(3),
|
| /* 45 E> */ B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(3), U8(1),
|
| B(ToBooleanLogicalNot),
|
| B(JumpIfFalse), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(3), U8(1),
|
| - B(LdaNamedProperty), R(3), U8(3), U8(11),
|
| + B(LdaNamedProperty), R(3), U8(3), U8(17),
|
| B(JumpIfToBooleanTrue), U8(43),
|
| - B(LdaNamedProperty), R(3), U8(4), U8(13),
|
| + B(LdaNamedProperty), R(3), U8(4), U8(19),
|
| B(Star), R(5),
|
| B(LdaSmi), I8(2),
|
| B(Star), R(4),
|
| @@ -339,11 +339,11 @@ bytecodes: [
|
| /* 34 E> */ B(StackCheck),
|
| B(Mov), R(0), R(1),
|
| /* 66 S> */ B(LdaSmi), I8(10),
|
| - /* 72 E> */ B(TestEqual), R(1), U8(15),
|
| + /* 72 E> */ B(TestEqual), R(1), U8(29),
|
| B(JumpIfFalse), U8(4),
|
| /* 79 S> */ B(Jump), U8(14),
|
| /* 91 S> */ B(LdaSmi), I8(20),
|
| - /* 97 E> */ B(TestEqual), R(1), U8(16),
|
| + /* 97 E> */ B(TestEqual), R(1), U8(30),
|
| B(JumpIfFalse), U8(4),
|
| /* 104 S> */ B(Jump), U8(8),
|
| B(LdaZero),
|
| @@ -356,7 +356,7 @@ bytecodes: [
|
| B(Star), R(12),
|
| B(PushContext), R(8),
|
| B(LdaSmi), I8(2),
|
| - B(TestEqualStrict), R(4), U8(17),
|
| + B(TestEqualStrict), R(4), U8(33),
|
| B(JumpIfFalse), U8(6),
|
| B(LdaSmi), I8(1),
|
| B(Star), R(4),
|
| @@ -374,21 +374,21 @@ bytecodes: [
|
| B(SetPendingMessage),
|
| B(Star), R(11),
|
| B(LdaZero),
|
| - B(TestEqualStrict), R(4), U8(18),
|
| + B(TestEqualStrict), R(4), U8(36),
|
| B(JumpIfTrue), U8(111),
|
| - B(LdaNamedProperty), R(2), U8(7), U8(19),
|
| + B(LdaNamedProperty), R(2), U8(7), U8(37),
|
| B(Star), R(6),
|
| B(TestUndetectable), R(6),
|
| B(JumpIfFalse), U8(4),
|
| B(Jump), U8(99),
|
| B(LdaSmi), I8(1),
|
| - B(TestEqualStrict), R(4), U8(22),
|
| + B(TestEqualStrict), R(4), U8(42),
|
| B(JumpIfFalse), U8(67),
|
| B(Ldar), R(6),
|
| B(TypeOf),
|
| B(Star), R(12),
|
| B(LdaConstant), U8(8),
|
| - B(TestEqualStrict), R(12), U8(23),
|
| + B(TestEqualStrict), R(12), U8(43),
|
| B(JumpIfFalse), U8(4),
|
| B(Jump), U8(18),
|
| B(Wide), B(LdaSmi), I16(130),
|
| @@ -412,9 +412,9 @@ bytecodes: [
|
| B(PushContext), R(8),
|
| B(PopContext), R(8),
|
| B(Jump), U8(27),
|
| - B(Mov), R(6), R(12),
|
| - B(Mov), R(2), R(13),
|
| - B(InvokeIntrinsic), U8(Runtime::k_Call), R(12), U8(2),
|
| + B(Mov), R(6), R(13),
|
| + B(Mov), R(2), R(14),
|
| + B(InvokeIntrinsic), U8(Runtime::k_Call), R(13), U8(2),
|
| B(Star), R(7),
|
| B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(7), U8(1),
|
| B(JumpIfToBooleanFalse), U8(4),
|
| @@ -455,44 +455,44 @@ snippet: "
|
| var x = { 'a': 1, 'b': 2 };
|
| for (x['a'] of [1,2,3]) { return x['a']; }
|
| "
|
| -frame size: 14
|
| +frame size: 15
|
| parameter count: 1
|
| bytecode array length: 297
|
| bytecodes: [
|
| /* 30 E> */ B(StackCheck),
|
| - /* 42 S> */ B(CreateObjectLiteral), U8(0), U8(2), U8(1), R(8),
|
| - B(Mov), R(8), R(0),
|
| + /* 42 S> */ B(CreateObjectLiteral), U8(0), U8(2), U8(1), R(9),
|
| + B(Mov), R(9), R(0),
|
| B(LdaZero),
|
| B(Star), R(3),
|
| B(Mov), R(context), R(10),
|
| B(Mov), R(context), R(11),
|
| - /* 77 S> */ B(CreateArrayLiteral), U8(1), U8(3), U8(9),
|
| - B(Star), R(12),
|
| - B(LdaNamedProperty), R(12), U8(2), U8(4),
|
| + /* 77 S> */ B(CreateArrayLiteral), U8(1), U8(7), U8(9),
|
| B(Star), R(13),
|
| - B(CallProperty), R(13), R(12), U8(1), U8(6),
|
| + B(LdaNamedProperty), R(13), U8(2), U8(8),
|
| + B(Star), R(14),
|
| + B(CallProperty), R(14), R(13), U8(1), U8(10),
|
| B(JumpIfJSReceiver), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowSymbolIteratorInvalid), R(0), U8(0),
|
| B(Star), R(1),
|
| - /* 74 S> */ B(LdaNamedProperty), R(1), U8(3), U8(10),
|
| - B(Star), R(12),
|
| - /* 74 E> */ B(CallProperty), R(12), R(1), U8(1), U8(8),
|
| + /* 74 S> */ B(LdaNamedProperty), R(1), U8(3), U8(16),
|
| + B(Star), R(13),
|
| + /* 74 E> */ B(CallProperty), R(13), R(1), U8(1), U8(14),
|
| B(Star), R(2),
|
| /* 74 E> */ B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(2), U8(1),
|
| B(ToBooleanLogicalNot),
|
| B(JumpIfFalse), U8(7),
|
| B(CallRuntime), U16(Runtime::kThrowIteratorResultNotAnObject), R(2), U8(1),
|
| - B(LdaNamedProperty), R(2), U8(4), U8(12),
|
| + B(LdaNamedProperty), R(2), U8(4), U8(20),
|
| B(JumpIfToBooleanTrue), U8(31),
|
| - /* 67 E> */ B(LdaNamedProperty), R(2), U8(5), U8(14),
|
| + /* 67 E> */ B(LdaNamedProperty), R(2), U8(5), U8(22),
|
| B(Star), R(4),
|
| B(LdaSmi), I8(2),
|
| B(Star), R(3),
|
| B(Ldar), R(4),
|
| - B(StaNamedPropertySloppy), R(0), U8(6), U8(16),
|
| + B(StaNamedPropertySloppy), R(0), U8(6), U8(28),
|
| /* 62 E> */ B(StackCheck),
|
| /* 88 S> */ B(Nop),
|
| - /* 96 E> */ B(LdaNamedProperty), R(0), U8(6), U8(18),
|
| + /* 96 E> */ B(LdaNamedProperty), R(0), U8(6), U8(32),
|
| B(Star), R(9),
|
| B(LdaZero),
|
| B(Star), R(8),
|
| @@ -504,7 +504,7 @@ bytecodes: [
|
| B(Star), R(11),
|
| B(PushContext), R(7),
|
| B(LdaSmi), I8(2),
|
| - B(TestEqualStrict), R(3), U8(20),
|
| + B(TestEqualStrict), R(3), U8(36),
|
| B(JumpIfFalse), U8(6),
|
| B(LdaSmi), I8(1),
|
| B(Star), R(3),
|
| @@ -522,21 +522,21 @@ bytecodes: [
|
| B(SetPendingMessage),
|
| B(Star), R(10),
|
| B(LdaZero),
|
| - B(TestEqualStrict), R(3), U8(21),
|
| + B(TestEqualStrict), R(3), U8(39),
|
| B(JumpIfTrue), U8(111),
|
| - B(LdaNamedProperty), R(1), U8(9), U8(22),
|
| + B(LdaNamedProperty), R(1), U8(9), U8(40),
|
| B(Star), R(5),
|
| B(TestUndetectable), R(5),
|
| B(JumpIfFalse), U8(4),
|
| B(Jump), U8(99),
|
| B(LdaSmi), I8(1),
|
| - B(TestEqualStrict), R(3), U8(25),
|
| + B(TestEqualStrict), R(3), U8(45),
|
| B(JumpIfFalse), U8(67),
|
| B(Ldar), R(5),
|
| B(TypeOf),
|
| B(Star), R(11),
|
| B(LdaConstant), U8(10),
|
| - B(TestEqualStrict), R(11), U8(26),
|
| + B(TestEqualStrict), R(11), U8(46),
|
| B(JumpIfFalse), U8(4),
|
| B(Jump), U8(18),
|
| B(Wide), B(LdaSmi), I16(130),
|
| @@ -560,9 +560,9 @@ bytecodes: [
|
| B(PushContext), R(7),
|
| B(PopContext), R(7),
|
| B(Jump), U8(27),
|
| - B(Mov), R(5), R(11),
|
| - B(Mov), R(1), R(12),
|
| - B(InvokeIntrinsic), U8(Runtime::k_Call), R(11), U8(2),
|
| + B(Mov), R(5), R(12),
|
| + B(Mov), R(1), R(13),
|
| + B(InvokeIntrinsic), U8(Runtime::k_Call), R(12), U8(2),
|
| B(Star), R(6),
|
| B(InvokeIntrinsic), U8(Runtime::k_IsJSReceiver), R(6), U8(1),
|
| B(JumpIfToBooleanFalse), U8(4),
|
|
|