relay-compiler 11.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 -25
  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 -19007
  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 -571
  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 -21
  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 -481
  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 -221
  131. package/lib/transforms/ConnectionTransform.js +0 -639
  132. package/lib/transforms/DeclarativeConnectionMutationTransform.js +0 -218
  133. package/lib/transforms/DeferStreamTransform.js +0 -246
  134. package/lib/transforms/DisallowIdAsAlias.js +0 -40
  135. package/lib/transforms/DisallowTypenameOnRoot.js +0 -53
  136. package/lib/transforms/FieldHandleTransform.js +0 -79
  137. package/lib/transforms/FilterCompilerDirectivesTransform.js +0 -29
  138. package/lib/transforms/FilterDirectivesTransform.js +0 -41
  139. package/lib/transforms/FlattenTransform.js +0 -306
  140. package/lib/transforms/GenerateIDFieldTransform.js +0 -135
  141. package/lib/transforms/GenerateTypeNameTransform.js +0 -149
  142. package/lib/transforms/InlineDataFragmentTransform.js +0 -100
  143. package/lib/transforms/InlineFragmentsTransform.js +0 -61
  144. package/lib/transforms/MaskTransform.js +0 -117
  145. package/lib/transforms/MatchTransform.js +0 -434
  146. package/lib/transforms/ReactFlightComponentTransform.js +0 -158
  147. package/lib/transforms/RefetchableFragmentTransform.js +0 -249
  148. package/lib/transforms/RelayDirectiveTransform.js +0 -83
  149. package/lib/transforms/RequiredFieldTransform.js +0 -369
  150. package/lib/transforms/SkipClientExtensionsTransform.js +0 -46
  151. package/lib/transforms/SkipHandleFieldTransform.js +0 -44
  152. package/lib/transforms/SkipRedundantNodesTransform.js +0 -254
  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 -82
  157. package/lib/transforms/TestOperationTransform.js +0 -144
  158. package/lib/transforms/TransformUtils.js +0 -21
  159. package/lib/transforms/ValidateGlobalVariablesTransform.js +0 -91
  160. package/lib/transforms/ValidateRequiredArgumentsTransform.js +0 -114
  161. package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +0 -108
  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/areEqualOSS.js +0 -133
  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 -225
  205. package/transforms/ConnectionTransform.js.flow +0 -855
  206. package/transforms/DeclarativeConnectionMutationTransform.js.flow +0 -247
  207. package/transforms/DeferStreamTransform.js.flow +0 -265
  208. package/transforms/DisallowIdAsAlias.js.flow +0 -47
  209. package/transforms/DisallowTypenameOnRoot.js.flow +0 -45
  210. package/transforms/FieldHandleTransform.js.flow +0 -79
  211. package/transforms/FilterCompilerDirectivesTransform.js.flow +0 -33
  212. package/transforms/FilterDirectivesTransform.js.flow +0 -45
  213. package/transforms/FlattenTransform.js.flow +0 -457
  214. package/transforms/GenerateIDFieldTransform.js.flow +0 -152
  215. package/transforms/GenerateTypeNameTransform.js.flow +0 -161
  216. package/transforms/InlineDataFragmentTransform.js.flow +0 -125
  217. package/transforms/InlineFragmentsTransform.js.flow +0 -71
  218. package/transforms/MaskTransform.js.flow +0 -126
  219. package/transforms/MatchTransform.js.flow +0 -589
  220. package/transforms/ReactFlightComponentTransform.js.flow +0 -195
  221. package/transforms/RefetchableFragmentTransform.js.flow +0 -272
  222. package/transforms/RelayDirectiveTransform.js.flow +0 -97
  223. package/transforms/RequiredFieldTransform.js.flow +0 -415
  224. package/transforms/SkipClientExtensionsTransform.js.flow +0 -54
  225. package/transforms/SkipHandleFieldTransform.js.flow +0 -44
  226. package/transforms/SkipRedundantNodesTransform.js.flow +0 -258
  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 -98
  231. package/transforms/TestOperationTransform.js.flow +0 -142
  232. package/transforms/TransformUtils.js.flow +0 -26
  233. package/transforms/ValidateGlobalVariablesTransform.js.flow +0 -81
  234. package/transforms/ValidateRequiredArgumentsTransform.js.flow +0 -127
  235. package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +0 -112
  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/areEqualOSS.js.flow +0 -123
  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,258 +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
