relay-compiler 0.0.0-main-4d287de9 → 0.0.0-main-9a79039d
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 -26
- package/win-x64/relay.exe +0 -0
- package/bin/RelayCompilerBin.js.flow +0 -168
- package/bin/RelayCompilerMain.js.flow +0 -513
- package/bin/__fixtures__/plugin-module.js.flow +0 -17
- package/bin/relay-compiler +0 -19066
- 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 -565
- 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 -1731
- 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 -486
- 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/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/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 -194
- 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 -255
- 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 -126
- package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +0 -111
- 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 -152
- 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,345 +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('./CompilerError'),
|
18
|
-
eachWithCombinedError = _require.eachWithCombinedError;
|
19
|
-
|
20
|
-
var invariant = require('invariant');
|
21
|
-
|
22
|
-
/**
|
23
|
-
* @public
|
24
|
-
*
|
25
|
-
* Helper for writing compiler transforms that apply "map" and/or "filter"-style
|
26
|
-
* operations to compiler contexts. The `visitor` argument accepts a map of IR
|
27
|
-
* kinds to user-defined functions that can map nodes of that kind to new values
|
28
|
-
* (of the same kind).
|
29
|
-
*
|
30
|
-
* If a visitor function is defined for a kind, the visitor function is
|
31
|
-
* responsible for traversing its children (by calling `this.traverse(node)`)
|
32
|
-
* and returning either the input (to indicate no changes), a new node (to
|
33
|
-
* indicate changes), or null/undefined (to indicate the removal of that node
|
34
|
-
* from the output).
|
35
|
-
*
|
36
|
-
* If a visitor function is *not* defined for a kind, a default traversal is
|
37
|
-
* used to evaluate its children.
|
38
|
-
*
|
39
|
-
* The `stateInitializer` argument accepts an optional function to construct the
|
40
|
-
* state for each document (fragment or root) in the context. Any documents for
|
41
|
-
* which the initializer returns null/undefined is deleted from the context
|
42
|
-
* without being traversed.
|
43
|
-
*
|
44
|
-
* Example: Alias all scalar fields with the reverse of their name:
|
45
|
-
*
|
46
|
-
* ```
|
47
|
-
* transform(context, {
|
48
|
-
* ScalarField: visitScalarField,
|
49
|
-
* });
|
50
|
-
*
|
51
|
-
* function visitScalarField(field: ScalarField, state: State): ?ScalarField {
|
52
|
-
* // Traverse child nodes - for a scalar field these are the arguments &
|
53
|
-
* // directives.
|
54
|
-
* const nextField = this.traverse(field, state);
|
55
|
-
* // Return a new node with a different alias.
|
56
|
-
* return {
|
57
|
-
* ...nextField,
|
58
|
-
* alias: nextField.name.split('').reverse().join(''),
|
59
|
-
* };
|
60
|
-
* }
|
61
|
-
* ```
|
62
|
-
*/
|
63
|
-
function transform(context, visitor, stateInitializer) {
|
64
|
-
var transformer = new Transformer(context, visitor);
|
65
|
-
return context.withMutations(function (ctx) {
|
66
|
-
var nextContext = ctx;
|
67
|
-
eachWithCombinedError(context.documents(), function (prevNode) {
|
68
|
-
var nextNode;
|
69
|
-
|
70
|
-
if (stateInitializer === undefined) {
|
71
|
-
nextNode = transformer.visit(prevNode, undefined);
|
72
|
-
} else {
|
73
|
-
var _state = stateInitializer(prevNode);
|
74
|
-
|
75
|
-
if (_state != null) {
|
76
|
-
nextNode = transformer.visit(prevNode, _state);
|
77
|
-
}
|
78
|
-
}
|
79
|
-
|
80
|
-
if (!nextNode) {
|
81
|
-
nextContext = nextContext.remove(prevNode.name);
|
82
|
-
} else if (nextNode !== prevNode) {
|
83
|
-
nextContext = nextContext.replace(nextNode);
|
84
|
-
}
|
85
|
-
});
|
86
|
-
return nextContext;
|
87
|
-
});
|
88
|
-
}
|
89
|
-
/**
|
90
|
-
* @internal
|
91
|
-
*/
|
92
|
-
|
93
|
-
|
94
|
-
var Transformer = /*#__PURE__*/function () {
|
95
|
-
function Transformer(context, visitor) {
|
96
|
-
this._context = context;
|
97
|
-
this._states = [];
|
98
|
-
this._visitor = visitor;
|
99
|
-
}
|
100
|
-
/**
|
101
|
-
* @public
|
102
|
-
*
|
103
|
-
* Returns the original compiler context that is being transformed. This can
|
104
|
-
* be used to look up fragments by name, for example.
|
105
|
-
*/
|
106
|
-
|
107
|
-
|
108
|
-
var _proto = Transformer.prototype;
|
109
|
-
|
110
|
-
_proto.getContext = function getContext() {
|
111
|
-
return this._context;
|
112
|
-
}
|
113
|
-
/**
|
114
|
-
* @public
|
115
|
-
*
|
116
|
-
* Transforms the node, calling a user-defined visitor function if defined for
|
117
|
-
* the node's kind. Uses the given state for this portion of the traversal.
|
118
|
-
*
|
119
|
-
* Note: This differs from `traverse` in that it calls a visitor function for
|
120
|
-
* the node itself.
|
121
|
-
*/
|
122
|
-
;
|
123
|
-
|
124
|
-
_proto.visit = function visit(node, state) {
|
125
|
-
this._states.push(state);
|
126
|
-
|
127
|
-
var nextNode = this._visit(node);
|
128
|
-
|
129
|
-
this._states.pop();
|
130
|
-
|
131
|
-
return nextNode;
|
132
|
-
}
|
133
|
-
/**
|
134
|
-
* @public
|
135
|
-
*
|
136
|
-
* Transforms the children of the given node, skipping the user-defined
|
137
|
-
* visitor function for the node itself. Uses the given state for this portion
|
138
|
-
* of the traversal.
|
139
|
-
*
|
140
|
-
* Note: This differs from `visit` in that it does not call a visitor function
|
141
|
-
* for the node itself.
|
142
|
-
*/
|
143
|
-
;
|
144
|
-
|
145
|
-
_proto.traverse = function traverse(node, state) {
|
146
|
-
this._states.push(state);
|
147
|
-
|
148
|
-
var nextNode = this._traverse(node);
|
149
|
-
|
150
|
-
this._states.pop();
|
151
|
-
|
152
|
-
return nextNode;
|
153
|
-
};
|
154
|
-
|
155
|
-
_proto._visit = function _visit(node) {
|
156
|
-
var nodeVisitor = this._visitor[node.kind];
|
157
|
-
|
158
|
-
if (nodeVisitor) {
|
159
|
-
// If a handler for the kind is defined, it is responsible for calling
|
160
|
-
// `traverse` to transform children as necessary.
|
161
|
-
var _state2 = this._getState();
|
162
|
-
|
163
|
-
var nextNode = nodeVisitor.call(this, node, _state2);
|
164
|
-
return nextNode;
|
165
|
-
} // Otherwise traverse is called automatically.
|
166
|
-
|
167
|
-
|
168
|
-
return this._traverse(node);
|
169
|
-
};
|
170
|
-
|
171
|
-
_proto._traverse = function _traverse(prevNode) {
|
172
|
-
var nextNode;
|
173
|
-
|
174
|
-
switch (prevNode.kind) {
|
175
|
-
case 'Argument':
|
176
|
-
nextNode = this._traverseChildren(prevNode, null, ['value']);
|
177
|
-
break;
|
178
|
-
|
179
|
-
case 'Literal':
|
180
|
-
case 'LocalArgumentDefinition':
|
181
|
-
case 'RootArgumentDefinition':
|
182
|
-
case 'Variable':
|
183
|
-
nextNode = prevNode;
|
184
|
-
break;
|
185
|
-
|
186
|
-
case 'Defer':
|
187
|
-
nextNode = this._traverseChildren(prevNode, ['selections'], ['if']);
|
188
|
-
break;
|
189
|
-
|
190
|
-
case 'Stream':
|
191
|
-
nextNode = this._traverseChildren(prevNode, ['selections'], ['if', 'initialCount']);
|
192
|
-
break;
|
193
|
-
|
194
|
-
case 'ClientExtension':
|
195
|
-
nextNode = this._traverseChildren(prevNode, ['selections']);
|
196
|
-
break;
|
197
|
-
|
198
|
-
case 'Directive':
|
199
|
-
nextNode = this._traverseChildren(prevNode, ['args']);
|
200
|
-
break;
|
201
|
-
|
202
|
-
case 'ModuleImport':
|
203
|
-
nextNode = this._traverseChildren(prevNode, ['selections']);
|
204
|
-
|
205
|
-
if (!nextNode.selections.length) {
|
206
|
-
nextNode = null;
|
207
|
-
}
|
208
|
-
|
209
|
-
break;
|
210
|
-
|
211
|
-
case 'FragmentSpread':
|
212
|
-
case 'ScalarField':
|
213
|
-
nextNode = this._traverseChildren(prevNode, ['args', 'directives']);
|
214
|
-
break;
|
215
|
-
|
216
|
-
case 'InlineDataFragmentSpread':
|
217
|
-
nextNode = this._traverseChildren(prevNode, ['selections']);
|
218
|
-
break;
|
219
|
-
|
220
|
-
case 'LinkedField':
|
221
|
-
nextNode = this._traverseChildren(prevNode, ['args', 'directives', 'selections']);
|
222
|
-
|
223
|
-
if (!nextNode.selections.length) {
|
224
|
-
nextNode = null;
|
225
|
-
}
|
226
|
-
|
227
|
-
break;
|
228
|
-
|
229
|
-
case 'ListValue':
|
230
|
-
nextNode = this._traverseChildren(prevNode, ['items']);
|
231
|
-
break;
|
232
|
-
|
233
|
-
case 'ObjectFieldValue':
|
234
|
-
nextNode = this._traverseChildren(prevNode, null, ['value']);
|
235
|
-
break;
|
236
|
-
|
237
|
-
case 'ObjectValue':
|
238
|
-
nextNode = this._traverseChildren(prevNode, ['fields']);
|
239
|
-
break;
|
240
|
-
|
241
|
-
case 'Condition':
|
242
|
-
nextNode = this._traverseChildren(prevNode, ['directives', 'selections'], ['condition']);
|
243
|
-
|
244
|
-
if (!nextNode.selections.length) {
|
245
|
-
nextNode = null;
|
246
|
-
}
|
247
|
-
|
248
|
-
break;
|
249
|
-
|
250
|
-
case 'InlineFragment':
|
251
|
-
nextNode = this._traverseChildren(prevNode, ['directives', 'selections']);
|
252
|
-
|
253
|
-
if (!nextNode.selections.length) {
|
254
|
-
nextNode = null;
|
255
|
-
}
|
256
|
-
|
257
|
-
break;
|
258
|
-
|
259
|
-
case 'Fragment':
|
260
|
-
case 'Root':
|
261
|
-
nextNode = this._traverseChildren(prevNode, ['argumentDefinitions', 'directives', 'selections']);
|
262
|
-
break;
|
263
|
-
|
264
|
-
case 'Request':
|
265
|
-
nextNode = this._traverseChildren(prevNode, null, ['fragment', 'root']);
|
266
|
-
break;
|
267
|
-
|
268
|
-
case 'SplitOperation':
|
269
|
-
nextNode = this._traverseChildren(prevNode, ['selections']);
|
270
|
-
break;
|
271
|
-
|
272
|
-
default:
|
273
|
-
prevNode;
|
274
|
-
!false ? process.env.NODE_ENV !== "production" ? invariant(false, 'IRTransformer: Unknown kind `%s`.', prevNode.kind) : invariant(false) : void 0;
|
275
|
-
}
|
276
|
-
|
277
|
-
return nextNode;
|
278
|
-
};
|
279
|
-
|
280
|
-
_proto._traverseChildren = function _traverseChildren(prevNode, pluralKeys, singularKeys) {
|
281
|
-
var _this = this;
|
282
|
-
|
283
|
-
var nextNode;
|
284
|
-
pluralKeys && pluralKeys.forEach(function (key) {
|
285
|
-
var prevItems = prevNode[key];
|
286
|
-
|
287
|
-
if (!prevItems) {
|
288
|
-
return;
|
289
|
-
}
|
290
|
-
|
291
|
-
!Array.isArray(prevItems) ? process.env.NODE_ENV !== "production" ? invariant(false, 'IRTransformer: Expected data for `%s` to be an array, got `%s`.', key, prevItems) : invariant(false) : void 0;
|
292
|
-
|
293
|
-
var nextItems = _this._map(prevItems);
|
294
|
-
|
295
|
-
if (nextNode || nextItems !== prevItems) {
|
296
|
-
nextNode = nextNode || (0, _objectSpread2["default"])({}, prevNode);
|
297
|
-
nextNode[key] = nextItems;
|
298
|
-
}
|
299
|
-
});
|
300
|
-
singularKeys && singularKeys.forEach(function (key) {
|
301
|
-
var prevItem = prevNode[key];
|
302
|
-
|
303
|
-
if (!prevItem) {
|
304
|
-
return;
|
305
|
-
}
|
306
|
-
|
307
|
-
var nextItem = _this._visit(prevItem);
|
308
|
-
|
309
|
-
if (nextNode || nextItem !== prevItem) {
|
310
|
-
nextNode = nextNode || (0, _objectSpread2["default"])({}, prevNode);
|
311
|
-
nextNode[key] = nextItem;
|
312
|
-
}
|
313
|
-
});
|
314
|
-
return nextNode || prevNode;
|
315
|
-
};
|
316
|
-
|
317
|
-
_proto._map = function _map(prevItems) {
|
318
|
-
var _this2 = this;
|
319
|
-
|
320
|
-
var nextItems;
|
321
|
-
prevItems.forEach(function (prevItem, index) {
|
322
|
-
var nextItem = _this2._visit(prevItem);
|
323
|
-
|
324
|
-
if (nextItems || nextItem !== prevItem) {
|
325
|
-
nextItems = nextItems || prevItems.slice(0, index);
|
326
|
-
|
327
|
-
if (nextItem) {
|
328
|
-
nextItems.push(nextItem);
|
329
|
-
}
|
330
|
-
}
|
331
|
-
});
|
332
|
-
return nextItems || prevItems;
|
333
|
-
};
|
334
|
-
|
335
|
-
_proto._getState = function _getState() {
|
336
|
-
!this._states.length ? process.env.NODE_ENV !== "production" ? invariant(false, 'IRTransformer: Expected a current state to be set but found none. ' + 'This is usually the result of mismatched number of pushState()/popState() ' + 'calls.') : invariant(false) : void 0;
|
337
|
-
return this._states[this._states.length - 1];
|
338
|
-
};
|
339
|
-
|
340
|
-
return Transformer;
|
341
|
-
}();
|
342
|
-
|
343
|
-
module.exports = {
|
344
|
-
transform: transform
|
345
|
-
};
|
package/lib/core/IRValidator.js
DELETED
@@ -1,226 +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 _require = require('./CompilerError'),
|
14
|
-
eachWithCombinedError = _require.eachWithCombinedError;
|
15
|
-
|
16
|
-
var invariant = require('invariant');
|
17
|
-
|
18
|
-
/**
|
19
|
-
* @public
|
20
|
-
*
|
21
|
-
* Helper for writing AST validators that shares the same logic with
|
22
|
-
* the transfomer
|
23
|
-
*
|
24
|
-
*/
|
25
|
-
function validate(context, visitor, stateInitializer) {
|
26
|
-
var validator = new Validator(context, visitor);
|
27
|
-
eachWithCombinedError(context.documents(), function (prevNode) {
|
28
|
-
if (stateInitializer === undefined) {
|
29
|
-
validator.visit(prevNode, undefined);
|
30
|
-
} else {
|
31
|
-
var _state = stateInitializer(prevNode);
|
32
|
-
|
33
|
-
if (_state != null) {
|
34
|
-
validator.visit(prevNode, _state);
|
35
|
-
}
|
36
|
-
}
|
37
|
-
});
|
38
|
-
}
|
39
|
-
/**
|
40
|
-
* @internal
|
41
|
-
*/
|
42
|
-
|
43
|
-
|
44
|
-
var Validator = /*#__PURE__*/function () {
|
45
|
-
function Validator(context, visitor) {
|
46
|
-
this._context = context;
|
47
|
-
this._states = [];
|
48
|
-
this._visitor = visitor;
|
49
|
-
}
|
50
|
-
|
51
|
-
var _proto = Validator.prototype;
|
52
|
-
|
53
|
-
_proto.getContext = function getContext() {
|
54
|
-
return this._context;
|
55
|
-
};
|
56
|
-
|
57
|
-
_proto.visit = function visit(node, state) {
|
58
|
-
this._states.push(state);
|
59
|
-
|
60
|
-
this._visit(node);
|
61
|
-
|
62
|
-
this._states.pop();
|
63
|
-
};
|
64
|
-
|
65
|
-
_proto.traverse = function traverse(node, state) {
|
66
|
-
this._states.push(state);
|
67
|
-
|
68
|
-
this._traverse(node);
|
69
|
-
|
70
|
-
this._states.pop();
|
71
|
-
};
|
72
|
-
|
73
|
-
_proto._visit = function _visit(node) {
|
74
|
-
var nodeVisitor = this._visitor[node.kind];
|
75
|
-
|
76
|
-
if (nodeVisitor) {
|
77
|
-
// If a handler for the kind is defined, it is responsible for calling
|
78
|
-
// `traverse` to transform children as necessary.
|
79
|
-
var _state2 = this._getState();
|
80
|
-
|
81
|
-
nodeVisitor.call(this, node, _state2);
|
82
|
-
return;
|
83
|
-
} // Otherwise traverse is called automatically.
|
84
|
-
|
85
|
-
|
86
|
-
this._traverse(node);
|
87
|
-
};
|
88
|
-
|
89
|
-
_proto._traverse = function _traverse(prevNode) {
|
90
|
-
switch (prevNode.kind) {
|
91
|
-
case 'Argument':
|
92
|
-
this._traverseChildren(prevNode, null, ['value']);
|
93
|
-
|
94
|
-
break;
|
95
|
-
|
96
|
-
case 'Literal':
|
97
|
-
case 'LocalArgumentDefinition':
|
98
|
-
case 'RootArgumentDefinition':
|
99
|
-
case 'Variable':
|
100
|
-
break;
|
101
|
-
|
102
|
-
case 'Defer':
|
103
|
-
this._traverseChildren(prevNode, ['selections'], ['if']);
|
104
|
-
|
105
|
-
break;
|
106
|
-
|
107
|
-
case 'Stream':
|
108
|
-
this._traverseChildren(prevNode, ['selections'], ['if', 'initialCount']);
|
109
|
-
|
110
|
-
break;
|
111
|
-
|
112
|
-
case 'ClientExtension':
|
113
|
-
this._traverseChildren(prevNode, ['selections']);
|
114
|
-
|
115
|
-
break;
|
116
|
-
|
117
|
-
case 'Directive':
|
118
|
-
this._traverseChildren(prevNode, ['args']);
|
119
|
-
|
120
|
-
break;
|
121
|
-
|
122
|
-
case 'ModuleImport':
|
123
|
-
this._traverseChildren(prevNode, ['selections']);
|
124
|
-
|
125
|
-
break;
|
126
|
-
|
127
|
-
case 'FragmentSpread':
|
128
|
-
case 'ScalarField':
|
129
|
-
this._traverseChildren(prevNode, ['args', 'directives']);
|
130
|
-
|
131
|
-
break;
|
132
|
-
|
133
|
-
case 'InlineDataFragmentSpread':
|
134
|
-
this._traverseChildren(prevNode, ['selections']);
|
135
|
-
|
136
|
-
break;
|
137
|
-
|
138
|
-
case 'LinkedField':
|
139
|
-
this._traverseChildren(prevNode, ['args', 'directives', 'selections']);
|
140
|
-
|
141
|
-
break;
|
142
|
-
|
143
|
-
case 'ListValue':
|
144
|
-
this._traverseChildren(prevNode, ['items']);
|
145
|
-
|
146
|
-
break;
|
147
|
-
|
148
|
-
case 'ObjectFieldValue':
|
149
|
-
this._traverseChildren(prevNode, null, ['value']);
|
150
|
-
|
151
|
-
break;
|
152
|
-
|
153
|
-
case 'ObjectValue':
|
154
|
-
this._traverseChildren(prevNode, ['fields']);
|
155
|
-
|
156
|
-
break;
|
157
|
-
|
158
|
-
case 'Condition':
|
159
|
-
this._traverseChildren(prevNode, ['directives', 'selections'], ['condition']);
|
160
|
-
|
161
|
-
break;
|
162
|
-
|
163
|
-
case 'InlineFragment':
|
164
|
-
this._traverseChildren(prevNode, ['directives', 'selections']);
|
165
|
-
|
166
|
-
break;
|
167
|
-
|
168
|
-
case 'Fragment':
|
169
|
-
case 'Root':
|
170
|
-
this._traverseChildren(prevNode, ['argumentDefinitions', 'directives', 'selections']);
|
171
|
-
|
172
|
-
break;
|
173
|
-
|
174
|
-
case 'Request':
|
175
|
-
this._traverseChildren(prevNode, null, ['fragment', 'root']);
|
176
|
-
|
177
|
-
break;
|
178
|
-
|
179
|
-
case 'SplitOperation':
|
180
|
-
this._traverseChildren(prevNode, ['selections']);
|
181
|
-
|
182
|
-
break;
|
183
|
-
|
184
|
-
default:
|
185
|
-
prevNode;
|
186
|
-
!false ? process.env.NODE_ENV !== "production" ? invariant(false, 'IRValidator: Unknown kind `%s`.', prevNode.kind) : invariant(false) : void 0;
|
187
|
-
}
|
188
|
-
};
|
189
|
-
|
190
|
-
_proto._traverseChildren = function _traverseChildren(prevNode, pluralKeys, singularKeys) {
|
191
|
-
var _this = this;
|
192
|
-
|
193
|
-
pluralKeys && pluralKeys.forEach(function (key) {
|
194
|
-
var prevItems = prevNode[key];
|
195
|
-
|
196
|
-
if (!prevItems) {
|
197
|
-
return;
|
198
|
-
}
|
199
|
-
|
200
|
-
!Array.isArray(prevItems) ? process.env.NODE_ENV !== "production" ? invariant(false, 'IRValidator: Expected data for `%s` to be an array, got `%s`.', key, prevItems) : invariant(false) : void 0;
|
201
|
-
prevItems.forEach(function (prevItem) {
|
202
|
-
return _this._visit(prevItem);
|
203
|
-
});
|
204
|
-
});
|
205
|
-
singularKeys && singularKeys.forEach(function (key) {
|
206
|
-
var prevItem = prevNode[key];
|
207
|
-
|
208
|
-
if (!prevItem) {
|
209
|
-
return;
|
210
|
-
}
|
211
|
-
|
212
|
-
_this._visit(prevItem);
|
213
|
-
});
|
214
|
-
};
|
215
|
-
|
216
|
-
_proto._getState = function _getState() {
|
217
|
-
!this._states.length ? process.env.NODE_ENV !== "production" ? invariant(false, 'IRValidator: Expected a current state to be set but found none. ' + 'This is usually the result of mismatched number of pushState()/popState() ' + 'calls.') : invariant(false) : void 0;
|
218
|
-
return this._states[this._states.length - 1];
|
219
|
-
};
|
220
|
-
|
221
|
-
return Validator;
|
222
|
-
}();
|
223
|
-
|
224
|
-
module.exports = {
|
225
|
-
validate: validate
|
226
|
-
};
|
package/lib/core/IRVisitor.js
DELETED
@@ -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
|
-
*
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
|
13
|
-
var _require = require('graphql'),
|
14
|
-
visit = _require.visit;
|
15
|
-
|
16
|
-
var NodeKeys = {
|
17
|
-
Argument: ['value'],
|
18
|
-
ClientExtension: ['selections'],
|
19
|
-
Condition: ['condition', 'selections'],
|
20
|
-
Defer: ['selections', 'if'],
|
21
|
-
Directive: ['args'],
|
22
|
-
Fragment: ['argumentDefinitions', 'directives', 'selections'],
|
23
|
-
FragmentSpread: ['args', 'directives'],
|
24
|
-
InlineDataFragmentSpread: ['selections'],
|
25
|
-
InlineFragment: ['directives', 'selections'],
|
26
|
-
LinkedField: ['args', 'directives', 'selections'],
|
27
|
-
Literal: [],
|
28
|
-
LocalArgumentDefinition: [],
|
29
|
-
ModuleImport: ['selections'],
|
30
|
-
Request: ['fragment', 'root'],
|
31
|
-
Root: ['argumentDefinitions', 'directives', 'selections'],
|
32
|
-
RootArgumentDefinition: [],
|
33
|
-
ScalarField: ['args', 'directives'],
|
34
|
-
SplitOperation: ['selections'],
|
35
|
-
Stream: ['selections', 'if', 'initialCount'],
|
36
|
-
Variable: []
|
37
|
-
};
|
38
|
-
|
39
|
-
function visitIR(root, visitor) {
|
40
|
-
return visit(root, visitor, NodeKeys);
|
41
|
-
}
|
42
|
-
|
43
|
-
module.exports = {
|
44
|
-
visit: visitIR
|
45
|
-
};
|
@@ -1,18 +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 FindGraphQLTags = require('../language/javascript/FindGraphQLTags');
|
14
|
-
|
15
|
-
var RelaySourceModuleParser = require('./RelaySourceModuleParser');
|
16
|
-
|
17
|
-
var JSModuleParser = RelaySourceModuleParser(FindGraphQLTags.find);
|
18
|
-
module.exports = JSModuleParser;
|