relay-compiler 9.0.0 → 10.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (217) hide show
  1. package/bin/RelayCompilerBin.js.flow +169 -0
  2. package/bin/RelayCompilerMain.js.flow +515 -0
  3. package/bin/__fixtures__/plugin-module.js.flow +17 -0
  4. package/bin/relay-compiler +3862 -2505
  5. package/codegen/CodegenDirectory.js.flow +375 -0
  6. package/codegen/CodegenRunner.js.flow +432 -0
  7. package/codegen/CodegenTypes.js.flow +28 -0
  8. package/codegen/CodegenWatcher.js.flow +254 -0
  9. package/codegen/NormalizationCodeGenerator.js.flow +571 -0
  10. package/codegen/ReaderCodeGenerator.js.flow +512 -0
  11. package/codegen/RelayCodeGenerator.js.flow +85 -0
  12. package/codegen/RelayFileWriter.js.flow +367 -0
  13. package/codegen/SourceControl.js.flow +58 -0
  14. package/codegen/compileRelayArtifacts.js.flow +182 -0
  15. package/codegen/createPrintRequireModuleDependency.js.flow +21 -0
  16. package/codegen/sortObjectByKey.js.flow +25 -0
  17. package/codegen/writeRelayGeneratedFile.js.flow +223 -0
  18. package/core/ASTCache.js.flow +74 -0
  19. package/core/ASTConvert.js.flow +233 -0
  20. package/core/CompilerContext.js.flow +191 -0
  21. package/core/CompilerError.js.flow +250 -0
  22. package/core/DotGraphQLParser.js.flow +39 -0
  23. package/core/GraphQLCompilerProfiler.js.flow +341 -0
  24. package/core/GraphQLDerivedFromMetadata.js.flow +36 -0
  25. package/core/GraphQLWatchmanClient.js.flow +111 -0
  26. package/core/IR.js.flow +326 -0
  27. package/core/IRPrinter.js.flow +477 -0
  28. package/core/IRTransformer.js.flow +377 -0
  29. package/core/IRValidator.js.flow +260 -0
  30. package/core/IRVisitor.js.flow +150 -0
  31. package/core/JSModuleParser.js.flow +24 -0
  32. package/core/RelayCompilerScope.js.flow +199 -0
  33. package/core/RelayFindGraphQLTags.js.flow +119 -0
  34. package/core/RelayGraphQLEnumsGenerator.js.flow +55 -0
  35. package/core/RelayIRTransforms.js.flow +138 -0
  36. package/core/RelayParser.js.flow +1731 -0
  37. package/core/RelaySourceModuleParser.js.flow +135 -0
  38. package/core/Schema.js.flow +2037 -0
  39. package/core/SchemaUtils.js.flow +120 -0
  40. package/core/filterContextForNode.js.flow +50 -0
  41. package/core/getFieldDefinition.js.flow +156 -0
  42. package/core/getIdentifierForArgumentValue.js.flow +49 -0
  43. package/core/getIdentifierForSelection.js.flow +69 -0
  44. package/core/getLiteralArgumentValues.js.flow +32 -0
  45. package/core/getNormalizationOperationName.js.flow +19 -0
  46. package/core/inferRootArgumentDefinitions.js.flow +323 -0
  47. package/index.js +1 -1
  48. package/index.js.flow +200 -0
  49. package/language/RelayLanguagePluginInterface.js.flow +283 -0
  50. package/language/javascript/FindGraphQLTags.js.flow +137 -0
  51. package/language/javascript/RelayFlowBabelFactories.js.flow +176 -0
  52. package/language/javascript/RelayFlowGenerator.js.flow +1099 -0
  53. package/language/javascript/RelayFlowTypeTransformers.js.flow +184 -0
  54. package/language/javascript/RelayLanguagePluginJavaScript.js.flow +34 -0
  55. package/language/javascript/formatGeneratedModule.js.flow +65 -0
  56. package/lib/bin/RelayCompilerBin.js +10 -0
  57. package/lib/bin/RelayCompilerMain.js +127 -130
  58. package/lib/codegen/CodegenDirectory.js +2 -6
  59. package/lib/codegen/CodegenRunner.js +37 -76
  60. package/lib/codegen/CodegenWatcher.js +13 -21
  61. package/lib/codegen/NormalizationCodeGenerator.js +131 -50
  62. package/lib/codegen/ReaderCodeGenerator.js +116 -49
  63. package/lib/codegen/RelayCodeGenerator.js +17 -6
  64. package/lib/codegen/RelayFileWriter.js +15 -37
  65. package/lib/codegen/compileRelayArtifacts.js +16 -30
  66. package/lib/codegen/sortObjectByKey.js +43 -0
  67. package/lib/codegen/writeRelayGeneratedFile.js +86 -96
  68. package/lib/core/ASTCache.js +3 -4
  69. package/lib/core/CompilerContext.js +3 -4
  70. package/lib/core/CompilerError.js +27 -54
  71. package/lib/core/GraphQLCompilerProfiler.js +8 -12
  72. package/lib/core/GraphQLDerivedFromMetadata.js +1 -10
  73. package/lib/core/GraphQLWatchmanClient.js +4 -12
  74. package/lib/core/IRPrinter.js +16 -21
  75. package/lib/core/IRTransformer.js +8 -6
  76. package/lib/core/IRValidator.js +1 -3
  77. package/lib/core/RelayCompilerScope.js +4 -4
  78. package/lib/core/RelayGraphQLEnumsGenerator.js +12 -15
  79. package/lib/core/RelayIRTransforms.js +23 -13
  80. package/lib/core/RelayParser.js +53 -89
  81. package/lib/core/RelaySourceModuleParser.js +1 -3
  82. package/lib/core/Schema.js +106 -77
  83. package/lib/core/SchemaUtils.js +15 -1
  84. package/lib/core/getFieldDefinition.js +12 -15
  85. package/lib/core/getIdentifierForSelection.js +1 -1
  86. package/lib/core/inferRootArgumentDefinitions.js +27 -36
  87. package/lib/index.js +1 -3
  88. package/lib/language/javascript/FindGraphQLTags.js +7 -72
  89. package/lib/language/javascript/RelayFlowBabelFactories.js +5 -5
  90. package/lib/language/javascript/RelayFlowGenerator.js +131 -108
  91. package/lib/language/javascript/RelayFlowTypeTransformers.js +1 -3
  92. package/lib/reporters/ConsoleReporter.js +1 -3
  93. package/lib/reporters/MultiReporter.js +1 -3
  94. package/lib/runner/Artifacts.js +69 -170
  95. package/lib/runner/BufferedFilesystem.js +32 -66
  96. package/lib/runner/GraphQLASTNodeGroup.js +54 -120
  97. package/lib/runner/GraphQLNodeMap.js +14 -19
  98. package/lib/runner/Sources.js +70 -85
  99. package/lib/runner/StrictMap.js +21 -37
  100. package/lib/runner/getChangedNodeNames.js +30 -62
  101. package/lib/transforms/ApplyFragmentArgumentTransform.js +71 -31
  102. package/lib/transforms/ClientExtensionsTransform.js +15 -15
  103. package/lib/transforms/ConnectionTransform.js +26 -38
  104. package/lib/transforms/DeclarativeConnectionMutationTransform.js +225 -0
  105. package/lib/transforms/DeferStreamTransform.js +27 -17
  106. package/lib/transforms/DisallowTypenameOnRoot.js +55 -0
  107. package/lib/transforms/FieldHandleTransform.js +7 -3
  108. package/lib/transforms/FilterCompilerDirectivesTransform.js +29 -0
  109. package/lib/transforms/FlattenTransform.js +23 -19
  110. package/lib/transforms/GenerateIDFieldTransform.js +56 -35
  111. package/lib/transforms/GenerateTypeNameTransform.js +84 -10
  112. package/lib/transforms/InlineDataFragmentTransform.js +9 -4
  113. package/lib/transforms/MaskTransform.js +17 -17
  114. package/lib/transforms/MatchTransform.js +114 -32
  115. package/lib/transforms/ReactFlightComponentTransform.js +162 -0
  116. package/lib/transforms/RefetchableFragmentTransform.js +21 -17
  117. package/lib/transforms/RelayDirectiveTransform.js +8 -3
  118. package/lib/transforms/RequiredFieldTransform.js +380 -0
  119. package/lib/transforms/SkipClientExtensionsTransform.js +8 -0
  120. package/lib/transforms/SkipHandleFieldTransform.js +6 -2
  121. package/lib/transforms/SkipRedundantNodesTransform.js +9 -2
  122. package/lib/transforms/SkipSplitOperationTransform.js +32 -0
  123. package/lib/transforms/SkipUnreachableNodeTransform.js +9 -2
  124. package/lib/transforms/SkipUnusedVariablesTransform.js +18 -17
  125. package/lib/transforms/SplitModuleImportTransform.js +2 -2
  126. package/lib/transforms/TestOperationTransform.js +26 -20
  127. package/lib/transforms/ValidateGlobalVariablesTransform.js +18 -30
  128. package/lib/transforms/ValidateRequiredArgumentsTransform.js +12 -15
  129. package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +16 -30
  130. package/lib/transforms/ValidateUnusedVariablesTransform.js +18 -30
  131. package/lib/transforms/query-generators/FetchableQueryGenerator.js +161 -0
  132. package/lib/transforms/query-generators/NodeQueryGenerator.js +22 -3
  133. package/lib/transforms/query-generators/QueryQueryGenerator.js +2 -1
  134. package/lib/transforms/query-generators/ViewerQueryGenerator.js +1 -0
  135. package/lib/transforms/query-generators/index.js +23 -6
  136. package/lib/transforms/query-generators/utils.js +17 -16
  137. package/lib/util/RelayCompilerCache.js +2 -4
  138. package/lib/util/argumentContainsVariables.js +37 -0
  139. package/lib/util/dedupeJSONStringify.js +15 -12
  140. package/lib/util/generateAbstractTypeRefinementKey.js +24 -0
  141. package/lib/util/getModuleName.js +1 -1
  142. package/lib/util/joinArgumentDefinitions.js +3 -1
  143. package/package.json +7 -7
  144. package/relay-compiler.js +4 -4
  145. package/relay-compiler.min.js +4 -4
  146. package/reporters/ConsoleReporter.js.flow +81 -0
  147. package/reporters/MultiReporter.js.flow +43 -0
  148. package/reporters/Reporter.js.flow +19 -0
  149. package/runner/Artifacts.js.flow +219 -0
  150. package/runner/BufferedFilesystem.js.flow +194 -0
  151. package/runner/GraphQLASTNodeGroup.js.flow +176 -0
  152. package/runner/GraphQLASTUtils.js.flow +26 -0
  153. package/runner/GraphQLNodeMap.js.flow +55 -0
  154. package/runner/Sources.js.flow +228 -0
  155. package/runner/StrictMap.js.flow +96 -0
  156. package/runner/compileArtifacts.js.flow +76 -0
  157. package/runner/extractAST.js.flow +100 -0
  158. package/runner/getChangedNodeNames.js.flow +48 -0
  159. package/runner/getSchemaInstance.js.flow +36 -0
  160. package/runner/types.js.flow +37 -0
  161. package/transforms/ApplyFragmentArgumentTransform.js.flow +526 -0
  162. package/transforms/ClientExtensionsTransform.js.flow +224 -0
  163. package/transforms/ConnectionTransform.js.flow +855 -0
  164. package/transforms/DeclarativeConnectionMutationTransform.js.flow +246 -0
  165. package/transforms/DeferStreamTransform.js.flow +265 -0
  166. package/transforms/DisallowIdAsAlias.js.flow +47 -0
  167. package/transforms/DisallowTypenameOnRoot.js.flow +45 -0
  168. package/transforms/FieldHandleTransform.js.flow +79 -0
  169. package/transforms/FilterCompilerDirectivesTransform.js.flow +33 -0
  170. package/transforms/FilterDirectivesTransform.js.flow +45 -0
  171. package/transforms/FlattenTransform.js.flow +454 -0
  172. package/transforms/GenerateIDFieldTransform.js.flow +152 -0
  173. package/transforms/GenerateTypeNameTransform.js.flow +161 -0
  174. package/transforms/InlineDataFragmentTransform.js.flow +125 -0
  175. package/transforms/InlineFragmentsTransform.js.flow +71 -0
  176. package/transforms/MaskTransform.js.flow +126 -0
  177. package/transforms/MatchTransform.js.flow +589 -0
  178. package/transforms/ReactFlightComponentTransform.js.flow +195 -0
  179. package/transforms/RefetchableFragmentTransform.js.flow +272 -0
  180. package/transforms/RelayDirectiveTransform.js.flow +97 -0
  181. package/transforms/RequiredFieldTransform.js.flow +415 -0
  182. package/transforms/SkipClientExtensionsTransform.js.flow +54 -0
  183. package/transforms/SkipHandleFieldTransform.js.flow +44 -0
  184. package/transforms/SkipRedundantNodesTransform.js.flow +257 -0
  185. package/transforms/SkipSplitOperationTransform.js.flow +37 -0
  186. package/transforms/SkipUnreachableNodeTransform.js.flow +149 -0
  187. package/transforms/SkipUnusedVariablesTransform.js.flow +59 -0
  188. package/transforms/SplitModuleImportTransform.js.flow +98 -0
  189. package/transforms/TestOperationTransform.js.flow +142 -0
  190. package/transforms/TransformUtils.js.flow +26 -0
  191. package/transforms/ValidateGlobalVariablesTransform.js.flow +81 -0
  192. package/transforms/ValidateRequiredArgumentsTransform.js.flow +127 -0
  193. package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +112 -0
  194. package/transforms/ValidateUnusedVariablesTransform.js.flow +89 -0
  195. package/transforms/query-generators/FetchableQueryGenerator.js.flow +189 -0
  196. package/transforms/query-generators/NodeQueryGenerator.js.flow +219 -0
  197. package/transforms/query-generators/QueryQueryGenerator.js.flow +57 -0
  198. package/transforms/query-generators/ViewerQueryGenerator.js.flow +97 -0
  199. package/transforms/query-generators/index.js.flow +90 -0
  200. package/transforms/query-generators/utils.js.flow +76 -0
  201. package/util/CodeMarker.js.flow +79 -0
  202. package/util/DefaultHandleKey.js.flow +17 -0
  203. package/util/RelayCompilerCache.js.flow +88 -0
  204. package/util/Rollout.js.flow +39 -0
  205. package/util/TimeReporter.js.flow +79 -0
  206. package/util/areEqualOSS.js.flow +123 -0
  207. package/util/argumentContainsVariables.js.flow +38 -0
  208. package/util/dedupeJSONStringify.js.flow +152 -0
  209. package/util/generateAbstractTypeRefinementKey.js.flow +29 -0
  210. package/util/getDefinitionNodeHash.js.flow +25 -0
  211. package/util/getModuleName.js.flow +39 -0
  212. package/util/joinArgumentDefinitions.js.flow +105 -0
  213. package/util/md5.js.flow +22 -0
  214. package/util/murmurHash.js.flow +94 -0
  215. package/util/nullthrowsOSS.js.flow +25 -0
  216. package/util/orList.js.flow +37 -0
  217. package/util/partitionArray.js.flow +37 -0
