relay-compiler 0.0.0-main-bfcb5c59 → 0.0.0-main-4467ae84

Sign up to get free protection for your applications and to get access to all the features.
Files changed (259) hide show
  1. package/cli.js +23 -0
  2. package/index.js +19 -3
  3. package/linux-x64/relay +0 -0
  4. package/macos-x64/relay +0 -0
  5. package/package.json +2 -26
  6. package/win-x64/relay.exe +0 -0
  7. package/bin/RelayCompilerBin.js.flow +0 -168
  8. package/bin/RelayCompilerMain.js.flow +0 -513
  9. package/bin/__fixtures__/plugin-module.js.flow +0 -17
  10. package/bin/relay-compiler +0 -19066
  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 -565
  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 -1731
  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 -486
  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/transforms/ApplyFragmentArgumentTransform.js +0 -393
  130. package/lib/transforms/ClientExtensionsTransform.js +0 -221
  131. package/lib/transforms/ConnectionTransform.js +0 -639
  132. package/lib/transforms/DeclarativeConnectionMutationTransform.js +0 -218
  133. package/lib/transforms/DeferStreamTransform.js +0 -246
  134. package/lib/transforms/DisallowIdAsAlias.js +0 -40
  135. package/lib/transforms/DisallowTypenameOnRoot.js +0 -53
  136. package/lib/transforms/FieldHandleTransform.js +0 -79
  137. package/lib/transforms/FilterCompilerDirectivesTransform.js +0 -29
  138. package/lib/transforms/FilterDirectivesTransform.js +0 -42
  139. package/lib/transforms/FlattenTransform.js +0 -306
  140. package/lib/transforms/GenerateIDFieldTransform.js +0 -135
  141. package/lib/transforms/GenerateTypeNameTransform.js +0 -149
  142. package/lib/transforms/InlineDataFragmentTransform.js +0 -100
  143. package/lib/transforms/InlineFragmentsTransform.js +0 -61
  144. package/lib/transforms/MaskTransform.js +0 -117
  145. package/lib/transforms/MatchTransform.js +0 -434
  146. package/lib/transforms/ReactFlightComponentTransform.js +0 -158
  147. package/lib/transforms/RefetchableFragmentTransform.js +0 -249
  148. package/lib/transforms/RelayDirectiveTransform.js +0 -83
  149. package/lib/transforms/RequiredFieldTransform.js +0 -369
  150. package/lib/transforms/SkipClientExtensionsTransform.js +0 -46
  151. package/lib/transforms/SkipHandleFieldTransform.js +0 -45
  152. package/lib/transforms/SkipRedundantNodesTransform.js +0 -261
  153. package/lib/transforms/SkipSplitOperationTransform.js +0 -32
  154. package/lib/transforms/SkipUnreachableNodeTransform.js +0 -158
  155. package/lib/transforms/SkipUnusedVariablesTransform.js +0 -75
  156. package/lib/transforms/SplitModuleImportTransform.js +0 -82
  157. package/lib/transforms/TestOperationTransform.js +0 -144
  158. package/lib/transforms/TransformUtils.js +0 -21
  159. package/lib/transforms/ValidateGlobalVariablesTransform.js +0 -92
  160. package/lib/transforms/ValidateRequiredArgumentsTransform.js +0 -114
  161. package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +0 -108
  162. package/lib/transforms/ValidateUnusedVariablesTransform.js +0 -96
  163. package/lib/transforms/query-generators/FetchableQueryGenerator.js +0 -157
  164. package/lib/transforms/query-generators/NodeQueryGenerator.js +0 -166
  165. package/lib/transforms/query-generators/QueryQueryGenerator.js +0 -48
  166. package/lib/transforms/query-generators/ViewerQueryGenerator.js +0 -77
  167. package/lib/transforms/query-generators/index.js +0 -60
  168. package/lib/transforms/query-generators/utils.js +0 -92
  169. package/lib/util/CodeMarker.js +0 -80
  170. package/lib/util/DefaultHandleKey.js +0 -15
  171. package/lib/util/RelayCompilerCache.js +0 -97
  172. package/lib/util/Rollout.js +0 -40
  173. package/lib/util/TimeReporter.js +0 -83
  174. package/lib/util/areEqualArgValues.js +0 -135
  175. package/lib/util/argumentContainsVariables.js +0 -37
  176. package/lib/util/dedupeJSONStringify.js +0 -160
  177. package/lib/util/generateAbstractTypeRefinementKey.js +0 -24
  178. package/lib/util/getDefinitionNodeHash.js +0 -22
  179. package/lib/util/getModuleName.js +0 -32
  180. package/lib/util/joinArgumentDefinitions.js +0 -67
  181. package/lib/util/md5.js +0 -17
  182. package/lib/util/murmurHash.js +0 -86
  183. package/lib/util/nullthrowsOSS.js +0 -23
  184. package/lib/util/orList.js +0 -36
  185. package/lib/util/partitionArray.js +0 -35
  186. package/relay-compiler.js +0 -17
  187. package/relay-compiler.min.js +0 -22
  188. package/reporters/ConsoleReporter.js.flow +0 -81
  189. package/reporters/MultiReporter.js.flow +0 -43
  190. package/reporters/Reporter.js.flow +0 -19
  191. package/runner/Artifacts.js.flow +0 -215
  192. package/runner/BufferedFilesystem.js.flow +0 -194
  193. package/runner/GraphQLASTNodeGroup.js.flow +0 -174
  194. package/runner/GraphQLASTUtils.js.flow +0 -26
  195. package/runner/GraphQLNodeMap.js.flow +0 -55
  196. package/runner/Sources.js.flow +0 -227
  197. package/runner/StrictMap.js.flow +0 -96
  198. package/runner/compileArtifacts.js.flow +0 -75
  199. package/runner/extractAST.js.flow +0 -98
  200. package/runner/getChangedNodeNames.js.flow +0 -48
  201. package/runner/getSchemaInstance.js.flow +0 -36
  202. package/runner/types.js.flow +0 -37
  203. package/transforms/ApplyFragmentArgumentTransform.js.flow +0 -524
  204. package/transforms/ClientExtensionsTransform.js.flow +0 -224
  205. package/transforms/ConnectionTransform.js.flow +0 -850
  206. package/transforms/DeclarativeConnectionMutationTransform.js.flow +0 -245
  207. package/transforms/DeferStreamTransform.js.flow +0 -263
  208. package/transforms/DisallowIdAsAlias.js.flow +0 -46
  209. package/transforms/DisallowTypenameOnRoot.js.flow +0 -44
  210. package/transforms/FieldHandleTransform.js.flow +0 -77
  211. package/transforms/FilterCompilerDirectivesTransform.js.flow +0 -33
  212. package/transforms/FilterDirectivesTransform.js.flow +0 -45
  213. package/transforms/FlattenTransform.js.flow +0 -458
  214. package/transforms/GenerateIDFieldTransform.js.flow +0 -151
  215. package/transforms/GenerateTypeNameTransform.js.flow +0 -159
  216. package/transforms/InlineDataFragmentTransform.js.flow +0 -123
  217. package/transforms/InlineFragmentsTransform.js.flow +0 -70
  218. package/transforms/MaskTransform.js.flow +0 -124
  219. package/transforms/MatchTransform.js.flow +0 -587
  220. package/transforms/ReactFlightComponentTransform.js.flow +0 -194
  221. package/transforms/RefetchableFragmentTransform.js.flow +0 -266
  222. package/transforms/RelayDirectiveTransform.js.flow +0 -96
  223. package/transforms/RequiredFieldTransform.js.flow +0 -413
  224. package/transforms/SkipClientExtensionsTransform.js.flow +0 -54
  225. package/transforms/SkipHandleFieldTransform.js.flow +0 -44
  226. package/transforms/SkipRedundantNodesTransform.js.flow +0 -255
  227. package/transforms/SkipSplitOperationTransform.js.flow +0 -37
  228. package/transforms/SkipUnreachableNodeTransform.js.flow +0 -148
  229. package/transforms/SkipUnusedVariablesTransform.js.flow +0 -59
  230. package/transforms/SplitModuleImportTransform.js.flow +0 -97
  231. package/transforms/TestOperationTransform.js.flow +0 -142
  232. package/transforms/TransformUtils.js.flow +0 -26
  233. package/transforms/ValidateGlobalVariablesTransform.js.flow +0 -80
  234. package/transforms/ValidateRequiredArgumentsTransform.js.flow +0 -126
  235. package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +0 -111
  236. package/transforms/ValidateUnusedVariablesTransform.js.flow +0 -88
  237. package/transforms/query-generators/FetchableQueryGenerator.js.flow +0 -188
  238. package/transforms/query-generators/NodeQueryGenerator.js.flow +0 -217
  239. package/transforms/query-generators/QueryQueryGenerator.js.flow +0 -57
  240. package/transforms/query-generators/ViewerQueryGenerator.js.flow +0 -97
  241. package/transforms/query-generators/index.js.flow +0 -89
  242. package/transforms/query-generators/utils.js.flow +0 -76
  243. package/util/CodeMarker.js.flow +0 -79
  244. package/util/DefaultHandleKey.js.flow +0 -17
  245. package/util/RelayCompilerCache.js.flow +0 -86
  246. package/util/Rollout.js.flow +0 -39
  247. package/util/TimeReporter.js.flow +0 -79
  248. package/util/areEqualArgValues.js.flow +0 -126
  249. package/util/argumentContainsVariables.js.flow +0 -38
  250. package/util/dedupeJSONStringify.js.flow +0 -152
  251. package/util/generateAbstractTypeRefinementKey.js.flow +0 -29
  252. package/util/getDefinitionNodeHash.js.flow +0 -24
  253. package/util/getModuleName.js.flow +0 -39
  254. package/util/joinArgumentDefinitions.js.flow +0 -105
  255. package/util/md5.js.flow +0 -19
  256. package/util/murmurHash.js.flow +0 -94
  257. package/util/nullthrowsOSS.js.flow +0 -25
  258. package/util/orList.js.flow +0 -37
  259. package/util/partitionArray.js.flow +0 -37
