relay-compiler 0.0.0-main-8ff54d69 → 0.0.0-main-38f1c96e

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