@@ -14,6 +14,12 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
14
14
 
15
15
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
16
16
 
17
+ function _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
18
+
19
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
20
+
21
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
22
+
17
23
  var GraphQLNodeMap = require('./GraphQLNodeMap');
18
24
 
19
25
  var _require = require('./GraphQLASTUtils'),
@@ -24,12 +30,12 @@ var _require2 = require('graphql'),
24
30
 
25
31
  function buildDependencyMap(nodes) {
26
32
  var dependencyMap = new Map();
27
- var _iteratorNormalCompletion = true;
28
- var _didIteratorError = false;
29
- var _iteratorError = undefined;
33
+
34
+ var _iterator = _createForOfIteratorHelper(nodes.values()),
35
+ _step;
30
36
 
31
37
  try {
32
- for (var _iterator = nodes.values()[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
38
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
33
39
  var node = _step.value;
34
40
  var name = getName(node);
35
41
 
@@ -40,18 +46,9 @@ function buildDependencyMap(nodes) {
40
46
  dependencyMap.set(name, findIncludedFragments(node));
41
47
  }
42
48
  } catch (err) {
43
- _didIteratorError = true;
44
- _iteratorError = err;
49
+ _iterator.e(err);
45
50
  } finally {
46
- try {
47
- if (!_iteratorNormalCompletion && _iterator["return"] != null) {
48
- _iterator["return"]();
49
- }
50
- } finally {
51
- if (_didIteratorError) {
52
- throw _iteratorError;
53
- }
54
- }
51
+ _iterator.f();
55
52
  }
56
53
 
57
54
  return dependencyMap;
@@ -59,19 +56,19 @@ function buildDependencyMap(nodes) {
59
56
 
60
57
  function mergeMaps(maps) {
61
58
  var result = new Map();
62
- var _iteratorNormalCompletion2 = true;
63
- var _didIteratorError2 = false;
64
- var _iteratorError2 = undefined;
59
+
60
+ var _iterator2 = _createForOfIteratorHelper(maps),
61
+ _step2;
65
62
 
66
63
  try {
67
- for (var _iterator2 = maps[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {
64
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
68
65
  var source = _step2.value;
69
- var _iteratorNormalCompletion3 = true;
70
- var _didIteratorError3 = false;
71
- var _iteratorError3 = undefined;
66
+
67
+ var _iterator3 = _createForOfIteratorHelper(source.entries()),
68
+ _step3;
72
69
 
73
70
  try {
74
- for (var _iterator3 = source.entries()[Symbol.iterator](), _step3; !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) {
71
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
75
72
  var _step3$value = _step3.value,
76
73
  key = _step3$value[0],
77
74
  value = _step3$value[1];
@@ -83,33 +80,15 @@ function mergeMaps(maps) {
83
80
  result.set(key, value);
84
81
  }
85
82
  } catch (err) {
86
- _didIteratorError3 = true;
87
- _iteratorError3 = err;
83
+ _iterator3.e(err);
88
84
  } finally {
89
- try {
90
- if (!_iteratorNormalCompletion3 && _iterator3["return"] != null) {
91
- _iterator3["return"]();
92
- }
93
- } finally {
94
- if (_didIteratorError3) {
95
- throw _iteratorError3;
96
- }
97
- }
85
+ _iterator3.f();
98
86
  }
99
87
  }
100
88
  } catch (err) {
101
- _didIteratorError2 = true;
102
- _iteratorError2 = err;
89
+ _iterator2.e(err);
103
90
  } finally {
104
- try {
105
- if (!_iteratorNormalCompletion2 && _iterator2["return"] != null) {
106
- _iterator2["return"]();
107
- }
108
- } finally {
109
- if (_didIteratorError2) {
110
- throw _iteratorError2;
111
- }
112
- }
91
+ _iterator2.f();
113
92
  }
114
93
 
115
94
  return result;
@@ -133,12 +112,12 @@ function forChanges(nodes, changedNames) {
133
112
  var directlyChangedAndAncestors = includeReachable(changedNames, invertedDependencyMap); // Now, we need to intersect obtained set with the project nodes
134
113
 
135
114
  var directlyChangedRelatedToProject = new Set();
136
- var _iteratorNormalCompletion4 = true;
137
- var _didIteratorError4 = false;
138
- var _iteratorError4 = undefined;
115
+
116
+ var _iterator4 = _createForOfIteratorHelper(directlyChangedAndAncestors),
117
+ _step4;
139
118
 
140
119
  try {
141
- for (var _iterator4 = directlyChangedAndAncestors[Symbol.iterator](), _step4; !(_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done); _iteratorNormalCompletion4 = true) {
120
+ for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
142
121
  var node = _step4.value;
143
122
 
144
123
  if (nodes.has(node)) {
@@ -148,18 +127,9 @@ function forChanges(nodes, changedNames) {
148
127
  // in the complete dependency map (project + base)
149
128
 
150
129
  } catch (err) {
151
- _didIteratorError4 = true;
152
- _iteratorError4 = err;
130
+ _iterator4.e(err);
153
131
  } finally {
154
- try {
155
- if (!_iteratorNormalCompletion4 && _iterator4["return"] != null) {
156
- _iterator4["return"]();
157
- }
158
- } finally {
159
- if (_didIteratorError4) {
160
- throw _iteratorError4;
161
- }
162
- }
132
+ _iterator4.f();
163
133
  }
164
134
 
165
135
  var allRelated = includeReachable(directlyChangedRelatedToProject, dependencyMap);
@@ -169,12 +139,12 @@ function forChanges(nodes, changedNames) {
169
139
  function buildResult(includedNames, nameToNode, baseNameToNode) {
170
140
  var baseNames = new Set();
171
141
  var nodes = [];
172
- var _iteratorNormalCompletion5 = true;
173
- var _didIteratorError5 = false;
174
- var _iteratorError5 = undefined;
142
+
143
+ var _iterator5 = _createForOfIteratorHelper(includedNames),
144
+ _step5;
175
145
 
176
146
  try {
177
- for (var _iterator5 = includedNames[Symbol.iterator](), _step5; !(_iteratorNormalCompletion5 = (_step5 = _iterator5.next()).done); _iteratorNormalCompletion5 = true) {
147
+ for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) {
178
148
  var name = _step5.value;
179
149
  var baseNode = baseNameToNode.get(name);
180
150
 
@@ -190,18 +160,9 @@ function buildResult(includedNames, nameToNode, baseNameToNode) {
190
160
  }
191
161
  }
192
162
  } catch (err) {
193
- _didIteratorError5 = true;
194
- _iteratorError5 = err;
163
+ _iterator5.e(err);
195
164
  } finally {
196
- try {
197
- if (!_iteratorNormalCompletion5 && _iterator5["return"] != null) {
198
- _iterator5["return"]();
199
- }
200
- } finally {
201
- if (_didIteratorError5) {
202
- throw _iteratorError5;
203
- }
204
- }
165
+ _iterator5.f();
205
166
  }
206
167
 
207
168
  return {
@@ -217,12 +178,12 @@ function includeReachable(changed, deps) {
217
178
  while (toVisit.length > 0) {
218
179
  var current = toVisit.pop();
219
180
  visited.add(current);
220
- var _iteratorNormalCompletion6 = true;
221
- var _didIteratorError6 = false;
222
- var _iteratorError6 = undefined;
181
+
182
+ var _iterator6 = _createForOfIteratorHelper(deps.get(current) || []),
183
+ _step6;
223
184
 
224
185
  try {
225
- for (var _iterator6 = (deps.get(current) || [])[Symbol.iterator](), _step6; !(_iteratorNormalCompletion6 = (_step6 = _iterator6.next()).done); _iteratorNormalCompletion6 = true) {
186
+ for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) {
226
187
  var dep = _step6.value;
227
188
 
228
189
  if (!visited.has(dep)) {
@@ -230,18 +191,9 @@ function includeReachable(changed, deps) {
230
191
  }
231
192
  }
232
193
  } catch (err) {
233
- _didIteratorError6 = true;
234
- _iteratorError6 = err;
194
+ _iterator6.e(err);
235
195
  } finally {
236
- try {
237
- if (!_iteratorNormalCompletion6 && _iterator6["return"] != null) {
238
- _iterator6["return"]();
239
- }
240
- } finally {
241
- if (_didIteratorError6) {
242
- throw _iteratorError6;
243
- }
244
- }
196
+ _iterator6.f();
245
197
  }
246
198
  }
247
199
 
@@ -260,22 +212,22 @@ function findIncludedFragments(node) {
260
212
 
261
213
  function inverseDependencyMap(map) {
262
214
  var invertedMap = new Map();
263
- var _iteratorNormalCompletion7 = true;
264
- var _didIteratorError7 = false;
265
- var _iteratorError7 = undefined;
215
+
216
+ var _iterator7 = _createForOfIteratorHelper(map.entries()),
217
+ _step7;
266
218
 
267
219
  try {
268
- for (var _iterator7 = map.entries()[Symbol.iterator](), _step7; !(_iteratorNormalCompletion7 = (_step7 = _iterator7.next()).done); _iteratorNormalCompletion7 = true) {
220
+ for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) {
269
221
  var _step7$value = _step7.value,
270
222
  source = _step7$value[0],
271
223
  dests = _step7$value[1];
272
224
  var inverseDest = source;
273
- var _iteratorNormalCompletion8 = true;
274
- var _didIteratorError8 = false;
275
- var _iteratorError8 = undefined;
225
+
226
+ var _iterator8 = _createForOfIteratorHelper(dests),
227
+ _step8;
276
228
 
277
229
  try {
278
- for (var _iterator8 = dests[Symbol.iterator](), _step8; !(_iteratorNormalCompletion8 = (_step8 = _iterator8.next()).done); _iteratorNormalCompletion8 = true) {
230
+ for (_iterator8.s(); !(_step8 = _iterator8.n()).done;) {
279
231
  var dest = _step8.value;
280
232
  var inverseSource = dest;
281
233
  var inverseDests = invertedMap.get(inverseSource);
@@ -288,33 +240,15 @@ function inverseDependencyMap(map) {
288
240
  inverseDests.push(inverseDest);
289
241
  }
290
242
  } catch (err) {
291
- _didIteratorError8 = true;
292
- _iteratorError8 = err;
243
+ _iterator8.e(err);
293
244
  } finally {
294
- try {
295
- if (!_iteratorNormalCompletion8 && _iterator8["return"] != null) {
296
- _iterator8["return"]();
297
- }
298
- } finally {
299
- if (_didIteratorError8) {
300
- throw _iteratorError8;
301
- }
302
- }
245
+ _iterator8.f();
303
246
  }
304
247
  }
305
248
  } catch (err) {
306
- _didIteratorError7 = true;
307
- _iteratorError7 = err;
249
+ _iterator7.e(err);
308
250
  } finally {
309
- try {
310
- if (!_iteratorNormalCompletion7 && _iterator7["return"] != null) {
311
- _iterator7["return"]();
312
- }
313
- } finally {
314
- if (_didIteratorError7) {
315
- throw _iteratorError7;
316
- }
317
- }
251
+ _iterator7.f();
318
252
  }
319
253
 
320
254
  return invertedMap;
@@ -16,6 +16,12 @@ var _inheritsLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/inh
16
16
 
17
17
  var _wrapNativeSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/wrapNativeSuper"));
18
18
 
19
+ function _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
20
+
21
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
22
+
23
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
24
+
19
25
  var _require = require('../core/CompilerError'),
20
26
  createUserError = _require.createUserError,
21
27
  createCompilerError = _require.createCompilerError;
@@ -23,9 +29,7 @@ var _require = require('../core/CompilerError'),
23
29
  var _require2 = require('./GraphQLASTUtils'),
24
30
  getName = _require2.getName;
25
31
 
26
- var GraphQLNodeMap =
27
- /*#__PURE__*/
28
- function (_Map) {
32
+ var GraphQLNodeMap = /*#__PURE__*/function (_Map) {
29
33
  (0, _inheritsLoose2["default"])(GraphQLNodeMap, _Map);
30
34
 
31
35
  function GraphQLNodeMap() {
@@ -34,12 +38,12 @@ function (_Map) {
34
38
 
35
39
  GraphQLNodeMap.from = function from(nodes) {
36
40
  var result = new GraphQLNodeMap();
37
- var _iteratorNormalCompletion = true;
38
- var _didIteratorError = false;
39
- var _iteratorError = undefined;
41
+
42
+ var _iterator = _createForOfIteratorHelper(nodes),
43
+ _step;
40
44
 
41
45
  try {
42
- for (var _iterator = nodes[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
46
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
43
47
  var node = _step.value;
44
48
  var name = getName(node);
45
49
  var prevNode = result.get(name);
@@ -51,18 +55,9 @@ function (_Map) {
51
55
  result.set(name, node);
52
56
  }
53
57
  } catch (err) {
54
- _didIteratorError = true;
55
- _iteratorError = err;
58
+ _iterator.e(err);
56
59
  } finally {
57
- try {
58
- if (!_iteratorNormalCompletion && _iterator["return"] != null) {
59
- _iterator["return"]();
60
- }
61
- } finally {
62
- if (_didIteratorError) {
63
- throw _iteratorError;
64
- }
65
- }
60
+ _iterator.f();
66
61
  }
67
62
 
68
63
  return result;
@@ -85,6 +80,6 @@ function (_Map) {
85
80
  };
86
81
 
87
82
  return GraphQLNodeMap;
88
- }((0, _wrapNativeSuper2["default"])(Map));
83
+ }( /*#__PURE__*/(0, _wrapNativeSuper2["default"])(Map));
89
84
 
90
85
  module.exports = GraphQLNodeMap;
@@ -13,10 +13,22 @@
13
13
 
14
14
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
15
15
 
16
- var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread"));
16
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
17
+
18
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
19
+
20
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
21
+
22
+ function _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
23
+
24
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
25
+
26
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
17
27
 
18
28
  var invariant = require("fbjs/lib/invariant");
19
29
 
30
+ var md5 = require('../util/md5');
31
+
20
32
  var _require = require('./extractAST'),
21
33
  toASTRecord = _require.toASTRecord;
22
34
 
@@ -24,20 +36,14 @@ var _require2 = require('graphql'),
24
36
  Source = _require2.Source,
25
37
  parse = _require2.parse;
26
38
 
27
- function md5(x) {
28
- return require('crypto').createHash('md5').update(x, 'utf8').digest('hex');
29
- }
30
-
31
- var Sources =
32
- /*#__PURE__*/
33
- function () {
34
- Sources.fromSavedState = function fromSavedState(_ref2) {
35
- var extractFromFile = _ref2.extractFromFile,
36
- savedState = _ref2.savedState;
39
+ var Sources = /*#__PURE__*/function () {
40
+ Sources.fromSavedState = function fromSavedState(_ref) {
41
+ var extractFromFile = _ref.extractFromFile,
42
+ savedState = _ref.savedState;
37
43
  var state = {};
38
- var _iteratorNormalCompletion = true;
39
- var _didIteratorError = false;
40
- var _iteratorError = undefined;
44
+
45
+ var _iterator = _createForOfIteratorHelper(savedState),
46
+ _step;
41
47
 
42
48
  try {
43
49
  var _loop = function _loop() {
@@ -46,12 +52,12 @@ function () {
46
52
  savedStateSources = _step$value.sources;
47
53
  var nodes = {};
48
54
  var sources = [];
49
- var _iteratorNormalCompletion2 = true;
50
- var _didIteratorError2 = false;
51
- var _iteratorError2 = undefined;
55
+
56
+ var _iterator2 = _createForOfIteratorHelper(savedStateSources),
57
+ _step2;
52
58
 
53
59
  try {
54
- for (var _iterator2 = savedStateSources[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {
60
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
55
61
  var text = _step2.value;
56
62
  var doc = parse(new Source(text, file));
57
63
  !doc.definitions.length ? process.env.NODE_ENV !== "production" ? invariant(false, 'expected not empty list of definitions') : invariant(false) : void 0;
@@ -64,18 +70,9 @@ function () {
64
70
  sources.push(text);
65
71
  }
66
72
  } catch (err) {
67
- _didIteratorError2 = true;
68
- _iteratorError2 = err;
73
+ _iterator2.e(err);
69
74
  } finally {
70
- try {
71
- if (!_iteratorNormalCompletion2 && _iterator2["return"] != null) {
72
- _iterator2["return"]();
73
- }
74
- } finally {
75
- if (_didIteratorError2) {
76
- throw _iteratorError2;
77
- }
78
- }
75
+ _iterator2.f();
79
76
  }
80
77
 
81
78
  state[file] = {
@@ -84,22 +81,13 @@ function () {
84
81
  };
85
82
  };
86
83
 
87
- for (var _iterator = savedState[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
84
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
88
85
  _loop();
89
86
  }
90
87
  } catch (err) {
91
- _didIteratorError = true;
92
- _iteratorError = err;
88
+ _iterator.e(err);
93
89
  } finally {
94
- try {
95
- if (!_iteratorNormalCompletion && _iterator["return"] != null) {
96
- _iterator["return"]();
97
- }
98
- } finally {
99
- if (_didIteratorError) {
100
- throw _iteratorError;
101
- }
102
- }
90
+ _iterator.f();
103
91
  }
104
92
 
105
93
  return new Sources({
@@ -108,26 +96,29 @@ function () {
108
96
  });
109
97
  };
110
98
 
111
- function Sources(_ref3) {
112
- var extractFromFile = _ref3.extractFromFile,
113
- state = _ref3.state;
99
+ function Sources(_ref2) {
100
+ var extractFromFile = _ref2.extractFromFile,
101
+ state = _ref2.state;
114
102
  this._extractFromFile = extractFromFile;
115
- this._state = (0, _objectSpread2["default"])({}, state);
103
+ this._state = _objectSpread({}, state);
116
104
  }
117
105
 
118
106
  var _proto = Sources.prototype;
119
107
 
120
108
  _proto.processChanges = function processChanges(baseDir, files) {
109
+ var _ast$name$value, _ast$name;
110
+
121
111
  var added = [];
122
112
  var removed = [];
123
- var state = (0, _objectSpread2["default"])({}, this._state);
124
- var _iteratorNormalCompletion3 = true;
125
- var _didIteratorError3 = false;
126
- var _iteratorError3 = undefined;
113
+
114
+ var state = _objectSpread({}, this._state);
115
+
116
+ var _iterator3 = _createForOfIteratorHelper(files),
117
+ _step3;
127
118
 
128
119
  try {
129
- for (var _iterator3 = files[Symbol.iterator](), _step3; !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) {
130
- var _ref, _state$file$name;
120
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
121
+ var _state$file$name$node, _state$file$name;
131
122
 
132
123
  var _file = _step3.value;
133
124
  var newDefs = void 0;
@@ -145,23 +136,40 @@ function () {
145
136
  }
146
137
 
147
138
  var hasEntry = state.hasOwnProperty(_file.name);
148
- var oldEntry = (_ref = (_state$file$name = state[_file.name]) === null || _state$file$name === void 0 ? void 0 : _state$file$name.nodes) !== null && _ref !== void 0 ? _ref : {}; // First case, we have new changes in the file
139
+ var oldEntry = (_state$file$name$node = (_state$file$name = state[_file.name]) === null || _state$file$name === void 0 ? void 0 : _state$file$name.nodes) !== null && _state$file$name$node !== void 0 ? _state$file$name$node : {}; // First case, we have new changes in the file
149
140
  // for example changed Query or Fragment
150
141
 
151
142
  if (newDefs != null && newDefs.length > 0) {
152
143
  // We need to add all entities from the changed file to added arrays
153
144
  var newEntry = {};
154
145
  var newTexts = new Set();
155
- var _iteratorNormalCompletion4 = true;
156
- var _didIteratorError4 = false;
157
- var _iteratorError4 = undefined;
146
+
147
+ var _iterator4 = _createForOfIteratorHelper(newDefs),
148
+ _step4;
158
149
 
159
150
  try {
160
- for (var _iterator4 = newDefs[Symbol.iterator](), _step4; !(_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done); _iteratorNormalCompletion4 = true) {
151
+ for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
161
152
  var _step4$value = _step4.value,
162
153
  _ast = _step4$value.ast,
163
154
  text = _step4$value.text;
164
155
  var hashedText = md5(text);
156
+
157
+ if (newTexts.has(hashedText)) {
158
+ var name = 'unknown';
159
+
160
+ switch (_ast.kind) {
161
+ case 'FragmentDefinition':
162
+ name = _ast.name.value;
163
+ break;
164
+
165
+ case 'OperationDefinition':
166
+ name = (_ast$name$value = (_ast$name = _ast.name) === null || _ast$name === void 0 ? void 0 : _ast$name.value) !== null && _ast$name$value !== void 0 ? _ast$name$value : 'unnamed operation';
167
+ break;
168
+ }
169
+
170
+ throw new Error("Duplicate definition of `".concat(name, "` in `").concat(_file.name, "`"));
171
+ }
172
+
165
173
  newTexts.add(hashedText);
166
174
 
167
175
  if (hasEntry && oldEntry[hashedText] != null) {
@@ -181,18 +189,9 @@ function () {
181
189
  // that are not included in the new changes
182
190
 
183
191
  } catch (err) {
184
- _didIteratorError4 = true;
185
- _iteratorError4 = err;
192
+ _iterator4.e(err);
186
193
  } finally {
187
- try {
188
- if (!_iteratorNormalCompletion4 && _iterator4["return"] != null) {
189
- _iterator4["return"]();
190
- }
191
- } finally {
192
- if (_didIteratorError4) {
193
- throw _iteratorError4;
194
- }
195
- }
194
+ _iterator4.f();
196
195
  }
197
196
 
198
197
  if (hasEntry) {
@@ -212,10 +211,7 @@ function () {
212
211
 
213
212
  state[_file.name] = {
214
213
  nodes: newEntry,
215
-
216
- /* $FlowFixMe(>=0.111.0) This comment suppresses an error found when
217
- * Flow v0.111.0 was deployed. To see the error, delete this comment
218
- * and run Flow. */
214
+ // $FlowFixMe[incompatible-type]
219
215
  sources: newSources
220
216
  };
221
217
  } else {
@@ -236,24 +232,13 @@ function () {
236
232
  }
237
233
  }
238
234
  } catch (err) {
239
- _didIteratorError3 = true;
240
- _iteratorError3 = err;
235
+ _iterator3.e(err);
241
236
  } finally {
242
- try {
243
- if (!_iteratorNormalCompletion3 && _iterator3["return"] != null) {
244
- _iterator3["return"]();
245
- }
246
- } finally {
247
- if (_didIteratorError3) {
248
- throw _iteratorError3;
249
- }
250
- }
237
+ _iterator3.f();
251
238
  }
252
239
 
253
240
  return {
254
- /* $FlowFixMe(>=0.111.0) This comment suppresses an error found when Flow
255
- * v0.111.0 was deployed. To see the error, delete this comment and run
256
- * Flow. */
241
+ // $FlowFixMe[incompatible-return]
257
242
  changes: {
258
243
  added: added,
259
244
  removed: removed