flow like the river
This commit is contained in:
commit
013fe673f3
42435 changed files with 5764238 additions and 0 deletions
54
BACK_BACK/node_modules/graphql/validation/rules/NoUnusedFragmentsRule.js.flow
generated
vendored
Executable file
54
BACK_BACK/node_modules/graphql/validation/rules/NoUnusedFragmentsRule.js.flow
generated
vendored
Executable file
|
|
@ -0,0 +1,54 @@
|
|||
// @flow strict
|
||||
import { GraphQLError } from '../../error/GraphQLError';
|
||||
|
||||
import type { ASTVisitor } from '../../language/visitor';
|
||||
|
||||
import type { ASTValidationContext } from '../ValidationContext';
|
||||
|
||||
/**
|
||||
* 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: ASTValidationContext,
|
||||
): ASTVisitor {
|
||||
const operationDefs = [];
|
||||
const fragmentDefs = [];
|
||||
|
||||
return {
|
||||
OperationDefinition(node) {
|
||||
operationDefs.push(node);
|
||||
return false;
|
||||
},
|
||||
FragmentDefinition(node) {
|
||||
fragmentDefs.push(node);
|
||||
return false;
|
||||
},
|
||||
Document: {
|
||||
leave() {
|
||||
const fragmentNameUsed = Object.create(null);
|
||||
for (const operation of operationDefs) {
|
||||
for (const fragment of context.getRecursivelyReferencedFragments(
|
||||
operation,
|
||||
)) {
|
||||
fragmentNameUsed[fragment.name.value] = true;
|
||||
}
|
||||
}
|
||||
|
||||
for (const fragmentDef of fragmentDefs) {
|
||||
const fragName = fragmentDef.name.value;
|
||||
if (fragmentNameUsed[fragName] !== true) {
|
||||
context.reportError(
|
||||
new GraphQLError(
|
||||
`Fragment "${fragName}" is never used.`,
|
||||
fragmentDef,
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
},
|
||||
},
|
||||
};
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue