relay-compiler 7.0.0 → 9.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (242) hide show
  1. package/bin/RelayCompilerBin.js.flow +169 -0
  2. package/bin/RelayCompilerMain.js.flow +508 -0
  3. package/bin/__fixtures__/plugin-module.js.flow +17 -0
  4. package/bin/relay-compiler +8554 -8142
  5. package/codegen/CodegenDirectory.js.flow +375 -0
  6. package/codegen/CodegenRunner.js.flow +431 -0
  7. package/codegen/CodegenTypes.js.flow +28 -0
  8. package/codegen/CodegenWatcher.js.flow +254 -0
  9. package/codegen/NormalizationCodeGenerator.js.flow +499 -0
  10. package/codegen/ReaderCodeGenerator.js.flow +453 -0
  11. package/codegen/RelayCodeGenerator.js.flow +76 -0
  12. package/codegen/RelayFileWriter.js.flow +366 -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/writeRelayGeneratedFile.js.flow +194 -0
  17. package/core/ASTCache.js.flow +73 -0
  18. package/core/ASTConvert.js.flow +233 -0
  19. package/core/CompilerContext.js.flow +190 -0
  20. package/core/CompilerError.js.flow +250 -0
  21. package/core/DotGraphQLParser.js.flow +39 -0
  22. package/core/GraphQLCompilerProfiler.js.flow +341 -0
  23. package/core/GraphQLDerivedFromMetadata.js.flow +48 -0
  24. package/core/GraphQLWatchmanClient.js.flow +111 -0
  25. package/core/IR.js.flow +329 -0
  26. package/core/IRPrinter.js.flow +488 -0
  27. package/core/IRTransformer.js.flow +377 -0
  28. package/core/IRValidator.js.flow +260 -0
  29. package/core/IRVisitor.js.flow +150 -0
  30. package/core/JSModuleParser.js.flow +24 -0
  31. package/core/RelayCompilerScope.js.flow +199 -0
  32. package/core/RelayFindGraphQLTags.js.flow +119 -0
  33. package/core/RelayGraphQLEnumsGenerator.js.flow +55 -0
  34. package/core/RelayIRTransforms.js.flow +130 -0
  35. package/core/RelayParser.js.flow +1759 -0
  36. package/core/RelaySourceModuleParser.js.flow +135 -0
  37. package/core/Schema.js.flow +1985 -0
  38. package/core/SchemaUtils.js.flow +109 -0
  39. package/core/filterContextForNode.js.flow +50 -0
  40. package/core/getFieldDefinition.js.flow +156 -0
  41. package/core/getIdentifierForArgumentValue.js.flow +49 -0
  42. package/core/getIdentifierForSelection.js.flow +69 -0
  43. package/core/getLiteralArgumentValues.js.flow +32 -0
  44. package/core/getNormalizationOperationName.js.flow +19 -0
  45. package/core/inferRootArgumentDefinitions.js.flow +323 -0
  46. package/index.js +1 -1
  47. package/index.js.flow +202 -0
  48. package/language/RelayLanguagePluginInterface.js.flow +283 -0
  49. package/language/javascript/FindGraphQLTags.js.flow +233 -0
  50. package/language/javascript/RelayFlowBabelFactories.js.flow +180 -0
  51. package/language/javascript/RelayFlowGenerator.js.flow +1040 -0
  52. package/language/javascript/RelayFlowTypeTransformers.js.flow +184 -0
  53. package/language/javascript/RelayLanguagePluginJavaScript.js.flow +34 -0
  54. package/language/javascript/formatGeneratedModule.js.flow +65 -0
  55. package/lib/bin/RelayCompilerBin.js +25 -7
  56. package/lib/bin/RelayCompilerMain.js +134 -125
  57. package/lib/bin/__fixtures__/plugin-module.js +1 -0
  58. package/lib/codegen/CodegenDirectory.js +14 -8
  59. package/lib/codegen/CodegenRunner.js +35 -75
  60. package/lib/codegen/CodegenTypes.js +1 -0
  61. package/lib/codegen/CodegenWatcher.js +14 -21
  62. package/lib/codegen/NormalizationCodeGenerator.js +80 -127
  63. package/lib/codegen/ReaderCodeGenerator.js +85 -111
  64. package/lib/codegen/RelayCodeGenerator.js +9 -6
  65. package/lib/codegen/RelayFileWriter.js +22 -41
  66. package/lib/codegen/SourceControl.js +1 -0
  67. package/lib/codegen/compileRelayArtifacts.js +18 -31
  68. package/lib/codegen/createPrintRequireModuleDependency.js +1 -0
  69. package/lib/codegen/writeRelayGeneratedFile.js +62 -90
  70. package/lib/core/ASTCache.js +4 -4
  71. package/lib/core/ASTConvert.js +1 -0
  72. package/lib/core/{GraphQLCompilerContext.js → CompilerContext.js} +10 -11
  73. package/lib/core/{RelayCompilerError.js → CompilerError.js} +29 -55
  74. package/lib/core/DotGraphQLParser.js +1 -0
  75. package/lib/core/GraphQLCompilerProfiler.js +9 -12
  76. package/lib/core/GraphQLDerivedFromMetadata.js +1 -0
  77. package/lib/core/GraphQLWatchmanClient.js +5 -12
  78. package/lib/core/{GraphQLIR.js → IR.js} +1 -0
  79. package/lib/core/{GraphQLIRPrinter.js → IRPrinter.js} +39 -17
  80. package/lib/core/{GraphQLIRTransformer.js → IRTransformer.js} +21 -16
  81. package/lib/core/{GraphQLIRValidator.js → IRValidator.js} +18 -10
  82. package/lib/core/{GraphQLIRVisitor.js → IRVisitor.js} +1 -2
  83. package/lib/core/JSModuleParser.js +18 -0
  84. package/lib/core/RelayCompilerScope.js +6 -5
  85. package/lib/core/RelayFindGraphQLTags.js +1 -0
  86. package/lib/core/RelayGraphQLEnumsGenerator.js +26 -12
  87. package/lib/core/RelayIRTransforms.js +12 -9
  88. package/lib/core/RelayParser.js +113 -75
  89. package/lib/core/RelaySourceModuleParser.js +4 -3
  90. package/lib/core/Schema.js +808 -317
  91. package/lib/core/SchemaUtils.js +1 -0
  92. package/lib/core/filterContextForNode.js +5 -4
  93. package/lib/core/getFieldDefinition.js +14 -16
  94. package/lib/core/getIdentifierForArgumentValue.js +18 -0
  95. package/lib/core/getIdentifierForSelection.js +4 -5
  96. package/lib/core/getLiteralArgumentValues.js +1 -0
  97. package/lib/core/getNormalizationOperationName.js +1 -0
  98. package/lib/core/inferRootArgumentDefinitions.js +79 -99
  99. package/lib/index.js +69 -19
  100. package/lib/language/RelayLanguagePluginInterface.js +1 -0
  101. package/lib/language/javascript/FindGraphQLTags.js +1 -0
  102. package/lib/language/javascript/RelayFlowBabelFactories.js +15 -0
  103. package/lib/language/javascript/RelayFlowGenerator.js +94 -173
  104. package/lib/language/javascript/RelayFlowTypeTransformers.js +2 -3
  105. package/lib/language/javascript/RelayLanguagePluginJavaScript.js +7 -4
  106. package/lib/language/javascript/formatGeneratedModule.js +14 -4
  107. package/lib/reporters/ConsoleReporter.js +2 -3
  108. package/lib/reporters/MultiReporter.js +2 -3
  109. package/lib/reporters/Reporter.js +1 -0
  110. package/lib/runner/Artifacts.js +327 -0
  111. package/lib/runner/BufferedFilesystem.js +265 -0
  112. package/lib/runner/GraphQLASTNodeGroup.js +260 -0
  113. package/lib/runner/GraphQLASTUtils.js +23 -0
  114. package/lib/runner/GraphQLNodeMap.js +85 -0
  115. package/lib/runner/Sources.js +266 -0
  116. package/lib/runner/StrictMap.js +136 -0
  117. package/lib/runner/compileArtifacts.js +39 -0
  118. package/lib/runner/extractAST.js +77 -0
  119. package/lib/runner/getChangedNodeNames.js +84 -0
  120. package/lib/runner/getSchemaInstance.js +30 -0
  121. package/lib/runner/types.js +12 -0
  122. package/lib/transforms/ApplyFragmentArgumentTransform.js +49 -55
  123. package/lib/transforms/ClientExtensionsTransform.js +11 -17
  124. package/lib/transforms/ConnectionTransform.js +35 -28
  125. package/lib/transforms/DeferStreamTransform.js +26 -74
  126. package/lib/transforms/DisallowIdAsAlias.js +5 -4
  127. package/lib/transforms/DisallowTypenameOnRoot.js +55 -0
  128. package/lib/transforms/FieldHandleTransform.js +8 -3
  129. package/lib/transforms/FilterDirectivesTransform.js +4 -3
  130. package/lib/transforms/FlattenTransform.js +23 -47
  131. package/lib/transforms/GenerateIDFieldTransform.js +9 -4
  132. package/lib/transforms/GenerateTypeNameTransform.js +8 -3
  133. package/lib/transforms/InlineDataFragmentTransform.js +11 -6
  134. package/lib/transforms/InlineFragmentsTransform.js +3 -2
  135. package/lib/transforms/MaskTransform.js +20 -19
  136. package/lib/transforms/MatchTransform.js +113 -34
  137. package/lib/transforms/RefetchableFragmentTransform.js +25 -41
  138. package/lib/transforms/RelayDirectiveTransform.js +13 -4
  139. package/lib/transforms/SkipClientExtensionsTransform.js +11 -2
  140. package/lib/transforms/SkipHandleFieldTransform.js +8 -3
  141. package/lib/transforms/SkipRedundantNodesTransform.js +9 -6
  142. package/lib/transforms/SkipSplitOperationTransform.js +32 -0
  143. package/lib/transforms/SkipUnreachableNodeTransform.js +12 -12
  144. package/lib/transforms/SkipUnusedVariablesTransform.js +19 -17
  145. package/lib/transforms/SplitModuleImportTransform.js +4 -3
  146. package/lib/transforms/TestOperationTransform.js +9 -6
  147. package/lib/transforms/TransformUtils.js +1 -0
  148. package/lib/transforms/ValidateGlobalVariablesTransform.js +20 -31
  149. package/lib/transforms/ValidateRequiredArgumentsTransform.js +17 -20
  150. package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +20 -33
  151. package/lib/transforms/ValidateUnusedVariablesTransform.js +20 -31
  152. package/lib/transforms/query-generators/FetchableQueryGenerator.js +161 -0
  153. package/lib/transforms/query-generators/NodeQueryGenerator.js +9 -3
  154. package/lib/transforms/query-generators/QueryQueryGenerator.js +2 -0
  155. package/lib/transforms/query-generators/ViewerQueryGenerator.js +6 -3
  156. package/lib/transforms/query-generators/index.js +25 -7
  157. package/lib/transforms/query-generators/utils.js +13 -15
  158. package/lib/util/CodeMarker.js +1 -0
  159. package/lib/util/DefaultHandleKey.js +1 -0
  160. package/lib/util/RelayCompilerCache.js +2 -3
  161. package/lib/util/Rollout.js +1 -0
  162. package/lib/util/TimeReporter.js +83 -0
  163. package/lib/util/areEqualOSS.js +1 -0
  164. package/lib/util/dedupeJSONStringify.js +16 -12
  165. package/lib/util/getDefinitionNodeHash.js +22 -0
  166. package/lib/util/getModuleName.js +4 -5
  167. package/lib/util/joinArgumentDefinitions.js +2 -1
  168. package/lib/util/md5.js +17 -0
  169. package/lib/util/murmurHash.js +1 -0
  170. package/lib/util/nullthrowsOSS.js +1 -0
  171. package/lib/util/orList.js +2 -1
  172. package/lib/util/partitionArray.js +1 -0
  173. package/package.json +4 -4
  174. package/relay-compiler.js +4 -4
  175. package/relay-compiler.min.js +4 -4
  176. package/reporters/ConsoleReporter.js.flow +81 -0
  177. package/reporters/MultiReporter.js.flow +43 -0
  178. package/reporters/Reporter.js.flow +19 -0
  179. package/runner/Artifacts.js.flow +219 -0
  180. package/runner/BufferedFilesystem.js.flow +194 -0
  181. package/runner/GraphQLASTNodeGroup.js.flow +176 -0
  182. package/runner/GraphQLASTUtils.js.flow +26 -0
  183. package/runner/GraphQLNodeMap.js.flow +55 -0
  184. package/runner/Sources.js.flow +218 -0
  185. package/runner/StrictMap.js.flow +96 -0
  186. package/runner/compileArtifacts.js.flow +76 -0
  187. package/runner/extractAST.js.flow +100 -0
  188. package/runner/getChangedNodeNames.js.flow +48 -0
  189. package/runner/getSchemaInstance.js.flow +36 -0
  190. package/runner/types.js.flow +37 -0
  191. package/transforms/ApplyFragmentArgumentTransform.js.flow +474 -0
  192. package/transforms/ClientExtensionsTransform.js.flow +220 -0
  193. package/transforms/ConnectionTransform.js.flow +869 -0
  194. package/transforms/DeferStreamTransform.js.flow +258 -0
  195. package/transforms/DisallowIdAsAlias.js.flow +47 -0
  196. package/transforms/DisallowTypenameOnRoot.js.flow +45 -0
  197. package/transforms/FieldHandleTransform.js.flow +80 -0
  198. package/transforms/FilterDirectivesTransform.js.flow +45 -0
  199. package/transforms/FlattenTransform.js.flow +456 -0
  200. package/transforms/GenerateIDFieldTransform.js.flow +134 -0
  201. package/transforms/GenerateTypeNameTransform.js.flow +81 -0
  202. package/transforms/InlineDataFragmentTransform.js.flow +124 -0
  203. package/transforms/InlineFragmentsTransform.js.flow +71 -0
  204. package/transforms/MaskTransform.js.flow +126 -0
  205. package/transforms/MatchTransform.js.flow +583 -0
  206. package/transforms/RefetchableFragmentTransform.js.flow +272 -0
  207. package/transforms/RelayDirectiveTransform.js.flow +99 -0
  208. package/transforms/SkipClientExtensionsTransform.js.flow +54 -0
  209. package/transforms/SkipHandleFieldTransform.js.flow +44 -0
  210. package/transforms/SkipRedundantNodesTransform.js.flow +253 -0
  211. package/transforms/SkipSplitOperationTransform.js.flow +37 -0
  212. package/transforms/SkipUnreachableNodeTransform.js.flow +149 -0
  213. package/transforms/SkipUnusedVariablesTransform.js.flow +59 -0
  214. package/transforms/SplitModuleImportTransform.js.flow +98 -0
  215. package/transforms/TestOperationTransform.js.flow +138 -0
  216. package/transforms/TransformUtils.js.flow +26 -0
  217. package/transforms/ValidateGlobalVariablesTransform.js.flow +81 -0
  218. package/transforms/ValidateRequiredArgumentsTransform.js.flow +127 -0
  219. package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +112 -0
  220. package/transforms/ValidateUnusedVariablesTransform.js.flow +89 -0
  221. package/transforms/query-generators/FetchableQueryGenerator.js.flow +190 -0
  222. package/transforms/query-generators/NodeQueryGenerator.js.flow +206 -0
  223. package/transforms/query-generators/QueryQueryGenerator.js.flow +57 -0
  224. package/transforms/query-generators/ViewerQueryGenerator.js.flow +97 -0
  225. package/transforms/query-generators/index.js.flow +90 -0
  226. package/transforms/query-generators/utils.js.flow +72 -0
  227. package/util/CodeMarker.js.flow +79 -0
  228. package/util/DefaultHandleKey.js.flow +17 -0
  229. package/util/RelayCompilerCache.js.flow +88 -0
  230. package/util/Rollout.js.flow +39 -0
  231. package/util/TimeReporter.js.flow +79 -0
  232. package/util/areEqualOSS.js.flow +123 -0
  233. package/util/dedupeJSONStringify.js.flow +152 -0
  234. package/util/getDefinitionNodeHash.js.flow +25 -0
  235. package/util/getModuleName.js.flow +39 -0
  236. package/util/joinArgumentDefinitions.js.flow +99 -0
  237. package/util/md5.js.flow +22 -0
  238. package/util/murmurHash.js.flow +94 -0
  239. package/util/nullthrowsOSS.js.flow +25 -0
  240. package/util/orList.js.flow +37 -0
  241. package/util/partitionArray.js.flow +37 -0
  242. package/lib/transforms/ConnectionFieldTransform.js +0 -275
