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.
Files changed (263) hide show
  1. package/cli.js +23 -0
  2. package/index.js +19 -3
  3. package/linux-x64/relay +0 -0
  4. package/macos-x64/relay +0 -0
  5. package/package.json +2 -24
  6. package/win-x64/relay.exe +0 -0
  7. package/bin/RelayCompilerBin.js.flow +0 -168
  8. package/bin/RelayCompilerMain.js.flow +0 -515
  9. package/bin/__fixtures__/plugin-module.js.flow +0 -17
  10. package/bin/relay-compiler +0 -19068
  11. package/codegen/CodegenDirectory.js.flow +0 -372
  12. package/codegen/CodegenRunner.js.flow +0 -424
  13. package/codegen/CodegenTypes.js.flow +0 -28
  14. package/codegen/CodegenWatcher.js.flow +0 -250
  15. package/codegen/NormalizationCodeGenerator.js.flow +0 -566
  16. package/codegen/ReaderCodeGenerator.js.flow +0 -510
  17. package/codegen/RelayCodeGenerator.js.flow +0 -85
  18. package/codegen/RelayFileWriter.js.flow +0 -365
  19. package/codegen/SourceControl.js.flow +0 -58
  20. package/codegen/compileRelayArtifacts.js.flow +0 -181
  21. package/codegen/createPrintRequireModuleDependency.js.flow +0 -19
  22. package/codegen/sortObjectByKey.js.flow +0 -25
  23. package/codegen/writeRelayGeneratedFile.js.flow +0 -235
  24. package/core/ASTCache.js.flow +0 -73
  25. package/core/ASTConvert.js.flow +0 -230
  26. package/core/CompilerContext.js.flow +0 -189
  27. package/core/CompilerError.js.flow +0 -255
  28. package/core/DotGraphQLParser.js.flow +0 -37
  29. package/core/GraphQLCompilerProfiler.js.flow +0 -341
  30. package/core/GraphQLDerivedFromMetadata.js.flow +0 -36
  31. package/core/GraphQLWatchmanClient.js.flow +0 -109
  32. package/core/IR.js.flow +0 -326
  33. package/core/IRPrinter.js.flow +0 -472
  34. package/core/IRTransformer.js.flow +0 -376
  35. package/core/IRValidator.js.flow +0 -259
  36. package/core/IRVisitor.js.flow +0 -150
  37. package/core/JSModuleParser.js.flow +0 -24
  38. package/core/RelayCompilerScope.js.flow +0 -199
  39. package/core/RelayFindGraphQLTags.js.flow +0 -118
  40. package/core/RelayGraphQLEnumsGenerator.js.flow +0 -55
  41. package/core/RelayIRTransforms.js.flow +0 -138
  42. package/core/RelayParser.js.flow +0 -1741
  43. package/core/RelaySourceModuleParser.js.flow +0 -133
  44. package/core/Schema.js.flow +0 -2035
  45. package/core/SchemaUtils.js.flow +0 -120
  46. package/core/filterContextForNode.js.flow +0 -49
  47. package/core/getFieldDefinition.js.flow +0 -156
  48. package/core/getIdentifierForArgumentValue.js.flow +0 -49
  49. package/core/getIdentifierForSelection.js.flow +0 -68
  50. package/core/getLiteralArgumentValues.js.flow +0 -32
  51. package/core/getNormalizationOperationName.js.flow +0 -19
  52. package/core/inferRootArgumentDefinitions.js.flow +0 -322
  53. package/index.js.flow +0 -198
  54. package/language/RelayLanguagePluginInterface.js.flow +0 -283
  55. package/language/javascript/FindGraphQLTags.js.flow +0 -136
  56. package/language/javascript/RelayFlowBabelFactories.js.flow +0 -176
  57. package/language/javascript/RelayFlowGenerator.js.flow +0 -1096
  58. package/language/javascript/RelayFlowTypeTransformers.js.flow +0 -181
  59. package/language/javascript/RelayLanguagePluginJavaScript.js.flow +0 -33
  60. package/language/javascript/formatGeneratedModule.js.flow +0 -65
  61. package/lib/bin/RelayCompilerBin.js +0 -143
  62. package/lib/bin/RelayCompilerMain.js +0 -488
  63. package/lib/bin/__fixtures__/plugin-module.js +0 -16
  64. package/lib/codegen/CodegenDirectory.js +0 -335
  65. package/lib/codegen/CodegenRunner.js +0 -433
  66. package/lib/codegen/CodegenTypes.js +0 -11
  67. package/lib/codegen/CodegenWatcher.js +0 -271
  68. package/lib/codegen/NormalizationCodeGenerator.js +0 -487
  69. package/lib/codegen/ReaderCodeGenerator.js +0 -473
  70. package/lib/codegen/RelayCodeGenerator.js +0 -75
  71. package/lib/codegen/RelayFileWriter.js +0 -270
  72. package/lib/codegen/SourceControl.js +0 -60
  73. package/lib/codegen/compileRelayArtifacts.js +0 -157
  74. package/lib/codegen/createPrintRequireModuleDependency.js +0 -19
  75. package/lib/codegen/sortObjectByKey.js +0 -41
  76. package/lib/codegen/writeRelayGeneratedFile.js +0 -206
  77. package/lib/core/ASTCache.js +0 -70
  78. package/lib/core/ASTConvert.js +0 -198
  79. package/lib/core/CompilerContext.js +0 -165
  80. package/lib/core/CompilerError.js +0 -252
  81. package/lib/core/DotGraphQLParser.js +0 -40
  82. package/lib/core/GraphQLCompilerProfiler.js +0 -299
  83. package/lib/core/GraphQLDerivedFromMetadata.js +0 -31
  84. package/lib/core/GraphQLWatchmanClient.js +0 -150
  85. package/lib/core/IR.js +0 -11
  86. package/lib/core/IRPrinter.js +0 -388
  87. package/lib/core/IRTransformer.js +0 -345
  88. package/lib/core/IRValidator.js +0 -226
  89. package/lib/core/IRVisitor.js +0 -45
  90. package/lib/core/JSModuleParser.js +0 -18
  91. package/lib/core/RelayCompilerScope.js +0 -183
  92. package/lib/core/RelayFindGraphQLTags.js +0 -79
  93. package/lib/core/RelayGraphQLEnumsGenerator.js +0 -50
  94. package/lib/core/RelayIRTransforms.js +0 -109
  95. package/lib/core/RelayParser.js +0 -1381
  96. package/lib/core/RelaySourceModuleParser.js +0 -104
  97. package/lib/core/Schema.js +0 -1877
  98. package/lib/core/SchemaUtils.js +0 -98
  99. package/lib/core/filterContextForNode.js +0 -50
  100. package/lib/core/getFieldDefinition.js +0 -145
  101. package/lib/core/getIdentifierForArgumentValue.js +0 -54
  102. package/lib/core/getIdentifierForSelection.js +0 -49
  103. package/lib/core/getLiteralArgumentValues.js +0 -26
  104. package/lib/core/getNormalizationOperationName.js +0 -17
  105. package/lib/core/inferRootArgumentDefinitions.js +0 -351
  106. package/lib/index.js +0 -178
  107. package/lib/language/RelayLanguagePluginInterface.js +0 -26
  108. package/lib/language/javascript/FindGraphQLTags.js +0 -126
  109. package/lib/language/javascript/RelayFlowBabelFactories.js +0 -160
  110. package/lib/language/javascript/RelayFlowGenerator.js +0 -856
  111. package/lib/language/javascript/RelayFlowTypeTransformers.js +0 -119
  112. package/lib/language/javascript/RelayLanguagePluginJavaScript.js +0 -30
  113. package/lib/language/javascript/formatGeneratedModule.js +0 -36
  114. package/lib/reporters/ConsoleReporter.js +0 -61
  115. package/lib/reporters/MultiReporter.js +0 -45
  116. package/lib/reporters/Reporter.js +0 -11
  117. package/lib/runner/Artifacts.js +0 -323
  118. package/lib/runner/BufferedFilesystem.js +0 -262
  119. package/lib/runner/GraphQLASTNodeGroup.js +0 -256
  120. package/lib/runner/GraphQLASTUtils.js +0 -23
  121. package/lib/runner/GraphQLNodeMap.js +0 -81
  122. package/lib/runner/Sources.js +0 -271
  123. package/lib/runner/StrictMap.js +0 -134
  124. package/lib/runner/compileArtifacts.js +0 -39
  125. package/lib/runner/extractAST.js +0 -77
  126. package/lib/runner/getChangedNodeNames.js +0 -82
  127. package/lib/runner/getSchemaInstance.js +0 -30
  128. package/lib/runner/types.js +0 -12
  129. package/lib/test-utils/TestSchema.js +0 -27
  130. package/lib/test-utils/parseGraphQLText.js +0 -30
  131. package/lib/transforms/ApplyFragmentArgumentTransform.js +0 -393
  132. package/lib/transforms/ClientExtensionsTransform.js +0 -221
  133. package/lib/transforms/ConnectionTransform.js +0 -639
  134. package/lib/transforms/DeclarativeConnectionMutationTransform.js +0 -218
  135. package/lib/transforms/DeferStreamTransform.js +0 -246
  136. package/lib/transforms/DisallowIdAsAlias.js +0 -40
  137. package/lib/transforms/DisallowTypenameOnRoot.js +0 -53
  138. package/lib/transforms/FieldHandleTransform.js +0 -79
  139. package/lib/transforms/FilterCompilerDirectivesTransform.js +0 -29
  140. package/lib/transforms/FilterDirectivesTransform.js +0 -42
  141. package/lib/transforms/FlattenTransform.js +0 -306
  142. package/lib/transforms/GenerateIDFieldTransform.js +0 -135
  143. package/lib/transforms/GenerateTypeNameTransform.js +0 -149
  144. package/lib/transforms/InlineDataFragmentTransform.js +0 -100
  145. package/lib/transforms/InlineFragmentsTransform.js +0 -61
  146. package/lib/transforms/MaskTransform.js +0 -117
  147. package/lib/transforms/MatchTransform.js +0 -434
  148. package/lib/transforms/ReactFlightComponentTransform.js +0 -158
  149. package/lib/transforms/RefetchableFragmentTransform.js +0 -249
  150. package/lib/transforms/RelayDirectiveTransform.js +0 -83
  151. package/lib/transforms/RequiredFieldTransform.js +0 -369
  152. package/lib/transforms/SkipClientExtensionsTransform.js +0 -46
  153. package/lib/transforms/SkipHandleFieldTransform.js +0 -45
  154. package/lib/transforms/SkipRedundantNodesTransform.js +0 -261
  155. package/lib/transforms/SkipSplitOperationTransform.js +0 -32
  156. package/lib/transforms/SkipUnreachableNodeTransform.js +0 -158
  157. package/lib/transforms/SkipUnusedVariablesTransform.js +0 -75
  158. package/lib/transforms/SplitModuleImportTransform.js +0 -82
  159. package/lib/transforms/TestOperationTransform.js +0 -144
  160. package/lib/transforms/TransformUtils.js +0 -21
  161. package/lib/transforms/ValidateGlobalVariablesTransform.js +0 -92
  162. package/lib/transforms/ValidateRequiredArgumentsTransform.js +0 -114
  163. package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +0 -108
  164. package/lib/transforms/ValidateUnusedVariablesTransform.js +0 -96
  165. package/lib/transforms/query-generators/FetchableQueryGenerator.js +0 -157
  166. package/lib/transforms/query-generators/NodeQueryGenerator.js +0 -166
  167. package/lib/transforms/query-generators/QueryQueryGenerator.js +0 -48
  168. package/lib/transforms/query-generators/ViewerQueryGenerator.js +0 -77
  169. package/lib/transforms/query-generators/index.js +0 -60
  170. package/lib/transforms/query-generators/utils.js +0 -92
  171. package/lib/util/CodeMarker.js +0 -80
  172. package/lib/util/DefaultHandleKey.js +0 -15
  173. package/lib/util/RelayCompilerCache.js +0 -97
  174. package/lib/util/Rollout.js +0 -40
  175. package/lib/util/TimeReporter.js +0 -83
  176. package/lib/util/areEqualArgValues.js +0 -135
  177. package/lib/util/argumentContainsVariables.js +0 -37
  178. package/lib/util/dedupeJSONStringify.js +0 -160
  179. package/lib/util/generateAbstractTypeRefinementKey.js +0 -24
  180. package/lib/util/getDefinitionNodeHash.js +0 -22
  181. package/lib/util/getModuleName.js +0 -32
  182. package/lib/util/joinArgumentDefinitions.js +0 -67
  183. package/lib/util/md5.js +0 -17
  184. package/lib/util/murmurHash.js +0 -86
  185. package/lib/util/nullthrowsOSS.js +0 -23
  186. package/lib/util/orList.js +0 -36
  187. package/lib/util/partitionArray.js +0 -35
  188. package/relay-compiler.js +0 -17
  189. package/relay-compiler.min.js +0 -22
  190. package/reporters/ConsoleReporter.js.flow +0 -81
  191. package/reporters/MultiReporter.js.flow +0 -43
  192. package/reporters/Reporter.js.flow +0 -19
  193. package/runner/Artifacts.js.flow +0 -215
  194. package/runner/BufferedFilesystem.js.flow +0 -194
  195. package/runner/GraphQLASTNodeGroup.js.flow +0 -174
  196. package/runner/GraphQLASTUtils.js.flow +0 -26
  197. package/runner/GraphQLNodeMap.js.flow +0 -55
  198. package/runner/Sources.js.flow +0 -227
  199. package/runner/StrictMap.js.flow +0 -96
  200. package/runner/compileArtifacts.js.flow +0 -75
  201. package/runner/extractAST.js.flow +0 -98
  202. package/runner/getChangedNodeNames.js.flow +0 -48
  203. package/runner/getSchemaInstance.js.flow +0 -36
  204. package/runner/types.js.flow +0 -37
  205. package/test-utils/TestSchema.js.flow +0 -30
  206. package/test-utils/parseGraphQLText.js.flow +0 -41
  207. package/transforms/ApplyFragmentArgumentTransform.js.flow +0 -524
  208. package/transforms/ClientExtensionsTransform.js.flow +0 -224
  209. package/transforms/ConnectionTransform.js.flow +0 -850
  210. package/transforms/DeclarativeConnectionMutationTransform.js.flow +0 -245
  211. package/transforms/DeferStreamTransform.js.flow +0 -263
  212. package/transforms/DisallowIdAsAlias.js.flow +0 -46
  213. package/transforms/DisallowTypenameOnRoot.js.flow +0 -44
  214. package/transforms/FieldHandleTransform.js.flow +0 -77
  215. package/transforms/FilterCompilerDirectivesTransform.js.flow +0 -33
  216. package/transforms/FilterDirectivesTransform.js.flow +0 -45
  217. package/transforms/FlattenTransform.js.flow +0 -458
  218. package/transforms/GenerateIDFieldTransform.js.flow +0 -151
  219. package/transforms/GenerateTypeNameTransform.js.flow +0 -159
  220. package/transforms/InlineDataFragmentTransform.js.flow +0 -123
  221. package/transforms/InlineFragmentsTransform.js.flow +0 -70
  222. package/transforms/MaskTransform.js.flow +0 -124
  223. package/transforms/MatchTransform.js.flow +0 -587
  224. package/transforms/ReactFlightComponentTransform.js.flow +0 -207
  225. package/transforms/RefetchableFragmentTransform.js.flow +0 -266
  226. package/transforms/RelayDirectiveTransform.js.flow +0 -96
  227. package/transforms/RequiredFieldTransform.js.flow +0 -413
  228. package/transforms/SkipClientExtensionsTransform.js.flow +0 -54
  229. package/transforms/SkipHandleFieldTransform.js.flow +0 -44
  230. package/transforms/SkipRedundantNodesTransform.js.flow +0 -277
  231. package/transforms/SkipSplitOperationTransform.js.flow +0 -37
  232. package/transforms/SkipUnreachableNodeTransform.js.flow +0 -148
  233. package/transforms/SkipUnusedVariablesTransform.js.flow +0 -59
  234. package/transforms/SplitModuleImportTransform.js.flow +0 -97
  235. package/transforms/TestOperationTransform.js.flow +0 -142
  236. package/transforms/TransformUtils.js.flow +0 -26
  237. package/transforms/ValidateGlobalVariablesTransform.js.flow +0 -80
  238. package/transforms/ValidateRequiredArgumentsTransform.js.flow +0 -130
  239. package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +0 -128
  240. package/transforms/ValidateUnusedVariablesTransform.js.flow +0 -88
  241. package/transforms/query-generators/FetchableQueryGenerator.js.flow +0 -188
  242. package/transforms/query-generators/NodeQueryGenerator.js.flow +0 -217
  243. package/transforms/query-generators/QueryQueryGenerator.js.flow +0 -57
  244. package/transforms/query-generators/ViewerQueryGenerator.js.flow +0 -97
  245. package/transforms/query-generators/index.js.flow +0 -89
  246. package/transforms/query-generators/utils.js.flow +0 -76
  247. package/util/CodeMarker.js.flow +0 -79
  248. package/util/DefaultHandleKey.js.flow +0 -17
  249. package/util/RelayCompilerCache.js.flow +0 -86
  250. package/util/Rollout.js.flow +0 -39
  251. package/util/TimeReporter.js.flow +0 -79
  252. package/util/areEqualArgValues.js.flow +0 -126
  253. package/util/argumentContainsVariables.js.flow +0 -38
  254. package/util/dedupeJSONStringify.js.flow +0 -156
  255. package/util/generateAbstractTypeRefinementKey.js.flow +0 -29
  256. package/util/getDefinitionNodeHash.js.flow +0 -24
  257. package/util/getModuleName.js.flow +0 -39
  258. package/util/joinArgumentDefinitions.js.flow +0 -105
  259. package/util/md5.js.flow +0 -19
  260. package/util/murmurHash.js.flow +0 -94
  261. package/util/nullthrowsOSS.js.flow +0 -25
  262. package/util/orList.js.flow +0 -37
  263. 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
- };
@@ -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
- };
@@ -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;