-
Notifications
You must be signed in to change notification settings - Fork 1.7k
Commit a1cca73
[dart2wasm] Fix exponential compile time in dynamic closure calls
In the loop that has 2 recursive calls: with a name and without a name
we should stop early if we already know that this is unreachable (e.g.
all name combinations require a name or don't have a name).
This should make us now have O(#name-combinations) recursive calls,
emitting unreachables as soon as there's a set of names that aren't
feasible in any name combination.
Change-Id: I4c91a5fa91709398aa80ffd8dc278e30638acb0c
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/462400
Reviewed-by: Ömer Ağacan <omersa@google.com>
Commit-Queue: Martin Kustermann <kustermann@google.com>1 parent d46bd8c commit a1cca73
File tree
2 files changed
+196
-31
lines changed- pkg/dart2wasm/lib
- tests/web/wasm/closures
2 files changed
+196
-31
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2516 | 2516 | | |
2517 | 2517 | | |
2518 | 2518 | | |
2519 | - | ||
2520 | - | ||
2519 | + | ||
2520 | + | ||
2521 | 2521 | | |
2522 | 2522 | | |
2523 | - | ||
2524 | - | ||
2525 | - | ||
2526 | - | ||
2527 | - | ||
2523 | + | ||
2524 | + | ||
2525 | + | ||
2526 | + | ||
2527 | + | ||
2528 | + | ||
2529 | + | ||
2530 | + | ||
2531 | + | ||
2532 | + | ||
2533 | + | ||
2534 | + | ||
2535 | + | ||
2536 | + | ||
2537 | + | ||
2538 | + | ||
2539 | + | ||
2540 | + | ||
2541 | + | ||
2542 | + | ||
2543 | + | ||
2544 | + | ||
2545 | + | ||
2546 | + | ||
2547 | + | ||
2548 | + | ||
2549 | + | ||
2550 | + | ||
2551 | + | ||
2552 | + | ||
2553 | + | ||
2554 | + | ||
2555 | + | ||
2556 | + | ||
2557 | + | ||
2558 | + | ||
2528 | 2559 | | |
2529 | - | ||
2560 | + | ||
2561 | + | ||
2562 | + | ||
2563 | + | ||
2564 | + | ||
2565 | + | ||
2530 | 2566 | | |
2531 | 2567 | | |
2532 | 2568 | | |
| |||
2543 | 2579 | | |
2544 | 2580 | | |
2545 | 2581 | | |
2546 | - | ||
2547 | - | ||
2548 | - | ||
2549 | - | ||
2550 | - | ||
2551 | - | ||
2552 | - | ||
2553 | - | ||
2554 | - | ||
2555 | - | ||
2556 | - | ||
2557 | - | ||
2558 | - | ||
2582 | + | ||
2583 | + | ||
2559 | 2584 | | |
2560 | - | ||
2585 | + | ||
2561 | 2586 | | |
2562 | - | ||
2563 | - | ||
2564 | - | ||
2565 | - | ||
2587 | + | ||
2588 | + | ||
2589 | + | ||
2590 | + | ||
2591 | + | ||
2592 | + | ||
2593 | + | ||
2594 | + | ||
2595 | + | ||
2596 | + | ||
2597 | + | ||
2598 | + | ||
2599 | + | ||
2600 | + | ||
2601 | + | ||
2602 | + | ||
2603 | + | ||
2566 | 2604 | | |
2567 | 2605 | | |
2568 | 2606 | | |
2569 | 2607 | | |
2570 | - | ||
2608 | + | ||
2571 | 2609 | | |
2572 | 2610 | | |
2573 | 2611 | | |
| |||
2592 | 2630 | | |
2593 | 2631 | | |
2594 | 2632 | | |
2595 | - | ||
2596 | - | ||
2633 | + | ||
2634 | + | ||
2635 | + | ||
2636 | + | ||
2637 | + | ||
2597 | 2638 | | |
2598 | 2639 | | |
2599 | 2640 | | |
2600 | 2641 | | |
2601 | - | ||
2642 | + | ||
2602 | 2643 | | |
2603 | 2644 | | |
2604 | - | ||
2645 | + | ||
2605 | 2646 | | |
2606 | 2647 | | |
2607 | 2648 | | |
| |||
Lines changed: 124 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | + | ||
2 | + | ||
3 | + | ||
4 | + | ||
5 | + | ||
6 | + | ||
7 | + | ||
8 | + | ||
9 | + | ||
10 | + | ||
11 | + | ||
12 | + | ||
13 | + | ||
14 | + | ||
15 | + | ||
16 | + | ||
17 | + | ||
18 | + | ||
19 | + | ||
20 | + | ||
21 | + | ||
22 | + | ||
23 | + | ||
24 | + | ||
25 | + | ||
26 | + | ||
27 | + | ||
28 | + | ||
29 | + | ||
30 | + | ||
31 | + | ||
32 | + | ||
33 | + | ||
34 | + | ||
35 | + | ||
36 | + | ||
37 | + | ||
38 | + | ||
39 | + | ||
40 | + | ||
41 | + | ||
42 | + | ||
43 | + | ||
44 | + | ||
45 | + | ||
46 | + | ||
47 | + | ||
48 | + | ||
49 | + | ||
50 | + | ||
51 | + | ||
52 | + | ||
53 | + | ||
54 | + | ||
55 | + | ||
56 | + | ||
57 | + | ||
58 | + | ||
59 | + | ||
60 | + | ||
61 | + | ||
62 | + | ||
63 | + | ||
64 | + | ||
65 | + | ||
66 | + | ||
67 | + | ||
68 | + | ||
69 | + | ||
70 | + | ||
71 | + | ||
72 | + | ||
73 | + | ||
74 | + | ||
75 | + | ||
76 | + | ||
77 | + | ||
78 | + | ||
79 | + | ||
80 | + | ||
81 | + | ||
82 | + | ||
83 | + | ||
84 | + | ||
85 | + | ||
86 | + | ||
87 | + | ||
88 | + | ||
89 | + | ||
90 | + | ||
91 | + | ||
92 | + | ||
93 | + | ||
94 | + | ||
95 | + | ||
96 | + | ||
97 | + | ||
98 | + | ||
99 | + | ||
100 | + | ||
101 | + | ||
102 | + | ||
103 | + | ||
104 | + | ||
105 | + | ||
106 | + | ||
107 | + | ||
108 | + | ||
109 | + | ||
110 | + | ||
111 | + | ||
112 | + | ||
113 | + | ||
114 | + | ||
115 | + | ||
116 | + | ||
117 | + | ||
118 | + | ||
119 | + | ||
120 | + | ||
121 | + | ||
122 | + | ||
123 | + | ||
124 | + | ||
0 commit comments