@@ -0,0 +1,136 @@
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
+ * @emails oncall+relay
10
+ */
11
+ // flowlint ambiguous-object-type:error
12
+ 'use strict';
13
+
14
+ var _asyncToGenerator = require("@babel/runtime/helpers/asyncToGenerator");
15
+
16
+ function _createForOfIteratorHelper(o) { if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (o = _unsupportedIterableToArray(o))) { 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 it, 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; } } }; }
17
+
18
+ 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(n); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
19
+
20
+ 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; }
21
+
22
+ var invariant = require("fbjs/lib/invariant");
23
+
24
+ var StrictMap = /*#__PURE__*/function () {
25
+ function StrictMap(iterable) {
26
+ this._map = new Map(iterable);
27
+ return this;
28
+ }
29
+
30
+ var _proto = StrictMap.prototype;
31
+
32
+ _proto.clear = function clear() {
33
+ this._map.clear();
34
+ };
35
+
36
+ _proto["delete"] = function _delete(key) {
37
+ return this._map["delete"](key);
38
+ };
39
+
40
+ _proto.entries = function entries() {
41
+ return this._map.entries();
42
+ };
43
+
44
+ _proto.forEach = function forEach(callbackfn, thisArg) {
45
+ this._map.forEach(callbackfn, thisArg);
46
+ };
47
+
48
+ _proto.map = function map(f) {
49
+ var result = new StrictMap();
50
+
51
+ var _iterator = _createForOfIteratorHelper(this._map),
52
+ _step;
53
+
54
+ try {
55
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
56
+ var _step$value = _step.value,
57
+ key = _step$value[0],
58
+ val = _step$value[1];
59
+ result.set(key, f(val, key, this));
60
+ }
61
+ } catch (err) {
62
+ _iterator.e(err);
63
+ } finally {
64
+ _iterator.f();
65
+ }
66
+
67
+ return result;
68
+ };
69
+
70
+ _proto.asyncMap = /*#__PURE__*/function () {
71
+ var _asyncMap = _asyncToGenerator(function* (f) {
72
+ var _this = this;
73
+
74
+ var entryPromises = [];
75
+
76
+ var _iterator2 = _createForOfIteratorHelper(this._map),
77
+ _step2;
78
+
79
+ try {
80
+ var _loop = function _loop() {
81
+ var _step2$value = _step2.value,
82
+ key = _step2$value[0],
83
+ val = _step2$value[1];
84
+ entryPromises.push(f(val, key, _this).then(function (resultVal) {
85
+ return [key, resultVal];
86
+ }));
87
+ };
88
+
89
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
90
+ _loop();
91
+ }
92
+ } catch (err) {
93
+ _iterator2.e(err);
94
+ } finally {
95
+ _iterator2.f();
96
+ }
97
+
98
+ var entries = yield Promise.all(entryPromises);
99
+ return new StrictMap(entries);
100
+ });
101
+
102
+ function asyncMap(_x) {
103
+ return _asyncMap.apply(this, arguments);
104
+ }
105
+
106
+ return asyncMap;
107
+ }();
108
+
109
+ _proto.get = function get(key) {
110
+ !this.has(key) ? process.env.NODE_ENV !== "production" ? invariant(false, 'StrictMap: trying to read non-existent key `%s`.', String(key)) : invariant(false) : void 0; // $FlowFixMe - we checked the key exists
111
+
112
+ return this._map.get(key);
113
+ };
114
+
115
+ _proto.has = function has(key) {
116
+ return this._map.has(key);
117
+ };
118
+
119
+ _proto.keys = function keys() {
120
+ return this._map.keys();
121
+ };
122
+
123
+ _proto.set = function set(key, value) {
124
+ this._map.set(key, value);
125
+
126
+ return this;
127
+ };
128
+
129
+ _proto.values = function values() {
130
+ return this._map.values();
131
+ };
132
+
133
+ return StrictMap;
134
+ }();
135
+
136
+ module.exports = StrictMap;
@@ -0,0 +1,39 @@
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 ASTConvert = require('../core/ASTConvert');
14
+
15
+ var CompilerContext = require('../core/CompilerContext');
16
+
17
+ var RelayParser = require('../core/RelayParser');
18
+
19
+ var compileRelayArtifacts = require('../codegen/compileRelayArtifacts');
20
+
21
+ function compileArtifacts(_ref) {
22
+ var schema = _ref.schema,
23
+ compilerTransforms = _ref.compilerTransforms,
24
+ inputDefinitions = _ref.definitions,
25
+ reporter = _ref.reporter,
26
+ typeGenerator = _ref.typeGenerator;
27
+ var definitions = ASTConvert.convertASTDocuments(schema, [{
28
+ kind: 'Document',
29
+ definitions: inputDefinitions
30
+ }], RelayParser.transform);
31
+ var compilerContext = new CompilerContext(schema).addAll(definitions);
32
+ var transformedTypeContext = compilerContext.applyTransforms(typeGenerator.transforms, reporter);
33
+ return {
34
+ transformedTypeContext: transformedTypeContext,
35
+ artifacts: compileRelayArtifacts(compilerContext, compilerTransforms, reporter)
36
+ };
37
+ }
38
+
39
+ module.exports = compileArtifacts;
@@ -0,0 +1,77 @@
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
+ * @format
8
+ *
9
+ */
10
+ // flowlint ambiguous-object-type:error
11
+ 'use strict';
12
+
13
+ var JSModuleParser = require('../core/JSModuleParser');
14
+
15
+ var invariant = require("fbjs/lib/invariant");
16
+
17
+ var _require = require('graphql'),
18
+ parse = _require.parse,
19
+ print = _require.print;
20
+
21
+ function extractFromJS(baseDir, file) {
22
+ if (!file.exists) {
23
+ return null;
24
+ }
25
+
26
+ var f = {
27
+ relPath: file.name,
28
+ exists: true,
29
+ hash: file['content.sha1hex']
30
+ };
31
+ var fileFilter = JSModuleParser.getFileFilter(baseDir);
32
+
33
+ if (!fileFilter(f)) {
34
+ return null;
35
+ }
36
+
37
+ var result = JSModuleParser.parseFileWithSources(baseDir, f);
38
+
39
+ if (result == null || result.document.definitions.length === 0) {
40
+ return null;
41
+ }
42
+
43
+ var doc = result.document,
44
+ sources = result.sources;
45
+ var nodes = doc.definitions.map(function (def) {
46
+ if (def.kind === 'FragmentDefinition' || def.kind === 'OperationDefinition') {
47
+ return toASTRecord(def);
48
+ }
49
+
50
+ throw new Error("Unexpected definition kind: ".concat(def.kind));
51
+ });
52
+ return {
53
+ nodes: nodes,
54
+ sources: sources
55
+ };
56
+ }
57
+
58
+ function toASTRecord(node) {
59
+ return {
60
+ ast: node,
61
+ text: print(node)
62
+ };
63
+ }
64
+
65
+ function parseExecutableNode(text) {
66
+ var nodes = parse(text).definitions;
67
+ !(nodes.length === 1) ? process.env.NODE_ENV !== "production" ? invariant(false, 'expected exactly 1 definition') : invariant(false) : void 0;
68
+ var node = nodes[0];
69
+ !(node.kind === 'OperationDefinition' || node.kind === 'FragmentDefinition') ? process.env.NODE_ENV !== "production" ? invariant(false, 'expected an ExecutableDefinitionNode') : invariant(false) : void 0;
70
+ return node;
71
+ }
72
+
73
+ module.exports = {
74
+ parseExecutableNode: parseExecutableNode,
75
+ toASTRecord: toASTRecord,
76
+ extractFromJS: extractFromJS
77
+ };
@@ -0,0 +1,84 @@
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
+ * @format
8
+ *
9
+ */
10
+ // flowlint ambiguous-object-type:error
11
+ 'use strict';
12
+
13
+ function _createForOfIteratorHelper(o) { if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (o = _unsupportedIterableToArray(o))) { 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 it, 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; } } }; }
14
+
15
+ 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(n); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
16
+
17
+ 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; }
18
+
19
+ var _require = require('./GraphQLASTUtils'),
20
+ getName = _require.getName;
21
+
22
+ function getChangedNodeNames(projectStates, projects) {
23
+ var changedNames = new Set();
24
+
25
+ var _iterator = _createForOfIteratorHelper(projects),
26
+ _step;
27
+
28
+ try {
29
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
30
+ var projectType = _step.value;
31
+ var subConfig = projectStates.get(projectType);
32
+
33
+ var _iterator2 = _createForOfIteratorHelper(subConfig.initialDirty),
34
+ _step2;
35
+
36
+ try {
37
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
38
+ var name = _step2.value;
39
+ changedNames.add(name);
40
+ }
41
+ } catch (err) {
42
+ _iterator2.e(err);
43
+ } finally {
44
+ _iterator2.f();
45
+ }
46
+
47
+ var _iterator3 = _createForOfIteratorHelper(subConfig.changes.added),
48
+ _step3;
49
+
50
+ try {
51
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
52
+ var ast = _step3.value.ast;
53
+ changedNames.add(getName(ast));
54
+ }
55
+ } catch (err) {
56
+ _iterator3.e(err);
57
+ } finally {
58
+ _iterator3.f();
59
+ }
60
+
61
+ var _iterator4 = _createForOfIteratorHelper(subConfig.changes.removed),
62
+ _step4;
63
+
64
+ try {
65
+ for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
66
+ var _ast = _step4.value.ast;
67
+ changedNames.add(getName(_ast));
68
+ }
69
+ } catch (err) {
70
+ _iterator4.e(err);
71
+ } finally {
72
+ _iterator4.f();
73
+ }
74
+ }
75
+ } catch (err) {
76
+ _iterator.e(err);
77
+ } finally {
78
+ _iterator.f();
79
+ }
80
+
81
+ return changedNames;
82
+ }
83
+
84
+ module.exports = getChangedNodeNames;
@@ -0,0 +1,30 @@
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 _require = require('../core/Schema'),
14
+ create = _require.create;
15
+
16
+ var schemaCache = new Map();
17
+
18
+ function getSchemaInstance(getSchemaSource, getSchemaExtensions, schemaExtensions) {
19
+ var source = getSchemaSource();
20
+ var schema = schemaCache.get(source);
21
+
22
+ if (schema == null) {
23
+ schema = create(source, getSchemaExtensions(), schemaExtensions);
24
+ schemaCache.set(source, schema);
25
+ }
26
+
27
+ return schema;
28
+ }
29
+
30
+ module.exports = getSchemaInstance;
@@ -0,0 +1,12 @@
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
+ * @emails oncall+relay
10
+ */
11
+ // flowlint ambiguous-object-type:error
12
+ 'use strict';
@@ -7,15 +7,26 @@
7
7
  *
