relay-compiler 12.0.0 → 13.0.0-rc.0

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