From 3d1cd02f27518f1a04374c7c8320cd5d82ede6e9 Mon Sep 17 00:00:00 2001 From: Minteck Date: Thu, 23 Feb 2023 19:34:56 +0100 Subject: Updated 40 files, added 37 files, deleted 1103 files and renamed 3905 files (automated) --- .../validation/rules/NoUnusedFragmentsRule.mjs | 45 ++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 includes/external/school/node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs (limited to 'includes/external/school/node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs') 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)); + } + } + } + } + }; +} -- cgit