8
8
  * @format
9
9
  */
10
+ // flowlint ambiguous-object-type:error
10
11
  'use strict';
11
12
 
12
13
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
13
14
 
14
- var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread"));
15
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
16
 
16
17
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
17
18
 
18
- var IRTransformer = require('../core/GraphQLIRTransformer');
19
+ 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; }
20
+
21
+ 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; }
22
+
23
+ function _createForOfIteratorHelper(o) { if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (o = _unsupportedIterableToArray(o))) { 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 it, 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; } } }; }
24
+
25
+ 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(n); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
26
+
27
+ 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; }
28
+
29
+ var IRTransformer = require('../core/IRTransformer');
19
30
 
20
31
  var RelayCompilerScope = require('../core/RelayCompilerScope');
21
32
 
@@ -23,7 +34,7 @@ var getIdentifierForArgumentValue = require('../core/getIdentifierForArgumentVal
23
34
 
24
35
  var murmurHash = require('../util/murmurHash');
25
36
 
26
- var _require = require('../core/RelayCompilerError'),
37
+ var _require = require('../core/CompilerError'),
27
38
  createCompilerError = _require.createCompilerError,
28
39
  createNonRecoverableUserError = _require.createNonRecoverableUserError;
29
40
 
@@ -59,18 +70,21 @@ function applyFragmentArgumentTransform(context) {
59
70
  var scope = getRootScope(node.argumentDefinitions);
60
71
  return transformNode(context, fragments, scope, node, [node]);
61
72
  },
73
+ SplitOperation: function SplitOperation(node) {
74
+ return transformNode(context, fragments, {}, node, [node]);
75
+ },
62
76
  // Fragments are included below where referenced.
63
77
  // Unreferenced fragments are not included.
64
78
  Fragment: function Fragment() {
65
79
  return null;
66
80
  }
67
81
  });
