@graphitation/supermassive 3.3.0 → 3.4.0

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 (58) hide show
  1. package/.eslintcache +1 -1
  2. package/CHANGELOG.md +10 -2
  3. package/lib/collectFields.d.ts +8 -21
  4. package/lib/collectFields.d.ts.map +1 -1
  5. package/lib/collectFields.js +95 -97
  6. package/lib/collectFields.js.map +2 -2
  7. package/lib/collectFields.mjs +95 -97
  8. package/lib/collectFields.mjs.map +2 -2
  9. package/lib/executeWithoutSchema.d.ts +50 -6
  10. package/lib/executeWithoutSchema.d.ts.map +1 -1
  11. package/lib/executeWithoutSchema.js +517 -622
  12. package/lib/executeWithoutSchema.js.map +3 -3
  13. package/lib/executeWithoutSchema.mjs +518 -633
  14. package/lib/executeWithoutSchema.mjs.map +3 -3
  15. package/lib/index.d.ts +1 -1
  16. package/lib/index.d.ts.map +1 -1
  17. package/lib/index.js.map +1 -1
  18. package/lib/index.mjs.map +1 -1
  19. package/lib/types.d.ts +27 -63
  20. package/lib/types.d.ts.map +1 -1
  21. package/lib/types.js.map +1 -1
  22. package/lib/values.d.ts +4 -5
  23. package/lib/values.d.ts.map +1 -1
  24. package/lib/values.js +8 -13
  25. package/lib/values.js.map +2 -2
  26. package/lib/values.mjs +8 -13
  27. package/lib/values.mjs.map +2 -2
  28. package/package.json +1 -1
  29. package/lib/IncrementalPublisher.d.ts +0 -131
  30. package/lib/IncrementalPublisher.d.ts.map +0 -1
  31. package/lib/IncrementalPublisher.js +0 -519
  32. package/lib/IncrementalPublisher.js.map +0 -7
  33. package/lib/IncrementalPublisher.mjs +0 -503
  34. package/lib/IncrementalPublisher.mjs.map +0 -7
  35. package/lib/buildFieldPlan.d.ts +0 -18
  36. package/lib/buildFieldPlan.d.ts.map +0 -1
  37. package/lib/buildFieldPlan.js +0 -120
  38. package/lib/buildFieldPlan.js.map +0 -7
  39. package/lib/buildFieldPlan.mjs +0 -101
  40. package/lib/buildFieldPlan.mjs.map +0 -7
  41. package/lib/jsutils/getBySet.d.ts +0 -2
  42. package/lib/jsutils/getBySet.d.ts.map +0 -1
  43. package/lib/jsutils/getBySet.js +0 -32
  44. package/lib/jsutils/getBySet.js.map +0 -7
  45. package/lib/jsutils/getBySet.mjs +0 -13
  46. package/lib/jsutils/getBySet.mjs.map +0 -7
  47. package/lib/jsutils/isSameSet.d.ts +0 -2
  48. package/lib/jsutils/isSameSet.d.ts.map +0 -1
  49. package/lib/jsutils/isSameSet.js +0 -34
  50. package/lib/jsutils/isSameSet.js.map +0 -7
  51. package/lib/jsutils/isSameSet.mjs +0 -15
  52. package/lib/jsutils/isSameSet.mjs.map +0 -7
  53. package/lib/jsutils/promiseWithResolvers.d.ts +0 -11
  54. package/lib/jsutils/promiseWithResolvers.d.ts.map +0 -1
  55. package/lib/jsutils/promiseWithResolvers.js +0 -32
  56. package/lib/jsutils/promiseWithResolvers.js.map +0 -7
  57. package/lib/jsutils/promiseWithResolvers.mjs +0 -13
  58. package/lib/jsutils/promiseWithResolvers.mjs.map +0 -7
