relay-compiler 0.0.0-main-8ff54d69 → 0.0.0-main-4467ae84

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