summaryrefslogtreecommitdiff
path: root/includes/external/school/node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs
diff options
context:
space:
mode:
authorMinteck <contact@minteck.org>2023-02-23 19:34:56 +0100
committerMinteck <contact@minteck.org>2023-02-23 19:34:56 +0100
commit3d1cd02f27518f1a04374c7c8320cd5d82ede6e9 (patch)
tree75be5fba4368472fb11c8015aee026b2b9a71888 /includes/external/school/node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs
parent8cc1f13c17fa2fb5a4410542d39e650e02945634 (diff)
downloadpluralconnect-3d1cd02f27518f1a04374c7c8320cd5d82ede6e9.tar.gz
pluralconnect-3d1cd02f27518f1a04374c7c8320cd5d82ede6e9.tar.bz2
pluralconnect-3d1cd02f27518f1a04374c7c8320cd5d82ede6e9.zip
Updated 40 files, added 37 files, deleted 1103 files and renamed 3905 files (automated)
Diffstat (limited to 'includes/external/school/node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs')
-rw-r--r--includes/external/school/node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs45
1 files changed, 45 insertions, 0 deletions
diff --git a/includes/external/school/node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs b/includes/external/school/node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs
new file mode 100644
index 0000000..1f5f816
--- /dev/null
+++ b/includes/external/school/node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs
@@ -0,0 +1,45 @@
+import { GraphQLError } from "../../error/GraphQLError.mjs";
+
+/**
+ * No unused fragments
+ *
+ * A GraphQL document is only valid if all fragment definitions are spread
+ * within operations, or spread within other fragments spread within operations.
+ */
+export function NoUnusedFragmentsRule(context) {
+ var operationDefs = [];
+ var fragmentDefs = [];
+ return {
+ OperationDefinition: function OperationDefinition(node) {
+ operationDefs.push(node);
+ return false;
+ },
+ FragmentDefinition: function FragmentDefinition(node) {
+ fragmentDefs.push(node);
+ return false;
+ },
+ Document: {
+ leave: function leave() {
+ var fragmentNameUsed = Object.create(null);
+
+ for (var _i2 = 0; _i2 < operationDefs.length; _i2++) {
+ var operation = operationDefs[_i2];
+
+ for (var _i4 = 0, _context$getRecursive2 = context.getRecursivelyReferencedFragments(operation); _i4 < _context$getRecursive2.length; _i4++) {
+ var fragment = _context$getRecursive2[_i4];
+ fragmentNameUsed[fragment.name.value] = true;
+ }
+ }
+
+ for (var _i6 = 0; _i6 < fragmentDefs.length; _i6++) {
+ var fragmentDef = fragmentDefs[_i6];
+ var fragName = fragmentDef.name.value;
+
+ if (fragmentNameUsed[fragName] !== true) {
+ context.reportError(new GraphQLError("Fragment \"".concat(fragName, "\" is never used."), fragmentDef));
+ }
+ }
+ }
+ }
+ };
+}