- const context: CompilerContext = this.getContext();
141
- return transformNode(context.getSchema(), node, new IMap()).node;
142
- }
143
-
144
- /**
145
- * The most straightforward approach would be two passes: one to record the
146
- * structure of the document, one to prune duplicates. This implementation uses
147
- * a single pass. Selections are sorted with fields first, "conditionals"
148
- * (inline fragments & conditions) last. This means that all fields that are
149
- * guaranteed to be fetched are encountered prior to any duplicates that may be
150
- * fetched within a conditional.
151
- *
152
- * Because selections fetched within a conditional are not guaranteed to be
153
- * fetched in the parent, a fork of the selection map is created when entering a
154
- * conditional. The sort ensures that guaranteed fields have already been seen
155
- * prior to the clone.
156
- */
157
- function transformNode<T: Node>(
158
- schema: Schema,
159
- node: T,
160
- selectionMap: SelectionMap,
161
- ): {
162
- selectionMap: SelectionMap,
163
- node: ?T,
164
- ...
165
- } {
166
- // This will optimize a traversal of the same subselections.
167
- // If it's the same node, and selectionMap is empty
168
- // result of transformNode has to be the same.
169
- const isEmptySelectionMap = selectionMap.size === 0;
170
- let result;
171
- if (isEmptySelectionMap) {
172
- // $FlowFixMe[escaped-generic]
173
- result = cache.get(node);
174
- if (result != null) {
175
- return result;
176
- }
177
- }
178
- const selections = [];
179
- sortSelections(node.selections).forEach(selection => {
180
- const identifier = getIdentifierForSelection(schema, selection);
181
- switch (selection.kind) {
182
- case 'ScalarField':
183
- case 'FragmentSpread': {
184
- if (!selectionMap.has(identifier)) {
185
- selections.push(selection);
186
- selectionMap = selectionMap.set(identifier, null);
187
- }
188
- break;
189
- }
190
- case 'Defer':
191
- case 'Stream':
192
- case 'ModuleImport':
193
- case 'ClientExtension':
194
- case 'InlineDataFragmentSpread':
195
- case 'LinkedField': {
196
- const transformed = transformNode(
197
- schema,
198
- selection,
199
- selectionMap.get(identifier) || new IMap(),
200
- );
201
- if (transformed.node) {
202
- selections.push(transformed.node);
203
- selectionMap = selectionMap.set(identifier, transformed.selectionMap);
204
- }
205
- break;
206
- }
207
- case 'InlineFragment':
208
- case 'Condition': {
209
- // Fork the selection map to prevent conditional selections from
210
- // affecting the outer "guaranteed" selections.
211
- const transformed = transformNode(
212
- schema,
213
- selection,
214
- selectionMap.get(identifier) || selectionMap,
215
- );
216
- if (transformed.node) {
217
- selections.push(transformed.node);
218
- selectionMap = selectionMap.set(identifier, transformed.selectionMap);
219
- }
220
- break;
221
- }
222
- default:
223
- (selection: empty);
224
- invariant(
225
- false,
226
- 'SkipRedundantNodesTransform: Unexpected node kind `%s`.',
227
- selection.kind,
228
- );
229
- }
230
- });
231
- const nextNode: any = selections.length ? {...node, selections} : null;
232
- result = {selectionMap, node: nextNode};
233
- if (isEmptySelectionMap) {
234
- // $FlowFixMe[escaped-generic]
235
- cache.set(node, result);
236
- }
237
- // $FlowFixMe[incompatible-return]
238
- return result;
239
- }
240
-
241
- /**
242
- * Sort inline fragments and conditions after other selections.
243
- */
244
- function sortSelections(
245
- selections: $ReadOnlyArray<Selection>,
246
- ): $ReadOnlyArray<Selection> {
247
- const isScalarOrLinkedField = selection =>
248
- selection.kind === 'ScalarField' || selection.kind === 'LinkedField';
249
- const [scalarsAndLinkedFields, rest] = partitionArray(
250
- selections,
251
- isScalarOrLinkedField,
252
- );
253
- return [...scalarsAndLinkedFields, ...rest];
254
- }
255
-
256
- module.exports = {
257
- transform: skipRedundantNodesTransform,
258
- };
@@ -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,98 +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
- return this.traverse(field, {
55
- parentType: field.type,
56
- splitOperations: state.splitOperations,
57
- });
58
- }
59
-
60
- function visitInlineFragment(
61
- fragment: InlineFragment,
62
- state: State,
63
- ): InlineFragment {
64
- return this.traverse(fragment, {
65
- parentType: fragment.typeCondition,
66
- splitOperations: state.splitOperations,
67
- });
68
- }
69
-
70
- function visitModuleImport(node: ModuleImport, state: State): ModuleImport {
71
- // It's possible for the same fragment to be selected in multiple usages
72
- // of @module: skip processing a node if its SplitOperation has already
73
- // been generated
74
- const normalizationName = getNormalizationOperationName(node.name);
75
- const createdSplitOperation = state.splitOperations.get(normalizationName);
76
- if (createdSplitOperation) {
77
- createdSplitOperation.parentSources.add(node.sourceDocument);
78
- return node;
79
- }
80
- const transformedNode = this.traverse(node, state);
81
- const splitOperation: SplitOperation = {
82
- kind: 'SplitOperation',
83
- name: normalizationName,
84
- selections: transformedNode.selections,
85
- loc: {kind: 'Derived', source: node.loc},
86
- parentSources: new Set([node.sourceDocument]),
87
- metadata: {
88
- derivedFrom: transformedNode.name,
89
- },
90
- type: state.parentType,
91
- };
92
- state.splitOperations.set(normalizationName, splitOperation);
93
- return transformedNode;
94
- }
95
-
96
- module.exports = {
97
- transform: splitMatchTransform,
98
- };