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,159 +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 {
|
17
|
-
Fragment,
|
18
|
-
InlineFragment,
|
19
|
-
LinkedField,
|
20
|
-
ScalarField,
|
21
|
-
} from '../core/IR';
|
22
|
-
import type {Schema} from '../core/Schema';
|
23
|
-
|
24
|
-
const IRTransformer = require('../core/IRTransformer');
|
25
|
-
const generateAbstractTypeRefinementKey = require('../util/generateAbstractTypeRefinementKey');
|
26
|
-
const {hasUnaliasedSelection} = require('./TransformUtils');
|
27
|
-
|
28
|
-
const TYPENAME_KEY = '__typename';
|
29
|
-
|
30
|
-
type State = {|
|
31
|
-
+typenameField: ScalarField,
|
32
|
-
|};
|
33
|
-
|
34
|
-
let cache = new Map();
|
35
|
-
|
36
|
-
/**
|
37
|
-
* A transform that adds `__typename` field on any `LinkedField` of a union or
|
38
|
-
* interface type where there is no unaliased `__typename` selection.
|
39
|
-
*/
|
40
|
-
function generateTypeNameTransform(context: CompilerContext): CompilerContext {
|
41
|
-
cache = new Map();
|
42
|
-
const schema = context.getSchema();
|
43
|
-
const typenameField: ScalarField = {
|
44
|
-
kind: 'ScalarField',
|
45
|
-
alias: TYPENAME_KEY,
|
46
|
-
args: [],
|
47
|
-
directives: [],
|
48
|
-
handles: null,
|
49
|
-
loc: {kind: 'Generated'},
|
50
|
-
metadata: null,
|
51
|
-
name: TYPENAME_KEY,
|
52
|
-
type: schema.assertScalarFieldType(
|
53
|
-
schema.getNonNullType(schema.expectStringType()),
|
54
|
-
),
|
55
|
-
};
|
56
|
-
return IRTransformer.transform(
|
57
|
-
context,
|
58
|
-
{
|
59
|
-
Fragment: visitFragment,
|
60
|
-
LinkedField: visitLinkedField,
|
61
|
-
InlineFragment: visitInlineFragment,
|
62
|
-
},
|
63
|
-
node => ({
|
64
|
-
typenameField,
|
65
|
-
}),
|
66
|
-
);
|
67
|
-
}
|
68
|
-
|
69
|
-
function visitFragment(fragment: Fragment, state: State): Fragment {
|
70
|
-
const schema: Schema = this.getContext().getSchema();
|
71
|
-
const rawType = schema.getRawType(fragment.type);
|
72
|
-
let transformedNode = (this.traverse(fragment, state): Fragment);
|
73
|
-
const isClientType = !schema.isServerType(rawType);
|
74
|
-
if (!isClientType && schema.isAbstractType(rawType)) {
|
75
|
-
const abstractKey = generateAbstractTypeRefinementKey(schema, rawType);
|
76
|
-
transformedNode = {
|
77
|
-
...transformedNode,
|
78
|
-
selections: [
|
79
|
-
{
|
80
|
-
kind: 'ScalarField',
|
81
|
-
alias: abstractKey,
|
82
|
-
args: [],
|
83
|
-
directives: [],
|
84
|
-
handles: null,
|
85
|
-
loc: {kind: 'Generated'},
|
86
|
-
metadata: {abstractKey},
|
87
|
-
name: TYPENAME_KEY,
|
88
|
-
type: schema.assertScalarFieldType(
|
89
|
-
schema.getNonNullType(schema.expectStringType()),
|
90
|
-
),
|
91
|
-
},
|
92
|
-
...transformedNode.selections,
|
93
|
-
],
|
94
|
-
};
|
95
|
-
}
|
96
|
-
return transformedNode;
|
97
|
-
}
|
98
|
-
|
99
|
-
function visitInlineFragment(
|
100
|
-
fragment: InlineFragment,
|
101
|
-
state: State,
|
102
|
-
): InlineFragment {
|
103
|
-
const schema: Schema = this.getContext().getSchema();
|
104
|
-
let transformedNode = cache.get(fragment);
|
105
|
-
if (transformedNode != null && transformedNode.kind === 'InlineFragment') {
|
106
|
-
return transformedNode;
|
107
|
-
}
|
108
|
-
const rawType = schema.getRawType(fragment.typeCondition);
|
109
|
-
transformedNode = (this.traverse(fragment, state): InlineFragment);
|
110
|
-
const isClientType = !schema.isServerType(rawType);
|
111
|
-
if (!isClientType && schema.isAbstractType(rawType)) {
|
112
|
-
const abstractKey = generateAbstractTypeRefinementKey(schema, rawType);
|
113
|
-
transformedNode = {
|
114
|
-
...transformedNode,
|
115
|
-
selections: [
|
116
|
-
{
|
117
|
-
kind: 'ScalarField',
|
118
|
-
alias: abstractKey,
|
119
|
-
args: [],
|
120
|
-
directives: [],
|
121
|
-
handles: null,
|
122
|
-
loc: {kind: 'Generated'},
|
123
|
-
metadata: {abstractKey},
|
124
|
-
name: TYPENAME_KEY,
|
125
|
-
type: schema.assertScalarFieldType(
|
126
|
-
schema.getNonNullType(schema.expectStringType()),
|
127
|
-
),
|
128
|
-
},
|
129
|
-
...transformedNode.selections,
|
130
|
-
],
|
131
|
-
};
|
132
|
-
}
|
133
|
-
cache.set(fragment, transformedNode);
|
134
|
-
return transformedNode;
|
135
|
-
}
|
136
|
-
|
137
|
-
function visitLinkedField(field: LinkedField, state: State): LinkedField {
|
138
|
-
const schema: Schema = this.getContext().getSchema();
|
139
|
-
let transformedNode = cache.get(field);
|
140
|
-
if (transformedNode != null && transformedNode.kind === 'LinkedField') {
|
141
|
-
return transformedNode;
|
142
|
-
}
|
143
|
-
transformedNode = (this.traverse(field, state): LinkedField);
|
144
|
-
if (
|
145
|
-
schema.isAbstractType(schema.getRawType(transformedNode.type)) &&
|
146
|
-
!hasUnaliasedSelection(transformedNode, TYPENAME_KEY)
|
147
|
-
) {
|
148
|
-
transformedNode = {
|
149
|
-
...transformedNode,
|
150
|
-
selections: [state.typenameField, ...transformedNode.selections],
|
151
|
-
};
|
152
|
-
}
|
153
|
-
cache.set(field, transformedNode);
|
154
|
-
return transformedNode;
|
155
|
-
}
|
156
|
-
|
157
|
-
module.exports = {
|
158
|
-
transform: generateTypeNameTransform,
|
159
|
-
};
|
@@ -1,123 +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 {
|
17
|
-
Fragment,
|
18
|
-
FragmentSpread,
|
19
|
-
InlineDataFragmentSpread,
|
20
|
-
} from '../core/IR';
|
21
|
-
|
22
|
-
const {createUserError} = require('../core/CompilerError');
|
23
|
-
const IRTransformer = require('../core/IRTransformer');
|
24
|
-
|
25
|
-
const SCHEMA_EXTENSION = `
|
26
|
-
directive @inline on FRAGMENT_DEFINITION
|
27
|
-
`;
|
28
|
-
|
29
|
-
/**
|
30
|
-
* A transform that converts fragment spreads where the referenced fragment
|
31
|
-
* is annotated with @inline to a InlineDataFragmentSpread.
|
32
|
-
* InlineDataFragmentSpreads have the selections of the referenced fragment inlined.
|
33
|
-
*/
|
34
|
-
function inlineDataFragmentTransform(
|
35
|
-
context: CompilerContext,
|
36
|
-
): CompilerContext {
|
37
|
-
return IRTransformer.transform(context, {
|
38
|
-
// $FlowFixMe[prop-missing] - this visitor intentionally changes node types
|
39
|
-
// $FlowFixMe[incompatible-call] - this visitor intentionally changes node types
|
40
|
-
FragmentSpread: visitFragmentSpread,
|
41
|
-
Fragment: visitFragment,
|
42
|
-
});
|
43
|
-
}
|
44
|
-
|
45
|
-
function visitFragment(fragment: Fragment): Fragment {
|
46
|
-
const transformedFragment = this.traverse(fragment);
|
47
|
-
|
48
|
-
const inlineDirective = transformedFragment.directives.find(
|
49
|
-
directive => directive.name === 'inline',
|
50
|
-
);
|
51
|
-
if (inlineDirective == null) {
|
52
|
-
return transformedFragment;
|
53
|
-
}
|
54
|
-
return {
|
55
|
-
...transformedFragment,
|
56
|
-
directives: transformedFragment.directives.filter(
|
57
|
-
directive => directive !== inlineDirective,
|
58
|
-
),
|
59
|
-
metadata: {
|
60
|
-
...(transformedFragment.metadata || {}),
|
61
|
-
inlineData: true,
|
62
|
-
},
|
63
|
-
};
|
64
|
-
}
|
65
|
-
|
66
|
-
function visitFragmentSpread(
|
67
|
-
fragmentSpread: FragmentSpread,
|
68
|
-
): FragmentSpread | InlineDataFragmentSpread {
|
69
|
-
const transformedFragmentSpread: FragmentSpread =
|
70
|
-
this.traverse(fragmentSpread);
|
71
|
-
|
72
|
-
const context: CompilerContext = this.getContext();
|
73
|
-
const fragment = context.get(transformedFragmentSpread.name);
|
74
|
-
if (
|
75
|
-
!fragment ||
|
76
|
-
fragment.kind !== 'Fragment' ||
|
77
|
-
!fragment.directives.some(directive => directive.name === 'inline')
|
78
|
-
) {
|
79
|
-
return transformedFragmentSpread;
|
80
|
-
}
|
81
|
-
|
82
|
-
if (
|
83
|
-
fragment.argumentDefinitions.length > 0 ||
|
84
|
-
transformedFragmentSpread.args.length > 0
|
85
|
-
) {
|
86
|
-
throw createUserError(
|
87
|
-
'Variables are not yet supported inside @inline fragments.',
|
88
|
-
[fragment.argumentDefinitions[0].loc],
|
89
|
-
);
|
90
|
-
}
|
91
|
-
|
92
|
-
if (transformedFragmentSpread.directives.length > 0) {
|
93
|
-
throw createUserError(
|
94
|
-
'Directives on fragment spreads for @inline fragments are not yet ' +
|
95
|
-
'supported',
|
96
|
-
[transformedFragmentSpread.loc],
|
97
|
-
);
|
98
|
-
}
|
99
|
-
|
100
|
-
const transformedFragment = (this.visit(fragment): Fragment);
|
101
|
-
|
102
|
-
return ({
|
103
|
-
kind: 'InlineDataFragmentSpread',
|
104
|
-
loc: transformedFragmentSpread.loc,
|
105
|
-
metadata: transformedFragmentSpread.metadata,
|
106
|
-
name: transformedFragmentSpread.name,
|
107
|
-
selections: [
|
108
|
-
{
|
109
|
-
directives: [],
|
110
|
-
kind: 'InlineFragment',
|
111
|
-
loc: {kind: 'Derived', source: transformedFragmentSpread.loc},
|
112
|
-
metadata: null,
|
113
|
-
selections: transformedFragment.selections,
|
114
|
-
typeCondition: transformedFragment.type,
|
115
|
-
},
|
116
|
-
],
|
117
|
-
}: InlineDataFragmentSpread);
|
118
|
-
}
|
119
|
-
|
120
|
-
module.exports = {
|
121
|
-
SCHEMA_EXTENSION,
|
122
|
-
transform: inlineDataFragmentTransform,
|
123
|
-
};
|
@@ -1,70 +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 {Fragment, FragmentSpread, InlineFragment} from '../core/IR';
|
17
|
-
|
18
|
-
const IRTransformer = require('../core/IRTransformer');
|
19
|
-
const invariant = require('invariant');
|
20
|
-
|
21
|
-
type FragmentVisitorCache = Map<FragmentSpread, FragmentSpread>;
|
22
|
-
type FragmentVisitor = (fragmentSpread: FragmentSpread) => ?FragmentSpread;
|
23
|
-
/**
|
24
|
-
* A transform that inlines all fragments and removes them.
|
25
|
-
*/
|
26
|
-
function inlineFragmentsTransform(context: CompilerContext): CompilerContext {
|
27
|
-
const visitFragmentSpread = fragmentSpreadVisitor(new Map());
|
28
|
-
return IRTransformer.transform(context, {
|
29
|
-
Fragment: visitFragment,
|
30
|
-
FragmentSpread: visitFragmentSpread,
|
31
|
-
});
|
32
|
-
}
|
33
|
-
|
34
|
-
function visitFragment(fragment: Fragment): null {
|
35
|
-
return null;
|
36
|
-
}
|
37
|
-
|
38
|
-
function fragmentSpreadVisitor(cache: FragmentVisitorCache): FragmentVisitor {
|
39
|
-
return function visitFragmentSpread(fragmentSpread: FragmentSpread) {
|
40
|
-
let traverseResult = cache.get(fragmentSpread);
|
41
|
-
if (traverseResult != null) {
|
42
|
-
return traverseResult;
|
43
|
-
}
|
44
|
-
invariant(
|
45
|
-
fragmentSpread.args.length === 0,
|
46
|
-
'InlineFragmentsTransform: Cannot flatten fragment spread `%s` with ' +
|
47
|
-
'arguments. Use the `ApplyFragmentArgumentTransform` before flattening',
|
48
|
-
fragmentSpread.name,
|
49
|
-
);
|
50
|
-
const fragment: Fragment = this.getContext().getFragment(
|
51
|
-
fragmentSpread.name,
|
52
|
-
fragmentSpread.loc,
|
53
|
-
);
|
54
|
-
const result: InlineFragment = {
|
55
|
-
kind: 'InlineFragment',
|
56
|
-
directives: fragmentSpread.directives,
|
57
|
-
loc: {kind: 'Derived', source: fragmentSpread.loc},
|
58
|
-
metadata: fragmentSpread.metadata,
|
59
|
-
selections: fragment.selections,
|
60
|
-
typeCondition: fragment.type,
|
61
|
-
};
|
62
|
-
traverseResult = this.traverse(result);
|
63
|
-
cache.set(fragmentSpread, traverseResult);
|
64
|
-
return traverseResult;
|
65
|
-
};
|
66
|
-
}
|
67
|
-
|
68
|
-
module.exports = {
|
69
|
-
transform: inlineFragmentsTransform,
|
70
|
-
};
|
@@ -1,124 +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 {
|
17
|
-
ArgumentDefinition,
|
18
|
-
Fragment,
|
19
|
-
FragmentSpread,
|
20
|
-
InlineFragment,
|
21
|
-
} from '../core/IR';
|
22
|
-
|
23
|
-
const {createUserError} = require('../core/CompilerError');
|
24
|
-
const IRTransformer = require('../core/IRTransformer');
|
25
|
-
const joinArgumentDefinitions = require('../util/joinArgumentDefinitions');
|
26
|
-
const invariant = require('invariant');
|
27
|
-
|
28
|
-
type State = {reachableArguments: Array<ArgumentDefinition>, ...};
|
29
|
-
|
30
|
-
/**
|
31
|
-
* A transform that inlines fragment spreads with the @relay(mask: false)
|
32
|
-
* directive.
|
33
|
-
*/
|
34
|
-
function maskTransform(context: CompilerContext): CompilerContext {
|
35
|
-
return IRTransformer.transform(
|
36
|
-
context,
|
37
|
-
{
|
38
|
-
FragmentSpread: visitFragmentSpread,
|
39
|
-
Fragment: visitFragment,
|
40
|
-
},
|
41
|
-
() => ({
|
42
|
-
reachableArguments: [],
|
43
|
-
}),
|
44
|
-
);
|
45
|
-
}
|
46
|
-
|
47
|
-
function visitFragment(fragment: Fragment, state: State): Fragment {
|
48
|
-
const result = this.traverse(fragment, state);
|
49
|
-
if (state.reachableArguments.length === 0) {
|
50
|
-
return result;
|
51
|
-
}
|
52
|
-
const joinedArgumentDefinitions = joinArgumentDefinitions(
|
53
|
-
this.getContext().getSchema(),
|
54
|
-
fragment,
|
55
|
-
state.reachableArguments,
|
56
|
-
'@relay(unmask: true)',
|
57
|
-
);
|
58
|
-
return {
|
59
|
-
...result,
|
60
|
-
argumentDefinitions: joinedArgumentDefinitions,
|
61
|
-
};
|
62
|
-
}
|
63
|
-
|
64
|
-
function visitFragmentSpread(
|
65
|
-
fragmentSpread: FragmentSpread,
|
66
|
-
state: State,
|
67
|
-
): FragmentSpread {
|
68
|
-
if (!isUnmaskedSpread(fragmentSpread)) {
|
69
|
-
return fragmentSpread;
|
70
|
-
}
|
71
|
-
invariant(
|
72
|
-
fragmentSpread.args.length === 0,
|
73
|
-
'MaskTransform: Cannot unmask fragment spread `%s` with ' +
|
74
|
-
'arguments. Use the `ApplyFragmentArgumentTransform` before flattening',
|
75
|
-
fragmentSpread.name,
|
76
|
-
);
|
77
|
-
const context = this.getContext();
|
78
|
-
const fragment: Fragment = context.getFragment(fragmentSpread.name);
|
79
|
-
const result: InlineFragment = {
|
80
|
-
kind: 'InlineFragment',
|
81
|
-
directives: fragmentSpread.directives,
|
82
|
-
loc: {kind: 'Derived', source: fragmentSpread.loc},
|
83
|
-
metadata: fragmentSpread.metadata,
|
84
|
-
selections: fragment.selections,
|
85
|
-
typeCondition: fragment.type,
|
86
|
-
};
|
87
|
-
|
88
|
-
if (fragment.directives.length > 0) {
|
89
|
-
throw new createUserError(
|
90
|
-
'Cannot use @relay(mask: false) on fragment spreads for fragments ' +
|
91
|
-
'with directives.',
|
92
|
-
[fragmentSpread.loc, fragment.directives[0].loc],
|
93
|
-
);
|
94
|
-
}
|
95
|
-
|
96
|
-
const localArgDef = fragment.argumentDefinitions.find(
|
97
|
-
argDef => argDef.kind === 'LocalArgumentDefinition',
|
98
|
-
);
|
99
|
-
if (localArgDef != null) {
|
100
|
-
throw createUserError(
|
101
|
-
'MaskTransform: Cannot use @relay(mask: false) on fragment spread ' +
|
102
|
-
'because the fragment definition uses @argumentDefinitions.',
|
103
|
-
[fragmentSpread.loc, localArgDef.loc],
|
104
|
-
);
|
105
|
-
}
|
106
|
-
|
107
|
-
// Note: defer validating arguments to the containing fragment in order
|
108
|
-
// to list all invalid variables/arguments instead of only one.
|
109
|
-
for (const argDef of fragment.argumentDefinitions) {
|
110
|
-
state.reachableArguments.push(argDef);
|
111
|
-
}
|
112
|
-
return this.traverse(result, state);
|
113
|
-
}
|
114
|
-
|
115
|
-
/**
|
116
|
-
* @private
|
117
|
-
*/
|
118
|
-
function isUnmaskedSpread(spread: FragmentSpread): boolean {
|
119
|
-
return Boolean(spread.metadata && spread.metadata.mask === false);
|
120
|
-
}
|
121
|
-
|
122
|
-
module.exports = {
|
123
|
-
transform: maskTransform,
|
124
|
-
};
|