@ardatan/relay-compiler 12.0.0

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 (256) hide show
  1. package/LICENSE +21 -0
  2. package/bin/RelayCompilerBin.js.flow +169 -0
  3. package/bin/RelayCompilerMain.js.flow +515 -0
  4. package/bin/__fixtures__/plugin-module.js.flow +17 -0
  5. package/bin/relay-compiler +19066 -0
  6. package/codegen/CodegenDirectory.js.flow +375 -0
  7. package/codegen/CodegenRunner.js.flow +432 -0
  8. package/codegen/CodegenTypes.js.flow +28 -0
  9. package/codegen/CodegenWatcher.js.flow +254 -0
  10. package/codegen/NormalizationCodeGenerator.js.flow +566 -0
  11. package/codegen/ReaderCodeGenerator.js.flow +512 -0
  12. package/codegen/RelayCodeGenerator.js.flow +85 -0
  13. package/codegen/RelayFileWriter.js.flow +367 -0
  14. package/codegen/SourceControl.js.flow +58 -0
  15. package/codegen/compileRelayArtifacts.js.flow +182 -0
  16. package/codegen/createPrintRequireModuleDependency.js.flow +19 -0
  17. package/codegen/sortObjectByKey.js.flow +25 -0
  18. package/codegen/writeRelayGeneratedFile.js.flow +239 -0
  19. package/core/ASTCache.js.flow +74 -0
  20. package/core/ASTConvert.js.flow +233 -0
  21. package/core/CompilerContext.js.flow +191 -0
  22. package/core/CompilerError.js.flow +255 -0
  23. package/core/DotGraphQLParser.js.flow +39 -0
  24. package/core/GraphQLCompilerProfiler.js.flow +341 -0
  25. package/core/GraphQLDerivedFromMetadata.js.flow +36 -0
  26. package/core/GraphQLWatchmanClient.js.flow +111 -0
  27. package/core/IR.js.flow +326 -0
  28. package/core/IRPrinter.js.flow +478 -0
  29. package/core/IRTransformer.js.flow +377 -0
  30. package/core/IRValidator.js.flow +260 -0
  31. package/core/IRVisitor.js.flow +150 -0
  32. package/core/JSModuleParser.js.flow +24 -0
  33. package/core/RelayCompilerScope.js.flow +199 -0
  34. package/core/RelayFindGraphQLTags.js.flow +119 -0
  35. package/core/RelayGraphQLEnumsGenerator.js.flow +55 -0
  36. package/core/RelayIRTransforms.js.flow +138 -0
  37. package/core/RelayParser.js.flow +1734 -0
  38. package/core/RelaySourceModuleParser.js.flow +135 -0
  39. package/core/Schema.js.flow +2037 -0
  40. package/core/SchemaUtils.js.flow +120 -0
  41. package/core/filterContextForNode.js.flow +50 -0
  42. package/core/getFieldDefinition.js.flow +156 -0
  43. package/core/getIdentifierForArgumentValue.js.flow +49 -0
  44. package/core/getIdentifierForSelection.js.flow +69 -0
  45. package/core/getLiteralArgumentValues.js.flow +32 -0
  46. package/core/getNormalizationOperationName.js.flow +19 -0
  47. package/core/inferRootArgumentDefinitions.js.flow +323 -0
  48. package/index.js +10 -0
  49. package/index.js.flow +200 -0
  50. package/language/RelayLanguagePluginInterface.js.flow +283 -0
  51. package/language/javascript/FindGraphQLTags.js.flow +137 -0
  52. package/language/javascript/RelayFlowBabelFactories.js.flow +176 -0
  53. package/language/javascript/RelayFlowGenerator.js.flow +1100 -0
  54. package/language/javascript/RelayFlowTypeTransformers.js.flow +184 -0
  55. package/language/javascript/RelayLanguagePluginJavaScript.js.flow +34 -0
  56. package/language/javascript/formatGeneratedModule.js.flow +65 -0
  57. package/lib/bin/RelayCompilerBin.js +143 -0
  58. package/lib/bin/RelayCompilerMain.js +486 -0
  59. package/lib/bin/__fixtures__/plugin-module.js +16 -0
  60. package/lib/codegen/CodegenDirectory.js +336 -0
  61. package/lib/codegen/CodegenRunner.js +433 -0
  62. package/lib/codegen/CodegenTypes.js +11 -0
  63. package/lib/codegen/CodegenWatcher.js +271 -0
  64. package/lib/codegen/NormalizationCodeGenerator.js +480 -0
  65. package/lib/codegen/ReaderCodeGenerator.js +472 -0
  66. package/lib/codegen/RelayCodeGenerator.js +68 -0
  67. package/lib/codegen/RelayFileWriter.js +270 -0
  68. package/lib/codegen/SourceControl.js +60 -0
  69. package/lib/codegen/compileRelayArtifacts.js +157 -0
  70. package/lib/codegen/createPrintRequireModuleDependency.js +19 -0
  71. package/lib/codegen/sortObjectByKey.js +41 -0
  72. package/lib/codegen/writeRelayGeneratedFile.js +208 -0
  73. package/lib/core/ASTCache.js +70 -0
  74. package/lib/core/ASTConvert.js +198 -0
  75. package/lib/core/CompilerContext.js +165 -0
  76. package/lib/core/CompilerError.js +251 -0
  77. package/lib/core/DotGraphQLParser.js +40 -0
  78. package/lib/core/GraphQLCompilerProfiler.js +299 -0
  79. package/lib/core/GraphQLDerivedFromMetadata.js +31 -0
  80. package/lib/core/GraphQLWatchmanClient.js +150 -0
  81. package/lib/core/IR.js +11 -0
  82. package/lib/core/IRPrinter.js +389 -0
  83. package/lib/core/IRTransformer.js +345 -0
  84. package/lib/core/IRValidator.js +226 -0
  85. package/lib/core/IRVisitor.js +45 -0
  86. package/lib/core/JSModuleParser.js +18 -0
  87. package/lib/core/RelayCompilerScope.js +149 -0
  88. package/lib/core/RelayFindGraphQLTags.js +79 -0
  89. package/lib/core/RelayGraphQLEnumsGenerator.js +50 -0
  90. package/lib/core/RelayIRTransforms.js +109 -0
  91. package/lib/core/RelayParser.js +1382 -0
  92. package/lib/core/RelaySourceModuleParser.js +104 -0
  93. package/lib/core/Schema.js +1877 -0
  94. package/lib/core/SchemaUtils.js +98 -0
  95. package/lib/core/filterContextForNode.js +49 -0
  96. package/lib/core/getFieldDefinition.js +145 -0
  97. package/lib/core/getIdentifierForArgumentValue.js +53 -0
  98. package/lib/core/getIdentifierForSelection.js +48 -0
  99. package/lib/core/getLiteralArgumentValues.js +26 -0
  100. package/lib/core/getNormalizationOperationName.js +17 -0
  101. package/lib/core/inferRootArgumentDefinitions.js +351 -0
  102. package/lib/index.js +178 -0
  103. package/lib/language/RelayLanguagePluginInterface.js +14 -0
  104. package/lib/language/javascript/FindGraphQLTags.js +126 -0
  105. package/lib/language/javascript/RelayFlowBabelFactories.js +160 -0
  106. package/lib/language/javascript/RelayFlowGenerator.js +857 -0
  107. package/lib/language/javascript/RelayFlowTypeTransformers.js +119 -0
  108. package/lib/language/javascript/RelayLanguagePluginJavaScript.js +30 -0
  109. package/lib/language/javascript/formatGeneratedModule.js +36 -0
  110. package/lib/reporters/ConsoleReporter.js +61 -0
  111. package/lib/reporters/MultiReporter.js +45 -0
  112. package/lib/reporters/Reporter.js +11 -0
  113. package/lib/runner/Artifacts.js +323 -0
  114. package/lib/runner/BufferedFilesystem.js +261 -0
  115. package/lib/runner/GraphQLASTNodeGroup.js +256 -0
  116. package/lib/runner/GraphQLASTUtils.js +23 -0
  117. package/lib/runner/GraphQLNodeMap.js +81 -0
  118. package/lib/runner/Sources.js +271 -0
  119. package/lib/runner/StrictMap.js +134 -0
  120. package/lib/runner/compileArtifacts.js +39 -0
  121. package/lib/runner/extractAST.js +77 -0
  122. package/lib/runner/getChangedNodeNames.js +82 -0
  123. package/lib/runner/getSchemaInstance.js +30 -0
  124. package/lib/runner/types.js +12 -0
  125. package/lib/transforms/ApplyFragmentArgumentTransform.js +393 -0
  126. package/lib/transforms/ClientExtensionsTransform.js +222 -0
  127. package/lib/transforms/ConnectionTransform.js +643 -0
  128. package/lib/transforms/DeclarativeConnectionMutationTransform.js +221 -0
  129. package/lib/transforms/DeferStreamTransform.js +247 -0
  130. package/lib/transforms/DisallowIdAsAlias.js +41 -0
  131. package/lib/transforms/DisallowTypenameOnRoot.js +53 -0
  132. package/lib/transforms/FieldHandleTransform.js +81 -0
  133. package/lib/transforms/FilterCompilerDirectivesTransform.js +29 -0
  134. package/lib/transforms/FilterDirectivesTransform.js +41 -0
  135. package/lib/transforms/FlattenTransform.js +308 -0
  136. package/lib/transforms/GenerateIDFieldTransform.js +137 -0
  137. package/lib/transforms/GenerateTypeNameTransform.js +155 -0
  138. package/lib/transforms/InlineDataFragmentTransform.js +104 -0
  139. package/lib/transforms/InlineFragmentsTransform.js +63 -0
  140. package/lib/transforms/MaskTransform.js +121 -0
  141. package/lib/transforms/MatchTransform.js +438 -0
  142. package/lib/transforms/ReactFlightComponentTransform.js +161 -0
  143. package/lib/transforms/RefetchableFragmentTransform.js +249 -0
  144. package/lib/transforms/RelayDirectiveTransform.js +85 -0
  145. package/lib/transforms/RequiredFieldTransform.js +373 -0
  146. package/lib/transforms/SkipClientExtensionsTransform.js +49 -0
  147. package/lib/transforms/SkipHandleFieldTransform.js +45 -0
  148. package/lib/transforms/SkipRedundantNodesTransform.js +255 -0
  149. package/lib/transforms/SkipSplitOperationTransform.js +32 -0
  150. package/lib/transforms/SkipUnreachableNodeTransform.js +158 -0
  151. package/lib/transforms/SkipUnusedVariablesTransform.js +74 -0
  152. package/lib/transforms/SplitModuleImportTransform.js +85 -0
  153. package/lib/transforms/TestOperationTransform.js +145 -0
  154. package/lib/transforms/TransformUtils.js +21 -0
  155. package/lib/transforms/ValidateGlobalVariablesTransform.js +91 -0
  156. package/lib/transforms/ValidateRequiredArgumentsTransform.js +118 -0
  157. package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +111 -0
  158. package/lib/transforms/ValidateUnusedVariablesTransform.js +96 -0
  159. package/lib/transforms/query-generators/FetchableQueryGenerator.js +157 -0
  160. package/lib/transforms/query-generators/NodeQueryGenerator.js +166 -0
  161. package/lib/transforms/query-generators/QueryQueryGenerator.js +48 -0
  162. package/lib/transforms/query-generators/ViewerQueryGenerator.js +77 -0
  163. package/lib/transforms/query-generators/index.js +60 -0
  164. package/lib/transforms/query-generators/utils.js +92 -0
  165. package/lib/util/CodeMarker.js +80 -0
  166. package/lib/util/DefaultHandleKey.js +15 -0
  167. package/lib/util/RelayCompilerCache.js +98 -0
  168. package/lib/util/Rollout.js +40 -0
  169. package/lib/util/TimeReporter.js +83 -0
  170. package/lib/util/areEqualArgValues.js +135 -0
  171. package/lib/util/argumentContainsVariables.js +37 -0
  172. package/lib/util/dedupeJSONStringify.js +160 -0
  173. package/lib/util/generateAbstractTypeRefinementKey.js +24 -0
  174. package/lib/util/getDefinitionNodeHash.js +22 -0
  175. package/lib/util/getModuleName.js +32 -0
  176. package/lib/util/joinArgumentDefinitions.js +66 -0
  177. package/lib/util/md5.js +17 -0
  178. package/lib/util/murmurHash.js +86 -0
  179. package/lib/util/nullthrowsOSS.js +23 -0
  180. package/lib/util/orList.js +36 -0
  181. package/lib/util/partitionArray.js +35 -0
  182. package/package.json +42 -0
  183. package/relay-compiler.js +17 -0
  184. package/relay-compiler.min.js +22 -0
  185. package/reporters/ConsoleReporter.js.flow +81 -0
  186. package/reporters/MultiReporter.js.flow +43 -0
  187. package/reporters/Reporter.js.flow +19 -0
  188. package/runner/Artifacts.js.flow +219 -0
  189. package/runner/BufferedFilesystem.js.flow +194 -0
  190. package/runner/GraphQLASTNodeGroup.js.flow +176 -0
  191. package/runner/GraphQLASTUtils.js.flow +26 -0
  192. package/runner/GraphQLNodeMap.js.flow +55 -0
  193. package/runner/Sources.js.flow +228 -0
  194. package/runner/StrictMap.js.flow +96 -0
  195. package/runner/compileArtifacts.js.flow +76 -0
  196. package/runner/extractAST.js.flow +100 -0
  197. package/runner/getChangedNodeNames.js.flow +48 -0
  198. package/runner/getSchemaInstance.js.flow +36 -0
  199. package/runner/types.js.flow +37 -0
  200. package/transforms/ApplyFragmentArgumentTransform.js.flow +526 -0
  201. package/transforms/ClientExtensionsTransform.js.flow +226 -0
  202. package/transforms/ConnectionTransform.js.flow +859 -0
  203. package/transforms/DeclarativeConnectionMutationTransform.js.flow +250 -0
  204. package/transforms/DeferStreamTransform.js.flow +266 -0
  205. package/transforms/DisallowIdAsAlias.js.flow +48 -0
  206. package/transforms/DisallowTypenameOnRoot.js.flow +45 -0
  207. package/transforms/FieldHandleTransform.js.flow +81 -0
  208. package/transforms/FilterCompilerDirectivesTransform.js.flow +33 -0
  209. package/transforms/FilterDirectivesTransform.js.flow +45 -0
  210. package/transforms/FlattenTransform.js.flow +462 -0
  211. package/transforms/GenerateIDFieldTransform.js.flow +154 -0
  212. package/transforms/GenerateTypeNameTransform.js.flow +167 -0
  213. package/transforms/InlineDataFragmentTransform.js.flow +129 -0
  214. package/transforms/InlineFragmentsTransform.js.flow +73 -0
  215. package/transforms/MaskTransform.js.flow +130 -0
  216. package/transforms/MatchTransform.js.flow +593 -0
  217. package/transforms/ReactFlightComponentTransform.js.flow +198 -0
  218. package/transforms/RefetchableFragmentTransform.js.flow +272 -0
  219. package/transforms/RelayDirectiveTransform.js.flow +99 -0
  220. package/transforms/RequiredFieldTransform.js.flow +419 -0
  221. package/transforms/SkipClientExtensionsTransform.js.flow +57 -0
  222. package/transforms/SkipHandleFieldTransform.js.flow +45 -0
  223. package/transforms/SkipRedundantNodesTransform.js.flow +259 -0
  224. package/transforms/SkipSplitOperationTransform.js.flow +37 -0
  225. package/transforms/SkipUnreachableNodeTransform.js.flow +149 -0
  226. package/transforms/SkipUnusedVariablesTransform.js.flow +59 -0
  227. package/transforms/SplitModuleImportTransform.js.flow +101 -0
  228. package/transforms/TestOperationTransform.js.flow +143 -0
  229. package/transforms/TransformUtils.js.flow +26 -0
  230. package/transforms/ValidateGlobalVariablesTransform.js.flow +81 -0
  231. package/transforms/ValidateRequiredArgumentsTransform.js.flow +131 -0
  232. package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +115 -0
  233. package/transforms/ValidateUnusedVariablesTransform.js.flow +89 -0
  234. package/transforms/query-generators/FetchableQueryGenerator.js.flow +189 -0
  235. package/transforms/query-generators/NodeQueryGenerator.js.flow +219 -0
  236. package/transforms/query-generators/QueryQueryGenerator.js.flow +57 -0
  237. package/transforms/query-generators/ViewerQueryGenerator.js.flow +97 -0
  238. package/transforms/query-generators/index.js.flow +90 -0
  239. package/transforms/query-generators/utils.js.flow +76 -0
  240. package/util/CodeMarker.js.flow +79 -0
  241. package/util/DefaultHandleKey.js.flow +17 -0
  242. package/util/RelayCompilerCache.js.flow +88 -0
  243. package/util/Rollout.js.flow +39 -0
  244. package/util/TimeReporter.js.flow +79 -0
  245. package/util/areEqualArgValues.js.flow +126 -0
  246. package/util/argumentContainsVariables.js.flow +38 -0
  247. package/util/dedupeJSONStringify.js.flow +152 -0
  248. package/util/generateAbstractTypeRefinementKey.js.flow +29 -0
  249. package/util/getDefinitionNodeHash.js.flow +25 -0
  250. package/util/getModuleName.js.flow +39 -0
  251. package/util/joinArgumentDefinitions.js.flow +105 -0
  252. package/util/md5.js.flow +22 -0
  253. package/util/murmurHash.js.flow +94 -0
  254. package/util/nullthrowsOSS.js.flow +25 -0
  255. package/util/orList.js.flow +37 -0
  256. package/util/partitionArray.js.flow +37 -0
