@qwik.dev/core 2.0.0-alpha.9 → 2.0.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (87) hide show
  1. package/bindings/qwik.darwin-arm64.node +0 -0
  2. package/bindings/qwik.darwin-x64.node +0 -0
  3. package/bindings/qwik.linux-x64-gnu.node +0 -0
  4. package/bindings/qwik.wasm.cjs +27 -27
  5. package/bindings/qwik.wasm.mjs +27 -27
  6. package/bindings/qwik.win32-x64-msvc.node +0 -0
  7. package/bindings/qwik_wasm_bg.wasm +0 -0
  8. package/dist/build/index.cjs +3 -3
  9. package/dist/build/index.d.ts +22 -22
  10. package/dist/build/package.json +1 -1
  11. package/dist/cli.cjs +6 -6
  12. package/dist/core-internal.d.ts +4447 -4153
  13. package/dist/core.cjs +5698 -5353
  14. package/dist/core.cjs.map +1 -1
  15. package/dist/core.min.mjs +1 -1
  16. package/dist/core.mjs +5691 -5350
  17. package/dist/core.mjs.map +1 -1
  18. package/dist/core.prod.cjs +2811 -2633
  19. package/dist/core.prod.mjs +3193 -3039
  20. package/dist/insights/index.qwik.cjs +1 -4142
  21. package/dist/insights/index.qwik.mjs +63 -4133
  22. package/dist/insights/vite/index.cjs +1 -82
  23. package/dist/insights/vite/index.mjs +65 -37
  24. package/dist/insights/vite.d.ts +22 -0
  25. package/dist/{insights/insights.d.ts → insights.d.ts} +33 -22
  26. package/dist/loader/index.cjs +2 -2
  27. package/dist/loader/index.mjs +2 -2
  28. package/dist/loader/package.json +1 -1
  29. package/dist/optimizer.cjs +554 -355
  30. package/dist/optimizer.d.ts +779 -707
  31. package/dist/optimizer.mjs +552 -399
  32. package/dist/preloader.cjs +269 -0
  33. package/dist/preloader.mjs +198 -0
  34. package/dist/qwikloader.debug.js +242 -222
  35. package/dist/qwikloader.js +1 -3
  36. package/dist/server.cjs +671 -570
  37. package/dist/server.d.ts +504 -402
  38. package/dist/server.mjs +642 -545
  39. package/dist/starters/adapters/aws-lambda/serverless.yml +15 -0
  40. package/dist/starters/adapters/aws-lambda/src/entry_aws-lambda.tsx +0 -2
  41. package/dist/starters/adapters/azure-swa/public/staticwebapp.config.json +7 -0
  42. package/dist/starters/adapters/azure-swa/src/entry.azure-swa.tsx +1 -2
  43. package/dist/starters/adapters/bun/src/entry.bun.ts +3 -2
  44. package/dist/starters/adapters/cloud-run/src/entry.cloud-run.tsx +1 -3
  45. package/dist/starters/adapters/cloudflare-pages/public/_headers +2 -0
  46. package/dist/starters/adapters/cloudflare-pages/src/entry.cloudflare-pages.tsx +1 -2
  47. package/dist/starters/adapters/deno/src/entry.deno.ts +3 -2
  48. package/dist/starters/adapters/express/src/entry.express.tsx +5 -2
  49. package/dist/starters/adapters/fastify/src/entry.fastify.tsx +2 -1
  50. package/dist/starters/adapters/fastify/src/plugins/fastify-qwik.ts +9 -1
  51. package/dist/starters/adapters/firebase/firebase.json +12 -1
  52. package/dist/starters/adapters/firebase/functions/index.js +2 -3
  53. package/dist/starters/adapters/firebase/src/entry-firebase.tsx +1 -2
  54. package/dist/starters/adapters/netlify-edge/public/_headers +2 -0
  55. package/dist/starters/adapters/netlify-edge/src/entry.netlify-edge.tsx +1 -2
  56. package/dist/starters/adapters/node-server/src/entry.node-server.tsx +3 -2
  57. package/dist/starters/adapters/static/README.md +4 -0
  58. package/dist/starters/adapters/vercel-edge/src/entry.vercel-edge.tsx +1 -2
  59. package/dist/starters/adapters/vercel-edge/vercel.json +1 -1
  60. package/dist/starters/features/bootstrap/src/routes/bootstrap/layout.tsx +0 -11
  61. package/dist/starters/features/localize/src/entry.ssr.tsx +0 -2
  62. package/dist/starters/features/localize/src/routes/[locale]/i18n-utils.ts +1 -1
  63. package/dist/starters/features/partytown/package.json +4 -4
  64. package/dist/starters/features/partytown/src/components/partytown/partytown.tsx +2 -2
  65. package/dist/starters/features/postcss/postcss.config.js +1 -1
  66. package/dist/starters/features/service-worker/package.json +13 -0
  67. package/dist/starters/features/service-worker/src/routes/service-worker.ts +14 -0
  68. package/dist/starters/features/styled-vanilla-extract/package.json +2 -1
  69. package/dist/starters/features/tailwind/package.json +2 -1
  70. package/dist/starters/features/tailwind/src/global.css +1 -1
  71. package/dist/starters/features/tailwind-v3/tailwind.config.js +2 -2
  72. package/dist/testing/index.cjs +8007 -7753
  73. package/dist/testing/index.d.ts +141 -141
  74. package/dist/testing/index.mjs +7848 -7600
  75. package/dist/testing/package.json +1 -1
  76. package/package.json +19 -11
  77. package/public.d.ts +4 -0
  78. package/server.d.ts +1 -0
  79. package/dist/insights/index.d.ts +0 -1
  80. package/dist/insights/vite/index.d.ts +0 -1
  81. package/dist/insights/vite/insights-plugin.d.ts +0 -10
  82. package/dist/prefetch/index.cjs +0 -4
  83. package/dist/prefetch/index.d.ts +0 -2
  84. package/dist/prefetch/index.mjs +0 -3
  85. package/dist/prefetch/package.json +0 -8
  86. package/dist/qwik-prefetch.debug.js +0 -244
  87. package/dist/qwik-prefetch.js +0 -1
