@prisma/param-graph 7.4.0-integration-parameterization.5 → 7.4.0-integration-parameterization.7

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.
@@ -0,0 +1,353 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var serialization_exports = {};
20
+ __export(serialization_exports, {
21
+ deserializeParamGraph: () => deserializeParamGraph,
22
+ serializeParamGraph: () => serializeParamGraph
23
+ });
24
+ module.exports = __toCommonJS(serialization_exports);
25
+ const FORMAT_COMPACT = 0;
26
+ const FORMAT_WIDE = 1;
27
+ const NONE_16 = 65535;
28
+ const NONE_32 = 4294967295;
29
+ const MAX_COMPACT_INDEX = 65534;
30
+ const BASE64URL_CHARS = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_";
31
+ function encodeBase64url(bytes) {
32
+ let result = "";
33
+ const len = bytes.length;
34
+ let i = 0;
35
+ while (i < len) {
36
+ const b0 = bytes[i++];
37
+ const hasB1 = i < len;
38
+ const b1 = hasB1 ? bytes[i++] : 0;
39
+ const hasB2 = i < len;
40
+ const b2 = hasB2 ? bytes[i++] : 0;
41
+ result += BASE64URL_CHARS[b0 >> 2 & 63];
42
+ result += BASE64URL_CHARS[(b0 << 4 | b1 >> 4) & 63];
43
+ if (hasB1) {
44
+ result += BASE64URL_CHARS[(b1 << 2 | b2 >> 6) & 63];
45
+ }
46
+ if (hasB2) {
47
+ result += BASE64URL_CHARS[b2 & 63];
48
+ }
49
+ }
50
+ return result;
51
+ }
52
+ function decodeBase64url(str) {
53
+ const charToIndex = new Uint8Array(128);
54
+ for (let i = 0; i < BASE64URL_CHARS.length; i++) {
55
+ charToIndex[BASE64URL_CHARS.charCodeAt(i)] = i;
56
+ }
57
+ const len = str.length;
58
+ const outputLen = Math.floor(len * 3 / 4);
59
+ const bytes = new Uint8Array(outputLen);
60
+ let bi = 0;
61
+ for (let i = 0; i < len; ) {
62
+ const c0 = charToIndex[str.charCodeAt(i++)];
63
+ const c1 = i < len ? charToIndex[str.charCodeAt(i++)] : 0;
64
+ const c2 = i < len ? charToIndex[str.charCodeAt(i++)] : 0;
65
+ const c3 = i < len ? charToIndex[str.charCodeAt(i++)] : 0;
66
+ bytes[bi++] = c0 << 2 | c1 >> 4;
67
+ if (bi < outputLen) bytes[bi++] = (c1 << 4 | c2 >> 2) & 255;
68
+ if (bi < outputLen) bytes[bi++] = (c2 << 6 | c3) & 255;
69
+ }
70
+ return bytes;
71
+ }
72
+ function serializeParamGraph(data) {
73
+ const rootKeys = Object.keys(data.roots);
74
+ const maxIndex = Math.max(
75
+ data.strings.length,
76
+ data.inputNodes.length,
77
+ data.outputNodes.length,
78
+ rootKeys.length
79
+ );
80
+ const useWide = maxIndex > MAX_COMPACT_INDEX;
81
+ let size = 1;
82
+ size += useWide ? 12 : 6;
83
+ for (const node of data.inputNodes) {
84
+ size += useWide ? 4 : 2;
85
+ const edgeCount = Object.keys(node.edges).length;
86
+ size += edgeCount * (useWide ? 20 : 10);
87
+ }
88
+ for (const node of data.outputNodes) {
89
+ size += useWide ? 4 : 2;
90
+ const edgeCount = Object.keys(node.edges).length;
91
+ size += edgeCount * (useWide ? 12 : 6);
92
+ }
93
+ size += rootKeys.length * (useWide ? 12 : 6);
94
+ const buffer = new ArrayBuffer(size);
95
+ const view = new DataView(buffer);
96
+ let offset = 0;
97
+ view.setUint8(offset++, useWide ? FORMAT_WIDE : FORMAT_COMPACT);
98
+ if (useWide) {
99
+ view.setUint32(offset, data.inputNodes.length, true);
100
+ offset += 4;
101
+ view.setUint32(offset, data.outputNodes.length, true);
102
+ offset += 4;
103
+ view.setUint32(offset, rootKeys.length, true);
104
+ offset += 4;
105
+ } else {
106
+ view.setUint16(offset, data.inputNodes.length, true);
107
+ offset += 2;
108
+ view.setUint16(offset, data.outputNodes.length, true);
109
+ offset += 2;
110
+ view.setUint16(offset, rootKeys.length, true);
111
+ offset += 2;
112
+ }
113
+ for (const node of data.inputNodes) {
114
+ const fieldIndices = Object.keys(node.edges).map(Number);
115
+ if (useWide) {
116
+ view.setUint32(offset, fieldIndices.length, true);
117
+ offset += 4;
118
+ } else {
119
+ view.setUint16(offset, fieldIndices.length, true);
120
+ offset += 2;
121
+ }
122
+ for (const fieldIndex of fieldIndices) {
123
+ const edge = node.edges[fieldIndex];
124
+ if (useWide) {
125
+ view.setUint32(offset, fieldIndex, true);
126
+ offset += 4;
127
+ view.setUint16(offset, edge.scalarMask ?? 0, true);
128
+ offset += 2;
129
+ offset += 2;
130
+ view.setUint32(offset, edge.childNodeId ?? NONE_32, true);
131
+ offset += 4;
132
+ view.setUint32(offset, edge.enumNameIndex ?? NONE_32, true);
133
+ offset += 4;
134
+ view.setUint8(offset, edge.flags);
135
+ offset += 1;
136
+ offset += 3;
137
+ } else {
138
+ view.setUint16(offset, fieldIndex, true);
139
+ offset += 2;
140
+ view.setUint16(offset, edge.scalarMask ?? 0, true);
141
+ offset += 2;
142
+ view.setUint16(offset, edge.childNodeId ?? NONE_16, true);
143
+ offset += 2;
144
+ view.setUint16(offset, edge.enumNameIndex ?? NONE_16, true);
145
+ offset += 2;
146
+ view.setUint8(offset, edge.flags);
147
+ offset += 1;
148
+ offset += 1;
149
+ }
150
+ }
151
+ }
152
+ for (const node of data.outputNodes) {
153
+ const fieldIndices = Object.keys(node.edges).map(Number);
154
+ if (useWide) {
155
+ view.setUint32(offset, fieldIndices.length, true);
156
+ offset += 4;
157
+ } else {
158
+ view.setUint16(offset, fieldIndices.length, true);
159
+ offset += 2;
160
+ }
161
+ for (const fieldIndex of fieldIndices) {
162
+ const edge = node.edges[fieldIndex];
163
+ if (useWide) {
164
+ view.setUint32(offset, fieldIndex, true);
165
+ offset += 4;
166
+ view.setUint32(offset, edge.argsNodeId ?? NONE_32, true);
167
+ offset += 4;
168
+ view.setUint32(offset, edge.outputNodeId ?? NONE_32, true);
169
+ offset += 4;
170
+ } else {
171
+ view.setUint16(offset, fieldIndex, true);
172
+ offset += 2;
173
+ view.setUint16(offset, edge.argsNodeId ?? NONE_16, true);
174
+ offset += 2;
175
+ view.setUint16(offset, edge.outputNodeId ?? NONE_16, true);
176
+ offset += 2;
177
+ }
178
+ }
179
+ }
180
+ for (const key of rootKeys) {
181
+ const root = data.roots[key];
182
+ const keyIndex = data.strings.indexOf(key);
183
+ if (useWide) {
184
+ view.setUint32(offset, keyIndex, true);
185
+ offset += 4;
186
+ view.setUint32(offset, root.argsNodeId ?? NONE_32, true);
187
+ offset += 4;
188
+ view.setUint32(offset, root.outputNodeId ?? NONE_32, true);
189
+ offset += 4;
190
+ } else {
191
+ view.setUint16(offset, keyIndex, true);
192
+ offset += 2;
193
+ view.setUint16(offset, root.argsNodeId ?? NONE_16, true);
194
+ offset += 2;
195
+ view.setUint16(offset, root.outputNodeId ?? NONE_16, true);
196
+ offset += 2;
197
+ }
198
+ }
199
+ return {
200
+ strings: data.strings,
201
+ graph: encodeBase64url(new Uint8Array(buffer))
202
+ };
203
+ }
204
+ function deserializeParamGraph(serialized) {
205
+ const bytes = decodeBase64url(serialized.graph);
206
+ const view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);
207
+ let offset = 0;
208
+ const format = view.getUint8(offset++);
209
+ const useWide = format === FORMAT_WIDE;
210
+ let inputNodeCount;
211
+ let outputNodeCount;
212
+ let rootCount;
213
+ if (useWide) {
214
+ inputNodeCount = view.getUint32(offset, true);
215
+ offset += 4;
216
+ outputNodeCount = view.getUint32(offset, true);
217
+ offset += 4;
218
+ rootCount = view.getUint32(offset, true);
219
+ offset += 4;
220
+ } else {
221
+ inputNodeCount = view.getUint16(offset, true);
222
+ offset += 2;
223
+ outputNodeCount = view.getUint16(offset, true);
224
+ offset += 2;
225
+ rootCount = view.getUint16(offset, true);
226
+ offset += 2;
227
+ }
228
+ const inputNodes = [];
229
+ for (let i = 0; i < inputNodeCount; i++) {
230
+ let edgeCount;
231
+ if (useWide) {
232
+ edgeCount = view.getUint32(offset, true);
233
+ offset += 4;
234
+ } else {
235
+ edgeCount = view.getUint16(offset, true);
236
+ offset += 2;
237
+ }
238
+ const edges = {};
239
+ for (let j = 0; j < edgeCount; j++) {
240
+ let fieldIndex;
241
+ let scalarMask;
242
+ let childNodeId;
243
+ let enumNameIndex;
244
+ let flags;
245
+ if (useWide) {
246
+ fieldIndex = view.getUint32(offset, true);
247
+ offset += 4;
248
+ scalarMask = view.getUint16(offset, true);
249
+ offset += 2;
250
+ offset += 2;
251
+ childNodeId = view.getUint32(offset, true);
252
+ offset += 4;
253
+ enumNameIndex = view.getUint32(offset, true);
254
+ offset += 4;
255
+ flags = view.getUint8(offset);
256
+ offset += 1;
257
+ offset += 3;
258
+ } else {
259
+ fieldIndex = view.getUint16(offset, true);
260
+ offset += 2;
261
+ scalarMask = view.getUint16(offset, true);
262
+ offset += 2;
263
+ childNodeId = view.getUint16(offset, true);
264
+ offset += 2;
265
+ enumNameIndex = view.getUint16(offset, true);
266
+ offset += 2;
267
+ flags = view.getUint8(offset);
268
+ offset += 1;
269
+ offset += 1;
270
+ }
271
+ const edge = { flags };
272
+ if (scalarMask !== 0) edge.scalarMask = scalarMask;
273
+ if (childNodeId !== (useWide ? NONE_32 : NONE_16)) edge.childNodeId = childNodeId;
274
+ if (enumNameIndex !== (useWide ? NONE_32 : NONE_16)) edge.enumNameIndex = enumNameIndex;
275
+ edges[fieldIndex] = edge;
276
+ }
277
+ inputNodes.push({ edges });
278
+ }
279
+ const outputNodes = [];
280
+ for (let i = 0; i < outputNodeCount; i++) {
281
+ let edgeCount;
282
+ if (useWide) {
283
+ edgeCount = view.getUint32(offset, true);
284
+ offset += 4;
285
+ } else {
286
+ edgeCount = view.getUint16(offset, true);
287
+ offset += 2;
288
+ }
289
+ const edges = {};
290
+ for (let j = 0; j < edgeCount; j++) {
291
+ let fieldIndex;
292
+ let argsNodeId;
293
+ let outputNodeId;
294
+ if (useWide) {
295
+ fieldIndex = view.getUint32(offset, true);
296
+ offset += 4;
297
+ argsNodeId = view.getUint32(offset, true);
298
+ offset += 4;
299
+ outputNodeId = view.getUint32(offset, true);
300
+ offset += 4;
301
+ } else {
302
+ fieldIndex = view.getUint16(offset, true);
303
+ offset += 2;
304
+ argsNodeId = view.getUint16(offset, true);
305
+ offset += 2;
306
+ outputNodeId = view.getUint16(offset, true);
307
+ offset += 2;
308
+ }
309
+ const edge = {};
310
+ if (argsNodeId !== (useWide ? NONE_32 : NONE_16)) edge.argsNodeId = argsNodeId;
311
+ if (outputNodeId !== (useWide ? NONE_32 : NONE_16)) edge.outputNodeId = outputNodeId;
312
+ edges[fieldIndex] = edge;
313
+ }
314
+ outputNodes.push({ edges });
315
+ }
316
+ const roots = {};
317
+ for (let i = 0; i < rootCount; i++) {
318
+ let keyIndex;
319
+ let argsNodeId;
320
+ let outputNodeId;
321
+ if (useWide) {
322
+ keyIndex = view.getUint32(offset, true);
323
+ offset += 4;
324
+ argsNodeId = view.getUint32(offset, true);
325
+ offset += 4;
326
+ outputNodeId = view.getUint32(offset, true);
327
+ offset += 4;
328
+ } else {
329
+ keyIndex = view.getUint16(offset, true);
330
+ offset += 2;
331
+ argsNodeId = view.getUint16(offset, true);
332
+ offset += 2;
333
+ outputNodeId = view.getUint16(offset, true);
334
+ offset += 2;
335
+ }
336
+ const key = serialized.strings[keyIndex];
337
+ const root = {};
338
+ if (argsNodeId !== (useWide ? NONE_32 : NONE_16)) root.argsNodeId = argsNodeId;
339
+ if (outputNodeId !== (useWide ? NONE_32 : NONE_16)) root.outputNodeId = outputNodeId;
340
+ roots[key] = root;
341
+ }
342
+ return {
343
+ strings: serialized.strings,
344
+ inputNodes,
345
+ outputNodes,
346
+ roots
347
+ };
348
+ }
349
+ // Annotate the CommonJS export names for ESM import in node:
350
+ 0 && (module.exports = {
351
+ deserializeParamGraph,
352
+ serializeParamGraph
353
+ });
@@ -0,0 +1,328 @@
1
+ const FORMAT_COMPACT = 0;
2
+ const FORMAT_WIDE = 1;
3
+ const NONE_16 = 65535;
4
+ const NONE_32 = 4294967295;
5
+ const MAX_COMPACT_INDEX = 65534;
6
+ const BASE64URL_CHARS = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_";
7
+ function encodeBase64url(bytes) {
8
+ let result = "";
9
+ const len = bytes.length;
10
+ let i = 0;
11
+ while (i < len) {
12
+ const b0 = bytes[i++];
13
+ const hasB1 = i < len;
14
+ const b1 = hasB1 ? bytes[i++] : 0;
15
+ const hasB2 = i < len;
16
+ const b2 = hasB2 ? bytes[i++] : 0;
17
+ result += BASE64URL_CHARS[b0 >> 2 & 63];
18
+ result += BASE64URL_CHARS[(b0 << 4 | b1 >> 4) & 63];
19
+ if (hasB1) {
20
+ result += BASE64URL_CHARS[(b1 << 2 | b2 >> 6) & 63];
21
+ }
22
+ if (hasB2) {
23
+ result += BASE64URL_CHARS[b2 & 63];
24
+ }
25
+ }
26
+ return result;
27
+ }
28
+ function decodeBase64url(str) {
29
+ const charToIndex = new Uint8Array(128);
30
+ for (let i = 0; i < BASE64URL_CHARS.length; i++) {
31
+ charToIndex[BASE64URL_CHARS.charCodeAt(i)] = i;
32
+ }
33
+ const len = str.length;
34
+ const outputLen = Math.floor(len * 3 / 4);
35
+ const bytes = new Uint8Array(outputLen);
36
+ let bi = 0;
37
+ for (let i = 0; i < len; ) {
38
+ const c0 = charToIndex[str.charCodeAt(i++)];
39
+ const c1 = i < len ? charToIndex[str.charCodeAt(i++)] : 0;
40
+ const c2 = i < len ? charToIndex[str.charCodeAt(i++)] : 0;
41
+ const c3 = i < len ? charToIndex[str.charCodeAt(i++)] : 0;
42
+ bytes[bi++] = c0 << 2 | c1 >> 4;
43
+ if (bi < outputLen) bytes[bi++] = (c1 << 4 | c2 >> 2) & 255;
44
+ if (bi < outputLen) bytes[bi++] = (c2 << 6 | c3) & 255;
45
+ }
46
+ return bytes;
47
+ }
48
+ function serializeParamGraph(data) {
49
+ const rootKeys = Object.keys(data.roots);
50
+ const maxIndex = Math.max(
51
+ data.strings.length,
52
+ data.inputNodes.length,
53
+ data.outputNodes.length,
54
+ rootKeys.length
55
+ );
56
+ const useWide = maxIndex > MAX_COMPACT_INDEX;
57
+ let size = 1;
58
+ size += useWide ? 12 : 6;
59
+ for (const node of data.inputNodes) {
60
+ size += useWide ? 4 : 2;
61
+ const edgeCount = Object.keys(node.edges).length;
62
+ size += edgeCount * (useWide ? 20 : 10);
63
+ }
64
+ for (const node of data.outputNodes) {
65
+ size += useWide ? 4 : 2;
66
+ const edgeCount = Object.keys(node.edges).length;
67
+ size += edgeCount * (useWide ? 12 : 6);
68
+ }
69
+ size += rootKeys.length * (useWide ? 12 : 6);
70
+ const buffer = new ArrayBuffer(size);
71
+ const view = new DataView(buffer);
72
+ let offset = 0;
73
+ view.setUint8(offset++, useWide ? FORMAT_WIDE : FORMAT_COMPACT);
74
+ if (useWide) {
75
+ view.setUint32(offset, data.inputNodes.length, true);
76
+ offset += 4;
77
+ view.setUint32(offset, data.outputNodes.length, true);
78
+ offset += 4;
79
+ view.setUint32(offset, rootKeys.length, true);
80
+ offset += 4;
81
+ } else {
82
+ view.setUint16(offset, data.inputNodes.length, true);
83
+ offset += 2;
84
+ view.setUint16(offset, data.outputNodes.length, true);
85
+ offset += 2;
86
+ view.setUint16(offset, rootKeys.length, true);
87
+ offset += 2;
88
+ }
89
+ for (const node of data.inputNodes) {
90
+ const fieldIndices = Object.keys(node.edges).map(Number);
91
+ if (useWide) {
92
+ view.setUint32(offset, fieldIndices.length, true);
93
+ offset += 4;
94
+ } else {
95
+ view.setUint16(offset, fieldIndices.length, true);
96
+ offset += 2;
97
+ }
98
+ for (const fieldIndex of fieldIndices) {
99
+ const edge = node.edges[fieldIndex];
100
+ if (useWide) {
101
+ view.setUint32(offset, fieldIndex, true);
102
+ offset += 4;
103
+ view.setUint16(offset, edge.scalarMask ?? 0, true);
104
+ offset += 2;
105
+ offset += 2;
106
+ view.setUint32(offset, edge.childNodeId ?? NONE_32, true);
107
+ offset += 4;
108
+ view.setUint32(offset, edge.enumNameIndex ?? NONE_32, true);
109
+ offset += 4;
110
+ view.setUint8(offset, edge.flags);
111
+ offset += 1;
112
+ offset += 3;
113
+ } else {
114
+ view.setUint16(offset, fieldIndex, true);
115
+ offset += 2;
116
+ view.setUint16(offset, edge.scalarMask ?? 0, true);
117
+ offset += 2;
118
+ view.setUint16(offset, edge.childNodeId ?? NONE_16, true);
119
+ offset += 2;
120
+ view.setUint16(offset, edge.enumNameIndex ?? NONE_16, true);
121
+ offset += 2;
122
+ view.setUint8(offset, edge.flags);
123
+ offset += 1;
124
+ offset += 1;
125
+ }
126
+ }
127
+ }
128
+ for (const node of data.outputNodes) {
129
+ const fieldIndices = Object.keys(node.edges).map(Number);
130
+ if (useWide) {
131
+ view.setUint32(offset, fieldIndices.length, true);
132
+ offset += 4;
133
+ } else {
134
+ view.setUint16(offset, fieldIndices.length, true);
135
+ offset += 2;
136
+ }
137
+ for (const fieldIndex of fieldIndices) {
138
+ const edge = node.edges[fieldIndex];
139
+ if (useWide) {
140
+ view.setUint32(offset, fieldIndex, true);
141
+ offset += 4;
142
+ view.setUint32(offset, edge.argsNodeId ?? NONE_32, true);
143
+ offset += 4;
144
+ view.setUint32(offset, edge.outputNodeId ?? NONE_32, true);
145
+ offset += 4;
146
+ } else {
147
+ view.setUint16(offset, fieldIndex, true);
148
+ offset += 2;
149
+ view.setUint16(offset, edge.argsNodeId ?? NONE_16, true);
150
+ offset += 2;
151
+ view.setUint16(offset, edge.outputNodeId ?? NONE_16, true);
152
+ offset += 2;
153
+ }
154
+ }
155
+ }
156
+ for (const key of rootKeys) {
157
+ const root = data.roots[key];
158
+ const keyIndex = data.strings.indexOf(key);
159
+ if (useWide) {
160
+ view.setUint32(offset, keyIndex, true);
161
+ offset += 4;
162
+ view.setUint32(offset, root.argsNodeId ?? NONE_32, true);
163
+ offset += 4;
164
+ view.setUint32(offset, root.outputNodeId ?? NONE_32, true);
165
+ offset += 4;
166
+ } else {
167
+ view.setUint16(offset, keyIndex, true);
168
+ offset += 2;
169
+ view.setUint16(offset, root.argsNodeId ?? NONE_16, true);
170
+ offset += 2;
171
+ view.setUint16(offset, root.outputNodeId ?? NONE_16, true);
172
+ offset += 2;
173
+ }
174
+ }
175
+ return {
176
+ strings: data.strings,
177
+ graph: encodeBase64url(new Uint8Array(buffer))
178
+ };
179
+ }
180
+ function deserializeParamGraph(serialized) {
181
+ const bytes = decodeBase64url(serialized.graph);
182
+ const view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);
183
+ let offset = 0;
184
+ const format = view.getUint8(offset++);
185
+ const useWide = format === FORMAT_WIDE;
186
+ let inputNodeCount;
187
+ let outputNodeCount;
188
+ let rootCount;
189
+ if (useWide) {
190
+ inputNodeCount = view.getUint32(offset, true);
191
+ offset += 4;
192
+ outputNodeCount = view.getUint32(offset, true);
193
+ offset += 4;
194
+ rootCount = view.getUint32(offset, true);
195
+ offset += 4;
196
+ } else {
197
+ inputNodeCount = view.getUint16(offset, true);
198
+ offset += 2;
199
+ outputNodeCount = view.getUint16(offset, true);
200
+ offset += 2;
201
+ rootCount = view.getUint16(offset, true);
202
+ offset += 2;
203
+ }
204
+ const inputNodes = [];
205
+ for (let i = 0; i < inputNodeCount; i++) {
206
+ let edgeCount;
207
+ if (useWide) {
208
+ edgeCount = view.getUint32(offset, true);
209
+ offset += 4;
210
+ } else {
211
+ edgeCount = view.getUint16(offset, true);
212
+ offset += 2;
213
+ }
214
+ const edges = {};
215
+ for (let j = 0; j < edgeCount; j++) {
216
+ let fieldIndex;
217
+ let scalarMask;
218
+ let childNodeId;
219
+ let enumNameIndex;
220
+ let flags;
221
+ if (useWide) {
222
+ fieldIndex = view.getUint32(offset, true);
223
+ offset += 4;
224
+ scalarMask = view.getUint16(offset, true);
225
+ offset += 2;
226
+ offset += 2;
227
+ childNodeId = view.getUint32(offset, true);
228
+ offset += 4;
229
+ enumNameIndex = view.getUint32(offset, true);
230
+ offset += 4;
231
+ flags = view.getUint8(offset);
232
+ offset += 1;
233
+ offset += 3;
234
+ } else {
235
+ fieldIndex = view.getUint16(offset, true);
236
+ offset += 2;
237
+ scalarMask = view.getUint16(offset, true);
238
+ offset += 2;
239
+ childNodeId = view.getUint16(offset, true);
240
+ offset += 2;
241
+ enumNameIndex = view.getUint16(offset, true);
242
+ offset += 2;
243
+ flags = view.getUint8(offset);
244
+ offset += 1;
245
+ offset += 1;
246
+ }
247
+ const edge = { flags };
248
+ if (scalarMask !== 0) edge.scalarMask = scalarMask;
249
+ if (childNodeId !== (useWide ? NONE_32 : NONE_16)) edge.childNodeId = childNodeId;
250
+ if (enumNameIndex !== (useWide ? NONE_32 : NONE_16)) edge.enumNameIndex = enumNameIndex;
251
+ edges[fieldIndex] = edge;
252
+ }
253
+ inputNodes.push({ edges });
254
+ }
255
+ const outputNodes = [];
256
+ for (let i = 0; i < outputNodeCount; i++) {
257
+ let edgeCount;
258
+ if (useWide) {
259
+ edgeCount = view.getUint32(offset, true);
260
+ offset += 4;
261
+ } else {
262
+ edgeCount = view.getUint16(offset, true);
263
+ offset += 2;
264
+ }
265
+ const edges = {};
266
+ for (let j = 0; j < edgeCount; j++) {
267
+ let fieldIndex;
268
+ let argsNodeId;
269
+ let outputNodeId;
270
+ if (useWide) {
271
+ fieldIndex = view.getUint32(offset, true);
272
+ offset += 4;
273
+ argsNodeId = view.getUint32(offset, true);
274
+ offset += 4;
275
+ outputNodeId = view.getUint32(offset, true);
276
+ offset += 4;
277
+ } else {
278
+ fieldIndex = view.getUint16(offset, true);
279
+ offset += 2;
280
+ argsNodeId = view.getUint16(offset, true);
281
+ offset += 2;
282
+ outputNodeId = view.getUint16(offset, true);
283
+ offset += 2;
284
+ }
285
+ const edge = {};
286
+ if (argsNodeId !== (useWide ? NONE_32 : NONE_16)) edge.argsNodeId = argsNodeId;
287
+ if (outputNodeId !== (useWide ? NONE_32 : NONE_16)) edge.outputNodeId = outputNodeId;
288
+ edges[fieldIndex] = edge;
289
+ }
290
+ outputNodes.push({ edges });
291
+ }
292
+ const roots = {};
293
+ for (let i = 0; i < rootCount; i++) {
294
+ let keyIndex;
295
+ let argsNodeId;
296
+ let outputNodeId;
297
+ if (useWide) {
298
+ keyIndex = view.getUint32(offset, true);
299
+ offset += 4;
300
+ argsNodeId = view.getUint32(offset, true);
301
+ offset += 4;
302
+ outputNodeId = view.getUint32(offset, true);
303
+ offset += 4;
304
+ } else {
305
+ keyIndex = view.getUint16(offset, true);
306
+ offset += 2;
307
+ argsNodeId = view.getUint16(offset, true);
308
+ offset += 2;
309
+ outputNodeId = view.getUint16(offset, true);
310
+ offset += 2;
311
+ }
312
+ const key = serialized.strings[keyIndex];
313
+ const root = {};
314
+ if (argsNodeId !== (useWide ? NONE_32 : NONE_16)) root.argsNodeId = argsNodeId;
315
+ if (outputNodeId !== (useWide ? NONE_32 : NONE_16)) root.outputNodeId = outputNodeId;
316
+ roots[key] = root;
317
+ }
318
+ return {
319
+ strings: serialized.strings,
320
+ inputNodes,
321
+ outputNodes,
322
+ roots
323
+ };
324
+ }
325
+ export {
326
+ deserializeParamGraph,
327
+ serializeParamGraph
328
+ };
@@ -0,0 +1 @@
1
+ export {};