@@ -0,0 +1,255 @@
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 _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
18
+
19
+ var IRTransformer = require('../core/IRTransformer');
20
+
21
+ var IMap = require('immutable').Map;
22
+
23
+ var partitionArray = require('../util/partitionArray');
24
+
25
+ var getIdentifierForSelection = require('../core/getIdentifierForSelection');
26
+
27
+ var invariant = require('invariant');
28
+
29
+ /**
30
+ * A transform that removes redundant fields and fragment spreads. Redundancy is
31
+ * defined in this context as any selection that is guaranteed to already be
32
+ * fetched by an ancestor selection. This can occur in two cases:
33
+ *
34
+ * 1. Simple duplicates at the same level of the document can always be skipped:
35
+ *
36
+ * ```
37
+ * fragment Foo on FooType {
38
+ * id
39
+ * id
40
+ * ...Bar
41
+ * ...Bar
42
+ * }
43
+ * ```
44
+ *
45
+ * Becomes
46
+ *
47
+ * ```
48
+ * fragment Foo on FooType {
49
+ * id
50
+ * ...Bar
51
+ * }
52
+ * ```
53
+ *
54
+ * 2. Inline fragments and conditions introduce the possibility for duplication
55
+ * at different levels of the tree. Whenever a selection is fetched in a parent,
56
+ * it is redundant to also fetch it in a child:
57
+ *
58
+ * ```
59
+ * fragment Foo on FooType {
60
+ * id
61
+ * ... on OtherType {
62
+ * id # 1
63
+ * }
64
+ * ... on FooType @include(if: $cond) {
65
+ * id # 2
66
+ * }
67
+ * }
68
+ * ```
69
+ *
70
+ * Becomes:
71
+ *
72
+ * ```
73
+ * fragment Foo on FooType {
74
+ * id
75
+ * }
76
+ * ```
77
+ *
78
+ * In this example:
79
+ * - 1 can be skipped because `id` is already fetched by the parent. Even
80
+ * though the type is different (FooType/OtherType), the inline fragment
81
+ * cannot match without the outer fragment matching so the outer `id` is
82
+ * guaranteed to already be fetched.
83
+ * - 2 can be skipped for similar reasons: it doesn't matter if the condition
84
+ * holds, `id` is already fetched by the parent regardless.
85
+ *
86
+ * This transform also handles more complicated cases in which selections are
87
+ * nested:
88
+ *
89
+ * ```
90
+ * fragment Foo on FooType {
91
+ * a {
92
+ * bb
93
+ * }
94
+ * ... on OtherType {
95
+ * a {
96
+ * bb # 1
97
+ * cc
98
+ * }
99
+ * }
100
+ * }
101
+ * ```
102
+ *
103
+ * Becomes
104
+ *
105
+ * ```
106
+ * fragment Foo on FooType {
107
+ * a {
108
+ * bb
109
+ * }
110
+ * ... on OtherType {
111
+ * a {
112
+ * cc
113
+ * }
114
+ * }
115
+ * }
116
+ * ```
117
+ *
118
+ * 1 can be skipped because it is already fetched at the outer level.
119
+ */
120
+ function skipRedundantNodesTransform(context) {
121
+ return IRTransformer.transform(context, {
122
+ Root: visitNode,
123
+ SplitOperation: visitNode,
124
+ Fragment: visitNode
125
+ });
126
+ }
127
+
128
+ var cache = new Map();
129
+
130
+ function visitNode(node) {
131
+ cache = new Map(); // $FlowFixMe[incompatible-use]
132
+
133
+ var context = this.getContext();
134
+ return transformNode(context.getSchema(), node, new IMap()).node;
135
+ }
136
+ /**
137
+ * The most straightforward approach would be two passes: one to record the
138
+ * structure of the document, one to prune duplicates. This implementation uses
139
+ * a single pass. Selections are sorted with fields first, "conditionals"
140
+ * (inline fragments & conditions) last. This means that all fields that are
141
+ * guaranteed to be fetched are encountered prior to any duplicates that may be
142
+ * fetched within a conditional.
143
+ *
144
+ * Because selections fetched within a conditional are not guaranteed to be
145
+ * fetched in the parent, a fork of the selection map is created when entering a
146
+ * conditional. The sort ensures that guaranteed fields have already been seen
147
+ * prior to the clone.
148
+ */
149
+
150
+
151
+ function transformNode(schema, node, selectionMap) {
152
+ // This will optimize a traversal of the same subselections.
153
+ // If it's the same node, and selectionMap is empty
154
+ // result of transformNode has to be the same.
155
+ var isEmptySelectionMap = selectionMap.size === 0;
156
+ var result;
157
+
158
+ if (isEmptySelectionMap) {
159
+ // $FlowFixMe[escaped-generic]
160
+ result = cache.get(node);
161
+
162
+ if (result != null) {
163
+ return result;
164
+ }
165
+ }
166
+
167
+ var selections = [];
168
+ sortSelections(node.selections).forEach(function (selection) {
169
+ var identifier = getIdentifierForSelection(schema, selection);
170
+
171
+ switch (selection.kind) {
172
+ case 'ScalarField':
173
+ case 'FragmentSpread':
174
+ {
175
+ if (!selectionMap.has(identifier)) {
176
+ selections.push(selection);
177
+ selectionMap = selectionMap.set(identifier, null);
178
+ }
179
+
180
+ break;
181
+ }
182
+
183
+ case 'Defer':
184
+ case 'Stream':
185
+ case 'ModuleImport':
186
+ case 'ClientExtension':
187
+ case 'InlineDataFragmentSpread':
188
+ case 'LinkedField':
189
+ {
190
+ var transformed = transformNode(schema, selection, selectionMap.get(identifier) || new IMap());
191
+
192
+ if (transformed.node) {
193
+ selections.push(transformed.node);
194
+ selectionMap = selectionMap.set(identifier, transformed.selectionMap);
195
+ }
196
+
197
+ break;
198
+ }
199
+
200
+ case 'InlineFragment':
201
+ case 'Condition':
202
+ {
203
+ // Fork the selection map to prevent conditional selections from
204
+ // affecting the outer "guaranteed" selections.
205
+ var _transformed = transformNode(schema, selection, selectionMap.get(identifier) || selectionMap);
206
+
207
+ if (_transformed.node) {
208
+ selections.push(_transformed.node);
209
+ selectionMap = selectionMap.set(identifier, _transformed.selectionMap);
210
+ }
211
+
212
+ break;
213
+ }
214
+
215
+ default:
216
+ selection;
217
+ !false ? process.env.NODE_ENV !== "production" ? invariant(false, 'SkipRedundantNodesTransform: Unexpected node kind `%s`.', selection.kind) : invariant(false) : void 0;
218
+ }
219
+ });
220
+ var nextNode = selections.length ? (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, node), {}, {
221
+ selections: selections
222
+ }) : null;
223
+ result = {
224
+ selectionMap: selectionMap,
225
+ node: nextNode
226
+ };
227
+
228
+ if (isEmptySelectionMap) {
229
+ // $FlowFixMe[escaped-generic]
230
+ cache.set(node, result);
231
+ } // $FlowFixMe[incompatible-return]
232
+
233
+
234
+ return result;
235
+ }
236
+ /**
237
+ * Sort inline fragments and conditions after other selections.
238
+ */
239
+
240
+
241
+ function sortSelections(selections) {
242
+ var isScalarOrLinkedField = function isScalarOrLinkedField(selection) {
243
+ return selection.kind === 'ScalarField' || selection.kind === 'LinkedField';
244
+ };
245
+
246
+ var _partitionArray = partitionArray(selections, isScalarOrLinkedField),
247
+ scalarsAndLinkedFields = _partitionArray[0],
248
+ rest = _partitionArray[1];
249
+
250
+ return [].concat((0, _toConsumableArray2["default"])(scalarsAndLinkedFields), (0, _toConsumableArray2["default"])(rest));
251
+ }
252
+
253
+ module.exports = {
254
+ transform: skipRedundantNodesTransform
255
+ };
@@ -0,0 +1,32 @@
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
+ function skipNode() {
16
+ return null;
17
+ }
18
+ /**
19
+ * A transform that removes field `splitOperations`. Intended for use when e.g.
20
+ * printing queries to send to a GraphQL server.
21
+ */
22
+
23
+
24
+ function skipSplitOperationTransform(context) {
25
+ return IRTransformer.transform(context, {
26
+ SplitOperation: skipNode
27
+ });
28
+ }
29
+
30
+ module.exports = {
31
+ transform: skipSplitOperationTransform
32
+ };
@@ -0,0 +1,158 @@
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 _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
18
+
19
+ var IRTransformer = require('../core/IRTransformer');
20
+
21
+ var invariant = require('invariant');
22
+
23
+ var FAIL = 'fail';
24
+ var PASS = 'pass';
25
+ var VARIABLE = 'variable';
26
+ /**
27
+ * A tranform that removes unreachable IR nodes from all documents in a corpus.
28
+ * The following nodes are removed:
29
+ * - Any node with `@include(if: false)`
30
+ * - Any node with `@skip(if: true)`
31
+ * - Any node with empty `selections`
32
+ */
33
+
34
+ function skipUnreachableNodeTransform(context) {
35
+ var fragments = new Map();
36
+ var nextContext = IRTransformer.transform(context, {
37
+ Root: function Root(node) {
38
+ return transformNode(context, fragments, node);
39
+ },
40
+ SplitOperation: function SplitOperation(node) {
41
+ return transformNode(context, fragments, node);
42
+ },
43
+ // Fragments are included below where referenced.
44
+ // Unreferenced fragments are not included.
45
+ Fragment: function Fragment(id) {
46
+ return null;
47
+ }
48
+ });
49
+ return Array.from(fragments.values()).reduce(function (ctx, fragment) {
50
+ return fragment ? ctx.add(fragment) : ctx;
51
+ }, nextContext);
52
+ }
53
+
54
+ function transformNode(context, fragments, node) {
55
+ var queue = (0, _toConsumableArray2["default"])(node.selections);
56
+ var selections;
57
+
58
+ while (queue.length) {
59
+ var selection = queue.shift();
60
+ var nextSelection = void 0;
61
+
62
+ switch (selection.kind) {
63
+ case 'Condition':
64
+ var match = testCondition(selection);
65
+
66
+ if (match === PASS) {
67
+ queue.unshift.apply(queue, (0, _toConsumableArray2["default"])(selection.selections));
68
+ } else if (match === VARIABLE) {
69
+ nextSelection = transformNode(context, fragments, selection);
70
+ }
71
+
72
+ break;
73
+
74
+ case 'FragmentSpread':
75
+ {
76
+ // Skip fragment spreads if the referenced fragment is empty
77
+ if (!fragments.has(selection.name)) {
78
+ var fragment = context.getFragment(selection.name);
79
+ var nextFragment = transformNode(context, fragments, fragment);
80
+ fragments.set(selection.name, nextFragment);
81
+ }
82
+
83
+ if (fragments.get(selection.name)) {
84
+ nextSelection = selection;
85
+ }
86
+
87
+ break;
88
+ }
89
+
90
+ case 'ClientExtension':
91
+ nextSelection = transformNode(context, fragments, selection);
92
+ break;
93
+
94
+ case 'ModuleImport':
95
+ nextSelection = transformNode(context, fragments, selection);
96
+ break;
97
+
98
+ case 'LinkedField':
99
+ nextSelection = transformNode(context, fragments, selection);
100
+ break;
101
+
102
+ case 'InlineFragment':
103
+ // TODO combine with the LinkedField case when flow supports this
104
+ nextSelection = transformNode(context, fragments, selection);
105
+ break;
106
+
107
+ case 'Defer':
108
+ nextSelection = transformNode(context, fragments, selection);
109
+ break;
110
+
111
+ case 'Stream':
112
+ nextSelection = transformNode(context, fragments, selection);
113
+ break;
114
+
115
+ case 'ScalarField':
116
+ nextSelection = selection;
117
+ break;
118
+
119
+ case 'InlineDataFragmentSpread':
120
+ !false ? process.env.NODE_ENV !== "production" ? invariant(false, 'SkipUnreachableNodeTransform: Did not expect an ' + 'InlineDataFragmentSpread here. Only expecting ' + 'InlineDataFragmentSpread in reader ASTs and this transform to ' + 'run only on normalization ASTs.') : invariant(false) : void 0;
121
+ // fallthrough
122
+
123
+ default:
124
+ selection.kind;
125
+ !false ? process.env.NODE_ENV !== "production" ? invariant(false, 'SkipUnreachableNodeTransform: Unexpected selection kind `%s`.', selection.kind) : invariant(false) : void 0;
126
+ }
127
+
128
+ if (nextSelection) {
129
+ selections = selections || [];
130
+ selections.push(nextSelection);
131
+ }
132
+ }
133
+
134
+ if (selections) {
135
+ return (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, node), {}, {
136
+ selections: selections
137
+ });
138
+ }
139
+
140
+ return null;
141
+ }
142
+ /**
143
+ * Determines whether a condition statically passes/fails or is unknown
144
+ * (variable).
145
+ */
146
+
147
+
148
+ function testCondition(condition) {
149
+ if (condition.condition.kind === 'Variable') {
150
+ return VARIABLE;
151
+ }
152
+
153
+ return condition.condition.value === condition.passingValue ? PASS : FAIL;
154
+ }
155
+
156
+ module.exports = {
157
+ transform: skipUnreachableNodeTransform
158
+ };
@@ -0,0 +1,74 @@
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 _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/createForOfIteratorHelper"));
18
+
19
+ var inferRootArgumentDefinitions = require('../core/inferRootArgumentDefinitions');
20
+
21
+ /**
22
+ * Refines the argument definitions for operations to remove unused arguments
23
+ * due to statically pruned conditional branches (e.g. because of overriding
24
+ * a variable used in `@include()` to be false).
25
+ */
26
+ function skipUnusedVariablesTransform(context) {
27
+ var contextWithUsedArguments = inferRootArgumentDefinitions(context);
28
+ return context.withMutations(function (ctx) {
29
+ var nextContext = ctx;
30
+
31
+ var _iterator = (0, _createForOfIteratorHelper2["default"])(nextContext.documents()),
32
+ _step;
33
+
34
+ try {
35
+ var _loop = function _loop() {
36
+ var node = _step.value;
37
+
38
+ if (node.kind !== 'Root') {
39
+ return "continue";
40
+ }
41
+
42
+ var usedArguments = new Set(contextWithUsedArguments.getRoot(node.name).argumentDefinitions.map(function (argDef) {
43
+ return argDef.name;
44
+ })); // Remove unused argument definitions
45
+
46
+ var usedArgumentDefinitions = node.argumentDefinitions.filter(function (argDef) {
47
+ return usedArguments.has(argDef.name);
48
+ });
49
+
50
+ if (usedArgumentDefinitions.length !== node.argumentDefinitions.length) {
51
+ nextContext = nextContext.replace((0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, node), {}, {
52
+ argumentDefinitions: usedArgumentDefinitions
53
+ }));
54
+ }
55
+ };
56
+
57
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
58
+ var _ret = _loop();
59
+
60
+ if (_ret === "continue") continue;
61
+ }
62
+ } catch (err) {
63
+ _iterator.e(err);
64
+ } finally {
65
+ _iterator.f();
66
+ }
67
+
68
+ return nextContext;
69
+ });
70
+ }
71
+
72
+ module.exports = {
73
+ transform: skipUnusedVariablesTransform
74
+ };
@@ -0,0 +1,85 @@
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 getNormalizationOperationName = require('../core/getNormalizationOperationName');
16
+
17
+ /**
18
+ * This transform creates a SplitOperation root for every ModuleImport.
19
+ */
20
+ function splitMatchTransform(context) {
21
+ var splitOperations = new Map();
22
+ var transformedContext = IRTransformer.transform(context, {
23
+ LinkedField: visitLinkedField,
24
+ InlineFragment: visitInlineFragment,
25
+ ModuleImport: visitModuleImport
26
+ }, function (node) {
27
+ return {
28
+ parentType: node.type,
29
+ splitOperations: splitOperations
30
+ };
31
+ });
32
+ return transformedContext.addAll(Array.from(splitOperations.values()));
33
+ }
34
+
35
+ function visitLinkedField(field, state) {
36
+ // $FlowFixMe[incompatible-use]
37
+ return this.traverse(field, {
38
+ parentType: field.type,
39
+ splitOperations: state.splitOperations
40
+ });
41
+ }
42
+
43
+ function visitInlineFragment(fragment, state) {
44
+ // $FlowFixMe[incompatible-use]
45
+ return this.traverse(fragment, {
46
+ parentType: fragment.typeCondition,
47
+ splitOperations: state.splitOperations
48
+ });
49
+ }
50
+
51
+ function visitModuleImport(node, state) {
52
+ // It's possible for the same fragment to be selected in multiple usages
53
+ // of @module: skip processing a node if its SplitOperation has already
54
+ // been generated
55
+ var normalizationName = getNormalizationOperationName(node.name);
56
+ var createdSplitOperation = state.splitOperations.get(normalizationName);
57
+
58
+ if (createdSplitOperation) {
59
+ createdSplitOperation.parentSources.add(node.sourceDocument);
60
+ return node;
61
+ } // $FlowFixMe[incompatible-use]
62
+
63
+
64
+ var transformedNode = this.traverse(node, state);
65
+ var splitOperation = {
66
+ kind: 'SplitOperation',
67
+ name: normalizationName,
68
+ selections: transformedNode.selections,
69
+ loc: {
70
+ kind: 'Derived',
71
+ source: node.loc
72
+ },
73
+ parentSources: new Set([node.sourceDocument]),
74
+ metadata: {
75
+ derivedFrom: transformedNode.name
76
+ },
77
+ type: state.parentType
78
+ };
79
+ state.splitOperations.set(normalizationName, splitOperation);
80
+ return transformedNode;
81
+ }
82
+
83
+ module.exports = {
84
+ transform: splitMatchTransform
85
+ };