@ardatan/relay-compiler 12.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (256) hide show
  1. package/LICENSE +21 -0
  2. package/bin/RelayCompilerBin.js.flow +169 -0
  3. package/bin/RelayCompilerMain.js.flow +515 -0
  4. package/bin/__fixtures__/plugin-module.js.flow +17 -0
  5. package/bin/relay-compiler +19066 -0
  6. package/codegen/CodegenDirectory.js.flow +375 -0
  7. package/codegen/CodegenRunner.js.flow +432 -0
  8. package/codegen/CodegenTypes.js.flow +28 -0
  9. package/codegen/CodegenWatcher.js.flow +254 -0
  10. package/codegen/NormalizationCodeGenerator.js.flow +566 -0
  11. package/codegen/ReaderCodeGenerator.js.flow +512 -0
  12. package/codegen/RelayCodeGenerator.js.flow +85 -0
  13. package/codegen/RelayFileWriter.js.flow +367 -0
  14. package/codegen/SourceControl.js.flow +58 -0
  15. package/codegen/compileRelayArtifacts.js.flow +182 -0
  16. package/codegen/createPrintRequireModuleDependency.js.flow +19 -0
  17. package/codegen/sortObjectByKey.js.flow +25 -0
  18. package/codegen/writeRelayGeneratedFile.js.flow +239 -0
  19. package/core/ASTCache.js.flow +74 -0
  20. package/core/ASTConvert.js.flow +233 -0
  21. package/core/CompilerContext.js.flow +191 -0
  22. package/core/CompilerError.js.flow +255 -0
  23. package/core/DotGraphQLParser.js.flow +39 -0
  24. package/core/GraphQLCompilerProfiler.js.flow +341 -0
  25. package/core/GraphQLDerivedFromMetadata.js.flow +36 -0
  26. package/core/GraphQLWatchmanClient.js.flow +111 -0
  27. package/core/IR.js.flow +326 -0
  28. package/core/IRPrinter.js.flow +478 -0
  29. package/core/IRTransformer.js.flow +377 -0
  30. package/core/IRValidator.js.flow +260 -0
  31. package/core/IRVisitor.js.flow +150 -0
  32. package/core/JSModuleParser.js.flow +24 -0
  33. package/core/RelayCompilerScope.js.flow +199 -0
  34. package/core/RelayFindGraphQLTags.js.flow +119 -0
  35. package/core/RelayGraphQLEnumsGenerator.js.flow +55 -0
  36. package/core/RelayIRTransforms.js.flow +138 -0
  37. package/core/RelayParser.js.flow +1734 -0
  38. package/core/RelaySourceModuleParser.js.flow +135 -0
  39. package/core/Schema.js.flow +2037 -0
  40. package/core/SchemaUtils.js.flow +120 -0
  41. package/core/filterContextForNode.js.flow +50 -0
  42. package/core/getFieldDefinition.js.flow +156 -0
  43. package/core/getIdentifierForArgumentValue.js.flow +49 -0
  44. package/core/getIdentifierForSelection.js.flow +69 -0
  45. package/core/getLiteralArgumentValues.js.flow +32 -0
  46. package/core/getNormalizationOperationName.js.flow +19 -0
  47. package/core/inferRootArgumentDefinitions.js.flow +323 -0
  48. package/index.js +10 -0
  49. package/index.js.flow +200 -0
  50. package/language/RelayLanguagePluginInterface.js.flow +283 -0
  51. package/language/javascript/FindGraphQLTags.js.flow +137 -0
  52. package/language/javascript/RelayFlowBabelFactories.js.flow +176 -0
  53. package/language/javascript/RelayFlowGenerator.js.flow +1100 -0
  54. package/language/javascript/RelayFlowTypeTransformers.js.flow +184 -0
  55. package/language/javascript/RelayLanguagePluginJavaScript.js.flow +34 -0
  56. package/language/javascript/formatGeneratedModule.js.flow +65 -0
  57. package/lib/bin/RelayCompilerBin.js +143 -0
  58. package/lib/bin/RelayCompilerMain.js +486 -0
  59. package/lib/bin/__fixtures__/plugin-module.js +16 -0
  60. package/lib/codegen/CodegenDirectory.js +336 -0
  61. package/lib/codegen/CodegenRunner.js +433 -0
  62. package/lib/codegen/CodegenTypes.js +11 -0
  63. package/lib/codegen/CodegenWatcher.js +271 -0
  64. package/lib/codegen/NormalizationCodeGenerator.js +480 -0
  65. package/lib/codegen/ReaderCodeGenerator.js +472 -0
  66. package/lib/codegen/RelayCodeGenerator.js +68 -0
  67. package/lib/codegen/RelayFileWriter.js +270 -0
  68. package/lib/codegen/SourceControl.js +60 -0
  69. package/lib/codegen/compileRelayArtifacts.js +157 -0
  70. package/lib/codegen/createPrintRequireModuleDependency.js +19 -0
  71. package/lib/codegen/sortObjectByKey.js +41 -0
  72. package/lib/codegen/writeRelayGeneratedFile.js +208 -0
  73. package/lib/core/ASTCache.js +70 -0
  74. package/lib/core/ASTConvert.js +198 -0
  75. package/lib/core/CompilerContext.js +165 -0
  76. package/lib/core/CompilerError.js +251 -0
  77. package/lib/core/DotGraphQLParser.js +40 -0
  78. package/lib/core/GraphQLCompilerProfiler.js +299 -0
  79. package/lib/core/GraphQLDerivedFromMetadata.js +31 -0
  80. package/lib/core/GraphQLWatchmanClient.js +150 -0
  81. package/lib/core/IR.js +11 -0
  82. package/lib/core/IRPrinter.js +389 -0
  83. package/lib/core/IRTransformer.js +345 -0
  84. package/lib/core/IRValidator.js +226 -0
  85. package/lib/core/IRVisitor.js +45 -0
  86. package/lib/core/JSModuleParser.js +18 -0
  87. package/lib/core/RelayCompilerScope.js +149 -0
  88. package/lib/core/RelayFindGraphQLTags.js +79 -0
  89. package/lib/core/RelayGraphQLEnumsGenerator.js +50 -0
  90. package/lib/core/RelayIRTransforms.js +109 -0
  91. package/lib/core/RelayParser.js +1382 -0
  92. package/lib/core/RelaySourceModuleParser.js +104 -0
  93. package/lib/core/Schema.js +1877 -0
  94. package/lib/core/SchemaUtils.js +98 -0
  95. package/lib/core/filterContextForNode.js +49 -0
  96. package/lib/core/getFieldDefinition.js +145 -0
  97. package/lib/core/getIdentifierForArgumentValue.js +53 -0
  98. package/lib/core/getIdentifierForSelection.js +48 -0
  99. package/lib/core/getLiteralArgumentValues.js +26 -0
  100. package/lib/core/getNormalizationOperationName.js +17 -0
  101. package/lib/core/inferRootArgumentDefinitions.js +351 -0
  102. package/lib/index.js +178 -0
  103. package/lib/language/RelayLanguagePluginInterface.js +14 -0
  104. package/lib/language/javascript/FindGraphQLTags.js +126 -0
  105. package/lib/language/javascript/RelayFlowBabelFactories.js +160 -0
  106. package/lib/language/javascript/RelayFlowGenerator.js +857 -0
  107. package/lib/language/javascript/RelayFlowTypeTransformers.js +119 -0
  108. package/lib/language/javascript/RelayLanguagePluginJavaScript.js +30 -0
  109. package/lib/language/javascript/formatGeneratedModule.js +36 -0
  110. package/lib/reporters/ConsoleReporter.js +61 -0
  111. package/lib/reporters/MultiReporter.js +45 -0
  112. package/lib/reporters/Reporter.js +11 -0
  113. package/lib/runner/Artifacts.js +323 -0
  114. package/lib/runner/BufferedFilesystem.js +261 -0
  115. package/lib/runner/GraphQLASTNodeGroup.js +256 -0
  116. package/lib/runner/GraphQLASTUtils.js +23 -0
  117. package/lib/runner/GraphQLNodeMap.js +81 -0
  118. package/lib/runner/Sources.js +271 -0
  119. package/lib/runner/StrictMap.js +134 -0
  120. package/lib/runner/compileArtifacts.js +39 -0
  121. package/lib/runner/extractAST.js +77 -0
  122. package/lib/runner/getChangedNodeNames.js +82 -0
  123. package/lib/runner/getSchemaInstance.js +30 -0
  124. package/lib/runner/types.js +12 -0
  125. package/lib/transforms/ApplyFragmentArgumentTransform.js +393 -0
  126. package/lib/transforms/ClientExtensionsTransform.js +222 -0
  127. package/lib/transforms/ConnectionTransform.js +643 -0
  128. package/lib/transforms/DeclarativeConnectionMutationTransform.js +221 -0
  129. package/lib/transforms/DeferStreamTransform.js +247 -0
  130. package/lib/transforms/DisallowIdAsAlias.js +41 -0
  131. package/lib/transforms/DisallowTypenameOnRoot.js +53 -0
  132. package/lib/transforms/FieldHandleTransform.js +81 -0
  133. package/lib/transforms/FilterCompilerDirectivesTransform.js +29 -0
  134. package/lib/transforms/FilterDirectivesTransform.js +41 -0
  135. package/lib/transforms/FlattenTransform.js +308 -0
  136. package/lib/transforms/GenerateIDFieldTransform.js +137 -0
  137. package/lib/transforms/GenerateTypeNameTransform.js +155 -0
  138. package/lib/transforms/InlineDataFragmentTransform.js +104 -0
  139. package/lib/transforms/InlineFragmentsTransform.js +63 -0
  140. package/lib/transforms/MaskTransform.js +121 -0
  141. package/lib/transforms/MatchTransform.js +438 -0
  142. package/lib/transforms/ReactFlightComponentTransform.js +161 -0
  143. package/lib/transforms/RefetchableFragmentTransform.js +249 -0
  144. package/lib/transforms/RelayDirectiveTransform.js +85 -0
  145. package/lib/transforms/RequiredFieldTransform.js +373 -0
  146. package/lib/transforms/SkipClientExtensionsTransform.js +49 -0
  147. package/lib/transforms/SkipHandleFieldTransform.js +45 -0
  148. package/lib/transforms/SkipRedundantNodesTransform.js +255 -0
  149. package/lib/transforms/SkipSplitOperationTransform.js +32 -0
  150. package/lib/transforms/SkipUnreachableNodeTransform.js +158 -0
  151. package/lib/transforms/SkipUnusedVariablesTransform.js +74 -0
  152. package/lib/transforms/SplitModuleImportTransform.js +85 -0
  153. package/lib/transforms/TestOperationTransform.js +145 -0
  154. package/lib/transforms/TransformUtils.js +21 -0
  155. package/lib/transforms/ValidateGlobalVariablesTransform.js +91 -0
  156. package/lib/transforms/ValidateRequiredArgumentsTransform.js +118 -0
  157. package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +111 -0
  158. package/lib/transforms/ValidateUnusedVariablesTransform.js +96 -0
  159. package/lib/transforms/query-generators/FetchableQueryGenerator.js +157 -0
  160. package/lib/transforms/query-generators/NodeQueryGenerator.js +166 -0
  161. package/lib/transforms/query-generators/QueryQueryGenerator.js +48 -0
  162. package/lib/transforms/query-generators/ViewerQueryGenerator.js +77 -0
  163. package/lib/transforms/query-generators/index.js +60 -0
  164. package/lib/transforms/query-generators/utils.js +92 -0
  165. package/lib/util/CodeMarker.js +80 -0
  166. package/lib/util/DefaultHandleKey.js +15 -0
  167. package/lib/util/RelayCompilerCache.js +98 -0
  168. package/lib/util/Rollout.js +40 -0
  169. package/lib/util/TimeReporter.js +83 -0
  170. package/lib/util/areEqualArgValues.js +135 -0
  171. package/lib/util/argumentContainsVariables.js +37 -0
  172. package/lib/util/dedupeJSONStringify.js +160 -0
  173. package/lib/util/generateAbstractTypeRefinementKey.js +24 -0
  174. package/lib/util/getDefinitionNodeHash.js +22 -0
  175. package/lib/util/getModuleName.js +32 -0
  176. package/lib/util/joinArgumentDefinitions.js +66 -0
  177. package/lib/util/md5.js +17 -0
  178. package/lib/util/murmurHash.js +86 -0
  179. package/lib/util/nullthrowsOSS.js +23 -0
  180. package/lib/util/orList.js +36 -0
  181. package/lib/util/partitionArray.js +35 -0
  182. package/package.json +42 -0
  183. package/relay-compiler.js +17 -0
  184. package/relay-compiler.min.js +22 -0
  185. package/reporters/ConsoleReporter.js.flow +81 -0
  186. package/reporters/MultiReporter.js.flow +43 -0
  187. package/reporters/Reporter.js.flow +19 -0
  188. package/runner/Artifacts.js.flow +219 -0
  189. package/runner/BufferedFilesystem.js.flow +194 -0
  190. package/runner/GraphQLASTNodeGroup.js.flow +176 -0
  191. package/runner/GraphQLASTUtils.js.flow +26 -0
  192. package/runner/GraphQLNodeMap.js.flow +55 -0
  193. package/runner/Sources.js.flow +228 -0
  194. package/runner/StrictMap.js.flow +96 -0
  195. package/runner/compileArtifacts.js.flow +76 -0
  196. package/runner/extractAST.js.flow +100 -0
  197. package/runner/getChangedNodeNames.js.flow +48 -0
  198. package/runner/getSchemaInstance.js.flow +36 -0
  199. package/runner/types.js.flow +37 -0
  200. package/transforms/ApplyFragmentArgumentTransform.js.flow +526 -0
  201. package/transforms/ClientExtensionsTransform.js.flow +226 -0
  202. package/transforms/ConnectionTransform.js.flow +859 -0
  203. package/transforms/DeclarativeConnectionMutationTransform.js.flow +250 -0
  204. package/transforms/DeferStreamTransform.js.flow +266 -0
  205. package/transforms/DisallowIdAsAlias.js.flow +48 -0
  206. package/transforms/DisallowTypenameOnRoot.js.flow +45 -0
  207. package/transforms/FieldHandleTransform.js.flow +81 -0
  208. package/transforms/FilterCompilerDirectivesTransform.js.flow +33 -0
  209. package/transforms/FilterDirectivesTransform.js.flow +45 -0
  210. package/transforms/FlattenTransform.js.flow +462 -0
  211. package/transforms/GenerateIDFieldTransform.js.flow +154 -0
  212. package/transforms/GenerateTypeNameTransform.js.flow +167 -0
  213. package/transforms/InlineDataFragmentTransform.js.flow +129 -0
  214. package/transforms/InlineFragmentsTransform.js.flow +73 -0
  215. package/transforms/MaskTransform.js.flow +130 -0
  216. package/transforms/MatchTransform.js.flow +593 -0
  217. package/transforms/ReactFlightComponentTransform.js.flow +198 -0
  218. package/transforms/RefetchableFragmentTransform.js.flow +272 -0
  219. package/transforms/RelayDirectiveTransform.js.flow +99 -0
  220. package/transforms/RequiredFieldTransform.js.flow +419 -0
  221. package/transforms/SkipClientExtensionsTransform.js.flow +57 -0
  222. package/transforms/SkipHandleFieldTransform.js.flow +45 -0
  223. package/transforms/SkipRedundantNodesTransform.js.flow +259 -0
  224. package/transforms/SkipSplitOperationTransform.js.flow +37 -0
  225. package/transforms/SkipUnreachableNodeTransform.js.flow +149 -0
  226. package/transforms/SkipUnusedVariablesTransform.js.flow +59 -0
  227. package/transforms/SplitModuleImportTransform.js.flow +101 -0
  228. package/transforms/TestOperationTransform.js.flow +143 -0
  229. package/transforms/TransformUtils.js.flow +26 -0
  230. package/transforms/ValidateGlobalVariablesTransform.js.flow +81 -0
  231. package/transforms/ValidateRequiredArgumentsTransform.js.flow +131 -0
  232. package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +115 -0
  233. package/transforms/ValidateUnusedVariablesTransform.js.flow +89 -0
  234. package/transforms/query-generators/FetchableQueryGenerator.js.flow +189 -0
  235. package/transforms/query-generators/NodeQueryGenerator.js.flow +219 -0
  236. package/transforms/query-generators/QueryQueryGenerator.js.flow +57 -0
  237. package/transforms/query-generators/ViewerQueryGenerator.js.flow +97 -0
  238. package/transforms/query-generators/index.js.flow +90 -0
  239. package/transforms/query-generators/utils.js.flow +76 -0
  240. package/util/CodeMarker.js.flow +79 -0
  241. package/util/DefaultHandleKey.js.flow +17 -0
  242. package/util/RelayCompilerCache.js.flow +88 -0
  243. package/util/Rollout.js.flow +39 -0
  244. package/util/TimeReporter.js.flow +79 -0
  245. package/util/areEqualArgValues.js.flow +126 -0
  246. package/util/argumentContainsVariables.js.flow +38 -0
  247. package/util/dedupeJSONStringify.js.flow +152 -0
  248. package/util/generateAbstractTypeRefinementKey.js.flow +29 -0
  249. package/util/getDefinitionNodeHash.js.flow +25 -0
  250. package/util/getModuleName.js.flow +39 -0
  251. package/util/joinArgumentDefinitions.js.flow +105 -0
  252. package/util/md5.js.flow +22 -0
  253. package/util/murmurHash.js.flow +94 -0
  254. package/util/nullthrowsOSS.js.flow +25 -0
  255. package/util/orList.js.flow +37 -0
  256. package/util/partitionArray.js.flow +37 -0