68
- var _iteratorNormalCompletion = true;
69
- var _didIteratorError = false;
70
- var _iteratorError = undefined;
82
+
83
+ var _iterator = _createForOfIteratorHelper(fragments.values()),
84
+ _step;
71
85
 
72
86
  try {
73
- for (var _iterator = fragments.values()[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
87
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
74
88
  var pendingFragment = _step.value;
75
89
 
76
90
  if (pendingFragment.kind === 'resolved' && pendingFragment.value) {
@@ -78,18 +92,9 @@ function applyFragmentArgumentTransform(context) {
78
92
  }
79
93
  }
80
94
  } catch (err) {
81
- _didIteratorError = true;
82
- _iteratorError = err;
95
+ _iterator.e(err);
83
96
  } finally {
84
- try {
85
- if (!_iteratorNormalCompletion && _iterator["return"] != null) {
86
- _iterator["return"]();
87
- }
88
- } finally {
89
- if (_didIteratorError) {
90
- throw _iteratorError;
91
- }
92
- }
97
+ _iterator.f();
93
98
  }
94
99
 
95
100
  return nextContext;
@@ -105,13 +110,13 @@ function transformNode(context, fragments, scope, node, errorContext) {
105
110
  if (node.hasOwnProperty('directives')) {
106
111
  var directives = transformDirectives(scope, node.directives, errorContext); // $FlowIssue: this is a valid `Node`:
107
112
 
108
- return (0, _objectSpread2["default"])({}, node, {
113
+ return _objectSpread({}, node, {
109
114
  directives: directives,
110
115
  selections: selections
111
116
  });
112
117
  }
113
118
 
114
- return (0, _objectSpread2["default"])({}, node, {
119
+ return _objectSpread({}, node, {
115
120
  selections: selections
116
121
  });
117
122
  }
@@ -124,12 +129,13 @@ function transformFragmentSpread(context, fragments, scope, spread, errorContext
124
129
  return null;
125
130
  }
126
131
 
127
- var transformed = (0, _objectSpread2["default"])({}, spread, {
132
+ var transformed = _objectSpread({}, spread, {
128
133
  kind: 'FragmentSpread',
129
134
  args: [],
130
135
  directives: directives,
131
136
  name: appliedFragment.name
132
137
  });
138
+
133
139
  return transformed;
134
140
  }
135
141
 
@@ -137,50 +143,26 @@ function transformField(context, fragments, scope, field, errorContext) {
137
143
  var args = transformArguments(scope, field.args, errorContext);
138
144
  var directives = transformDirectives(scope, field.directives, errorContext);
139
145
 
140
- if (field.kind === 'LinkedField' || field.kind === 'ConnectionField') {
146
+ if (field.kind === 'LinkedField') {
141
147
  var selections = transformSelections(context, fragments, scope, field.selections, errorContext);
142
148
 
143
149
  if (!selections) {
144
150
  return null;
145
151
  }
146
152
 
147
- return (0, _objectSpread2["default"])({}, field, {
153
+ return _objectSpread({}, field, {
148
154
  args: args,
149
155
  directives: directives,
150
156
  selections: selections
151
157
  });
152
158
  } else {
153
- return (0, _objectSpread2["default"])({}, field, {
159
+ return _objectSpread({}, field, {
154
160
  args: args,
155
161
  directives: directives
156
162
  });
157
163
  }
158
164
  }
159
165
 
160
- function transformConnection(context, fragments, scope, connection, errorContext) {
161
- var args = transformArguments(scope, connection.args, errorContext);
162
- var stream = connection.stream;
163
-
164
- if (stream != null) {
165
- stream = (0, _objectSpread2["default"])({}, stream, {
166
- "if": stream["if"] != null ? transformValue(scope, stream["if"], errorContext) : null,
167
- initialCount: transformValue(scope, stream.initialCount, errorContext)
168
- });
169
- }
170
-
171
- var selections = transformSelections(context, fragments, scope, connection.selections, errorContext);
172
-
173
- if (!selections) {
174
- return null;
175
- }
176
-
177
- return (0, _objectSpread2["default"])({}, connection, {
178
- args: args,
179
- selections: selections,
180
- stream: stream
181
- });
182
- }
183
-
184
166
  function transformCondition(context, fragments, scope, node, errorContext) {
185
167
  var condition = transformValue(scope, node.condition, errorContext);
186
168
 
@@ -207,7 +189,7 @@ function transformCondition(context, fragments, scope, node, errorContext) {
207
189
  return selections;
208
190
  }
209
191
 
210
- return [(0, _objectSpread2["default"])({}, node, {
192
+ return [_objectSpread({}, node, {
211
193
  condition: condition,
212
194
  selections: selections
213
195
  })];
@@ -232,9 +214,7 @@ function transformSelections(context, fragments, scope, selections, errorContext
232
214
 
233
215
  (_nextSelections = nextSelections).push.apply(_nextSelections, (0, _toConsumableArray2["default"])(conditionSelections));
234
216
  }
235
- } else if (selection.kind === 'Connection') {
236
- nextSelection = transformConnection(context, fragments, scope, selection, errorContext);
237
- } else if (selection.kind === 'LinkedField' || selection.kind === 'ScalarField' || selection.kind === 'ConnectionField') {
217
+ } else if (selection.kind === 'LinkedField' || selection.kind === 'ScalarField') {
238
218
  nextSelection = transformField(context, fragments, scope, selection, errorContext);
239
219
  } else {
240
220
  selection;
@@ -252,7 +232,7 @@ function transformSelections(context, fragments, scope, selections, errorContext
252
232
  function transformDirectives(scope, directives, errorContext) {
253
233
  return directives.map(function (directive) {
254
234
  var args = transformArguments(scope, directive.args, errorContext);
255
- return (0, _objectSpread2["default"])({}, directive, {
235
+ return _objectSpread({}, directive, {
256
236
  args: args
257
237
  });
258
238
  });
@@ -261,7 +241,7 @@ function transformDirectives(scope, directives, errorContext) {
261
241
  function transformArguments(scope, args, errorContext) {
262
242
  return args.map(function (arg) {
263
243
  var value = transformValue(scope, arg.value, errorContext);
264
- return value === arg.value ? arg : (0, _objectSpread2["default"])({}, arg, {
244
+ return value === arg.value ? arg : _objectSpread({}, arg, {
265
245
  value: value
266
246
  });
267
247
  });
@@ -281,6 +261,20 @@ function transformValue(scope, value, errorContext) {
281
261
  }
282
262
 
283
263
  return scopeValue;
264
+ } else if (value.kind === 'ObjectValue') {
265
+ return _objectSpread({}, value, {
266
+ fields: value.fields.map(function (field) {
267
+ return _objectSpread({}, field, {
268
+ value: transformValue(scope, field.value, errorContext)
269
+ });
270
+ })
271
+ });
272
+ } else if (value.kind === 'ListValue') {
273
+ return _objectSpread({}, value, {
274
+ items: value.items.map(function (item) {
275
+ return transformValue(scope, item, errorContext);
276
+ })
277
+ });
284
278
  }
285
279
 
286
280
  return value;
@@ -320,7 +314,7 @@ function transformFragment(context, fragments, parentScope, spread, args, errorC
320
314
  var selections = transformSelections(context, fragments, fragmentScope, fragment.selections, errorContext);
321
315
 
322
316
  if (selections) {
323
- transformedFragment = (0, _objectSpread2["default"])({}, fragment, {
317
+ transformedFragment = _objectSpread({}, fragment, {
324
318
  selections: selections,
325
319
  name: fragmentName,
326
320
  argumentDefinitions: []