2017-05-24 12:12:53 +00:00
|
|
|
Tests breakable locations in for-of loops.
|
|
|
|
|
|
|
|
Running test: testBreakLocations
|
|
|
|
|
[inspector] moved var initialization break location before init expression (reland)
This CL improves break locations for expressions like 'var a = <expr>'. Without CL we use <expr> position as break location for initialization statement, with this CL we use position of first character after '=' as position.
Benefits (see test for details):
- only one break in expressions which includes mix of property lookup and calls, e.g. var p = Promise.resolve().then(x => x * 2),
- removed redundant break location for expressions like: let { x, y } = { x: 1, y: 2}.
TBR=dgozman@chromium.org,rmcilroy@chromium.org,machenbach@chromium.org,marja@chromium.org,kozyatinskiy@chromium.org,devtools-reviews@chromium.org,v8-reviews@googlegroups.com
# Not skipping CQ checks because original CL landed > 1 day ago.
Bug: v8:5909
Change-Id: Ie84fa79afeed09e28cf8478ba610a0cfbfdfc294
Reviewed-on: https://chromium-review.googlesource.com/518116
Commit-Queue: Aleksey Kozyatinskiy <kozyatinskiy@chromium.org>
Reviewed-by: Aleksey Kozyatinskiy <kozyatinskiy@chromium.org>
Cr-Commit-Position: refs/heads/master@{#45598}
2017-05-30 12:25:55 +00:00
|
|
|
Running test: testStepInto
|
|
|
|
|
2017-05-24 12:12:53 +00:00
|
|
|
function testFunction() {
|
|
|
|
var obj = |_|{a : 1};
|
|
|
|
var arr = |_|[1];
|
|
|
|
var all = |_|[];
|
2017-07-17 19:02:35 +00:00
|
|
|
for (var |_|k in |_|arr) { all.|C|push(k); }
|
Revert "[esnext] load `iterator.next` only once at beginning of iteration"
This reverts commit bf4cc9ee154f15942594016777f77d3208230f5f.
Reason for revert: Breaks windows with msvc and linux with gcc
https://build.chromium.org/p/client.v8/builders/V8%20Win64%20-%20msvc/builds/841
https://build.chromium.org/p/client.v8/builders/V8%20Linux%20gcc%204.8/builds/17265
Original change's description:
> [esnext] load `iterator.next` only once at beginning of iteration
>
> https://github.com/tc39/ecma262/pull/988 gained concensus during the
> september 2017 TC39 meetings. This moves the load of the "next" method
> to the very beginning of the iteration protocol, rather than during
> each iteration step.
>
> This impacts:
>
> - yield*
> - for-of loops
> - spread arguments
> - array spreads
>
> In the v8 implementation, this also affects async iteration versions of
> these things (the sole exception being the Async-From-Sync iterator,
> which requires a few more changes to work with this, likely done in a
> followup patch).
>
> This change introduces a new AST node, ResolvedProperty, which can be used
> as a callee by Call nodes to produce the same bytecode as Property calls,
> without observably re-loading the property. This is used in several
> AST-desugarings involving the iteration protocol.
>
> BUG=v8:6861, v8:5699
> R=rmcilroy@chromium.org, neis@chromium.org, adamk@chromium.org
>
> Cq-Include-Trybots: luci.v8.try:v8_linux_noi18n_rel_ng
> Change-Id: Ib81106a0182687fc5efea0bc32302ad06376773b
> Reviewed-on: https://chromium-review.googlesource.com/687997
> Commit-Queue: Caitlin Potter <caitp@igalia.com>
> Reviewed-by: Ross McIlroy <rmcilroy@chromium.org>
> Reviewed-by: Adam Klein <adamk@chromium.org>
> Reviewed-by: Georg Neis <neis@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#50452}
TBR=rmcilroy@chromium.org,adamk@chromium.org,neis@chromium.org,caitp@igalia.com,caitp@chromium.org
Change-Id: I1797c0d596dfd6850d6f0f505f591a7a990dd1f1
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: v8:6861, v8:5699
Cq-Include-Trybots: luci.v8.try:v8_linux_noi18n_rel_ng
Reviewed-on: https://chromium-review.googlesource.com/857616
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#50454}
2018-01-09 16:50:16 +00:00
|
|
|
for (var |_|k of |_|arr) { all.|C|push(k); }
|
2017-07-17 19:02:35 +00:00
|
|
|
for (var |_|k in |_|obj) { all.|C|push(k); }
|
|
|
|
for (let |_|k in |_|arr) { all.|C|push(k); }
|
Revert "[esnext] load `iterator.next` only once at beginning of iteration"
This reverts commit bf4cc9ee154f15942594016777f77d3208230f5f.
Reason for revert: Breaks windows with msvc and linux with gcc
https://build.chromium.org/p/client.v8/builders/V8%20Win64%20-%20msvc/builds/841
https://build.chromium.org/p/client.v8/builders/V8%20Linux%20gcc%204.8/builds/17265
Original change's description:
> [esnext] load `iterator.next` only once at beginning of iteration
>
> https://github.com/tc39/ecma262/pull/988 gained concensus during the
> september 2017 TC39 meetings. This moves the load of the "next" method
> to the very beginning of the iteration protocol, rather than during
> each iteration step.
>
> This impacts:
>
> - yield*
> - for-of loops
> - spread arguments
> - array spreads
>
> In the v8 implementation, this also affects async iteration versions of
> these things (the sole exception being the Async-From-Sync iterator,
> which requires a few more changes to work with this, likely done in a
> followup patch).
>
> This change introduces a new AST node, ResolvedProperty, which can be used
> as a callee by Call nodes to produce the same bytecode as Property calls,
> without observably re-loading the property. This is used in several
> AST-desugarings involving the iteration protocol.
>
> BUG=v8:6861, v8:5699
> R=rmcilroy@chromium.org, neis@chromium.org, adamk@chromium.org
>
> Cq-Include-Trybots: luci.v8.try:v8_linux_noi18n_rel_ng
> Change-Id: Ib81106a0182687fc5efea0bc32302ad06376773b
> Reviewed-on: https://chromium-review.googlesource.com/687997
> Commit-Queue: Caitlin Potter <caitp@igalia.com>
> Reviewed-by: Ross McIlroy <rmcilroy@chromium.org>
> Reviewed-by: Adam Klein <adamk@chromium.org>
> Reviewed-by: Georg Neis <neis@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#50452}
TBR=rmcilroy@chromium.org,adamk@chromium.org,neis@chromium.org,caitp@igalia.com,caitp@chromium.org
Change-Id: I1797c0d596dfd6850d6f0f505f591a7a990dd1f1
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: v8:6861, v8:5699
Cq-Include-Trybots: luci.v8.try:v8_linux_noi18n_rel_ng
Reviewed-on: https://chromium-review.googlesource.com/857616
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#50454}
2018-01-09 16:50:16 +00:00
|
|
|
for (let |_|k of |_|arr) { all.|C|push(k); }
|
2017-07-17 19:02:35 +00:00
|
|
|
for (let |_|k in |_|obj) { all.|C|push(k); }
|
2017-05-24 12:12:53 +00:00
|
|
|
|
|
|
|
var iterable = |_|{
|
|
|
|
[Symbol.iterator]() {
|
|
|
|
|_|return {
|
|
|
|
i: 0,
|
|
|
|
next() {
|
2017-07-17 19:02:35 +00:00
|
|
|
if (this.|_|i < 1) {
|
2017-07-14 17:50:09 +00:00
|
|
|
|_|return { value: this.i++, done: false };|R|
|
2017-05-24 12:12:53 +00:00
|
|
|
}
|
2017-07-14 17:50:09 +00:00
|
|
|
|_|return { value: undefined, done: true };|R|
|
|
|
|
}
|
|
|
|
};|R|
|
|
|
|
}
|
2017-05-24 12:12:53 +00:00
|
|
|
};
|
Revert "[esnext] load `iterator.next` only once at beginning of iteration"
This reverts commit bf4cc9ee154f15942594016777f77d3208230f5f.
Reason for revert: Breaks windows with msvc and linux with gcc
https://build.chromium.org/p/client.v8/builders/V8%20Win64%20-%20msvc/builds/841
https://build.chromium.org/p/client.v8/builders/V8%20Linux%20gcc%204.8/builds/17265
Original change's description:
> [esnext] load `iterator.next` only once at beginning of iteration
>
> https://github.com/tc39/ecma262/pull/988 gained concensus during the
> september 2017 TC39 meetings. This moves the load of the "next" method
> to the very beginning of the iteration protocol, rather than during
> each iteration step.
>
> This impacts:
>
> - yield*
> - for-of loops
> - spread arguments
> - array spreads
>
> In the v8 implementation, this also affects async iteration versions of
> these things (the sole exception being the Async-From-Sync iterator,
> which requires a few more changes to work with this, likely done in a
> followup patch).
>
> This change introduces a new AST node, ResolvedProperty, which can be used
> as a callee by Call nodes to produce the same bytecode as Property calls,
> without observably re-loading the property. This is used in several
> AST-desugarings involving the iteration protocol.
>
> BUG=v8:6861, v8:5699
> R=rmcilroy@chromium.org, neis@chromium.org, adamk@chromium.org
>
> Cq-Include-Trybots: luci.v8.try:v8_linux_noi18n_rel_ng
> Change-Id: Ib81106a0182687fc5efea0bc32302ad06376773b
> Reviewed-on: https://chromium-review.googlesource.com/687997
> Commit-Queue: Caitlin Potter <caitp@igalia.com>
> Reviewed-by: Ross McIlroy <rmcilroy@chromium.org>
> Reviewed-by: Adam Klein <adamk@chromium.org>
> Reviewed-by: Georg Neis <neis@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#50452}
TBR=rmcilroy@chromium.org,adamk@chromium.org,neis@chromium.org,caitp@igalia.com,caitp@chromium.org
Change-Id: I1797c0d596dfd6850d6f0f505f591a7a990dd1f1
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: v8:6861, v8:5699
Cq-Include-Trybots: luci.v8.try:v8_linux_noi18n_rel_ng
Reviewed-on: https://chromium-review.googlesource.com/857616
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#50454}
2018-01-09 16:50:16 +00:00
|
|
|
for (var |_|k of |_|iterable) { all.|C|push(k); }
|
2017-05-24 12:12:53 +00:00
|
|
|
|_|iterable.i = 0;
|
Revert "[esnext] load `iterator.next` only once at beginning of iteration"
This reverts commit bf4cc9ee154f15942594016777f77d3208230f5f.
Reason for revert: Breaks windows with msvc and linux with gcc
https://build.chromium.org/p/client.v8/builders/V8%20Win64%20-%20msvc/builds/841
https://build.chromium.org/p/client.v8/builders/V8%20Linux%20gcc%204.8/builds/17265
Original change's description:
> [esnext] load `iterator.next` only once at beginning of iteration
>
> https://github.com/tc39/ecma262/pull/988 gained concensus during the
> september 2017 TC39 meetings. This moves the load of the "next" method
> to the very beginning of the iteration protocol, rather than during
> each iteration step.
>
> This impacts:
>
> - yield*
> - for-of loops
> - spread arguments
> - array spreads
>
> In the v8 implementation, this also affects async iteration versions of
> these things (the sole exception being the Async-From-Sync iterator,
> which requires a few more changes to work with this, likely done in a
> followup patch).
>
> This change introduces a new AST node, ResolvedProperty, which can be used
> as a callee by Call nodes to produce the same bytecode as Property calls,
> without observably re-loading the property. This is used in several
> AST-desugarings involving the iteration protocol.
>
> BUG=v8:6861, v8:5699
> R=rmcilroy@chromium.org, neis@chromium.org, adamk@chromium.org
>
> Cq-Include-Trybots: luci.v8.try:v8_linux_noi18n_rel_ng
> Change-Id: Ib81106a0182687fc5efea0bc32302ad06376773b
> Reviewed-on: https://chromium-review.googlesource.com/687997
> Commit-Queue: Caitlin Potter <caitp@igalia.com>
> Reviewed-by: Ross McIlroy <rmcilroy@chromium.org>
> Reviewed-by: Adam Klein <adamk@chromium.org>
> Reviewed-by: Georg Neis <neis@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#50452}
TBR=rmcilroy@chromium.org,adamk@chromium.org,neis@chromium.org,caitp@igalia.com,caitp@chromium.org
Change-Id: I1797c0d596dfd6850d6f0f505f591a7a990dd1f1
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: v8:6861, v8:5699
Cq-Include-Trybots: luci.v8.try:v8_linux_noi18n_rel_ng
Reviewed-on: https://chromium-review.googlesource.com/857616
Reviewed-by: Michael Achenbach <machenbach@chromium.org>
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#50454}
2018-01-09 16:50:16 +00:00
|
|
|
for (let |_|k of |_|iterable) { all.|C|push(k); }
|
2017-05-24 12:12:53 +00:00
|
|
|
|R|}
|
|
|
|
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
|
|
|
|
|
|
|
|
testFunction (test.js:2:12)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
function testFunction() {
|
|
|
|
var obj = #{a : 1};
|
|
|
|
var arr = [1];
|
|
|
|
|
|
|
|
testFunction (test.js:3:12)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
var obj = {a : 1};
|
|
|
|
var arr = #[1];
|
|
|
|
var all = [];
|
|
|
|
|
|
|
|
testFunction (test.js:4:12)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
var arr = [1];
|
|
|
|
var all = #[];
|
|
|
|
for (var k in arr) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:5:16)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
var all = [];
|
|
|
|
for (var k in #arr) { all.push(k); }
|
|
|
|
for (var k of arr) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:5:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
var all = [];
|
|
|
|
for (var #k in arr) { all.push(k); }
|
|
|
|
for (var k of arr) { all.push(k); }
|
|
|
|
|
2017-07-17 19:02:35 +00:00
|
|
|
testFunction (test.js:5:27)
|
2017-05-24 12:12:53 +00:00
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
var all = [];
|
2017-07-17 19:02:35 +00:00
|
|
|
for (var k in arr) { all.#push(k); }
|
2017-05-24 12:12:53 +00:00
|
|
|
for (var k of arr) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:5:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
var all = [];
|
|
|
|
for (var #k in arr) { all.push(k); }
|
|
|
|
for (var k of arr) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:6:16)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (var k in arr) { all.push(k); }
|
|
|
|
for (var k of #arr) { all.push(k); }
|
|
|
|
for (var k in obj) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:6:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (var k in arr) { all.push(k); }
|
|
|
|
for (var #k of arr) { all.push(k); }
|
|
|
|
for (var k in obj) { all.push(k); }
|
|
|
|
|
2017-07-17 19:02:35 +00:00
|
|
|
testFunction (test.js:6:27)
|
2017-05-24 12:12:53 +00:00
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (var k in arr) { all.push(k); }
|
2017-07-17 19:02:35 +00:00
|
|
|
for (var k of arr) { all.#push(k); }
|
2017-05-24 12:12:53 +00:00
|
|
|
for (var k in obj) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:6:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (var k in arr) { all.push(k); }
|
|
|
|
for (var #k of arr) { all.push(k); }
|
|
|
|
for (var k in obj) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:7:16)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (var k of arr) { all.push(k); }
|
|
|
|
for (var k in #obj) { all.push(k); }
|
|
|
|
for (let k in arr) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:7:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (var k of arr) { all.push(k); }
|
|
|
|
for (var #k in obj) { all.push(k); }
|
|
|
|
for (let k in arr) { all.push(k); }
|
|
|
|
|
2017-07-17 19:02:35 +00:00
|
|
|
testFunction (test.js:7:27)
|
2017-05-24 12:12:53 +00:00
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (var k of arr) { all.push(k); }
|
2017-07-17 19:02:35 +00:00
|
|
|
for (var k in obj) { all.#push(k); }
|
2017-05-24 12:12:53 +00:00
|
|
|
for (let k in arr) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:7:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (var k of arr) { all.push(k); }
|
|
|
|
for (var #k in obj) { all.push(k); }
|
|
|
|
for (let k in arr) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:8:16)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (var k in obj) { all.push(k); }
|
|
|
|
for (let k in #arr) { all.push(k); }
|
|
|
|
for (let k of arr) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:8:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (var k in obj) { all.push(k); }
|
|
|
|
for (let #k in arr) { all.push(k); }
|
|
|
|
for (let k of arr) { all.push(k); }
|
|
|
|
|
2017-07-17 19:02:35 +00:00
|
|
|
testFunction (test.js:8:27)
|
2017-05-24 12:12:53 +00:00
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (var k in obj) { all.push(k); }
|
2017-07-17 19:02:35 +00:00
|
|
|
for (let k in arr) { all.#push(k); }
|
2017-05-24 12:12:53 +00:00
|
|
|
for (let k of arr) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:8:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (var k in obj) { all.push(k); }
|
|
|
|
for (let #k in arr) { all.push(k); }
|
|
|
|
for (let k of arr) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:9:16)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (let k in arr) { all.push(k); }
|
|
|
|
for (let k of #arr) { all.push(k); }
|
|
|
|
for (let k in obj) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:9:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (let k in arr) { all.push(k); }
|
|
|
|
for (let #k of arr) { all.push(k); }
|
|
|
|
for (let k in obj) { all.push(k); }
|
|
|
|
|
2017-07-17 19:02:35 +00:00
|
|
|
testFunction (test.js:9:27)
|
2017-05-24 12:12:53 +00:00
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (let k in arr) { all.push(k); }
|
2017-07-17 19:02:35 +00:00
|
|
|
for (let k of arr) { all.#push(k); }
|
2017-05-24 12:12:53 +00:00
|
|
|
for (let k in obj) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:9:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (let k in arr) { all.push(k); }
|
|
|
|
for (let #k of arr) { all.push(k); }
|
|
|
|
for (let k in obj) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:10:16)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (let k of arr) { all.push(k); }
|
|
|
|
for (let k in #obj) { all.push(k); }
|
|
|
|
|
|
|
|
|
|
|
|
testFunction (test.js:10:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (let k of arr) { all.push(k); }
|
|
|
|
for (let #k in obj) { all.push(k); }
|
|
|
|
|
|
|
|
|
2017-07-17 19:02:35 +00:00
|
|
|
testFunction (test.js:10:27)
|
2017-05-24 12:12:53 +00:00
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (let k of arr) { all.push(k); }
|
2017-07-17 19:02:35 +00:00
|
|
|
for (let k in obj) { all.#push(k); }
|
2017-05-24 12:12:53 +00:00
|
|
|
|
|
|
|
|
|
|
|
testFunction (test.js:10:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (let k of arr) { all.push(k); }
|
|
|
|
for (let #k in obj) { all.push(k); }
|
|
|
|
|
|
|
|
|
|
|
|
testFunction (test.js:12:17)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
|
|
|
|
var iterable = #{
|
|
|
|
[Symbol.iterator]() {
|
|
|
|
|
|
|
|
testFunction (test.js:25:16)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
};
|
|
|
|
for (var k of #iterable) { all.push(k); }
|
|
|
|
iterable.i = 0;
|
|
|
|
|
|
|
|
[Symbol.iterator] (test.js:14:6)
|
|
|
|
testFunction (test.js:25:16)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
[Symbol.iterator]() {
|
|
|
|
#return {
|
|
|
|
i: 0,
|
|
|
|
|
2017-07-14 17:50:09 +00:00
|
|
|
[Symbol.iterator] (test.js:22:8)
|
2017-05-24 12:12:53 +00:00
|
|
|
testFunction (test.js:25:16)
|
|
|
|
(anonymous) (expr.js:0:0)
|
2017-07-14 17:50:09 +00:00
|
|
|
}
|
|
|
|
};#
|
|
|
|
}
|
2017-05-24 12:12:53 +00:00
|
|
|
|
|
|
|
testFunction (test.js:25:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
};
|
|
|
|
for (var #k of iterable) { all.push(k); }
|
|
|
|
iterable.i = 0;
|
|
|
|
|
2017-07-17 19:02:35 +00:00
|
|
|
next (test.js:17:19)
|
2017-05-24 12:12:53 +00:00
|
|
|
testFunction (test.js:25:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
next() {
|
2017-07-17 19:02:35 +00:00
|
|
|
if (this.#i < 1) {
|
2017-05-24 12:12:53 +00:00
|
|
|
return { value: this.i++, done: false };
|
|
|
|
|
|
|
|
next (test.js:18:12)
|
|
|
|
testFunction (test.js:25:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
if (this.i < 1) {
|
|
|
|
#return { value: this.i++, done: false };
|
|
|
|
}
|
|
|
|
|
2017-07-14 17:50:09 +00:00
|
|
|
next (test.js:18:52)
|
2017-05-24 12:12:53 +00:00
|
|
|
testFunction (test.js:25:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
2017-07-14 17:50:09 +00:00
|
|
|
if (this.i < 1) {
|
|
|
|
return { value: this.i++, done: false };#
|
|
|
|
}
|
2017-05-24 12:12:53 +00:00
|
|
|
|
2017-07-17 19:02:35 +00:00
|
|
|
testFunction (test.js:25:32)
|
2017-05-24 12:12:53 +00:00
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
};
|
2017-07-17 19:02:35 +00:00
|
|
|
for (var k of iterable) { all.#push(k); }
|
2017-05-24 12:12:53 +00:00
|
|
|
iterable.i = 0;
|
|
|
|
|
|
|
|
testFunction (test.js:25:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
};
|
|
|
|
for (var #k of iterable) { all.push(k); }
|
|
|
|
iterable.i = 0;
|
|
|
|
|
2017-07-17 19:02:35 +00:00
|
|
|
next (test.js:17:19)
|
2017-05-24 12:12:53 +00:00
|
|
|
testFunction (test.js:25:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
next() {
|
2017-07-17 19:02:35 +00:00
|
|
|
if (this.#i < 1) {
|
2017-05-24 12:12:53 +00:00
|
|
|
return { value: this.i++, done: false };
|
|
|
|
|
|
|
|
next (test.js:20:10)
|
|
|
|
testFunction (test.js:25:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
}
|
|
|
|
#return { value: undefined, done: true };
|
|
|
|
}
|
|
|
|
|
2017-07-14 17:50:09 +00:00
|
|
|
next (test.js:20:50)
|
2017-05-24 12:12:53 +00:00
|
|
|
testFunction (test.js:25:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
2017-07-14 17:50:09 +00:00
|
|
|
}
|
|
|
|
return { value: undefined, done: true };#
|
|
|
|
}
|
2017-05-24 12:12:53 +00:00
|
|
|
|
|
|
|
testFunction (test.js:26:2)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (var k of iterable) { all.push(k); }
|
|
|
|
#iterable.i = 0;
|
|
|
|
for (let k of iterable) { all.push(k); }
|
|
|
|
|
|
|
|
testFunction (test.js:27:16)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
iterable.i = 0;
|
|
|
|
for (let k of #iterable) { all.push(k); }
|
|
|
|
}
|
|
|
|
|
|
|
|
[Symbol.iterator] (test.js:14:6)
|
|
|
|
testFunction (test.js:27:16)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
[Symbol.iterator]() {
|
|
|
|
#return {
|
|
|
|
i: 0,
|
|
|
|
|
2017-07-14 17:50:09 +00:00
|
|
|
[Symbol.iterator] (test.js:22:8)
|
2017-05-24 12:12:53 +00:00
|
|
|
testFunction (test.js:27:16)
|
|
|
|
(anonymous) (expr.js:0:0)
|
2017-07-14 17:50:09 +00:00
|
|
|
}
|
|
|
|
};#
|
|
|
|
}
|
2017-05-24 12:12:53 +00:00
|
|
|
|
|
|
|
testFunction (test.js:27:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
iterable.i = 0;
|
|
|
|
for (let #k of iterable) { all.push(k); }
|
|
|
|
}
|
|
|
|
|
2017-07-17 19:02:35 +00:00
|
|
|
next (test.js:17:19)
|
2017-05-24 12:12:53 +00:00
|
|
|
testFunction (test.js:27:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
next() {
|
2017-07-17 19:02:35 +00:00
|
|
|
if (this.#i < 1) {
|
2017-05-24 12:12:53 +00:00
|
|
|
return { value: this.i++, done: false };
|
|
|
|
|
|
|
|
next (test.js:18:12)
|
|
|
|
testFunction (test.js:27:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
if (this.i < 1) {
|
|
|
|
#return { value: this.i++, done: false };
|
|
|
|
}
|
|
|
|
|
2017-07-14 17:50:09 +00:00
|
|
|
next (test.js:18:52)
|
2017-05-24 12:12:53 +00:00
|
|
|
testFunction (test.js:27:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
2017-07-14 17:50:09 +00:00
|
|
|
if (this.i < 1) {
|
|
|
|
return { value: this.i++, done: false };#
|
|
|
|
}
|
2017-05-24 12:12:53 +00:00
|
|
|
|
2017-07-17 19:02:35 +00:00
|
|
|
testFunction (test.js:27:32)
|
2017-05-24 12:12:53 +00:00
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
iterable.i = 0;
|
2017-07-17 19:02:35 +00:00
|
|
|
for (let k of iterable) { all.#push(k); }
|
2017-05-24 12:12:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
testFunction (test.js:27:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
iterable.i = 0;
|
|
|
|
for (let #k of iterable) { all.push(k); }
|
|
|
|
}
|
|
|
|
|
2017-07-17 19:02:35 +00:00
|
|
|
next (test.js:17:19)
|
2017-05-24 12:12:53 +00:00
|
|
|
testFunction (test.js:27:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
next() {
|
2017-07-17 19:02:35 +00:00
|
|
|
if (this.#i < 1) {
|
2017-05-24 12:12:53 +00:00
|
|
|
return { value: this.i++, done: false };
|
|
|
|
|
|
|
|
next (test.js:20:10)
|
|
|
|
testFunction (test.js:27:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
}
|
|
|
|
#return { value: undefined, done: true };
|
|
|
|
}
|
|
|
|
|
2017-07-14 17:50:09 +00:00
|
|
|
next (test.js:20:50)
|
2017-05-24 12:12:53 +00:00
|
|
|
testFunction (test.js:27:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
2017-07-14 17:50:09 +00:00
|
|
|
}
|
|
|
|
return { value: undefined, done: true };#
|
|
|
|
}
|
2017-05-24 12:12:53 +00:00
|
|
|
|
|
|
|
testFunction (test.js:28:0)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
for (let k of iterable) { all.push(k); }
|
|
|
|
#}
|
|
|
|
|
|
|
|
(anonymous) (expr.js:0:34)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Running test: testStepIntoAfterBreakpoint
|
|
|
|
testFunction (test.js:25:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
};
|
|
|
|
for (var #k of iterable) { all.push(k); }
|
|
|
|
iterable.i = 0;
|
|
|
|
|
2017-07-17 19:02:35 +00:00
|
|
|
next (test.js:17:19)
|
2017-05-24 12:12:53 +00:00
|
|
|
testFunction (test.js:25:11)
|
|
|
|
(anonymous) (expr.js:0:0)
|
|
|
|
next() {
|
2017-07-17 19:02:35 +00:00
|
|
|
if (this.#i < 1) {
|
2017-05-24 12:12:53 +00:00
|
|
|
return { value: this.i++, done: false };
|
|
|
|
|