@@ -0,0 +1,269 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const build = require("@qwik.dev/core/build");
4
+ const doc = build.isBrowser ? document : void 0;
5
+ const config = {
6
+ $DEBUG$: false,
7
+ $maxIdlePreloads$: 25,
8
+ $invPreloadProbability$: 0.65
9
+ };
10
+ const rel = build.isBrowser && doc.createElement("link").relList.supports("modulepreload") ? "modulePreload" : "preload";
11
+ const loadStart = Date.now();
12
+ const isJSRegex = /\.[mc]?js$/;
13
+ const BundleImportState_None = 0;
14
+ const BundleImportState_Queued = 1;
15
+ const BundleImportState_Preload = 2;
16
+ const BundleImportState_Alias = 3;
17
+ const BundleImportState_Loaded = 4;
18
+ const bundles = /* @__PURE__ */ new Map();
19
+ let queueDirty;
20
+ let preloadCount = 0;
21
+ const queue = [];
22
+ const log = (...args) => {
23
+ console.log(
24
+ `Preloader ${Date.now() - loadStart}ms ${preloadCount}/${queue.length} queued>`,
25
+ ...args
26
+ );
27
+ };
28
+ const sortQueue = () => {
29
+ if (queueDirty) {
30
+ queue.sort((a, b) => a.$inverseProbability$ - b.$inverseProbability$);
31
+ queueDirty = false;
32
+ }
33
+ };
34
+ const trigger = () => {
35
+ if (!queue.length) {
36
+ return;
37
+ }
38
+ sortQueue();
39
+ while (queue.length) {
40
+ const bundle = queue[0];
41
+ const inverseProbability = bundle.$inverseProbability$;
42
+ const probability = 1 - inverseProbability;
43
+ const allowedPreloads = graph ? (
44
+ // The more likely the bundle, the more simultaneous preloads we want to allow
45
+ Math.max(1, config.$maxIdlePreloads$ * probability)
46
+ ) : (
47
+ // While the graph is not available, we limit to 2 preloads
48
+ 2
49
+ );
50
+ if (probability >= 0.99 || preloadCount < allowedPreloads) {
51
+ queue.shift();
52
+ preloadOne(bundle);
53
+ } else {
54
+ break;
55
+ }
56
+ }
57
+ if (config.$DEBUG$ && !queue.length) {
58
+ const loaded = [...bundles.values()].filter((b) => b.$state$ > BundleImportState_None);
59
+ const waitTime = loaded.reduce((acc, b) => acc + b.$waitedMs$, 0);
60
+ const loadTime = loaded.reduce((acc, b) => acc + b.$loadedMs$, 0);
61
+ log(
62
+ `>>>> done ${loaded.length}/${bundles.size} total: ${waitTime}ms waited, ${loadTime}ms loaded`
63
+ );
64
+ }
65
+ };
66
+ const preloadOne = (bundle) => {
67
+ if (bundle.$state$ >= BundleImportState_Preload) {
68
+ return;
69
+ }
70
+ preloadCount++;
71
+ const start = Date.now();
72
+ bundle.$waitedMs$ = start - bundle.$createdTs$;
73
+ bundle.$state$ = BundleImportState_Preload;
74
+ config.$DEBUG$ && log(
75
+ `<< load ${Math.round((1 - bundle.$inverseProbability$) * 100)}% after ${`${bundle.$waitedMs$}ms`}`,
76
+ bundle.$name$
77
+ );
78
+ const link = doc.createElement("link");
79
+ link.href = new URL(`${base}${bundle.$name$}`, doc.baseURI).toString();
80
+ link.rel = rel;
81
+ link.as = "script";
82
+ link.onload = link.onerror = () => {
83
+ preloadCount--;
84
+ const end = Date.now();
85
+ bundle.$loadedMs$ = end - start;
86
+ bundle.$state$ = BundleImportState_Loaded;
87
+ config.$DEBUG$ && log(`>> done after ${bundle.$loadedMs$}ms`, bundle.$name$);
88
+ link.remove();
89
+ trigger();
90
+ };
91
+ doc.head.appendChild(link);
92
+ };
93
+ const adjustProbabilities = (bundle, newInverseProbability, seen) => {
94
+ if (seen == null ? void 0 : seen.has(bundle)) {
95
+ return;
96
+ }
97
+ const previousInverseProbability = bundle.$inverseProbability$;
98
+ bundle.$inverseProbability$ = newInverseProbability;
99
+ if (previousInverseProbability - bundle.$inverseProbability$ < 0.01) {
100
+ return;
101
+ }
102
+ if (
103
+ // don't queue until we have initialized the preloader
104
+ base != null && bundle.$state$ < BundleImportState_Preload && bundle.$inverseProbability$ < config.$invPreloadProbability$
105
+ ) {
106
+ if (bundle.$state$ === BundleImportState_None) {
107
+ bundle.$state$ = BundleImportState_Queued;
108
+ queue.push(bundle);
109
+ config.$DEBUG$ && log(`queued ${Math.round((1 - bundle.$inverseProbability$) * 100)}%`, bundle.$name$);
110
+ }
111
+ queueDirty = true;
112
+ }
113
+ if (bundle.$deps$) {
114
+ seen || (seen = /* @__PURE__ */ new Set());
115
+ seen.add(bundle);
116
+ const probability = 1 - bundle.$inverseProbability$;
117
+ for (const dep of bundle.$deps$) {
118
+ const depBundle = getBundle(dep.$name$);
119
+ if (depBundle.$inverseProbability$ === 0) {
120
+ continue;
121
+ }
122
+ let newInverseProbability2;
123
+ if (dep.$importProbability$ > 0.5 && (probability === 1 || probability >= 0.99 && depsCount < 100)) {
124
+ depsCount++;
125
+ newInverseProbability2 = Math.min(0.01, 1 - dep.$importProbability$);
126
+ } else {
127
+ const newInverseImportProbability = 1 - dep.$importProbability$ * probability;
128
+ const prevAdjust = dep.$factor$;
129
+ const factor = newInverseImportProbability / prevAdjust;
130
+ newInverseProbability2 = Math.max(0.02, depBundle.$inverseProbability$ * factor);
131
+ dep.$factor$ = factor;
132
+ }
133
+ adjustProbabilities(depBundle, newInverseProbability2, seen);
134
+ }
135
+ }
136
+ };
137
+ const handleBundle = (name, inverseProbability) => {
138
+ const bundle = getBundle(name);
139
+ if (bundle && bundle.$inverseProbability$ > inverseProbability) {
140
+ adjustProbabilities(bundle, inverseProbability);
141
+ }
142
+ };
143
+ let depsCount;
144
+ const preload = (name, probability) => {
145
+ if (!(name == null ? void 0 : name.length)) {
146
+ return;
147
+ }
148
+ depsCount = 0;
149
+ let inverseProbability = probability ? 1 - probability : 0.4;
150
+ if (Array.isArray(name)) {
151
+ for (let i = name.length - 1; i >= 0; i--) {
152
+ const item = name[i];
153
+ if (typeof item === "number") {
154
+ inverseProbability = 1 - item / 10;
155
+ } else {
156
+ handleBundle(item, inverseProbability);
157
+ }
158
+ }
159
+ } else {
160
+ handleBundle(name, inverseProbability);
161
+ }
162
+ if (build.isBrowser) {
163
+ trigger();
164
+ }
165
+ };
166
+ if (build.isBrowser) {
167
+ document.addEventListener("qsymbol", (ev) => {
168
+ const { symbol, href } = ev.detail;
169
+ if (href) {
170
+ const hash = symbol.slice(symbol.lastIndexOf("_") + 1);
171
+ preload(hash, 1);
172
+ }
173
+ });
174
+ }
175
+ let base;
176
+ let graph;
177
+ const makeBundle = (name, deps) => {
178
+ return {
179
+ $name$: name,
180
+ $state$: isJSRegex.test(name) ? BundleImportState_None : BundleImportState_Alias,
181
+ $deps$: deps,
182
+ $inverseProbability$: 1,
183
+ $createdTs$: Date.now(),
184
+ $waitedMs$: 0,
185
+ $loadedMs$: 0
186
+ };
187
+ };
188
+ const parseBundleGraph = (serialized) => {
189
+ const graph2 = /* @__PURE__ */ new Map();
190
+ let i = 0;
191
+ while (i < serialized.length) {
192
+ const name = serialized[i++];
193
+ const deps = [];
194
+ let idx;
195
+ let probability = 1;
196
+ while (idx = serialized[i], typeof idx === "number") {
197
+ if (idx < 0) {
198
+ probability = -idx / 10;
199
+ } else {
200
+ deps.push({
201
+ $name$: serialized[idx],
202
+ $importProbability$: probability,
203
+ $factor$: 1
204
+ });
205
+ }
206
+ i++;
207
+ }
208
+ graph2.set(name, deps);
209
+ }
210
+ return graph2;
211
+ };
212
+ const getBundle = (name) => {
213
+ let bundle = bundles.get(name);
214
+ if (!bundle) {
215
+ let deps;
216
+ if (graph) {
217
+ deps = graph.get(name);
218
+ if (!deps) {
219
+ return;
220
+ }
221
+ if (!deps.length) {
222
+ deps = void 0;
223
+ }
224
+ }
225
+ bundle = makeBundle(name, deps);
226
+ bundles.set(name, bundle);
227
+ }
228
+ return bundle;
229
+ };
230
+ const loadBundleGraph = (basePath, serializedResponse, opts) => {
231
+ if (opts) {
232
+ if ("d" in opts) {
233
+ config.$DEBUG$ = !!opts.d;
234
+ }
235
+ if ("P" in opts) {
236
+ config.$maxIdlePreloads$ = opts["P"];
237
+ }
238
+ if ("Q" in opts) {
239
+ config.$invPreloadProbability$ = 1 - opts["Q"];
240
+ }
241
+ }
242
+ if (!build.isBrowser || basePath == null) {
243
+ return;
244
+ }
245
+ base = basePath;
246
+ if (serializedResponse) {
247
+ serializedResponse.then((r) => r.text()).then((text) => {
248
+ graph = parseBundleGraph(JSON.parse(text));
249
+ const toAdjust = [];
250
+ for (const [name, deps] of graph.entries()) {
251
+ const bundle = getBundle(name);
252
+ bundle.$deps$ = deps;
253
+ if (bundle.$inverseProbability$ < 1) {
254
+ toAdjust.push([bundle, bundle.$inverseProbability$]);
255
+ bundle.$inverseProbability$ = 1;
256
+ }
257
+ }
258
+ config.$DEBUG$ && log(`parseBundleGraph got ${graph.size} bundles, adjusting ${toAdjust.length}`);
259
+ for (const [bundle, inverseProbability] of toAdjust) {
260
+ adjustProbabilities(bundle, inverseProbability);
261
+ }
262
+ trigger();
263
+ }).catch(console.warn);
264
+ }
265
+ };
266
+ exports.g = parseBundleGraph;
267
+ exports.h = handleBundle;
268
+ exports.l = loadBundleGraph;
269
+ exports.p = preload;
@@ -0,0 +1,198 @@
1
+ import { isBrowser } from "@qwik.dev/core/build";
2
+ const doc = isBrowser ? document : void 0;
3
+ const config = { t: 0, o: 25, l: 0.65 };
4
+ const rel = isBrowser && doc.createElement("link").relList.supports("modulepreload") ? "modulePreload" : "preload";
5
+ const loadStart = Date.now();
6
+ const isJSRegex = /\.[mc]?js$/;
7
+ const BundleImportState_None = 0;
8
+ const BundleImportState_Queued = 1;
9
+ const BundleImportState_Preload = 2;
10
+ const BundleImportState_Alias = 3;
11
+ const BundleImportState_Loaded = 4;
12
+ const bundles = /* @__PURE__ */ new Map();
13
+ let queueDirty;
14
+ let preloadCount = 0;
15
+ const queue = [];
16
+ const log = (...e) => {
17
+ console.log(`Preloader ${Date.now() - loadStart}ms ${preloadCount}/${queue.length} queued>`, ...e);
18
+ };
19
+ const sortQueue = () => {
20
+ if (queueDirty) {
21
+ queue.sort((e, t) => e.u - t.u);
22
+ queueDirty = 0;
23
+ }
24
+ };
25
+ const trigger = () => {
26
+ if (!queue.length) return;
27
+ sortQueue();
28
+ while (queue.length) {
29
+ const e = queue[0];
30
+ const t = e.u;
31
+ const o = 1 - t;
32
+ const n = graph ? (
33
+ // The more likely the bundle, the more simultaneous preloads we want to allow
34
+ Math.max(1, config.o * o)
35
+ ) : (
36
+ // While the graph is not available, we limit to 2 preloads
37
+ 2
38
+ );
39
+ if (o >= 0.99 || preloadCount < n) {
40
+ queue.shift();
41
+ preloadOne(e);
42
+ } else break;
43
+ }
44
+ if (config.t && !queue.length) {
45
+ const e = [...bundles.values()].filter((e2) => e2.i > BundleImportState_None);
46
+ const t = e.reduce((e2, t2) => e2 + t2.p, 0);
47
+ const o = e.reduce((e2, t2) => e2 + t2.$, 0);
48
+ log(`>>>> done ${e.length}/${bundles.size} total: ${t}ms waited, ${o}ms loaded`);
49
+ }
50
+ };
51
+ const preloadOne = (e) => {
52
+ if (e.i >= BundleImportState_Preload) return;
53
+ preloadCount++;
54
+ const t = Date.now();
55
+ e.p = t - e.B;
56
+ e.i = BundleImportState_Preload;
57
+ config.t && log(`<< load ${Math.round((1 - e.u) * 100)}% after ${`${e.p}ms`}`, e.m);
58
+ const o = doc.createElement("link");
59
+ o.href = new URL(`${base}${e.m}`, doc.baseURI).toString();
60
+ o.rel = rel;
61
+ o.as = "script";
62
+ o.onload = o.onerror = () => {
63
+ preloadCount--;
64
+ const n = Date.now();
65
+ e.$ = n - t;
66
+ e.i = BundleImportState_Loaded;
67
+ config.t && log(`>> done after ${e.$}ms`, e.m);
68
+ o.remove();
69
+ trigger();
70
+ };
71
+ doc.head.appendChild(o);
72
+ };
73
+ const adjustProbabilities = (e, t, o) => {
74
+ if (o == null ? void 0 : o.has(e)) return;
75
+ const n = e.u;
76
+ e.u = t;
77
+ if (n - e.u < 0.01) return;
78
+ if (
79
+ // don't queue until we have initialized the preloader
80
+ base != null && e.i < BundleImportState_Preload && e.u < config.l
81
+ ) {
82
+ if (e.i === BundleImportState_None) {
83
+ e.i = BundleImportState_Queued;
84
+ queue.push(e);
85
+ config.t && log(`queued ${Math.round((1 - e.u) * 100)}%`, e.m);
86
+ }
87
+ queueDirty = 1;
88
+ }
89
+ if (e.h) {
90
+ o || (o = /* @__PURE__ */ new Set());
91
+ o.add(e);
92
+ const t2 = 1 - e.u;
93
+ for (const n2 of e.h) {
94
+ const e2 = getBundle(n2.m);
95
+ if (e2.u === 0) continue;
96
+ let r;
97
+ if (n2.S > 0.5 && (t2 === 1 || t2 >= 0.99 && depsCount < 100)) {
98
+ depsCount++;
99
+ r = Math.min(0.01, 1 - n2.S);
100
+ } else {
101
+ const o2 = 1 - n2.S * t2;
102
+ const s = n2.q;
103
+ const l = o2 / s;
104
+ r = Math.max(0.02, e2.u * l);
105
+ n2.q = l;
106
+ }
107
+ adjustProbabilities(e2, r, o);
108
+ }
109
+ }
110
+ };
111
+ const handleBundle = (e, t) => {
112
+ const o = getBundle(e);
113
+ if (o && o.u > t) adjustProbabilities(o, t);
114
+ };
115
+ let depsCount;
116
+ const preload = (e, t) => {
117
+ if (!(e == null ? void 0 : e.length)) return;
118
+ depsCount = 0;
119
+ let o = t ? 1 - t : 0.4;
120
+ if (Array.isArray(e)) for (let t2 = e.length - 1; t2 >= 0; t2--) {
121
+ const n = e[t2];
122
+ if (typeof n === "number") o = 1 - n / 10;
123
+ else handleBundle(n, o);
124
+ }
125
+ else handleBundle(e, o);
126
+ if (isBrowser) trigger();
127
+ };
128
+ if (isBrowser) document.addEventListener("qsymbol", (e) => {
129
+ const { symbol: t, href: o } = e.detail;
130
+ if (o) {
131
+ const e2 = t.slice(t.lastIndexOf("_") + 1);
132
+ preload(e2, 1);
133
+ }
134
+ });
135
+ let base;
136
+ let graph;
137
+ const makeBundle = (e, t) => ({ m: e, i: isJSRegex.test(e) ? BundleImportState_None : BundleImportState_Alias, h: t, u: 1, B: Date.now(), p: 0, $: 0 });
138
+ const parseBundleGraph = (e) => {
139
+ const t = /* @__PURE__ */ new Map();
140
+ let o = 0;
141
+ while (o < e.length) {
142
+ const n = e[o++];
143
+ const r = [];
144
+ let s;
145
+ let l = 1;
146
+ while (s = e[o], typeof s === "number") {
147
+ if (s < 0) l = -s / 10;
148
+ else r.push({ m: e[s], S: l, q: 1 });
149
+ o++;
150
+ }
151
+ t.set(n, r);
152
+ }
153
+ return t;
154
+ };
155
+ const getBundle = (e) => {
156
+ let t = bundles.get(e);
157
+ if (!t) {
158
+ let o;
159
+ if (graph) {
160
+ o = graph.get(e);
161
+ if (!o) return;
162
+ if (!o.length) o = void 0;
163
+ }
164
+ t = makeBundle(e, o);
165
+ bundles.set(e, t);
166
+ }
167
+ return t;
168
+ };
169
+ const loadBundleGraph = (e, t, o) => {
170
+ if (o) {
171
+ if ("d" in o) config.t = !!o.d;
172
+ if ("P" in o) config.o = o["P"];
173
+ if ("Q" in o) config.l = 1 - o["Q"];
174
+ }
175
+ if (!isBrowser || e == null) return;
176
+ base = e;
177
+ if (t) t.then((e2) => e2.text()).then((e2) => {
178
+ graph = parseBundleGraph(JSON.parse(e2));
179
+ const t2 = [];
180
+ for (const [e3, o2] of graph.entries()) {
181
+ const n = getBundle(e3);
182
+ n.h = o2;
183
+ if (n.u < 1) {
184
+ t2.push([n, n.u]);
185
+ n.u = 1;
186
+ }
187
+ }
188
+ config.t && log(`parseBundleGraph got ${graph.size} bundles, adjusting ${t2.length}`);
189
+ for (const [e3, o2] of t2) adjustProbabilities(e3, o2);
190
+ trigger();
191
+ }).catch(console.warn);
192
+ };
193
+ export {
194
+ parseBundleGraph as g,
195
+ handleBundle as h,
196
+ loadBundleGraph as l,
197
+ preload as p
198
+ };