@@ -1,18 +0,0 @@
1
- import type { DeferUsage, FieldDetails } from "./collectFields.js";
2
- export type DeferUsageSet = ReadonlySet<DeferUsage>;
3
- export interface FieldGroup {
4
- fields: ReadonlyArray<FieldDetails>;
5
- deferUsages?: DeferUsageSet | undefined;
6
- knownDeferUsages?: DeferUsageSet | undefined;
7
- }
8
- export type GroupedFieldSet = Map<string, FieldGroup>;
9
- export interface NewGroupedFieldSetDetails {
10
- groupedFieldSet: GroupedFieldSet;
11
- shouldInitiateDefer: boolean;
12
- }
13
- export declare function buildFieldPlan(fields: Map<string, ReadonlyArray<FieldDetails>>, parentDeferUsages?: DeferUsageSet, knownDeferUsages?: DeferUsageSet): {
14
- groupedFieldSet: GroupedFieldSet;
15
- newGroupedFieldSetDetailsMap: Map<DeferUsageSet, NewGroupedFieldSetDetails>;
16
- newDeferUsages: ReadonlyArray<DeferUsage>;
17
- };
18
- //# sourceMappingURL=buildFieldPlan.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"buildFieldPlan.d.ts","sourceRoot":"","sources":["../src/buildFieldPlan.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAEnE,MAAM,MAAM,aAAa,GAAG,WAAW,CAAC,UAAU,CAAC,CAAC;AAEpD,MAAM,WAAW,UAAU;IACzB,MAAM,EAAE,aAAa,CAAC,YAAY,CAAC,CAAC;IACpC,WAAW,CAAC,EAAE,aAAa,GAAG,SAAS,CAAC;IACxC,gBAAgB,CAAC,EAAE,aAAa,GAAG,SAAS,CAAC;CAC9C;AAED,MAAM,MAAM,eAAe,GAAG,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;AAEtD,MAAM,WAAW,yBAAyB;IACxC,eAAe,EAAE,eAAe,CAAC;IACjC,mBAAmB,EAAE,OAAO,CAAC;CAC9B;AAED,wBAAgB,cAAc,CAC5B,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,aAAa,CAAC,YAAY,CAAC,CAAC,EAChD,iBAAiB,GAAE,aAAqC,EACxD,gBAAgB,GAAE,aAAqC,GACtD;IACD,eAAe,EAAE,eAAe,CAAC;IACjC,4BAA4B,EAAE,GAAG,CAAC,aAAa,EAAE,yBAAyB,CAAC,CAAC;IAC5E,cAAc,EAAE,aAAa,CAAC,UAAU,CAAC,CAAC;CAC3C,CA8HA"}
@@ -1,120 +0,0 @@
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 buildFieldPlan_exports = {};
20
- __export(buildFieldPlan_exports, {
21
- buildFieldPlan: () => buildFieldPlan
22
- });
23
- module.exports = __toCommonJS(buildFieldPlan_exports);
24
- var import_getBySet = require("./jsutils/getBySet");
25
- var import_isSameSet = require("./jsutils/isSameSet");
26
- function buildFieldPlan(fields, parentDeferUsages = /* @__PURE__ */ new Set(), knownDeferUsages = /* @__PURE__ */ new Set()) {
27
- const newDeferUsages = /* @__PURE__ */ new Set();
28
- const newKnownDeferUsages = new Set(knownDeferUsages);
29
- const groupedFieldSet = /* @__PURE__ */ new Map();
30
- const newGroupedFieldSetDetailsMap = /* @__PURE__ */ new Map();
31
- const map = /* @__PURE__ */ new Map();
32
- for (const [responseKey, fieldDetailsList] of fields) {
33
- const deferUsageSet = /* @__PURE__ */ new Set();
34
- let inOriginalResult = false;
35
- for (const fieldDetails of fieldDetailsList) {
36
- const deferUsage = fieldDetails.deferUsage;
37
- if (deferUsage === void 0) {
38
- inOriginalResult = true;
39
- continue;
40
- }
41
- deferUsageSet.add(deferUsage);
42
- if (!knownDeferUsages.has(deferUsage)) {
43
- newDeferUsages.add(deferUsage);
44
- newKnownDeferUsages.add(deferUsage);
45
- }
46
- }
47
- if (inOriginalResult) {
48
- deferUsageSet.clear();
49
- } else {
50
- deferUsageSet.forEach((deferUsage) => {
51
- const ancestors = getAncestors(deferUsage);
52
- for (const ancestor of ancestors) {
53
- if (deferUsageSet.has(ancestor)) {
54
- deferUsageSet.delete(deferUsage);
55
- }
56
- }
57
- });
58
- }
59
- map.set(responseKey, { deferUsageSet, fieldDetailsList });
60
- }
61
- for (const [responseKey, { deferUsageSet, fieldDetailsList }] of map) {
62
- if ((0, import_isSameSet.isSameSet)(deferUsageSet, parentDeferUsages)) {
63
- let fieldGroup2 = groupedFieldSet.get(responseKey);
64
- if (fieldGroup2 === void 0) {
65
- fieldGroup2 = {
66
- fields: [],
67
- deferUsages: deferUsageSet,
68
- knownDeferUsages: newKnownDeferUsages
69
- };
70
- groupedFieldSet.set(responseKey, fieldGroup2);
71
- }
72
- fieldGroup2.fields.push(...fieldDetailsList);
73
- continue;
74
- }
75
- let newGroupedFieldSetDetails = (0, import_getBySet.getBySet)(
76
- newGroupedFieldSetDetailsMap,
77
- deferUsageSet
78
- );
79
- let newGroupedFieldSet;
80
- if (newGroupedFieldSetDetails === void 0) {
81
- newGroupedFieldSet = /* @__PURE__ */ new Map();
82
- newGroupedFieldSetDetails = {
83
- groupedFieldSet: newGroupedFieldSet,
84
- shouldInitiateDefer: Array.from(deferUsageSet).some(
85
- (deferUsage) => !parentDeferUsages.has(deferUsage)
86
- )
87
- };
88
- newGroupedFieldSetDetailsMap.set(
89
- deferUsageSet,
90
- newGroupedFieldSetDetails
91
- );
92
- } else {
93
- newGroupedFieldSet = newGroupedFieldSetDetails.groupedFieldSet;
94
- }
95
- let fieldGroup = newGroupedFieldSet.get(responseKey);
96
- if (fieldGroup === void 0) {
97
- fieldGroup = {
98
- fields: [],
99
- deferUsages: deferUsageSet,
100
- knownDeferUsages: newKnownDeferUsages
101
- };
102
- newGroupedFieldSet.set(responseKey, fieldGroup);
103
- }
104
- fieldGroup.fields.push(...fieldDetailsList);
105
- }
106
- return {
107
- groupedFieldSet,
108
- newGroupedFieldSetDetailsMap,
109
- newDeferUsages: Array.from(newDeferUsages)
110
- };
111
- }
112
- function getAncestors(deferUsage) {
113
- const ancestors = [];
114
- let parentDeferUsage = deferUsage.parentDeferUsage;
115
- while (parentDeferUsage !== void 0) {
116
- ancestors.unshift(parentDeferUsage);
117
- parentDeferUsage = parentDeferUsage.parentDeferUsage;
118
- }
119
- return ancestors;
120
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../src/buildFieldPlan.ts"],
4
- "sourcesContent": ["import { getBySet } from \"./jsutils/getBySet\";\nimport { isSameSet } from \"./jsutils/isSameSet\";\n\nimport type { DeferUsage, FieldDetails } from \"./collectFields.js\";\n\nexport type DeferUsageSet = ReadonlySet<DeferUsage>;\n\nexport interface FieldGroup {\n fields: ReadonlyArray<FieldDetails>;\n deferUsages?: DeferUsageSet | undefined;\n knownDeferUsages?: DeferUsageSet | undefined;\n}\n\nexport type GroupedFieldSet = Map<string, FieldGroup>;\n\nexport interface NewGroupedFieldSetDetails {\n groupedFieldSet: GroupedFieldSet;\n shouldInitiateDefer: boolean;\n}\n\nexport function buildFieldPlan(\n fields: Map<string, ReadonlyArray<FieldDetails>>,\n parentDeferUsages: DeferUsageSet = new Set<DeferUsage>(),\n knownDeferUsages: DeferUsageSet = new Set<DeferUsage>(),\n): {\n groupedFieldSet: GroupedFieldSet;\n newGroupedFieldSetDetailsMap: Map<DeferUsageSet, NewGroupedFieldSetDetails>;\n newDeferUsages: ReadonlyArray<DeferUsage>;\n} {\n const newDeferUsages: Set<DeferUsage> = new Set<DeferUsage>();\n const newKnownDeferUsages = new Set<DeferUsage>(knownDeferUsages);\n\n const groupedFieldSet = new Map<\n string,\n {\n fields: Array<FieldDetails>;\n deferUsages: DeferUsageSet;\n knownDeferUsages: DeferUsageSet;\n }\n >();\n\n const newGroupedFieldSetDetailsMap = new Map<\n DeferUsageSet,\n {\n groupedFieldSet: Map<\n string,\n {\n fields: Array<FieldDetails>;\n deferUsages: DeferUsageSet;\n knownDeferUsages: DeferUsageSet;\n }\n >;\n shouldInitiateDefer: boolean;\n }\n >();\n\n const map = new Map<\n string,\n {\n deferUsageSet: DeferUsageSet;\n fieldDetailsList: ReadonlyArray<FieldDetails>;\n }\n >();\n\n for (const [responseKey, fieldDetailsList] of fields) {\n const deferUsageSet = new Set<DeferUsage>();\n let inOriginalResult = false;\n for (const fieldDetails of fieldDetailsList) {\n const deferUsage = fieldDetails.deferUsage;\n if (deferUsage === undefined) {\n inOriginalResult = true;\n continue;\n }\n deferUsageSet.add(deferUsage);\n if (!knownDeferUsages.has(deferUsage)) {\n newDeferUsages.add(deferUsage);\n newKnownDeferUsages.add(deferUsage);\n }\n }\n if (inOriginalResult) {\n deferUsageSet.clear();\n } else {\n deferUsageSet.forEach((deferUsage) => {\n const ancestors = getAncestors(deferUsage);\n for (const ancestor of ancestors) {\n if (deferUsageSet.has(ancestor)) {\n deferUsageSet.delete(deferUsage);\n }\n }\n });\n }\n map.set(responseKey, { deferUsageSet, fieldDetailsList });\n }\n\n for (const [responseKey, { deferUsageSet, fieldDetailsList }] of map) {\n if (isSameSet(deferUsageSet, parentDeferUsages)) {\n let fieldGroup = groupedFieldSet.get(responseKey);\n if (fieldGroup === undefined) {\n fieldGroup = {\n fields: [],\n deferUsages: deferUsageSet,\n knownDeferUsages: newKnownDeferUsages,\n };\n groupedFieldSet.set(responseKey, fieldGroup);\n }\n fieldGroup.fields.push(...fieldDetailsList);\n continue;\n }\n\n let newGroupedFieldSetDetails = getBySet(\n newGroupedFieldSetDetailsMap,\n deferUsageSet,\n );\n let newGroupedFieldSet;\n if (newGroupedFieldSetDetails === undefined) {\n newGroupedFieldSet = new Map<\n string,\n {\n fields: Array<FieldDetails>;\n deferUsages: DeferUsageSet;\n knownDeferUsages: DeferUsageSet;\n }\n >();\n\n newGroupedFieldSetDetails = {\n groupedFieldSet: newGroupedFieldSet,\n shouldInitiateDefer: Array.from(deferUsageSet).some(\n (deferUsage) => !parentDeferUsages.has(deferUsage),\n ),\n };\n newGroupedFieldSetDetailsMap.set(\n deferUsageSet,\n newGroupedFieldSetDetails,\n );\n } else {\n newGroupedFieldSet = newGroupedFieldSetDetails.groupedFieldSet;\n }\n let fieldGroup = newGroupedFieldSet.get(responseKey);\n if (fieldGroup === undefined) {\n fieldGroup = {\n fields: [],\n deferUsages: deferUsageSet,\n knownDeferUsages: newKnownDeferUsages,\n };\n newGroupedFieldSet.set(responseKey, fieldGroup);\n }\n fieldGroup.fields.push(...fieldDetailsList);\n }\n\n return {\n groupedFieldSet,\n newGroupedFieldSetDetailsMap,\n newDeferUsages: Array.from(newDeferUsages),\n };\n}\n\nfunction getAncestors(deferUsage: DeferUsage): ReadonlyArray<DeferUsage> {\n const ancestors: Array<DeferUsage> = [];\n let parentDeferUsage: DeferUsage | undefined = deferUsage.parentDeferUsage;\n while (parentDeferUsage !== undefined) {\n ancestors.unshift(parentDeferUsage);\n parentDeferUsage = parentDeferUsage.parentDeferUsage;\n }\n return ancestors;\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sBAAyB;AACzB,uBAA0B;AAmBnB,SAAS,eACd,QACA,oBAAmC,oBAAI,IAAgB,GACvD,mBAAkC,oBAAI,IAAgB,GAKtD;AACA,QAAM,iBAAkC,oBAAI,IAAgB;AAC5D,QAAM,sBAAsB,IAAI,IAAgB,gBAAgB;AAEhE,QAAM,kBAAkB,oBAAI,IAO1B;AAEF,QAAM,+BAA+B,oBAAI,IAavC;AAEF,QAAM,MAAM,oBAAI,IAMd;AAEF,aAAW,CAAC,aAAa,gBAAgB,KAAK,QAAQ;AACpD,UAAM,gBAAgB,oBAAI,IAAgB;AAC1C,QAAI,mBAAmB;AACvB,eAAW,gBAAgB,kBAAkB;AAC3C,YAAM,aAAa,aAAa;AAChC,UAAI,eAAe,QAAW;AAC5B,2BAAmB;AACnB;AAAA,MACF;AACA,oBAAc,IAAI,UAAU;AAC5B,UAAI,CAAC,iBAAiB,IAAI,UAAU,GAAG;AACrC,uBAAe,IAAI,UAAU;AAC7B,4BAAoB,IAAI,UAAU;AAAA,MACpC;AAAA,IACF;AACA,QAAI,kBAAkB;AACpB,oBAAc,MAAM;AAAA,IACtB,OAAO;AACL,oBAAc,QAAQ,CAAC,eAAe;AACpC,cAAM,YAAY,aAAa,UAAU;AACzC,mBAAW,YAAY,WAAW;AAChC,cAAI,cAAc,IAAI,QAAQ,GAAG;AAC/B,0BAAc,OAAO,UAAU;AAAA,UACjC;AAAA,QACF;AAAA,MACF,CAAC;AAAA,IACH;AACA,QAAI,IAAI,aAAa,EAAE,eAAe,iBAAiB,CAAC;AAAA,EAC1D;AAEA,aAAW,CAAC,aAAa,EAAE,eAAe,iBAAiB,CAAC,KAAK,KAAK;AACpE,YAAI,4BAAU,eAAe,iBAAiB,GAAG;AAC/C,UAAIA,cAAa,gBAAgB,IAAI,WAAW;AAChD,UAAIA,gBAAe,QAAW;AAC5B,QAAAA,cAAa;AAAA,UACX,QAAQ,CAAC;AAAA,UACT,aAAa;AAAA,UACb,kBAAkB;AAAA,QACpB;AACA,wBAAgB,IAAI,aAAaA,WAAU;AAAA,MAC7C;AACA,MAAAA,YAAW,OAAO,KAAK,GAAG,gBAAgB;AAC1C;AAAA,IACF;AAEA,QAAI,gCAA4B;AAAA,MAC9B;AAAA,MACA;AAAA,IACF;AACA,QAAI;AACJ,QAAI,8BAA8B,QAAW;AAC3C,2BAAqB,oBAAI,IAOvB;AAEF,kCAA4B;AAAA,QAC1B,iBAAiB;AAAA,QACjB,qBAAqB,MAAM,KAAK,aAAa,EAAE;AAAA,UAC7C,CAAC,eAAe,CAAC,kBAAkB,IAAI,UAAU;AAAA,QACnD;AAAA,MACF;AACA,mCAA6B;AAAA,QAC3B;AAAA,QACA;AAAA,MACF;AAAA,IACF,OAAO;AACL,2BAAqB,0BAA0B;AAAA,IACjD;AACA,QAAI,aAAa,mBAAmB,IAAI,WAAW;AACnD,QAAI,eAAe,QAAW;AAC5B,mBAAa;AAAA,QACX,QAAQ,CAAC;AAAA,QACT,aAAa;AAAA,QACb,kBAAkB;AAAA,MACpB;AACA,yBAAmB,IAAI,aAAa,UAAU;AAAA,IAChD;AACA,eAAW,OAAO,KAAK,GAAG,gBAAgB;AAAA,EAC5C;AAEA,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA,gBAAgB,MAAM,KAAK,cAAc;AAAA,EAC3C;AACF;AAEA,SAAS,aAAa,YAAmD;AACvE,QAAM,YAA+B,CAAC;AACtC,MAAI,mBAA2C,WAAW;AAC1D,SAAO,qBAAqB,QAAW;AACrC,cAAU,QAAQ,gBAAgB;AAClC,uBAAmB,iBAAiB;AAAA,EACtC;AACA,SAAO;AACT;",
6
- "names": ["fieldGroup"]
7
- }
@@ -1,101 +0,0 @@
1
- // src/buildFieldPlan.ts
2
- import { getBySet } from "./jsutils/getBySet.mjs";
3
- import { isSameSet } from "./jsutils/isSameSet.mjs";
4
- function buildFieldPlan(fields, parentDeferUsages = /* @__PURE__ */ new Set(), knownDeferUsages = /* @__PURE__ */ new Set()) {
5
- const newDeferUsages = /* @__PURE__ */ new Set();
6
- const newKnownDeferUsages = new Set(knownDeferUsages);
7
- const groupedFieldSet = /* @__PURE__ */ new Map();
8
- const newGroupedFieldSetDetailsMap = /* @__PURE__ */ new Map();
9
- const map = /* @__PURE__ */ new Map();
10
- for (const [responseKey, fieldDetailsList] of fields) {
11
- const deferUsageSet = /* @__PURE__ */ new Set();
12
- let inOriginalResult = false;
13
- for (const fieldDetails of fieldDetailsList) {
14
- const deferUsage = fieldDetails.deferUsage;
15
- if (deferUsage === void 0) {
16
- inOriginalResult = true;
17
- continue;
18
- }
19
- deferUsageSet.add(deferUsage);
20
- if (!knownDeferUsages.has(deferUsage)) {
21
- newDeferUsages.add(deferUsage);
22
- newKnownDeferUsages.add(deferUsage);
23
- }
24
- }
25
- if (inOriginalResult) {
26
- deferUsageSet.clear();
27
- } else {
28
- deferUsageSet.forEach((deferUsage) => {
29
- const ancestors = getAncestors(deferUsage);
30
- for (const ancestor of ancestors) {
31
- if (deferUsageSet.has(ancestor)) {
32
- deferUsageSet.delete(deferUsage);
33
- }
34
- }
35
- });
36
- }
37
- map.set(responseKey, { deferUsageSet, fieldDetailsList });
38
- }
39
- for (const [responseKey, { deferUsageSet, fieldDetailsList }] of map) {
40
- if (isSameSet(deferUsageSet, parentDeferUsages)) {
41
- let fieldGroup2 = groupedFieldSet.get(responseKey);
42
- if (fieldGroup2 === void 0) {
43
- fieldGroup2 = {
44
- fields: [],
45
- deferUsages: deferUsageSet,
46
- knownDeferUsages: newKnownDeferUsages
47
- };
48
- groupedFieldSet.set(responseKey, fieldGroup2);
49
- }
50
- fieldGroup2.fields.push(...fieldDetailsList);
51
- continue;
52
- }
53
- let newGroupedFieldSetDetails = getBySet(
54
- newGroupedFieldSetDetailsMap,
55
- deferUsageSet
56
- );
57
- let newGroupedFieldSet;
58
- if (newGroupedFieldSetDetails === void 0) {
59
- newGroupedFieldSet = /* @__PURE__ */ new Map();
60
- newGroupedFieldSetDetails = {
61
- groupedFieldSet: newGroupedFieldSet,
62
- shouldInitiateDefer: Array.from(deferUsageSet).some(
63
- (deferUsage) => !parentDeferUsages.has(deferUsage)
64
- )
65
- };
66
- newGroupedFieldSetDetailsMap.set(
67
- deferUsageSet,
68
- newGroupedFieldSetDetails
69
- );
70
- } else {
71
- newGroupedFieldSet = newGroupedFieldSetDetails.groupedFieldSet;
72
- }
73
- let fieldGroup = newGroupedFieldSet.get(responseKey);
74
- if (fieldGroup === void 0) {
75
- fieldGroup = {
76
- fields: [],
77
- deferUsages: deferUsageSet,
78
- knownDeferUsages: newKnownDeferUsages
79
- };
80
- newGroupedFieldSet.set(responseKey, fieldGroup);
81
- }
82
- fieldGroup.fields.push(...fieldDetailsList);
83
- }
84
- return {
85
- groupedFieldSet,
86
- newGroupedFieldSetDetailsMap,
87
- newDeferUsages: Array.from(newDeferUsages)
88
- };
89
- }
90
- function getAncestors(deferUsage) {
91
- const ancestors = [];
92
- let parentDeferUsage = deferUsage.parentDeferUsage;
93
- while (parentDeferUsage !== void 0) {
94
- ancestors.unshift(parentDeferUsage);
95
- parentDeferUsage = parentDeferUsage.parentDeferUsage;
96
- }
97
- return ancestors;
98
- }
99
- export {
100
- buildFieldPlan
101
- };
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../src/buildFieldPlan.ts"],
4
- "sourcesContent": ["import { getBySet } from \"./jsutils/getBySet\";\nimport { isSameSet } from \"./jsutils/isSameSet\";\n\nimport type { DeferUsage, FieldDetails } from \"./collectFields.js\";\n\nexport type DeferUsageSet = ReadonlySet<DeferUsage>;\n\nexport interface FieldGroup {\n fields: ReadonlyArray<FieldDetails>;\n deferUsages?: DeferUsageSet | undefined;\n knownDeferUsages?: DeferUsageSet | undefined;\n}\n\nexport type GroupedFieldSet = Map<string, FieldGroup>;\n\nexport interface NewGroupedFieldSetDetails {\n groupedFieldSet: GroupedFieldSet;\n shouldInitiateDefer: boolean;\n}\n\nexport function buildFieldPlan(\n fields: Map<string, ReadonlyArray<FieldDetails>>,\n parentDeferUsages: DeferUsageSet = new Set<DeferUsage>(),\n knownDeferUsages: DeferUsageSet = new Set<DeferUsage>(),\n): {\n groupedFieldSet: GroupedFieldSet;\n newGroupedFieldSetDetailsMap: Map<DeferUsageSet, NewGroupedFieldSetDetails>;\n newDeferUsages: ReadonlyArray<DeferUsage>;\n} {\n const newDeferUsages: Set<DeferUsage> = new Set<DeferUsage>();\n const newKnownDeferUsages = new Set<DeferUsage>(knownDeferUsages);\n\n const groupedFieldSet = new Map<\n string,\n {\n fields: Array<FieldDetails>;\n deferUsages: DeferUsageSet;\n knownDeferUsages: DeferUsageSet;\n }\n >();\n\n const newGroupedFieldSetDetailsMap = new Map<\n DeferUsageSet,\n {\n groupedFieldSet: Map<\n string,\n {\n fields: Array<FieldDetails>;\n deferUsages: DeferUsageSet;\n knownDeferUsages: DeferUsageSet;\n }\n >;\n shouldInitiateDefer: boolean;\n }\n >();\n\n const map = new Map<\n string,\n {\n deferUsageSet: DeferUsageSet;\n fieldDetailsList: ReadonlyArray<FieldDetails>;\n }\n >();\n\n for (const [responseKey, fieldDetailsList] of fields) {\n const deferUsageSet = new Set<DeferUsage>();\n let inOriginalResult = false;\n for (const fieldDetails of fieldDetailsList) {\n const deferUsage = fieldDetails.deferUsage;\n if (deferUsage === undefined) {\n inOriginalResult = true;\n continue;\n }\n deferUsageSet.add(deferUsage);\n if (!knownDeferUsages.has(deferUsage)) {\n newDeferUsages.add(deferUsage);\n newKnownDeferUsages.add(deferUsage);\n }\n }\n if (inOriginalResult) {\n deferUsageSet.clear();\n } else {\n deferUsageSet.forEach((deferUsage) => {\n const ancestors = getAncestors(deferUsage);\n for (const ancestor of ancestors) {\n if (deferUsageSet.has(ancestor)) {\n deferUsageSet.delete(deferUsage);\n }\n }\n });\n }\n map.set(responseKey, { deferUsageSet, fieldDetailsList });\n }\n\n for (const [responseKey, { deferUsageSet, fieldDetailsList }] of map) {\n if (isSameSet(deferUsageSet, parentDeferUsages)) {\n let fieldGroup = groupedFieldSet.get(responseKey);\n if (fieldGroup === undefined) {\n fieldGroup = {\n fields: [],\n deferUsages: deferUsageSet,\n knownDeferUsages: newKnownDeferUsages,\n };\n groupedFieldSet.set(responseKey, fieldGroup);\n }\n fieldGroup.fields.push(...fieldDetailsList);\n continue;\n }\n\n let newGroupedFieldSetDetails = getBySet(\n newGroupedFieldSetDetailsMap,\n deferUsageSet,\n );\n let newGroupedFieldSet;\n if (newGroupedFieldSetDetails === undefined) {\n newGroupedFieldSet = new Map<\n string,\n {\n fields: Array<FieldDetails>;\n deferUsages: DeferUsageSet;\n knownDeferUsages: DeferUsageSet;\n }\n >();\n\n newGroupedFieldSetDetails = {\n groupedFieldSet: newGroupedFieldSet,\n shouldInitiateDefer: Array.from(deferUsageSet).some(\n (deferUsage) => !parentDeferUsages.has(deferUsage),\n ),\n };\n newGroupedFieldSetDetailsMap.set(\n deferUsageSet,\n newGroupedFieldSetDetails,\n );\n } else {\n newGroupedFieldSet = newGroupedFieldSetDetails.groupedFieldSet;\n }\n let fieldGroup = newGroupedFieldSet.get(responseKey);\n if (fieldGroup === undefined) {\n fieldGroup = {\n fields: [],\n deferUsages: deferUsageSet,\n knownDeferUsages: newKnownDeferUsages,\n };\n newGroupedFieldSet.set(responseKey, fieldGroup);\n }\n fieldGroup.fields.push(...fieldDetailsList);\n }\n\n return {\n groupedFieldSet,\n newGroupedFieldSetDetailsMap,\n newDeferUsages: Array.from(newDeferUsages),\n };\n}\n\nfunction getAncestors(deferUsage: DeferUsage): ReadonlyArray<DeferUsage> {\n const ancestors: Array<DeferUsage> = [];\n let parentDeferUsage: DeferUsage | undefined = deferUsage.parentDeferUsage;\n while (parentDeferUsage !== undefined) {\n ancestors.unshift(parentDeferUsage);\n parentDeferUsage = parentDeferUsage.parentDeferUsage;\n }\n return ancestors;\n}\n"],
5
- "mappings": ";AAAA,SAAS,gBAAgB;AACzB,SAAS,iBAAiB;AAmBnB,SAAS,eACd,QACA,oBAAmC,oBAAI,IAAgB,GACvD,mBAAkC,oBAAI,IAAgB,GAKtD;AACA,QAAM,iBAAkC,oBAAI,IAAgB;AAC5D,QAAM,sBAAsB,IAAI,IAAgB,gBAAgB;AAEhE,QAAM,kBAAkB,oBAAI,IAO1B;AAEF,QAAM,+BAA+B,oBAAI,IAavC;AAEF,QAAM,MAAM,oBAAI,IAMd;AAEF,aAAW,CAAC,aAAa,gBAAgB,KAAK,QAAQ;AACpD,UAAM,gBAAgB,oBAAI,IAAgB;AAC1C,QAAI,mBAAmB;AACvB,eAAW,gBAAgB,kBAAkB;AAC3C,YAAM,aAAa,aAAa;AAChC,UAAI,eAAe,QAAW;AAC5B,2BAAmB;AACnB;AAAA,MACF;AACA,oBAAc,IAAI,UAAU;AAC5B,UAAI,CAAC,iBAAiB,IAAI,UAAU,GAAG;AACrC,uBAAe,IAAI,UAAU;AAC7B,4BAAoB,IAAI,UAAU;AAAA,MACpC;AAAA,IACF;AACA,QAAI,kBAAkB;AACpB,oBAAc,MAAM;AAAA,IACtB,OAAO;AACL,oBAAc,QAAQ,CAAC,eAAe;AACpC,cAAM,YAAY,aAAa,UAAU;AACzC,mBAAW,YAAY,WAAW;AAChC,cAAI,cAAc,IAAI,QAAQ,GAAG;AAC/B,0BAAc,OAAO,UAAU;AAAA,UACjC;AAAA,QACF;AAAA,MACF,CAAC;AAAA,IACH;AACA,QAAI,IAAI,aAAa,EAAE,eAAe,iBAAiB,CAAC;AAAA,EAC1D;AAEA,aAAW,CAAC,aAAa,EAAE,eAAe,iBAAiB,CAAC,KAAK,KAAK;AACpE,QAAI,UAAU,eAAe,iBAAiB,GAAG;AAC/C,UAAIA,cAAa,gBAAgB,IAAI,WAAW;AAChD,UAAIA,gBAAe,QAAW;AAC5B,QAAAA,cAAa;AAAA,UACX,QAAQ,CAAC;AAAA,UACT,aAAa;AAAA,UACb,kBAAkB;AAAA,QACpB;AACA,wBAAgB,IAAI,aAAaA,WAAU;AAAA,MAC7C;AACA,MAAAA,YAAW,OAAO,KAAK,GAAG,gBAAgB;AAC1C;AAAA,IACF;AAEA,QAAI,4BAA4B;AAAA,MAC9B;AAAA,MACA;AAAA,IACF;AACA,QAAI;AACJ,QAAI,8BAA8B,QAAW;AAC3C,2BAAqB,oBAAI,IAOvB;AAEF,kCAA4B;AAAA,QAC1B,iBAAiB;AAAA,QACjB,qBAAqB,MAAM,KAAK,aAAa,EAAE;AAAA,UAC7C,CAAC,eAAe,CAAC,kBAAkB,IAAI,UAAU;AAAA,QACnD;AAAA,MACF;AACA,mCAA6B;AAAA,QAC3B;AAAA,QACA;AAAA,MACF;AAAA,IACF,OAAO;AACL,2BAAqB,0BAA0B;AAAA,IACjD;AACA,QAAI,aAAa,mBAAmB,IAAI,WAAW;AACnD,QAAI,eAAe,QAAW;AAC5B,mBAAa;AAAA,QACX,QAAQ,CAAC;AAAA,QACT,aAAa;AAAA,QACb,kBAAkB;AAAA,MACpB;AACA,yBAAmB,IAAI,aAAa,UAAU;AAAA,IAChD;AACA,eAAW,OAAO,KAAK,GAAG,gBAAgB;AAAA,EAC5C;AAEA,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA,gBAAgB,MAAM,KAAK,cAAc;AAAA,EAC3C;AACF;AAEA,SAAS,aAAa,YAAmD;AACvE,QAAM,YAA+B,CAAC;AACtC,MAAI,mBAA2C,WAAW;AAC1D,SAAO,qBAAqB,QAAW;AACrC,cAAU,QAAQ,gBAAgB;AAClC,uBAAmB,iBAAiB;AAAA,EACtC;AACA,SAAO;AACT;",
6
- "names": ["fieldGroup"]
7
- }
@@ -1,2 +0,0 @@
1
- export declare function getBySet<T, U>(map: ReadonlyMap<ReadonlySet<T>, U>, setToMatch: ReadonlySet<T>): U | undefined;
2
- //# sourceMappingURL=getBySet.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"getBySet.d.ts","sourceRoot":"","sources":["../../src/jsutils/getBySet.ts"],"names":[],"mappings":"AAEA,wBAAgB,QAAQ,CAAC,CAAC,EAAE,CAAC,EAC3B,GAAG,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EACnC,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,GACzB,CAAC,GAAG,SAAS,CAOf"}
@@ -1,32 +0,0 @@
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 getBySet_exports = {};
20
- __export(getBySet_exports, {
21
- getBySet: () => getBySet
22
- });
23
- module.exports = __toCommonJS(getBySet_exports);
24
- var import_isSameSet = require("./isSameSet");
25
- function getBySet(map, setToMatch) {
26
- for (const set of map.keys()) {
27
- if ((0, import_isSameSet.isSameSet)(set, setToMatch)) {
28
- return map.get(set);
29
- }
30
- }
31
- return void 0;
32
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/jsutils/getBySet.ts"],
4
- "sourcesContent": ["import { isSameSet } from \"./isSameSet\";\n\nexport function getBySet<T, U>(\n map: ReadonlyMap<ReadonlySet<T>, U>,\n setToMatch: ReadonlySet<T>,\n): U | undefined {\n for (const set of map.keys()) {\n if (isSameSet(set, setToMatch)) {\n return map.get(set);\n }\n }\n return undefined;\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,uBAA0B;AAEnB,SAAS,SACd,KACA,YACe;AACf,aAAW,OAAO,IAAI,KAAK,GAAG;AAC5B,YAAI,4BAAU,KAAK,UAAU,GAAG;AAC9B,aAAO,IAAI,IAAI,GAAG;AAAA,IACpB;AAAA,EACF;AACA,SAAO;AACT;",
6
- "names": []
7
- }
@@ -1,13 +0,0 @@
1
- // src/jsutils/getBySet.ts
2
- import { isSameSet } from "./isSameSet.mjs";
3
- function getBySet(map, setToMatch) {
4
- for (const set of map.keys()) {
5
- if (isSameSet(set, setToMatch)) {
6
- return map.get(set);
7
- }
8
- }
9
- return void 0;
10
- }
11
- export {
12
- getBySet
13
- };
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/jsutils/getBySet.ts"],
4
- "sourcesContent": ["import { isSameSet } from \"./isSameSet\";\n\nexport function getBySet<T, U>(\n map: ReadonlyMap<ReadonlySet<T>, U>,\n setToMatch: ReadonlySet<T>,\n): U | undefined {\n for (const set of map.keys()) {\n if (isSameSet(set, setToMatch)) {\n return map.get(set);\n }\n }\n return undefined;\n}\n"],
5
- "mappings": ";AAAA,SAAS,iBAAiB;AAEnB,SAAS,SACd,KACA,YACe;AACf,aAAW,OAAO,IAAI,KAAK,GAAG;AAC5B,QAAI,UAAU,KAAK,UAAU,GAAG;AAC9B,aAAO,IAAI,IAAI,GAAG;AAAA,IACpB;AAAA,EACF;AACA,SAAO;AACT;",
6
- "names": []
7
- }
@@ -1,2 +0,0 @@
1
- export declare function isSameSet<T>(setA: ReadonlySet<T>, setB: ReadonlySet<T>): boolean;
2
- //# sourceMappingURL=isSameSet.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"isSameSet.d.ts","sourceRoot":"","sources":["../../src/jsutils/isSameSet.ts"],"names":[],"mappings":"AAAA,wBAAgB,SAAS,CAAC,CAAC,EACzB,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,EACpB,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,GACnB,OAAO,CAUT"}
@@ -1,34 +0,0 @@
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 isSameSet_exports = {};
20
- __export(isSameSet_exports, {
21
- isSameSet: () => isSameSet
22
- });
23
- module.exports = __toCommonJS(isSameSet_exports);
24
- function isSameSet(setA, setB) {
25
- if (setA.size !== setB.size) {
26
- return false;
27
- }
28
- for (const item of setA) {
29
- if (!setB.has(item)) {
30
- return false;
31
- }
32
- }
33
- return true;
34
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/jsutils/isSameSet.ts"],
4
- "sourcesContent": ["export function isSameSet<T>(\n setA: ReadonlySet<T>,\n setB: ReadonlySet<T>,\n): boolean {\n if (setA.size !== setB.size) {\n return false;\n }\n for (const item of setA) {\n if (!setB.has(item)) {\n return false;\n }\n }\n return true;\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAAS,UACd,MACA,MACS;AACT,MAAI,KAAK,SAAS,KAAK,MAAM;AAC3B,WAAO;AAAA,EACT;AACA,aAAW,QAAQ,MAAM;AACvB,QAAI,CAAC,KAAK,IAAI,IAAI,GAAG;AACnB,aAAO;AAAA,IACT;AAAA,EACF;AACA,SAAO;AACT;",
6
- "names": []
7
- }
@@ -1,15 +0,0 @@
1
- // src/jsutils/isSameSet.ts
2
- function isSameSet(setA, setB) {
3
- if (setA.size !== setB.size) {
4
- return false;
5
- }
6
- for (const item of setA) {
7
- if (!setB.has(item)) {
8
- return false;
9
- }
10
- }
11
- return true;
12
- }
13
- export {
14
- isSameSet
15
- };
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/jsutils/isSameSet.ts"],
4
- "sourcesContent": ["export function isSameSet<T>(\n setA: ReadonlySet<T>,\n setB: ReadonlySet<T>,\n): boolean {\n if (setA.size !== setB.size) {\n return false;\n }\n for (const item of setA) {\n if (!setB.has(item)) {\n return false;\n }\n }\n return true;\n}\n"],
5
- "mappings": ";AAAO,SAAS,UACd,MACA,MACS;AACT,MAAI,KAAK,SAAS,KAAK,MAAM;AAC3B,WAAO;AAAA,EACT;AACA,aAAW,QAAQ,MAAM;AACvB,QAAI,CAAC,KAAK,IAAI,IAAI,GAAG;AACnB,aAAO;AAAA,IACT;AAAA,EACF;AACA,SAAO;AACT;",
6
- "names": []
7
- }
@@ -1,11 +0,0 @@
1
- import type { PromiseOrValue } from "./PromiseOrValue";
2
- /**
3
- * Based on Promise.withResolvers proposal
4
- * https://github.com/tc39/proposal-promise-with-resolvers
5
- */
6
- export declare function promiseWithResolvers<T>(): {
7
- promise: Promise<T>;
8
- resolve: (value: T | PromiseOrValue<T>) => void;
9
- reject: (reason?: unknown) => void;
10
- };
11
- //# sourceMappingURL=promiseWithResolvers.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"promiseWithResolvers.d.ts","sourceRoot":"","sources":["../../src/jsutils/promiseWithResolvers.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAEvD;;;GAGG;AACH,wBAAgB,oBAAoB,CAAC,CAAC,KAAK;IACzC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACpB,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC,GAAG,cAAc,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC;IAChD,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,OAAO,KAAK,IAAI,CAAC;CACpC,CASA"}
@@ -1,32 +0,0 @@
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 promiseWithResolvers_exports = {};
20
- __export(promiseWithResolvers_exports, {
21
- promiseWithResolvers: () => promiseWithResolvers
22
- });
23
- module.exports = __toCommonJS(promiseWithResolvers_exports);
24
- function promiseWithResolvers() {
25
- let resolve;
26
- let reject;
27
- const promise = new Promise((res, rej) => {
28
- resolve = res;
29
- reject = rej;
30
- });
31
- return { promise, resolve, reject };
32
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/jsutils/promiseWithResolvers.ts"],
4
- "sourcesContent": ["import type { PromiseOrValue } from \"./PromiseOrValue\";\n\n/**\n * Based on Promise.withResolvers proposal\n * https://github.com/tc39/proposal-promise-with-resolvers\n */\nexport function promiseWithResolvers<T>(): {\n promise: Promise<T>;\n resolve: (value: T | PromiseOrValue<T>) => void;\n reject: (reason?: unknown) => void;\n} {\n // these are assigned synchronously within the Promise constructor\n let resolve!: (value: T | PromiseOrValue<T>) => void;\n let reject!: (reason?: unknown) => void;\n const promise = new Promise<T>((res, rej) => {\n resolve = res;\n reject = rej;\n });\n return { promise, resolve, reject };\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAMO,SAAS,uBAId;AAEA,MAAI;AACJ,MAAI;AACJ,QAAM,UAAU,IAAI,QAAW,CAAC,KAAK,QAAQ;AAC3C,cAAU;AACV,aAAS;AAAA,EACX,CAAC;AACD,SAAO,EAAE,SAAS,SAAS,OAAO;AACpC;",
6
- "names": []
7
- }
@@ -1,13 +0,0 @@
1
- // src/jsutils/promiseWithResolvers.ts
2
- function promiseWithResolvers() {
3
- let resolve;
4
- let reject;
5
- const promise = new Promise((res, rej) => {
6
- resolve = res;
7
- reject = rej;
8
- });
9
- return { promise, resolve, reject };
10
- }
11
- export {
12
- promiseWithResolvers
13
- };
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/jsutils/promiseWithResolvers.ts"],
4
- "sourcesContent": ["import type { PromiseOrValue } from \"./PromiseOrValue\";\n\n/**\n * Based on Promise.withResolvers proposal\n * https://github.com/tc39/proposal-promise-with-resolvers\n */\nexport function promiseWithResolvers<T>(): {\n promise: Promise<T>;\n resolve: (value: T | PromiseOrValue<T>) => void;\n reject: (reason?: unknown) => void;\n} {\n // these are assigned synchronously within the Promise constructor\n let resolve!: (value: T | PromiseOrValue<T>) => void;\n let reject!: (reason?: unknown) => void;\n const promise = new Promise<T>((res, rej) => {\n resolve = res;\n reject = rej;\n });\n return { promise, resolve, reject };\n}\n"],
5
- "mappings": ";AAMO,SAAS,uBAId;AAEA,MAAI;AACJ,MAAI;AACJ,QAAM,UAAU,IAAI,QAAW,CAAC,KAAK,QAAQ;AAC3C,cAAU;AACV,aAAS;AAAA,EACX,CAAC;AACD,SAAO,EAAE,SAAS,SAAS,OAAO;AACpC;",
6
- "names": []
7
- }