relay-compiler 0.0.0-main-f0b65f0b → 0.0.0-main-e0026a71
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,100 +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
|
-
*
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
|
13
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
14
|
-
|
15
|
-
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
16
|
-
|
17
|
-
var _require = require('../core/CompilerError'),
|
18
|
-
createUserError = _require.createUserError;
|
19
|
-
|
20
|
-
var IRTransformer = require('../core/IRTransformer');
|
21
|
-
|
22
|
-
var SCHEMA_EXTENSION = "\ndirective @inline on FRAGMENT_DEFINITION\n";
|
23
|
-
/**
|
24
|
-
* A transform that converts fragment spreads where the referenced fragment
|
25
|
-
* is annotated with @inline to a InlineDataFragmentSpread.
|
26
|
-
* InlineDataFragmentSpreads have the selections of the referenced fragment inlined.
|
27
|
-
*/
|
28
|
-
|
29
|
-
function inlineDataFragmentTransform(context) {
|
30
|
-
return IRTransformer.transform(context, {
|
31
|
-
// $FlowFixMe[prop-missing] - this visitor intentionally changes node types
|
32
|
-
// $FlowFixMe[incompatible-call] - this visitor intentionally changes node types
|
33
|
-
FragmentSpread: visitFragmentSpread,
|
34
|
-
Fragment: visitFragment
|
35
|
-
});
|
36
|
-
}
|
37
|
-
|
38
|
-
function visitFragment(fragment) {
|
39
|
-
var transformedFragment = this.traverse(fragment);
|
40
|
-
var inlineDirective = transformedFragment.directives.find(function (directive) {
|
41
|
-
return directive.name === 'inline';
|
42
|
-
});
|
43
|
-
|
44
|
-
if (inlineDirective == null) {
|
45
|
-
return transformedFragment;
|
46
|
-
}
|
47
|
-
|
48
|
-
return (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, transformedFragment), {}, {
|
49
|
-
directives: transformedFragment.directives.filter(function (directive) {
|
50
|
-
return directive !== inlineDirective;
|
51
|
-
}),
|
52
|
-
metadata: (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, transformedFragment.metadata || {}), {}, {
|
53
|
-
inlineData: true
|
54
|
-
})
|
55
|
-
});
|
56
|
-
}
|
57
|
-
|
58
|
-
function visitFragmentSpread(fragmentSpread) {
|
59
|
-
var transformedFragmentSpread = this.traverse(fragmentSpread);
|
60
|
-
var context = this.getContext();
|
61
|
-
var fragment = context.get(transformedFragmentSpread.name);
|
62
|
-
|
63
|
-
if (!fragment || fragment.kind !== 'Fragment' || !fragment.directives.some(function (directive) {
|
64
|
-
return directive.name === 'inline';
|
65
|
-
})) {
|
66
|
-
return transformedFragmentSpread;
|
67
|
-
}
|
68
|
-
|
69
|
-
if (fragment.argumentDefinitions.length > 0 || transformedFragmentSpread.args.length > 0) {
|
70
|
-
throw createUserError('Variables are not yet supported inside @inline fragments.', [fragment.argumentDefinitions[0].loc]);
|
71
|
-
}
|
72
|
-
|
73
|
-
if (transformedFragmentSpread.directives.length > 0) {
|
74
|
-
throw createUserError('Directives on fragment spreads for @inline fragments are not yet ' + 'supported', [transformedFragmentSpread.loc]);
|
75
|
-
}
|
76
|
-
|
77
|
-
var transformedFragment = this.visit(fragment);
|
78
|
-
return {
|
79
|
-
kind: 'InlineDataFragmentSpread',
|
80
|
-
loc: transformedFragmentSpread.loc,
|
81
|
-
metadata: transformedFragmentSpread.metadata,
|
82
|
-
name: transformedFragmentSpread.name,
|
83
|
-
selections: [{
|
84
|
-
directives: [],
|
85
|
-
kind: 'InlineFragment',
|
86
|
-
loc: {
|
87
|
-
kind: 'Derived',
|
88
|
-
source: transformedFragmentSpread.loc
|
89
|
-
},
|
90
|
-
metadata: null,
|
91
|
-
selections: transformedFragment.selections,
|
92
|
-
typeCondition: transformedFragment.type
|
93
|
-
}]
|
94
|
-
};
|
95
|
-
}
|
96
|
-
|
97
|
-
module.exports = {
|
98
|
-
SCHEMA_EXTENSION: SCHEMA_EXTENSION,
|
99
|
-
transform: inlineDataFragmentTransform
|
100
|
-
};
|
@@ -1,61 +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
|
-
*
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
|
13
|
-
var IRTransformer = require('../core/IRTransformer');
|
14
|
-
|
15
|
-
var invariant = require('invariant');
|
16
|
-
|
17
|
-
/**
|
18
|
-
* A transform that inlines all fragments and removes them.
|
19
|
-
*/
|
20
|
-
function inlineFragmentsTransform(context) {
|
21
|
-
var visitFragmentSpread = fragmentSpreadVisitor(new Map());
|
22
|
-
return IRTransformer.transform(context, {
|
23
|
-
Fragment: visitFragment,
|
24
|
-
FragmentSpread: visitFragmentSpread
|
25
|
-
});
|
26
|
-
}
|
27
|
-
|
28
|
-
function visitFragment(fragment) {
|
29
|
-
return null;
|
30
|
-
}
|
31
|
-
|
32
|
-
function fragmentSpreadVisitor(cache) {
|
33
|
-
return function visitFragmentSpread(fragmentSpread) {
|
34
|
-
var traverseResult = cache.get(fragmentSpread);
|
35
|
-
|
36
|
-
if (traverseResult != null) {
|
37
|
-
return traverseResult;
|
38
|
-
}
|
39
|
-
|
40
|
-
!(fragmentSpread.args.length === 0) ? process.env.NODE_ENV !== "production" ? invariant(false, 'InlineFragmentsTransform: Cannot flatten fragment spread `%s` with ' + 'arguments. Use the `ApplyFragmentArgumentTransform` before flattening', fragmentSpread.name) : invariant(false) : void 0;
|
41
|
-
var fragment = this.getContext().getFragment(fragmentSpread.name, fragmentSpread.loc);
|
42
|
-
var result = {
|
43
|
-
kind: 'InlineFragment',
|
44
|
-
directives: fragmentSpread.directives,
|
45
|
-
loc: {
|
46
|
-
kind: 'Derived',
|
47
|
-
source: fragmentSpread.loc
|
48
|
-
},
|
49
|
-
metadata: fragmentSpread.metadata,
|
50
|
-
selections: fragment.selections,
|
51
|
-
typeCondition: fragment.type
|
52
|
-
};
|
53
|
-
traverseResult = this.traverse(result);
|
54
|
-
cache.set(fragmentSpread, traverseResult);
|
55
|
-
return traverseResult;
|
56
|
-
};
|
57
|
-
}
|
58
|
-
|
59
|
-
module.exports = {
|
60
|
-
transform: inlineFragmentsTransform
|
61
|
-
};
|
@@ -1,117 +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
|
-
*
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
|
13
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
14
|
-
|
15
|
-
var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/createForOfIteratorHelper"));
|
16
|
-
|
17
|
-
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
18
|
-
|
19
|
-
var _require = require('../core/CompilerError'),
|
20
|
-
createUserError = _require.createUserError;
|
21
|
-
|
22
|
-
var IRTransformer = require('../core/IRTransformer');
|
23
|
-
|
24
|
-
var joinArgumentDefinitions = require('../util/joinArgumentDefinitions');
|
25
|
-
|
26
|
-
var invariant = require('invariant');
|
27
|
-
|
28
|
-
/**
|
29
|
-
* A transform that inlines fragment spreads with the @relay(mask: false)
|
30
|
-
* directive.
|
31
|
-
*/
|
32
|
-
function maskTransform(context) {
|
33
|
-
return IRTransformer.transform(context, {
|
34
|
-
FragmentSpread: visitFragmentSpread,
|
35
|
-
Fragment: visitFragment
|
36
|
-
}, function () {
|
37
|
-
return {
|
38
|
-
reachableArguments: []
|
39
|
-
};
|
40
|
-
});
|
41
|
-
}
|
42
|
-
|
43
|
-
function visitFragment(fragment, state) {
|
44
|
-
var result = this.traverse(fragment, state);
|
45
|
-
|
46
|
-
if (state.reachableArguments.length === 0) {
|
47
|
-
return result;
|
48
|
-
}
|
49
|
-
|
50
|
-
var joinedArgumentDefinitions = joinArgumentDefinitions(this.getContext().getSchema(), fragment, state.reachableArguments, '@relay(unmask: true)');
|
51
|
-
return (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, result), {}, {
|
52
|
-
argumentDefinitions: joinedArgumentDefinitions
|
53
|
-
});
|
54
|
-
}
|
55
|
-
|
56
|
-
function visitFragmentSpread(fragmentSpread, state) {
|
57
|
-
if (!isUnmaskedSpread(fragmentSpread)) {
|
58
|
-
return fragmentSpread;
|
59
|
-
}
|
60
|
-
|
61
|
-
!(fragmentSpread.args.length === 0) ? process.env.NODE_ENV !== "production" ? invariant(false, 'MaskTransform: Cannot unmask fragment spread `%s` with ' + 'arguments. Use the `ApplyFragmentArgumentTransform` before flattening', fragmentSpread.name) : invariant(false) : void 0;
|
62
|
-
var context = this.getContext();
|
63
|
-
var fragment = context.getFragment(fragmentSpread.name);
|
64
|
-
var result = {
|
65
|
-
kind: 'InlineFragment',
|
66
|
-
directives: fragmentSpread.directives,
|
67
|
-
loc: {
|
68
|
-
kind: 'Derived',
|
69
|
-
source: fragmentSpread.loc
|
70
|
-
},
|
71
|
-
metadata: fragmentSpread.metadata,
|
72
|
-
selections: fragment.selections,
|
73
|
-
typeCondition: fragment.type
|
74
|
-
};
|
75
|
-
|
76
|
-
if (fragment.directives.length > 0) {
|
77
|
-
throw new createUserError('Cannot use @relay(mask: false) on fragment spreads for fragments ' + 'with directives.', [fragmentSpread.loc, fragment.directives[0].loc]);
|
78
|
-
}
|
79
|
-
|
80
|
-
var localArgDef = fragment.argumentDefinitions.find(function (argDef) {
|
81
|
-
return argDef.kind === 'LocalArgumentDefinition';
|
82
|
-
});
|
83
|
-
|
84
|
-
if (localArgDef != null) {
|
85
|
-
throw createUserError('MaskTransform: Cannot use @relay(mask: false) on fragment spread ' + 'because the fragment definition uses @argumentDefinitions.', [fragmentSpread.loc, localArgDef.loc]);
|
86
|
-
} // Note: defer validating arguments to the containing fragment in order
|
87
|
-
// to list all invalid variables/arguments instead of only one.
|
88
|
-
|
89
|
-
|
90
|
-
var _iterator = (0, _createForOfIteratorHelper2["default"])(fragment.argumentDefinitions),
|
91
|
-
_step;
|
92
|
-
|
93
|
-
try {
|
94
|
-
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
95
|
-
var argDef = _step.value;
|
96
|
-
state.reachableArguments.push(argDef);
|
97
|
-
}
|
98
|
-
} catch (err) {
|
99
|
-
_iterator.e(err);
|
100
|
-
} finally {
|
101
|
-
_iterator.f();
|
102
|
-
}
|
103
|
-
|
104
|
-
return this.traverse(result, state);
|
105
|
-
}
|
106
|
-
/**
|
107
|
-
* @private
|
108
|
-
*/
|
109
|
-
|
110
|
-
|
111
|
-
function isUnmaskedSpread(spread) {
|
112
|
-
return Boolean(spread.metadata && spread.metadata.mask === false);
|
113
|
-
}
|
114
|
-
|
115
|
-
module.exports = {
|
116
|
-
transform: maskTransform
|
117
|
-
};
|