relay-compiler 0.0.0-main-8ff54d69 → 0.0.0-main-38f1c96e
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.
- package/cli.js +23 -0
- package/index.js +19 -3
- package/linux-x64/relay +0 -0
- package/macos-x64/relay +0 -0
- package/package.json +2 -24
- package/win-x64/relay.exe +0 -0
- package/bin/RelayCompilerBin.js.flow +0 -168
- package/bin/RelayCompilerMain.js.flow +0 -515
- package/bin/__fixtures__/plugin-module.js.flow +0 -17
- package/bin/relay-compiler +0 -19068
- package/codegen/CodegenDirectory.js.flow +0 -372
- package/codegen/CodegenRunner.js.flow +0 -424
- package/codegen/CodegenTypes.js.flow +0 -28
- package/codegen/CodegenWatcher.js.flow +0 -250
- package/codegen/NormalizationCodeGenerator.js.flow +0 -566
- package/codegen/ReaderCodeGenerator.js.flow +0 -510
- package/codegen/RelayCodeGenerator.js.flow +0 -85
- package/codegen/RelayFileWriter.js.flow +0 -365
- package/codegen/SourceControl.js.flow +0 -58
- package/codegen/compileRelayArtifacts.js.flow +0 -181
- package/codegen/createPrintRequireModuleDependency.js.flow +0 -19
- package/codegen/sortObjectByKey.js.flow +0 -25
- package/codegen/writeRelayGeneratedFile.js.flow +0 -235
- package/core/ASTCache.js.flow +0 -73
- package/core/ASTConvert.js.flow +0 -230
- package/core/CompilerContext.js.flow +0 -189
- package/core/CompilerError.js.flow +0 -255
- package/core/DotGraphQLParser.js.flow +0 -37
- package/core/GraphQLCompilerProfiler.js.flow +0 -341
- package/core/GraphQLDerivedFromMetadata.js.flow +0 -36
- package/core/GraphQLWatchmanClient.js.flow +0 -109
- package/core/IR.js.flow +0 -326
- package/core/IRPrinter.js.flow +0 -472
- package/core/IRTransformer.js.flow +0 -376
- package/core/IRValidator.js.flow +0 -259
- package/core/IRVisitor.js.flow +0 -150
- package/core/JSModuleParser.js.flow +0 -24
- package/core/RelayCompilerScope.js.flow +0 -199
- package/core/RelayFindGraphQLTags.js.flow +0 -118
- package/core/RelayGraphQLEnumsGenerator.js.flow +0 -55
- package/core/RelayIRTransforms.js.flow +0 -138
- package/core/RelayParser.js.flow +0 -1741
- package/core/RelaySourceModuleParser.js.flow +0 -133
- package/core/Schema.js.flow +0 -2035
- package/core/SchemaUtils.js.flow +0 -120
- package/core/filterContextForNode.js.flow +0 -49
- package/core/getFieldDefinition.js.flow +0 -156
- package/core/getIdentifierForArgumentValue.js.flow +0 -49
- package/core/getIdentifierForSelection.js.flow +0 -68
- package/core/getLiteralArgumentValues.js.flow +0 -32
- package/core/getNormalizationOperationName.js.flow +0 -19
- package/core/inferRootArgumentDefinitions.js.flow +0 -322
- package/index.js.flow +0 -198
- package/language/RelayLanguagePluginInterface.js.flow +0 -283
- package/language/javascript/FindGraphQLTags.js.flow +0 -136
- package/language/javascript/RelayFlowBabelFactories.js.flow +0 -176
- package/language/javascript/RelayFlowGenerator.js.flow +0 -1096
- package/language/javascript/RelayFlowTypeTransformers.js.flow +0 -181
- package/language/javascript/RelayLanguagePluginJavaScript.js.flow +0 -33
- package/language/javascript/formatGeneratedModule.js.flow +0 -65
- package/lib/bin/RelayCompilerBin.js +0 -143
- package/lib/bin/RelayCompilerMain.js +0 -488
- package/lib/bin/__fixtures__/plugin-module.js +0 -16
- package/lib/codegen/CodegenDirectory.js +0 -335
- package/lib/codegen/CodegenRunner.js +0 -433
- package/lib/codegen/CodegenTypes.js +0 -11
- package/lib/codegen/CodegenWatcher.js +0 -271
- package/lib/codegen/NormalizationCodeGenerator.js +0 -487
- package/lib/codegen/ReaderCodeGenerator.js +0 -473
- package/lib/codegen/RelayCodeGenerator.js +0 -75
- package/lib/codegen/RelayFileWriter.js +0 -270
- package/lib/codegen/SourceControl.js +0 -60
- package/lib/codegen/compileRelayArtifacts.js +0 -157
- package/lib/codegen/createPrintRequireModuleDependency.js +0 -19
- package/lib/codegen/sortObjectByKey.js +0 -41
- package/lib/codegen/writeRelayGeneratedFile.js +0 -206
- package/lib/core/ASTCache.js +0 -70
- package/lib/core/ASTConvert.js +0 -198
- package/lib/core/CompilerContext.js +0 -165
- package/lib/core/CompilerError.js +0 -252
- package/lib/core/DotGraphQLParser.js +0 -40
- package/lib/core/GraphQLCompilerProfiler.js +0 -299
- package/lib/core/GraphQLDerivedFromMetadata.js +0 -31
- package/lib/core/GraphQLWatchmanClient.js +0 -150
- package/lib/core/IR.js +0 -11
- package/lib/core/IRPrinter.js +0 -388
- package/lib/core/IRTransformer.js +0 -345
- package/lib/core/IRValidator.js +0 -226
- package/lib/core/IRVisitor.js +0 -45
- package/lib/core/JSModuleParser.js +0 -18
- package/lib/core/RelayCompilerScope.js +0 -183
- package/lib/core/RelayFindGraphQLTags.js +0 -79
- package/lib/core/RelayGraphQLEnumsGenerator.js +0 -50
- package/lib/core/RelayIRTransforms.js +0 -109
- package/lib/core/RelayParser.js +0 -1381
- package/lib/core/RelaySourceModuleParser.js +0 -104
- package/lib/core/Schema.js +0 -1877
- package/lib/core/SchemaUtils.js +0 -98
- package/lib/core/filterContextForNode.js +0 -50
- package/lib/core/getFieldDefinition.js +0 -145
- package/lib/core/getIdentifierForArgumentValue.js +0 -54
- package/lib/core/getIdentifierForSelection.js +0 -49
- package/lib/core/getLiteralArgumentValues.js +0 -26
- package/lib/core/getNormalizationOperationName.js +0 -17
- package/lib/core/inferRootArgumentDefinitions.js +0 -351
- package/lib/index.js +0 -178
- package/lib/language/RelayLanguagePluginInterface.js +0 -26
- package/lib/language/javascript/FindGraphQLTags.js +0 -126
- package/lib/language/javascript/RelayFlowBabelFactories.js +0 -160
- package/lib/language/javascript/RelayFlowGenerator.js +0 -856
- package/lib/language/javascript/RelayFlowTypeTransformers.js +0 -119
- package/lib/language/javascript/RelayLanguagePluginJavaScript.js +0 -30
- package/lib/language/javascript/formatGeneratedModule.js +0 -36
- package/lib/reporters/ConsoleReporter.js +0 -61
- package/lib/reporters/MultiReporter.js +0 -45
- package/lib/reporters/Reporter.js +0 -11
- package/lib/runner/Artifacts.js +0 -323
- package/lib/runner/BufferedFilesystem.js +0 -262
- package/lib/runner/GraphQLASTNodeGroup.js +0 -256
- package/lib/runner/GraphQLASTUtils.js +0 -23
- package/lib/runner/GraphQLNodeMap.js +0 -81
- package/lib/runner/Sources.js +0 -271
- package/lib/runner/StrictMap.js +0 -134
- package/lib/runner/compileArtifacts.js +0 -39
- package/lib/runner/extractAST.js +0 -77
- package/lib/runner/getChangedNodeNames.js +0 -82
- package/lib/runner/getSchemaInstance.js +0 -30
- package/lib/runner/types.js +0 -12
- package/lib/test-utils/TestSchema.js +0 -27
- package/lib/test-utils/parseGraphQLText.js +0 -30
- package/lib/transforms/ApplyFragmentArgumentTransform.js +0 -393
- package/lib/transforms/ClientExtensionsTransform.js +0 -221
- package/lib/transforms/ConnectionTransform.js +0 -639
- package/lib/transforms/DeclarativeConnectionMutationTransform.js +0 -218
- package/lib/transforms/DeferStreamTransform.js +0 -246
- package/lib/transforms/DisallowIdAsAlias.js +0 -40
- package/lib/transforms/DisallowTypenameOnRoot.js +0 -53
- package/lib/transforms/FieldHandleTransform.js +0 -79
- package/lib/transforms/FilterCompilerDirectivesTransform.js +0 -29
- package/lib/transforms/FilterDirectivesTransform.js +0 -42
- package/lib/transforms/FlattenTransform.js +0 -306
- package/lib/transforms/GenerateIDFieldTransform.js +0 -135
- package/lib/transforms/GenerateTypeNameTransform.js +0 -149
- package/lib/transforms/InlineDataFragmentTransform.js +0 -100
- package/lib/transforms/InlineFragmentsTransform.js +0 -61
- package/lib/transforms/MaskTransform.js +0 -117
- package/lib/transforms/MatchTransform.js +0 -434
- package/lib/transforms/ReactFlightComponentTransform.js +0 -158
- package/lib/transforms/RefetchableFragmentTransform.js +0 -249
- package/lib/transforms/RelayDirectiveTransform.js +0 -83
- package/lib/transforms/RequiredFieldTransform.js +0 -369
- package/lib/transforms/SkipClientExtensionsTransform.js +0 -46
- package/lib/transforms/SkipHandleFieldTransform.js +0 -45
- package/lib/transforms/SkipRedundantNodesTransform.js +0 -261
- package/lib/transforms/SkipSplitOperationTransform.js +0 -32
- package/lib/transforms/SkipUnreachableNodeTransform.js +0 -158
- package/lib/transforms/SkipUnusedVariablesTransform.js +0 -75
- package/lib/transforms/SplitModuleImportTransform.js +0 -82
- package/lib/transforms/TestOperationTransform.js +0 -144
- package/lib/transforms/TransformUtils.js +0 -21
- package/lib/transforms/ValidateGlobalVariablesTransform.js +0 -92
- package/lib/transforms/ValidateRequiredArgumentsTransform.js +0 -114
- package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +0 -108
- package/lib/transforms/ValidateUnusedVariablesTransform.js +0 -96
- package/lib/transforms/query-generators/FetchableQueryGenerator.js +0 -157
- package/lib/transforms/query-generators/NodeQueryGenerator.js +0 -166
- package/lib/transforms/query-generators/QueryQueryGenerator.js +0 -48
- package/lib/transforms/query-generators/ViewerQueryGenerator.js +0 -77
- package/lib/transforms/query-generators/index.js +0 -60
- package/lib/transforms/query-generators/utils.js +0 -92
- package/lib/util/CodeMarker.js +0 -80
- package/lib/util/DefaultHandleKey.js +0 -15
- package/lib/util/RelayCompilerCache.js +0 -97
- package/lib/util/Rollout.js +0 -40
- package/lib/util/TimeReporter.js +0 -83
- package/lib/util/areEqualArgValues.js +0 -135
- package/lib/util/argumentContainsVariables.js +0 -37
- package/lib/util/dedupeJSONStringify.js +0 -160
- package/lib/util/generateAbstractTypeRefinementKey.js +0 -24
- package/lib/util/getDefinitionNodeHash.js +0 -22
- package/lib/util/getModuleName.js +0 -32
- package/lib/util/joinArgumentDefinitions.js +0 -67
- package/lib/util/md5.js +0 -17
- package/lib/util/murmurHash.js +0 -86
- package/lib/util/nullthrowsOSS.js +0 -23
- package/lib/util/orList.js +0 -36
- package/lib/util/partitionArray.js +0 -35
- package/relay-compiler.js +0 -17
- package/relay-compiler.min.js +0 -22
- package/reporters/ConsoleReporter.js.flow +0 -81
- package/reporters/MultiReporter.js.flow +0 -43
- package/reporters/Reporter.js.flow +0 -19
- package/runner/Artifacts.js.flow +0 -215
- package/runner/BufferedFilesystem.js.flow +0 -194
- package/runner/GraphQLASTNodeGroup.js.flow +0 -174
- package/runner/GraphQLASTUtils.js.flow +0 -26
- package/runner/GraphQLNodeMap.js.flow +0 -55
- package/runner/Sources.js.flow +0 -227
- package/runner/StrictMap.js.flow +0 -96
- package/runner/compileArtifacts.js.flow +0 -75
- package/runner/extractAST.js.flow +0 -98
- package/runner/getChangedNodeNames.js.flow +0 -48
- package/runner/getSchemaInstance.js.flow +0 -36
- package/runner/types.js.flow +0 -37
- package/test-utils/TestSchema.js.flow +0 -30
- package/test-utils/parseGraphQLText.js.flow +0 -41
- package/transforms/ApplyFragmentArgumentTransform.js.flow +0 -524
- package/transforms/ClientExtensionsTransform.js.flow +0 -224
- package/transforms/ConnectionTransform.js.flow +0 -850
- package/transforms/DeclarativeConnectionMutationTransform.js.flow +0 -245
- package/transforms/DeferStreamTransform.js.flow +0 -263
- package/transforms/DisallowIdAsAlias.js.flow +0 -46
- package/transforms/DisallowTypenameOnRoot.js.flow +0 -44
- package/transforms/FieldHandleTransform.js.flow +0 -77
- package/transforms/FilterCompilerDirectivesTransform.js.flow +0 -33
- package/transforms/FilterDirectivesTransform.js.flow +0 -45
- package/transforms/FlattenTransform.js.flow +0 -458
- package/transforms/GenerateIDFieldTransform.js.flow +0 -151
- package/transforms/GenerateTypeNameTransform.js.flow +0 -159
- package/transforms/InlineDataFragmentTransform.js.flow +0 -123
- package/transforms/InlineFragmentsTransform.js.flow +0 -70
- package/transforms/MaskTransform.js.flow +0 -124
- package/transforms/MatchTransform.js.flow +0 -587
- package/transforms/ReactFlightComponentTransform.js.flow +0 -207
- package/transforms/RefetchableFragmentTransform.js.flow +0 -266
- package/transforms/RelayDirectiveTransform.js.flow +0 -96
- package/transforms/RequiredFieldTransform.js.flow +0 -413
- package/transforms/SkipClientExtensionsTransform.js.flow +0 -54
- package/transforms/SkipHandleFieldTransform.js.flow +0 -44
- package/transforms/SkipRedundantNodesTransform.js.flow +0 -277
- package/transforms/SkipSplitOperationTransform.js.flow +0 -37
- package/transforms/SkipUnreachableNodeTransform.js.flow +0 -148
- package/transforms/SkipUnusedVariablesTransform.js.flow +0 -59
- package/transforms/SplitModuleImportTransform.js.flow +0 -97
- package/transforms/TestOperationTransform.js.flow +0 -142
- package/transforms/TransformUtils.js.flow +0 -26
- package/transforms/ValidateGlobalVariablesTransform.js.flow +0 -80
- package/transforms/ValidateRequiredArgumentsTransform.js.flow +0 -130
- package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +0 -128
- package/transforms/ValidateUnusedVariablesTransform.js.flow +0 -88
- package/transforms/query-generators/FetchableQueryGenerator.js.flow +0 -188
- package/transforms/query-generators/NodeQueryGenerator.js.flow +0 -217
- package/transforms/query-generators/QueryQueryGenerator.js.flow +0 -57
- package/transforms/query-generators/ViewerQueryGenerator.js.flow +0 -97
- package/transforms/query-generators/index.js.flow +0 -89
- package/transforms/query-generators/utils.js.flow +0 -76
- package/util/CodeMarker.js.flow +0 -79
- package/util/DefaultHandleKey.js.flow +0 -17
- package/util/RelayCompilerCache.js.flow +0 -86
- package/util/Rollout.js.flow +0 -39
- package/util/TimeReporter.js.flow +0 -79
- package/util/areEqualArgValues.js.flow +0 -126
- package/util/argumentContainsVariables.js.flow +0 -38
- package/util/dedupeJSONStringify.js.flow +0 -156
- package/util/generateAbstractTypeRefinementKey.js.flow +0 -29
- package/util/getDefinitionNodeHash.js.flow +0 -24
- package/util/getModuleName.js.flow +0 -39
- package/util/joinArgumentDefinitions.js.flow +0 -105
- package/util/md5.js.flow +0 -19
- package/util/murmurHash.js.flow +0 -94
- package/util/nullthrowsOSS.js.flow +0 -25
- package/util/orList.js.flow +0 -37
- package/util/partitionArray.js.flow +0 -37
@@ -1,45 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
3
|
-
*
|
4
|
-
* This source code is licensed under the MIT license found in the
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
6
|
-
*
|
7
|
-
* @flow strict-local
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
|
11
|
-
// flowlint ambiguous-object-type:error
|
12
|
-
|
13
|
-
'use strict';
|
14
|
-
|
15
|
-
import type CompilerContext from '../core/CompilerContext';
|
16
|
-
import type {Directive} from '../core/IR';
|
17
|
-
|
18
|
-
const IRTransformer = require('../core/IRTransformer');
|
19
|
-
|
20
|
-
/**
|
21
|
-
* A transform that removes any directives that were not present in the
|
22
|
-
* server schema.
|
23
|
-
*/
|
24
|
-
function filterDirectivesTransform(context: CompilerContext): CompilerContext {
|
25
|
-
const schemaDirectives = new Set(
|
26
|
-
context
|
27
|
-
.getSchema()
|
28
|
-
.getDirectives()
|
29
|
-
.filter(directive => !directive.isClient)
|
30
|
-
.map(schemaDirective => schemaDirective.name),
|
31
|
-
);
|
32
|
-
const visitDirective = (directive: Directive): ?Directive => {
|
33
|
-
if (schemaDirectives.has(directive.name)) {
|
34
|
-
return directive;
|
35
|
-
}
|
36
|
-
return null;
|
37
|
-
};
|
38
|
-
return IRTransformer.transform(context, {
|
39
|
-
Directive: visitDirective,
|
40
|
-
});
|
41
|
-
}
|
42
|
-
|
43
|
-
module.exports = {
|
44
|
-
transform: filterDirectivesTransform,
|
45
|
-
};
|
@@ -1,458 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
3
|
-
*
|
4
|
-
* This source code is licensed under the MIT license found in the
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
6
|
-
*
|
7
|
-
* @format
|
8
|
-
* @flow
|
9
|
-
*/
|
10
|
-
|
11
|
-
// flowlint ambiguous-object-type:error
|
12
|
-
|
13
|
-
'use strict';
|
14
|
-
|
15
|
-
import type CompilerContext from '../core/CompilerContext';
|
16
|
-
import type {
|
17
|
-
Argument,
|
18
|
-
Field,
|
19
|
-
Handle,
|
20
|
-
InlineFragment,
|
21
|
-
LinkedField,
|
22
|
-
Node,
|
23
|
-
ScalarField,
|
24
|
-
Selection,
|
25
|
-
} from '../core/IR';
|
26
|
-
import type {Schema, TypeID} from '../core/Schema';
|
27
|
-
|
28
|
-
const {createCompilerError, createUserError} = require('../core/CompilerError');
|
29
|
-
const getIdentifierForSelection = require('../core/getIdentifierForSelection');
|
30
|
-
const IRTransformer = require('../core/IRTransformer');
|
31
|
-
const areEqualArgValues = require('../util/areEqualArgValues');
|
32
|
-
|
33
|
-
export type FlattenOptions = {|+isForCodegen?: boolean|};
|
34
|
-
|
35
|
-
type State = {|
|
36
|
-
+isForCodegen: boolean,
|
37
|
-
parentType: ?TypeID,
|
38
|
-
|};
|
39
|
-
|
40
|
-
/**
|
41
|
-
* Transform that flattens inline fragments, fragment spreads, and conditionals.
|
42
|
-
*
|
43
|
-
* Inline fragments are inlined (replaced with their selections) when:
|
44
|
-
* - The fragment type matches the type of its parent, and its `isForCodegen`,
|
45
|
-
* or if it's for printing, there is no directive on the inline fragment.
|
46
|
-
*/
|
47
|
-
function flattenTransformImpl(
|
48
|
-
context: CompilerContext,
|
49
|
-
options?: FlattenOptions,
|
50
|
-
): CompilerContext {
|
51
|
-
const state = {
|
52
|
-
isForCodegen: !!(options && options.isForCodegen),
|
53
|
-
parentType: null,
|
54
|
-
};
|
55
|
-
const visitorFn = memoizedFlattenSelection(new Map());
|
56
|
-
return IRTransformer.transform(
|
57
|
-
context,
|
58
|
-
{
|
59
|
-
Condition: visitorFn,
|
60
|
-
Defer: visitorFn,
|
61
|
-
Fragment: visitorFn,
|
62
|
-
InlineDataFragmentSpread: visitorFn,
|
63
|
-
InlineFragment: visitorFn,
|
64
|
-
LinkedField: visitorFn,
|
65
|
-
ModuleImport: visitorFn,
|
66
|
-
Root: visitorFn,
|
67
|
-
SplitOperation: visitorFn,
|
68
|
-
},
|
69
|
-
() => state,
|
70
|
-
);
|
71
|
-
}
|
72
|
-
|
73
|
-
function memoizedFlattenSelection(cache: Map<Node, Map<?TypeID, any>>) {
|
74
|
-
return function flattenSelectionsFn<T: Node>(node: T, state: State): T {
|
75
|
-
const context: CompilerContext = this.getContext();
|
76
|
-
let nodeCache = cache.get(node);
|
77
|
-
if (nodeCache == null) {
|
78
|
-
nodeCache = new Map();
|
79
|
-
cache.set(node, nodeCache);
|
80
|
-
}
|
81
|
-
// Determine the current type.
|
82
|
-
const parentType = state.parentType;
|
83
|
-
const result = nodeCache.get(parentType);
|
84
|
-
if (result != null) {
|
85
|
-
return result;
|
86
|
-
}
|
87
|
-
|
88
|
-
const type =
|
89
|
-
node.kind === 'LinkedField' ||
|
90
|
-
node.kind === 'Fragment' ||
|
91
|
-
node.kind === 'Root' ||
|
92
|
-
node.kind === 'SplitOperation'
|
93
|
-
? node.type
|
94
|
-
: node.kind === 'InlineFragment'
|
95
|
-
? node.typeCondition
|
96
|
-
: parentType;
|
97
|
-
if (type == null) {
|
98
|
-
throw createCompilerError('FlattenTransform: Expected a parent type.', [
|
99
|
-
node.loc,
|
100
|
-
]);
|
101
|
-
}
|
102
|
-
|
103
|
-
// Flatten the selections in this node, creating a new node with flattened
|
104
|
-
// selections if possible, then deeply traverse the flattened node, while
|
105
|
-
// keeping track of the parent type.
|
106
|
-
const nextSelections = new Map();
|
107
|
-
const hasFlattened = flattenSelectionsInto(
|
108
|
-
context.getSchema(),
|
109
|
-
nextSelections,
|
110
|
-
node,
|
111
|
-
state,
|
112
|
-
type,
|
113
|
-
);
|
114
|
-
const flattenedNode = hasFlattened
|
115
|
-
? {...node, selections: Array.from(nextSelections.values())}
|
116
|
-
: node;
|
117
|
-
state.parentType = type;
|
118
|
-
const deeplyFlattenedNode = this.traverse(flattenedNode, state);
|
119
|
-
state.parentType = parentType;
|
120
|
-
nodeCache.set(parentType, deeplyFlattenedNode);
|
121
|
-
return deeplyFlattenedNode;
|
122
|
-
};
|
123
|
-
}
|
124
|
-
|
125
|
-
/**
|
126
|
-
* @private
|
127
|
-
*/
|
128
|
-
function flattenSelectionsInto(
|
129
|
-
schema: Schema,
|
130
|
-
flattenedSelections: Map<string, Selection>,
|
131
|
-
node: Node,
|
132
|
-
state: State,
|
133
|
-
type: TypeID,
|
134
|
-
): boolean {
|
135
|
-
let hasFlattened = false;
|
136
|
-
node.selections.forEach(selection => {
|
137
|
-
if (
|
138
|
-
selection.kind === 'InlineFragment' &&
|
139
|
-
shouldFlattenInlineFragment(schema, selection, state, type)
|
140
|
-
) {
|
141
|
-
hasFlattened = true;
|
142
|
-
flattenSelectionsInto(
|
143
|
-
schema,
|
144
|
-
flattenedSelections,
|
145
|
-
selection,
|
146
|
-
state,
|
147
|
-
type,
|
148
|
-
);
|
149
|
-
return;
|
150
|
-
}
|
151
|
-
const nodeIdentifier = getIdentifierForSelection(schema, selection);
|
152
|
-
const flattenedSelection = flattenedSelections.get(nodeIdentifier);
|
153
|
-
// If this selection hasn't been seen before, keep track of it.
|
154
|
-
if (!flattenedSelection) {
|
155
|
-
flattenedSelections.set(nodeIdentifier, selection);
|
156
|
-
return;
|
157
|
-
}
|
158
|
-
// Otherwise a similar selection exists which should be merged.
|
159
|
-
hasFlattened = true;
|
160
|
-
if (flattenedSelection.kind === 'InlineFragment') {
|
161
|
-
if (selection.kind !== 'InlineFragment') {
|
162
|
-
throw createCompilerError(
|
163
|
-
`FlattenTransform: Expected an InlineFragment, got a '${selection.kind}'`,
|
164
|
-
[selection.loc],
|
165
|
-
);
|
166
|
-
}
|
167
|
-
flattenedSelections.set(nodeIdentifier, {
|
168
|
-
...flattenedSelection,
|
169
|
-
selections: mergeSelections(
|
170
|
-
schema,
|
171
|
-
flattenedSelection,
|
172
|
-
selection,
|
173
|
-
state,
|
174
|
-
selection.typeCondition,
|
175
|
-
),
|
176
|
-
});
|
177
|
-
} else if (flattenedSelection.kind === 'Condition') {
|
178
|
-
if (selection.kind !== 'Condition') {
|
179
|
-
throw createCompilerError(
|
180
|
-
`FlattenTransform: Expected a Condition, got a '${selection.kind}'`,
|
181
|
-
[selection.loc],
|
182
|
-
);
|
183
|
-
}
|
184
|
-
flattenedSelections.set(nodeIdentifier, {
|
185
|
-
...flattenedSelection,
|
186
|
-
selections: mergeSelections(
|
187
|
-
schema,
|
188
|
-
flattenedSelection,
|
189
|
-
selection,
|
190
|
-
state,
|
191
|
-
type,
|
192
|
-
),
|
193
|
-
});
|
194
|
-
} else if (flattenedSelection.kind === 'ClientExtension') {
|
195
|
-
if (selection.kind !== 'ClientExtension') {
|
196
|
-
throw createCompilerError(
|
197
|
-
`FlattenTransform: Expected a ClientExtension, got a '${selection.kind}'`,
|
198
|
-
[selection.loc],
|
199
|
-
);
|
200
|
-
}
|
201
|
-
flattenedSelections.set(nodeIdentifier, {
|
202
|
-
...flattenedSelection,
|
203
|
-
selections: mergeSelections(
|
204
|
-
schema,
|
205
|
-
flattenedSelection,
|
206
|
-
selection,
|
207
|
-
state,
|
208
|
-
type,
|
209
|
-
),
|
210
|
-
});
|
211
|
-
} else if (flattenedSelection.kind === 'FragmentSpread') {
|
212
|
-
// Ignore duplicate fragment spreads.
|
213
|
-
} else if (flattenedSelection.kind === 'ModuleImport') {
|
214
|
-
if (selection.kind !== 'ModuleImport') {
|
215
|
-
throw createCompilerError(
|
216
|
-
`FlattenTransform: Expected a ModuleImport, got a '${selection.kind}'`,
|
217
|
-
[selection.loc],
|
218
|
-
);
|
219
|
-
}
|
220
|
-
if (
|
221
|
-
selection.name !== flattenedSelection.name ||
|
222
|
-
selection.module !== flattenedSelection.module ||
|
223
|
-
selection.key !== flattenedSelection.key
|
224
|
-
) {
|
225
|
-
throw createUserError(
|
226
|
-
'Found conflicting @module selections: use a unique alias on the ' +
|
227
|
-
'parent fields.',
|
228
|
-
[selection.loc, flattenedSelection.loc],
|
229
|
-
);
|
230
|
-
}
|
231
|
-
flattenedSelections.set(nodeIdentifier, {
|
232
|
-
...flattenedSelection,
|
233
|
-
selections: mergeSelections(
|
234
|
-
schema,
|
235
|
-
flattenedSelection,
|
236
|
-
selection,
|
237
|
-
state,
|
238
|
-
type,
|
239
|
-
),
|
240
|
-
});
|
241
|
-
} else if (flattenedSelection.kind === 'Defer') {
|
242
|
-
if (selection.kind !== 'Defer') {
|
243
|
-
throw createCompilerError(
|
244
|
-
`FlattenTransform: Expected a Defer, got a '${selection.kind}'`,
|
245
|
-
[selection.loc],
|
246
|
-
);
|
247
|
-
}
|
248
|
-
flattenedSelections.set(nodeIdentifier, {
|
249
|
-
kind: 'Defer',
|
250
|
-
...flattenedSelection,
|
251
|
-
selections: mergeSelections(
|
252
|
-
schema,
|
253
|
-
flattenedSelection,
|
254
|
-
selection,
|
255
|
-
state,
|
256
|
-
type,
|
257
|
-
),
|
258
|
-
});
|
259
|
-
} else if (flattenedSelection.kind === 'Stream') {
|
260
|
-
if (selection.kind !== 'Stream') {
|
261
|
-
throw createCompilerError(
|
262
|
-
`FlattenTransform: Expected a Stream, got a '${selection.kind}'`,
|
263
|
-
[selection.loc],
|
264
|
-
);
|
265
|
-
}
|
266
|
-
flattenedSelections.set(nodeIdentifier, {
|
267
|
-
kind: 'Stream',
|
268
|
-
...flattenedSelection,
|
269
|
-
selections: mergeSelections(
|
270
|
-
schema,
|
271
|
-
flattenedSelection,
|
272
|
-
selection,
|
273
|
-
state,
|
274
|
-
type,
|
275
|
-
),
|
276
|
-
});
|
277
|
-
} else if (flattenedSelection.kind === 'LinkedField') {
|
278
|
-
if (selection.kind !== 'LinkedField') {
|
279
|
-
throw createCompilerError(
|
280
|
-
`FlattenTransform: Expected a LinkedField, got a '${selection.kind}'`,
|
281
|
-
[selection.loc],
|
282
|
-
);
|
283
|
-
}
|
284
|
-
assertUniqueArgsForAlias(selection, flattenedSelection);
|
285
|
-
// NOTE: not using object spread here as this code is pretty hot
|
286
|
-
flattenedSelections.set(nodeIdentifier, {
|
287
|
-
kind: 'LinkedField',
|
288
|
-
alias: flattenedSelection.alias,
|
289
|
-
args: flattenedSelection.args,
|
290
|
-
connection: flattenedSelection.connection || selection.connection,
|
291
|
-
directives: flattenedSelection.directives,
|
292
|
-
handles: mergeHandles(flattenedSelection, selection),
|
293
|
-
loc: flattenedSelection.loc,
|
294
|
-
metadata: flattenedSelection.metadata,
|
295
|
-
name: flattenedSelection.name,
|
296
|
-
selections: mergeSelections(
|
297
|
-
schema,
|
298
|
-
flattenedSelection,
|
299
|
-
selection,
|
300
|
-
state,
|
301
|
-
selection.type,
|
302
|
-
),
|
303
|
-
type: flattenedSelection.type,
|
304
|
-
});
|
305
|
-
} else if (flattenedSelection.kind === 'ScalarField') {
|
306
|
-
if (selection.kind !== 'ScalarField') {
|
307
|
-
throw createCompilerError(
|
308
|
-
`FlattenTransform: Expected a ScalarField, got a '${selection.kind}'`,
|
309
|
-
[selection.loc],
|
310
|
-
);
|
311
|
-
}
|
312
|
-
assertUniqueArgsForAlias(selection, flattenedSelection);
|
313
|
-
if (selection.handles && selection.handles.length > 0) {
|
314
|
-
flattenedSelections.set(nodeIdentifier, {
|
315
|
-
kind: 'ScalarField',
|
316
|
-
...flattenedSelection,
|
317
|
-
handles: mergeHandles(selection, flattenedSelection),
|
318
|
-
});
|
319
|
-
}
|
320
|
-
} else if (flattenedSelection.kind === 'InlineDataFragmentSpread') {
|
321
|
-
throw createCompilerError(
|
322
|
-
'FlattenTransform: did not expect an InlineDataFragmentSpread node. ' +
|
323
|
-
'Only expecting InlineDataFragmentSpread in reader ASTs and this ' +
|
324
|
-
'transform to run only on normalization ASTs.',
|
325
|
-
[selection.loc],
|
326
|
-
);
|
327
|
-
} else {
|
328
|
-
(flattenedSelection.kind: empty);
|
329
|
-
throw createCompilerError(
|
330
|
-
`FlattenTransform: Unknown kind '${flattenedSelection.kind}'`,
|
331
|
-
);
|
332
|
-
}
|
333
|
-
});
|
334
|
-
return hasFlattened;
|
335
|
-
}
|
336
|
-
|
337
|
-
/**
|
338
|
-
* @private
|
339
|
-
*/
|
340
|
-
function mergeSelections(
|
341
|
-
schema: Schema,
|
342
|
-
nodeA: Node,
|
343
|
-
nodeB: Node,
|
344
|
-
state: State,
|
345
|
-
type: TypeID,
|
346
|
-
): $ReadOnlyArray<Selection> {
|
347
|
-
const flattenedSelections = new Map();
|
348
|
-
flattenSelectionsInto(schema, flattenedSelections, nodeA, state, type);
|
349
|
-
flattenSelectionsInto(schema, flattenedSelections, nodeB, state, type);
|
350
|
-
return Array.from(flattenedSelections.values());
|
351
|
-
}
|
352
|
-
|
353
|
-
/**
|
354
|
-
* @private
|
355
|
-
* TODO(T19327202) This is redundant with OverlappingFieldsCanBeMergedRule once
|
356
|
-
* it can be enabled.
|
357
|
-
*/
|
358
|
-
function assertUniqueArgsForAlias(field: Field, otherField: Field): void {
|
359
|
-
if (!areEqualFields(field, otherField)) {
|
360
|
-
throw createUserError(
|
361
|
-
'Expected all fields on the same parent with the name or alias ' +
|
362
|
-
`'${field.alias}' to have the same name and arguments.`,
|
363
|
-
[field.loc, otherField.loc],
|
364
|
-
);
|
365
|
-
}
|
366
|
-
}
|
367
|
-
|
368
|
-
/**
|
369
|
-
* @private
|
370
|
-
*/
|
371
|
-
function shouldFlattenInlineFragment(
|
372
|
-
schema: Schema,
|
373
|
-
fragment: InlineFragment,
|
374
|
-
state: State,
|
375
|
-
type: TypeID,
|
376
|
-
): boolean {
|
377
|
-
return (
|
378
|
-
schema.areEqualTypes(fragment.typeCondition, schema.getRawType(type)) &&
|
379
|
-
(state.isForCodegen || fragment.directives.length === 0)
|
380
|
-
);
|
381
|
-
}
|
382
|
-
|
383
|
-
/**
|
384
|
-
* @private
|
385
|
-
*
|
386
|
-
* Verify that two fields are equal in all properties other than their
|
387
|
-
* selections.
|
388
|
-
*/
|
389
|
-
function areEqualFields(thisField: Field, thatField: Field): boolean {
|
390
|
-
return (
|
391
|
-
thisField.kind === thatField.kind &&
|
392
|
-
thisField.name === thatField.name &&
|
393
|
-
thisField.alias === thatField.alias &&
|
394
|
-
areEqualArgs(thisField.args, thatField.args)
|
395
|
-
);
|
396
|
-
}
|
397
|
-
|
398
|
-
/**
|
399
|
-
* Verify that two sets of arguments are equivalent - same argument names
|
400
|
-
* and values. Notably this ignores the types of arguments and values, which
|
401
|
-
* may not always be inferred identically.
|
402
|
-
*/
|
403
|
-
function areEqualArgs(
|
404
|
-
thisArgs: $ReadOnlyArray<Argument>,
|
405
|
-
thatArgs: $ReadOnlyArray<Argument>,
|
406
|
-
): boolean {
|
407
|
-
return (
|
408
|
-
thisArgs.length === thatArgs.length &&
|
409
|
-
thisArgs.every((thisArg, index) => {
|
410
|
-
const thatArg = thatArgs[index];
|
411
|
-
return (
|
412
|
-
thisArg.name === thatArg.name &&
|
413
|
-
thisArg.value.kind === thatArg.value.kind &&
|
414
|
-
(thisArg.value: any).variableName ===
|
415
|
-
(thatArg.value: any).variableName &&
|
416
|
-
areEqualArgValues(
|
417
|
-
(thisArg.value: any).value,
|
418
|
-
(thatArg.value: any).value,
|
419
|
-
)
|
420
|
-
);
|
421
|
-
})
|
422
|
-
);
|
423
|
-
}
|
424
|
-
|
425
|
-
/**
|
426
|
-
* @private
|
427
|
-
*/
|
428
|
-
function mergeHandles<T: LinkedField | ScalarField>(
|
429
|
-
nodeA: T,
|
430
|
-
nodeB: T,
|
431
|
-
): ?$ReadOnlyArray<Handle> {
|
432
|
-
if (!nodeA.handles) {
|
433
|
-
return nodeB.handles;
|
434
|
-
}
|
435
|
-
if (!nodeB.handles) {
|
436
|
-
return nodeA.handles;
|
437
|
-
}
|
438
|
-
const uniqueItems = new Map();
|
439
|
-
nodeA.handles
|
440
|
-
// $FlowFixMe[incompatible-use]
|
441
|
-
.concat(nodeB.handles)
|
442
|
-
// $FlowFixMe[incompatible-use]
|
443
|
-
.forEach(item => uniqueItems.set(item.name + item.key, item));
|
444
|
-
// $FlowFixMe[incompatible-return]
|
445
|
-
return Array.from(uniqueItems.values());
|
446
|
-
}
|
447
|
-
|
448
|
-
function transformWithOptions(
|
449
|
-
options: FlattenOptions,
|
450
|
-
): (context: CompilerContext) => CompilerContext {
|
451
|
-
return function flattenTransform(context: CompilerContext): CompilerContext {
|
452
|
-
return flattenTransformImpl(context, options);
|
453
|
-
};
|
454
|
-
}
|
455
|
-
|
456
|
-
module.exports = {
|
457
|
-
transformWithOptions,
|
458
|
-
};
|
@@ -1,151 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
3
|
-
*
|
4
|
-
* This source code is licensed under the MIT license found in the
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
6
|
-
*
|
7
|
-
* @flow strict-local
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
|
11
|
-
// flowlint ambiguous-object-type:error
|
12
|
-
|
13
|
-
'use strict';
|
14
|
-
|
15
|
-
import type CompilerContext from '../core/CompilerContext';
|
16
|
-
import type {InlineFragment, LinkedField, ScalarField} from '../core/IR';
|
17
|
-
import type {CompositeTypeID} from '../core/Schema';
|
18
|
-
|
19
|
-
const IRTransformer = require('../core/IRTransformer');
|
20
|
-
const {generateIDField} = require('../core/SchemaUtils');
|
21
|
-
const {hasUnaliasedSelection} = require('./TransformUtils');
|
22
|
-
|
23
|
-
const ID = 'id';
|
24
|
-
const NODE_TYPE = 'Node';
|
25
|
-
|
26
|
-
type State = {|
|
27
|
-
idFieldForType: CompositeTypeID => ScalarField,
|
28
|
-
idFragmentForType: CompositeTypeID => InlineFragment,
|
29
|
-
|};
|
30
|
-
|
31
|
-
/**
|
32
|
-
* A transform that adds an `id` field on any type that has an id field but
|
33
|
-
* where there is no unaliased `id` selection.
|
34
|
-
*/
|
35
|
-
function generateIDFieldTransform(context: CompilerContext): CompilerContext {
|
36
|
-
const schema = context.getSchema();
|
37
|
-
|
38
|
-
const typeToIDField = new Map();
|
39
|
-
function idFieldForType(type: CompositeTypeID): ScalarField {
|
40
|
-
let idField = typeToIDField.get(type);
|
41
|
-
if (idField == null) {
|
42
|
-
idField = generateIDField(schema, type);
|
43
|
-
typeToIDField.set(type, idField);
|
44
|
-
}
|
45
|
-
return idField;
|
46
|
-
}
|
47
|
-
|
48
|
-
const typeToIDFragment = new Map();
|
49
|
-
function idFragmentForType(type: CompositeTypeID): InlineFragment {
|
50
|
-
let fragment = typeToIDFragment.get(type);
|
51
|
-
if (fragment == null) {
|
52
|
-
fragment = {
|
53
|
-
kind: 'InlineFragment',
|
54
|
-
directives: [],
|
55
|
-
loc: {kind: 'Generated'},
|
56
|
-
metadata: null,
|
57
|
-
selections: [idFieldForType(type)],
|
58
|
-
typeCondition: type,
|
59
|
-
};
|
60
|
-
typeToIDFragment.set(type, fragment);
|
61
|
-
}
|
62
|
-
return fragment;
|
63
|
-
}
|
64
|
-
|
65
|
-
const state = {
|
66
|
-
idFieldForType,
|
67
|
-
idFragmentForType,
|
68
|
-
};
|
69
|
-
return IRTransformer.transform(
|
70
|
-
context,
|
71
|
-
{
|
72
|
-
LinkedField: visitLinkedField,
|
73
|
-
},
|
74
|
-
() => state,
|
75
|
-
);
|
76
|
-
}
|
77
|
-
|
78
|
-
function visitLinkedField(field: LinkedField, state: State): LinkedField {
|
79
|
-
const transformedNode = this.traverse(field, state);
|
80
|
-
|
81
|
-
// If the field already has an unaliased `id` field, do nothing
|
82
|
-
if (hasUnaliasedSelection(field, ID)) {
|
83
|
-
return transformedNode;
|
84
|
-
}
|
85
|
-
|
86
|
-
const context: CompilerContext = this.getContext();
|
87
|
-
const schema = context.getSchema();
|
88
|
-
const unmodifiedType = schema.assertCompositeType(
|
89
|
-
schema.getRawType(field.type),
|
90
|
-
);
|
91
|
-
|
92
|
-
// If the field type has an `id` subfield add an `id` selection
|
93
|
-
if (
|
94
|
-
schema.canHaveSelections(unmodifiedType) &&
|
95
|
-
schema.hasId(unmodifiedType)
|
96
|
-
) {
|
97
|
-
return {
|
98
|
-
...transformedNode,
|
99
|
-
selections: [
|
100
|
-
...transformedNode.selections,
|
101
|
-
state.idFieldForType(unmodifiedType),
|
102
|
-
],
|
103
|
-
};
|
104
|
-
}
|
105
|
-
|
106
|
-
// If the field type is abstract, then generate a `... on Node { id }`
|
107
|
-
// fragment if *any* concrete type implements Node. Then generate a
|
108
|
-
// `... on PossibleType { id }` for every concrete type that does *not*
|
109
|
-
// implement `Node`
|
110
|
-
const nodeType = schema.getTypeFromString(NODE_TYPE);
|
111
|
-
if (!nodeType) {
|
112
|
-
return transformedNode;
|
113
|
-
}
|
114
|
-
|
115
|
-
const nodeInterface = schema.assertInterfaceType(nodeType);
|
116
|
-
|
117
|
-
if (schema.isAbstractType(unmodifiedType)) {
|
118
|
-
const selections = [...transformedNode.selections];
|
119
|
-
if (schema.mayImplement(unmodifiedType, nodeInterface)) {
|
120
|
-
selections.push(state.idFragmentForType(nodeInterface));
|
121
|
-
}
|
122
|
-
Array.from(
|
123
|
-
schema
|
124
|
-
.getPossibleTypes(schema.assertAbstractType(unmodifiedType))
|
125
|
-
.values(),
|
126
|
-
)
|
127
|
-
.filter(
|
128
|
-
concreteType =>
|
129
|
-
!schema.implementsInterface(
|
130
|
-
schema.assertCompositeType(concreteType),
|
131
|
-
nodeInterface,
|
132
|
-
) && schema.hasId(concreteType),
|
133
|
-
)
|
134
|
-
.sort((a, b) =>
|
135
|
-
schema.getTypeString(a) < schema.getTypeString(b) ? -1 : 1,
|
136
|
-
)
|
137
|
-
.forEach(concreteType => {
|
138
|
-
selections.push(state.idFragmentForType(concreteType));
|
139
|
-
});
|
140
|
-
return {
|
141
|
-
...transformedNode,
|
142
|
-
selections,
|
143
|
-
};
|
144
|
-
}
|
145
|
-
|
146
|
-
return transformedNode;
|
147
|
-
}
|
148
|
-
|
149
|
-
module.exports = {
|
150
|
-
transform: generateIDFieldTransform,
|
151
|
-
};
|