@@ -1,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,45 +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
- * A transform that removes field `handles`. Intended for use when e.g.
20
- * printing queries to send to a GraphQL server.
21
- */
22
-
23
-
24
- function skipHandleFieldTransform(context) {
25
- return IRTransformer.transform(context, {
26
- LinkedField: visitField,
27
- ScalarField: visitField
28
- });
29
- }
30
-
31
- function visitField(field) {
32
- var transformedNode = this.traverse(field);
33
-
34
- if (transformedNode.handles) {
35
- return (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, transformedNode), {}, {
36
- handles: null
37
- });
38
- }
39
-
40
- return transformedNode;
41
- }
42
-
43
- module.exports = {
44
- transform: skipHandleFieldTransform
45
- };
@@ -1,261 +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 getIdentifierForSelection = require('../core/getIdentifierForSelection');
20
-
21
- var IRTransformer = require('../core/IRTransformer');
22
-
23
- var partitionArray = require('../util/partitionArray');
24
-
25
- var IMap = require('immutable').Map;
26
-
27
- var invariant = require('invariant');
28
- /**
29
- * A simplified representation of a document: keys in the map are unique
30
- * identifiers for the selections of a node, values are either null (for scalars)
31
- * or nested maps for items with subselections (linked fields, inline fragments,
32
- * etc).
33
- */
34
- // $FlowFixMe[value-as-type]
35
-
36
-
37
- /**
38
- * A transform that removes redundant fields and fragment spreads. Redundancy is
39
- * defined in this context as any selection that is guaranteed to already be
40
- * fetched by an ancestor selection. This can occur in two cases:
41
- *
42
- * 1. Simple duplicates at the same level of the document can always be skipped:
43
- *
44
- * ```
45
- * fragment Foo on FooType {
46
- * id
47
- * id
48
- * ...Bar
49
- * ...Bar
50
- * }
51
- * ```
52
- *
53
- * Becomes
54
- *
55
- * ```
56
- * fragment Foo on FooType {
57
- * id
58
- * ...Bar
59
- * }
60
- * ```
61
- *
62
- * 2. Inline fragments and conditions introduce the possibility for duplication
63
- * at different levels of the tree. Whenever a selection is fetched in a parent,
64
- * it is redundant to also fetch it in a child:
65
- *
66
- * ```
67
- * fragment Foo on FooType {
68
- * id
69
- * ... on OtherType {
70
- * id # 1
71
- * }
72
- * ... on FooType @include(if: $cond) {
73
- * id # 2
74
- * }
75
- * }
76
- * ```
77
- *
78
- * Becomes:
79
- *
80
- * ```
81
- * fragment Foo on FooType {
82
- * id
83
- * }
84
- * ```
85
- *
86
- * In this example:
87
- * - 1 can be skipped because `id` is already fetched by the parent. Even
88
- * though the type is different (FooType/OtherType), the inline fragment
89
- * cannot match without the outer fragment matching so the outer `id` is
90
- * guaranteed to already be fetched.
91
- * - 2 can be skipped for similar reasons: it doesn't matter if the condition
92
- * holds, `id` is already fetched by the parent regardless.
93
- *
94
- * This transform also handles more complicated cases in which selections are
95
- * nested:
96
- *
97
- * ```
98
- * fragment Foo on FooType {
99
- * a {
100
- * bb
101
- * }
102
- * ... on OtherType {
103
- * a {
104
- * bb # 1
105
- * cc
106
- * }
107
- * }
108
- * }
109
- * ```
110
- *
111
- * Becomes
112
- *
113
- * ```
114
- * fragment Foo on FooType {
115
- * a {
116
- * bb
117
- * }
118
- * ... on OtherType {
119
- * a {
120
- * cc
121
- * }
122
- * }
123
- * }
124
- * ```
125
- *
126
- * 1 can be skipped because it is already fetched at the outer level.
127
- */
128
- function skipRedundantNodesTransform(context) {
129
- return IRTransformer.transform(context, {
130
- Root: visitNode,
131
- SplitOperation: visitNode,
132
- Fragment: visitNode
133
- });
134
- }
135
-
136
- var cache = new Map();
137
-
138
- function visitNode(node) {
139
- cache = new Map();
140
- var context = this.getContext();
141
- return transformNode(context.getSchema(), node, new IMap()).node;
142
- }
143
- /**
144
- * The most straightforward approach would be two passes: one to record the
145
- * structure of the document, one to prune duplicates. This implementation uses
146
- * a single pass. Selections are sorted with fields first, "conditionals"
147
- * (inline fragments & conditions) last. This means that all fields that are
148
- * guaranteed to be fetched are encountered prior to any duplicates that may be
149
- * fetched within a conditional.
150
- *
151
- * Because selections fetched within a conditional are not guaranteed to be
152
- * fetched in the parent, a fork of the selection map is created when entering a
153
- * conditional. The sort ensures that guaranteed fields have already been seen
154
- * prior to the clone.
155
- */
156
-
157
-
158
- function transformNode(schema, node, selectionMap) {
159
- // This will optimize a traversal of the same subselections.
160
- // If it's the same node, and selectionMap is empty
161
- // result of transformNode has to be the same.
162
- var isEmptySelectionMap = selectionMap.size === 0;
163
- var result;
164
-
165
- if (isEmptySelectionMap) {
166
- // $FlowFixMe[escaped-generic]
167
- result = cache.get(node);
168
-
169
- if (result != null) {
170
- return result;
171
- }
172
- }
173
-
174
- var selections = [];
175
- sortSelections(node.selections).forEach(function (selection) {
176
- var identifier = getIdentifierForSelection(schema, selection);
177
-
178
- switch (selection.kind) {
179
- case 'ScalarField':
180
- case 'FragmentSpread':
181
- {
182
- if (!selectionMap.has(identifier)) {
183
- selections.push(selection);
184
- selectionMap = selectionMap.set(identifier, null);
185
- }
186
-
187
- break;
188
- }
189
-
190
- case 'Defer':
191
- case 'Stream':
192
- case 'ModuleImport':
193
- case 'ClientExtension':
194
- case 'InlineDataFragmentSpread':
195
- case 'LinkedField':
196
- {
197
- var transformed = transformNode(schema, selection, selectionMap.get(identifier) || new IMap());
198
-
199
- if (transformed.node) {
200
- selections.push(transformed.node);
201
- selectionMap = selectionMap.set(identifier, transformed.selectionMap);
202
- }
203
-
204
- break;
205
- }
206
-
207
- case 'InlineFragment':
208
- case 'Condition':
209
- {
210
- // Fork the selection map to prevent conditional selections from
211
- // affecting the outer "guaranteed" selections.
212
- var _transformed = transformNode(schema, selection, selectionMap.get(identifier) || selectionMap);
213
-
214
- if (_transformed.node) {
215
- selections.push(_transformed.node);
216
- selectionMap = selectionMap.set(identifier, _transformed.selectionMap);
217
- }
218
-
219
- break;
220
- }
221
-
222
- default:
223
- selection;
224
- !false ? process.env.NODE_ENV !== "production" ? invariant(false, 'SkipRedundantNodesTransform: Unexpected node kind `%s`.', selection.kind) : invariant(false) : void 0;
225
- }
226
- });
227
- var nextNode = selections.length ? (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, node), {}, {
228
- selections: selections
229
- }) : null;
230
- result = {
231
- selectionMap: selectionMap,
232
- node: nextNode
233
- };
234
-
235
- if (isEmptySelectionMap) {
236
- // $FlowFixMe[escaped-generic]
237
- cache.set(node, result);
238
- }
239
-
240
- return result;
241
- }
242
- /**
243
- * Sort inline fragments and conditions after other selections.
244
- */
245
-
246
-
247
- function sortSelections(selections) {
248
- var isScalarOrLinkedField = function isScalarOrLinkedField(selection) {
249
- return selection.kind === 'ScalarField' || selection.kind === 'LinkedField';
250
- };
251
-
252
- var _partitionArray = partitionArray(selections, isScalarOrLinkedField),
253
- scalarsAndLinkedFields = _partitionArray[0],
254
- rest = _partitionArray[1];
255
-
256
- return [].concat((0, _toConsumableArray2["default"])(scalarsAndLinkedFields), (0, _toConsumableArray2["default"])(rest));
257
- }
258
-
259
- module.exports = {
260
- transform: skipRedundantNodesTransform
261
- };
@@ -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,75 +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
- * 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
-
26
-
27
- function skipUnusedVariablesTransform(context) {
28
- var contextWithUsedArguments = inferRootArgumentDefinitions(context);
29
- return context.withMutations(function (ctx) {
30
- var nextContext = ctx;
31
-
32
- var _iterator = (0, _createForOfIteratorHelper2["default"])(nextContext.documents()),
33
- _step;
34
-
35
- try {
36
- var _loop = function _loop() {
37
- var node = _step.value;
38
-
39
- if (node.kind !== 'Root') {
40
- return "continue";
41
- }
42
-
43
- var usedArguments = new Set(contextWithUsedArguments.getRoot(node.name).argumentDefinitions.map(function (argDef) {
44
- return argDef.name;
45
- })); // Remove unused argument definitions
46
-
47
- var usedArgumentDefinitions = node.argumentDefinitions.filter(function (argDef) {
48
- return usedArguments.has(argDef.name);
49
- });
50
-
51
- if (usedArgumentDefinitions.length !== node.argumentDefinitions.length) {
52
- nextContext = nextContext.replace((0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, node), {}, {
53
- argumentDefinitions: usedArgumentDefinitions
54
- }));
55
- }
56
- };
57
-
58
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
59
- var _ret = _loop();
60
-
61
- if (_ret === "continue") continue;
62
- }
63
- } catch (err) {
64
- _iterator.e(err);
65
- } finally {
66
- _iterator.f();
67
- }
68
-
69
- return nextContext;
70
- });
71
- }
72
-
73
- module.exports = {
74
- transform: skipUnusedVariablesTransform
75
- };
@@ -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 getNormalizationOperationName = require('../core/getNormalizationOperationName');
14
-
15
- var IRTransformer = require('../core/IRTransformer');
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
- };