@@ -0,0 +1,98 @@
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 _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
16
+
17
+ var Profiler = require('../core/GraphQLCompilerProfiler');
18
+
19
+ var crypto = require('crypto');
20
+
21
+ var fs = require('fs');
22
+
23
+ var os = require('os');
24
+
25
+ var path = require('path');
26
+ /**
27
+ * A file backed cache. Values are JSON encoded on disk, so only JSON
28
+ * serializable values should be used.
29
+ */
30
+
31
+
32
+ var RelayCompilerCache = /*#__PURE__*/function () {
33
+ /**
34
+ * @param name Human readable identifier for the cache
35
+ * @param cacheBreaker This should be changed in order to invalidate existing
36
+ * caches.
37
+ */
38
+ function RelayCompilerCache(name, cacheBreaker) {
39
+ (0, _defineProperty2["default"])(this, "_dir", null);
40
+ this._name = name;
41
+ this._cacheBreaker = cacheBreaker;
42
+ }
43
+
44
+ var _proto = RelayCompilerCache.prototype;
45
+
46
+ _proto._getFile = function _getFile(key) {
47
+ if (this._dir == null) {
48
+ // Include username in the cache dir to avoid issues with directories being
49
+ // owned by a different user.
50
+ var username = os.userInfo().username;
51
+ var cacheID = crypto.createHash('md5').update(this._cacheBreaker).update(username).digest('hex');
52
+ var dir = path.join(os.tmpdir(), "".concat(this._name, "-").concat(cacheID));
53
+
54
+ if (!fs.existsSync(dir)) {
55
+ try {
56
+ fs.mkdirSync(dir);
57
+ } catch (error) {
58
+ if (error.code !== 'EEXIST') {
59
+ throw error;
60
+ }
61
+ }
62
+ }
63
+
64
+ this._dir = dir;
65
+ }
66
+
67
+ return path.join(this._dir, key);
68
+ };
69
+
70
+ _proto.getOrCompute = function getOrCompute(key, compute) {
71
+ var _this = this;
72
+
73
+ return Profiler.run('RelayCompilerCache.getOrCompute', function () {
74
+ var cacheFile = _this._getFile(key);
75
+
76
+ if (fs.existsSync(cacheFile)) {
77
+ try {
78
+ return JSON.parse(fs.readFileSync(cacheFile, 'utf8'));
79
+ } catch (_unused) {// ignore
80
+ }
81
+ }
82
+
83
+ var value = compute();
84
+
85
+ try {
86
+ // $FlowFixMe[incompatible-call] JSON.stringify can return undefined
87
+ fs.writeFileSync(cacheFile, JSON.stringify(value), 'utf8');
88
+ } catch (_unused2) {// ignore
89
+ }
90
+
91
+ return value;
92
+ });
93
+ };
94
+
95
+ return RelayCompilerCache;
96
+ }();
97
+
98
+ module.exports = RelayCompilerCache;
@@ -0,0 +1,40 @@
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 whitelistsByProject = null;
14
+ /**
15
+ * This module helps gradually rolling out changes to the code generation by
16
+ * gradually enabling more buckets representing randomly distributed artifacts.
17
+ */
18
+
19
+ function set(newWhitelistsByProject) {
20
+ whitelistsByProject = newWhitelistsByProject;
21
+ }
22
+
23
+ function check(project, key) {
24
+ if (whitelistsByProject == null) {
25
+ return true;
26
+ }
27
+
28
+ var whitelist = whitelistsByProject.get(project);
29
+
30
+ if (whitelist == null) {
31
+ return true;
32
+ }
33
+
34
+ return whitelist.has(key);
35
+ }
36
+
37
+ module.exports = {
38
+ set: set,
39
+ check: check
40
+ };
@@ -0,0 +1,83 @@
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
+ * @emails oncall+relay
10
+ */
11
+ // flowlint ambiguous-object-type:error
12
+ 'use strict';
13
+
14
+ var _asyncToGenerator = require("@babel/runtime/helpers/asyncToGenerator");
15
+
16
+ var _require = require('relay-runtime'),
17
+ isPromise = _require.isPromise;
18
+
19
+ function reportTime(reporter, message, fn) {
20
+ return reportAndReturnTime(reporter, message, fn)[0];
21
+ }
22
+
23
+ function reportAndReturnTime(reporter, message, fn) {
24
+ var startTime = Date.now();
25
+ var result = fn();
26
+
27
+ if (isPromise(result)) {
28
+ throw new Error('reportAndReturnTime: fn(...) returned an unexpected promise.' + ' Please use `reportAndReturnAsyncTime` method instead.');
29
+ }
30
+
31
+ var elapsedTime = Date.now() - startTime;
32
+ reporter.reportTime(message, elapsedTime);
33
+ return [result, elapsedTime];
34
+ }
35
+
36
+ function reportAndReturnAsyncTime(_x, _x2, _x3) {
37
+ return _reportAndReturnAsyncTime.apply(this, arguments);
38
+ }
39
+
40
+ function _reportAndReturnAsyncTime() {
41
+ _reportAndReturnAsyncTime = _asyncToGenerator(function* (reporter, message, fn) {
42
+ var startTime = Date.now();
43
+ var promise = fn();
44
+
45
+ if (!isPromise(promise)) {
46
+ throw new Error('reportAsyncTime: fn(...) expected to return a promise.');
47
+ }
48
+
49
+ var result = yield promise;
50
+ var elapsedTime = Date.now() - startTime;
51
+ reporter.reportTime(message, elapsedTime);
52
+ return [result, elapsedTime];
53
+ });
54
+ return _reportAndReturnAsyncTime.apply(this, arguments);
55
+ }
56
+
57
+ function reportAsyncTime(_x4, _x5, _x6) {
58
+ return _reportAsyncTime.apply(this, arguments);
59
+ }
60
+
61
+ function _reportAsyncTime() {
62
+ _reportAsyncTime = _asyncToGenerator(function* (reporter, message, fn) {
63
+ var startTime = Date.now();
64
+ var promise = fn();
65
+
66
+ if (!isPromise(promise)) {
67
+ throw new Error('reportAsyncTime: fn(...) expected to return a promise.');
68
+ }
69
+
70
+ var result = yield promise;
71
+ var elapsedTime = Date.now() - startTime;
72
+ reporter.reportTime(message, elapsedTime);
73
+ return result;
74
+ });
75
+ return _reportAsyncTime.apply(this, arguments);
76
+ }
77
+
78
+ module.exports = {
79
+ reportTime: reportTime,
80
+ reportAndReturnTime: reportAndReturnTime,
81
+ reportAsyncTime: reportAsyncTime,
82
+ reportAndReturnAsyncTime: reportAndReturnAsyncTime
83
+ };
@@ -0,0 +1,135 @@
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
+ // TODO: This is only used with `ArgumentValue` types, so it could be simpler.
11
+ // flowlint ambiguous-object-type:error
12
+ 'use strict';
13
+
14
+ var aStackPool = [];
15
+ var bStackPool = [];
16
+ /**
17
+ * Checks if two values are equal. Values may be primitives, arrays, or objects.
18
+ * Returns true if both arguments have the same keys and values.
19
+ *
20
+ * @see http://underscorejs.org
21
+ * @copyright 2009-2013 Jeremy Ashkenas, DocumentCloud Inc.
22
+ * @license MIT
23
+ */
24
+
25
+ function areEqualArgValues(a, b) {
26
+ var aStack = aStackPool.length ? aStackPool.pop() : [];
27
+ var bStack = bStackPool.length ? bStackPool.pop() : [];
28
+ var result = eq(a, b, aStack, bStack);
29
+ aStack.length = 0;
30
+ bStack.length = 0;
31
+ aStackPool.push(aStack);
32
+ bStackPool.push(bStack);
33
+ return result;
34
+ }
35
+
36
+ function eq(a, b, aStack, bStack) {
37
+ if (a === b) {
38
+ // Identical objects are equal. `0 === -0`, but they aren't identical.
39
+ return a !== 0 || 1 / a === 1 / b;
40
+ }
41
+
42
+ if (a == null || b == null) {
43
+ // a or b can be `null` or `undefined`
44
+ return false;
45
+ }
46
+
47
+ if (typeof a !== 'object' || typeof b !== 'object') {
48
+ return false;
49
+ } // $FlowFixMe[method-unbinding] added when improving typing for this parameters
50
+
51
+
52
+ var objToStr = Object.prototype.toString;
53
+ var className = objToStr.call(a);
54
+
55
+ if (className !== objToStr.call(b)) {
56
+ return false;
57
+ }
58
+
59
+ switch (className) {
60
+ case '[object String]':
61
+ return a === String(b);
62
+
63
+ case '[object Number]':
64
+ return isNaN(a) || isNaN(b) ? false : a === Number(b);
65
+
66
+ case '[object Date]':
67
+ case '[object Boolean]':
68
+ return +a === +b;
69
+
70
+ case '[object RegExp]':
71
+ return a.source === b.source && a.global === b.global && a.multiline === b.multiline && a.ignoreCase === b.ignoreCase;
72
+ } // Assume equality for cyclic structures.
73
+
74
+
75
+ var length = aStack.length;
76
+
77
+ while (length--) {
78
+ if (aStack[length] === a) {
79
+ return bStack[length] === b;
80
+ }
81
+ }
82
+
83
+ aStack.push(a);
84
+ bStack.push(b);
85
+ var size = 0; // Recursively compare objects and arrays.
86
+
87
+ if (className === '[object Array]') {
88
+ size = a.length;
89
+
90
+ if (size !== b.length) {
91
+ return false;
92
+ } // Deep compare the contents, ignoring non-numeric properties.
93
+
94
+
95
+ while (size--) {
96
+ if (!eq(a[size], b[size], aStack, bStack)) {
97
+ return false;
98
+ }
99
+ }
100
+ } else {
101
+ if (a.constructor !== b.constructor) {
102
+ return false;
103
+ }
104
+
105
+ if (a.hasOwnProperty('valueOf') && b.hasOwnProperty('valueOf')) {
106
+ return a.valueOf() === b.valueOf();
107
+ }
108
+
109
+ var keys = Object.keys(a);
110
+
111
+ if (keys.length !== Object.keys(b).length) {
112
+ return false;
113
+ }
114
+
115
+ for (var i = 0; i < keys.length; i++) {
116
+ if (keys[i] === '_owner') {
117
+ // HACK: Comparing deeply nested React trees is slow since you end up
118
+ // comparing the entire tree (all ancestors and all children) and
119
+ // likely not what you want if you're comparing two elements with
120
+ // areEqualArgValues. We bail out here for now.
121
+ continue;
122
+ }
123
+
124
+ if (!b.hasOwnProperty(keys[i]) || !eq(a[keys[i]], b[keys[i]], aStack, bStack)) {
125
+ return false;
126
+ }
127
+ }
128
+ }
129
+
130
+ aStack.pop();
131
+ bStack.pop();
132
+ return true;
133
+ }
134
+
135
+ module.exports = areEqualArgValues;
@@ -0,0 +1,37 @@
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
+ function argumentContainsVariables(arg) {
14
+ if (arg == null) {
15
+ return false;
16
+ }
17
+
18
+ switch (arg.kind) {
19
+ case 'Variable':
20
+ return true;
21
+
22
+ case 'Literal':
23
+ return false;
24
+
25
+ case 'ListValue':
26
+ return arg.items.some(argumentContainsVariables);
27
+
28
+ case 'ObjectValue':
29
+ return arg.fields.some(argumentContainsVariables);
30
+
31
+ default:
32
+ arg.kind;
33
+ return false;
34
+ }
35
+ }
36
+
37
+ module.exports = argumentContainsVariables;
@@ -0,0 +1,160 @@
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
+ * This function works similar to JSON.stringify except that for the case there
14
+ * are multiple common subtrees, it generates a string for a IIFE that re-uses
15
+ * the same objects for the duplicate subtrees.
16
+ */
17
+
18
+ function dedupeJSONStringify(jsonValue) {
19
+ var metadataForHash = new Map();
20
+ var metadataForVal = new WeakMap();
21
+ var varDefs = [];
22
+ collectMetadata(jsonValue);
23
+ collectDuplicates(jsonValue);
24
+ var code = printJSCode(false, '', jsonValue);
25
+ return varDefs.length === 0 ? code : "(function(){\nvar ".concat(varDefs.join(',\n'), ";\nreturn ").concat(code, ";\n})()"); // Collect common metadata for each object in the value tree, ensuring that
26
+ // equivalent values have the *same reference* to the same metadata. Note that
27
+ // the hashes generated are not exactly JSON, but still identify equivalent
28
+ // values. Runs in linear time due to hashing in a bottom-up recursion.
29
+
30
+ function collectMetadata(value) {
31
+ if (value == null || typeof value !== 'object') {
32
+ // $FlowFixMe[incompatible-return] - JSON.stringify can return undefined
33
+ return JSON.stringify(value);
34
+ }
35
+
36
+ var hash;
37
+
38
+ if (Array.isArray(value)) {
39
+ hash = '[';
40
+
41
+ for (var i = 0; i < value.length; i++) {
42
+ hash += collectMetadata(value[i]) + ',';
43
+ }
44
+ } else {
45
+ hash = '{';
46
+
47
+ for (var k in value) {
48
+ if (value.hasOwnProperty(k) && value[k] !== undefined) {
49
+ hash += k + ':' + collectMetadata(value[k]) + ',';
50
+ }
51
+ }
52
+ }
53
+
54
+ var metadata = metadataForHash.get(hash);
55
+
56
+ if (!metadata) {
57
+ metadata = {
58
+ value: value,
59
+ hash: hash,
60
+ count: 0
61
+ };
62
+ metadataForHash.set(hash, metadata);
63
+ }
64
+
65
+ metadataForVal.set(value, metadata);
66
+ return hash;
67
+ } // Using top-down recursion, linearly scan the JSON tree to determine which
68
+ // values should be deduplicated.
69
+
70
+
71
+ function collectDuplicates(value) {
72
+ if (value == null || typeof value !== 'object') {
73
+ return;
74
+ }
75
+
76
+ var metadata = metadataForVal.get(value); // Only consider duplicates with hashes longer than 2 (excludes [] and {}).
77
+
78
+ if (metadata && metadata.hash.length > 2) {
79
+ metadata.count++;
80
+
81
+ if (metadata.count > 1) {
82
+ return;
83
+ }
84
+ }
85
+
86
+ if (Array.isArray(value)) {
87
+ for (var i = 0; i < value.length; i++) {
88
+ collectDuplicates(value[i]);
89
+ }
90
+ } else {
91
+ for (var k in value) {
92
+ if (value.hasOwnProperty(k) && value[k] !== undefined) {
93
+ collectDuplicates(value[k]);
94
+ }
95
+ }
96
+ }
97
+ } // Stringify JS, replacing duplicates with variable references.
98
+
99
+
100
+ function printJSCode(isDupedVar, depth, value) {
101
+ if (value == null || typeof value !== 'object') {
102
+ // $FlowFixMe[incompatible-return] : JSON.stringify can return undefined
103
+ return JSON.stringify(value);
104
+ } // Only use variable references at depth beyond the top level.
105
+
106
+
107
+ if (depth !== '') {
108
+ var metadata = metadataForVal.get(value);
109
+
110
+ if (metadata && metadata.count > 1) {
111
+ var varName = metadata.varName;
112
+
113
+ if (varName == null) {
114
+ var refCode = printJSCode(true, '', value);
115
+ varName = metadata.varName = 'v' + varDefs.length;
116
+ varDefs.push(metadata.varName + ' = ' + refCode);
117
+ }
118
+
119
+ return '(' + varName + '/*: any*/)';
120
+ }
121
+ }
122
+
123
+ var str;
124
+ var isEmpty = true;
125
+ var depth2 = depth + ' ';
126
+
127
+ if (Array.isArray(value)) {
128
+ // Empty arrays can only have one inferred flow type and then conflict if
129
+ // used in different places, this is unsound if we would write to them but
130
+ // this whole module is based on the idea of a read only JSON tree.
131
+ if (isDupedVar && value.length === 0) {
132
+ return '([]/*: any*/)';
133
+ }
134
+
135
+ str = '[';
136
+
137
+ for (var i = 0; i < value.length; i++) {
138
+ str += (isEmpty ? '\n' : ',\n') + depth2 + printJSCode(isDupedVar, depth2, value[i]);
139
+ isEmpty = false;
140
+ }
141
+
142
+ str += isEmpty ? ']' : "\n".concat(depth, "]");
143
+ } else {
144
+ str = '{';
145
+
146
+ for (var k in value) {
147
+ if (value.hasOwnProperty(k) && value[k] !== undefined) {
148
+ str += (isEmpty ? '\n' : ',\n') + depth2 + JSON.stringify(k) + ': ' + printJSCode(isDupedVar, depth2, value[k]);
149
+ isEmpty = false;
150
+ }
151
+ }
152
+
153
+ str += isEmpty ? '}' : "\n".concat(depth, "}");
154
+ }
155
+
156
+ return str;
157
+ }
158
+ }
159
+
160
+ module.exports = dedupeJSONStringify;
@@ -0,0 +1,24 @@
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/CompilerError'),
14
+ createCompilerError = _require.createCompilerError;
15
+
16
+ function generateAbstractTypeRefinementKey(schema, type) {
17
+ if (!schema.isAbstractType(type)) {
18
+ throw createCompilerError('Expected an abstract type');
19
+ }
20
+
21
+ return "__is".concat(schema.getTypeString(type));
22
+ }
23
+
24
+ module.exports = generateAbstractTypeRefinementKey;
@@ -0,0 +1,22 @@
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 md5 = require('./md5');
14
+
15
+ var _require = require('graphql'),
16
+ print = _require.print;
17
+
18
+ function getDefinitionNodeHash(node) {
19
+ return md5(print(node));
20
+ }
21
+
22
+ module.exports = getDefinitionNodeHash;
@@ -0,0 +1,32 @@
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 path = require('path');
14
+
15
+ function getModuleName(filePath) {
16
+ // index.js -> index
17
+ // index.js.flow -> index.js
18
+ var filename = path.basename(filePath, path.extname(filePath)); // index.js -> index (when extension has multiple segments)
19
+ // index.react -> index (when extension has multiple segments)
20
+
21
+ filename = filename.replace(/(\.(?!ios|android)[_a-zA-Z0-9\\-]+)+/g, ''); // /path/to/button/index.js -> button
22
+
23
+ var moduleName = filename === 'index' ? path.basename(path.dirname(filePath)) : filename; // foo-bar -> fooBar
24
+ // Relay compatibility mode splits on _, so we can't use that here.
25
+
26
+ moduleName = moduleName.replace(/[^a-zA-Z0-9]+(\w?)/g, function (match, next) {
27
+ return next.toUpperCase();
28
+ });
29
+ return moduleName;
30
+ }
31
+
32
+ module.exports = getModuleName;
@@ -0,0 +1,66 @@
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/CompilerError'),
14
+ createUserError = _require.createUserError;
15
+
16
+ /**
17
+ * Attempts to join the argument definitions for a root fragment
18
+ * and any unmasked fragment spreads reachable from that root fragment,
19
+ * returning a combined list of arguments or throwing if the same
20
+ * variable(s) are used in incompatible ways in different fragments.
21
+ */
22
+ function joinArgumentDefinitions(schema, fragment, reachableArguments, directiveName) {
23
+ var joinedArgumentDefinitions = new Map();
24
+ fragment.argumentDefinitions.forEach(function (prevArgDef) {
25
+ joinedArgumentDefinitions.set(prevArgDef.name, prevArgDef);
26
+ });
27
+ reachableArguments.forEach(function (nextArgDef) {
28
+ var prevArgDef = joinedArgumentDefinitions.get(nextArgDef.name);
29
+ var joinedArgDef = prevArgDef == null ? nextArgDef : joinArgumentDefinition(schema, prevArgDef, nextArgDef, directiveName);
30
+ joinedArgumentDefinitions.set(joinedArgDef.name, joinedArgDef);
31
+ });
32
+ return Array.from(joinedArgumentDefinitions.values());
33
+ }
34
+ /**
35
+ * @private
36
+ *
37
+ * Attempts to join two argument definitions, returning a single argument
38
+ * definition that is compatible with both of the inputs:
39
+ * - If the kind, name, or defaultValue is different then the arguments
40
+ * cannot be joined, indicated by returning null.
41
+ * - If either of next/prev is a subtype of the other, return the one
42
+ * that is the subtype: a more narrow type can flow into a more general
43
+ * type but not the inverse.
44
+ * - Otherwise there is no subtyping relation between prev/next, so return
45
+ * null to indicate they cannot be joined.
46
+ */
47
+
48
+
49
+ function joinArgumentDefinition(schema, prevArgDef, nextArgDef, directiveName) {
50
+ if (prevArgDef.kind !== nextArgDef.kind) {
51
+ throw createUserError('Cannot combine global and local variables when applying ' + "".concat(directiveName, "."), [prevArgDef.loc, nextArgDef.loc]);
52
+ } else if (prevArgDef.kind === 'LocalArgumentDefinition' && nextArgDef.kind === 'LocalArgumentDefinition' && prevArgDef.defaultValue !== nextArgDef.defaultValue) {
53
+ throw createUserError('Cannot combine local variables with different defaultValues when ' + "applying ".concat(directiveName, "."), [prevArgDef.loc, nextArgDef.loc]);
54
+ } else if (schema.isTypeSubTypeOf(nextArgDef.type, prevArgDef.type)) {
55
+ // prevArgDef is less strict than nextArgDef
56
+ return nextArgDef;
57
+ } else if (schema.isTypeSubTypeOf(prevArgDef.type, nextArgDef.type)) {
58
+ return prevArgDef;
59
+ } else {
60
+ var prevArgType = prevArgDef.type != null ? schema.getTypeString(prevArgDef.type) : 'unknown';
61
+ var nextArgType = nextArgDef.type != null ? schema.getTypeString(nextArgDef.type) : 'unknown';
62
+ throw createUserError('Cannot combine variables with incompatible types ' + "".concat(prevArgType, " and ").concat(nextArgType, " ") + "when applying ".concat(directiveName, "."), [prevArgDef.loc, nextArgDef.loc]);
63
+ }
64
+ }
65
+
66
+ module.exports = joinArgumentDefinitions;