relay-compiler 11.0.2 → 13.0.0-rc.2

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