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

Sign up to get free protection for your applications and to get access to all the features.
Files changed (259) hide show
  1. package/cli.js +23 -0
  2. package/index.js +19 -3
  3. package/linux-x64/relay +0 -0
  4. package/macos-x64/relay +0 -0
  5. package/package.json +2 -26
  6. package/win-x64/relay.exe +0 -0
  7. package/bin/RelayCompilerBin.js.flow +0 -168
  8. package/bin/RelayCompilerMain.js.flow +0 -513
  9. package/bin/__fixtures__/plugin-module.js.flow +0 -17
  10. package/bin/relay-compiler +0 -19066
  11. package/codegen/CodegenDirectory.js.flow +0 -372
  12. package/codegen/CodegenRunner.js.flow +0 -424
  13. package/codegen/CodegenTypes.js.flow +0 -28
  14. package/codegen/CodegenWatcher.js.flow +0 -250
  15. package/codegen/NormalizationCodeGenerator.js.flow +0 -565
  16. package/codegen/ReaderCodeGenerator.js.flow +0 -510
  17. package/codegen/RelayCodeGenerator.js.flow +0 -85
  18. package/codegen/RelayFileWriter.js.flow +0 -365
  19. package/codegen/SourceControl.js.flow +0 -58
  20. package/codegen/compileRelayArtifacts.js.flow +0 -181
  21. package/codegen/createPrintRequireModuleDependency.js.flow +0 -19
  22. package/codegen/sortObjectByKey.js.flow +0 -25
  23. package/codegen/writeRelayGeneratedFile.js.flow +0 -235
  24. package/core/ASTCache.js.flow +0 -73
  25. package/core/ASTConvert.js.flow +0 -230
  26. package/core/CompilerContext.js.flow +0 -189
  27. package/core/CompilerError.js.flow +0 -255
  28. package/core/DotGraphQLParser.js.flow +0 -37
  29. package/core/GraphQLCompilerProfiler.js.flow +0 -341
  30. package/core/GraphQLDerivedFromMetadata.js.flow +0 -36
  31. package/core/GraphQLWatchmanClient.js.flow +0 -109
  32. package/core/IR.js.flow +0 -326
  33. package/core/IRPrinter.js.flow +0 -472
  34. package/core/IRTransformer.js.flow +0 -376
  35. package/core/IRValidator.js.flow +0 -259
  36. package/core/IRVisitor.js.flow +0 -150
  37. package/core/JSModuleParser.js.flow +0 -24
  38. package/core/RelayCompilerScope.js.flow +0 -199
  39. package/core/RelayFindGraphQLTags.js.flow +0 -118
  40. package/core/RelayGraphQLEnumsGenerator.js.flow +0 -55
  41. package/core/RelayIRTransforms.js.flow +0 -138
  42. package/core/RelayParser.js.flow +0 -1731
  43. package/core/RelaySourceModuleParser.js.flow +0 -133
  44. package/core/Schema.js.flow +0 -2035
  45. package/core/SchemaUtils.js.flow +0 -120
  46. package/core/filterContextForNode.js.flow +0 -49
  47. package/core/getFieldDefinition.js.flow +0 -156
  48. package/core/getIdentifierForArgumentValue.js.flow +0 -49
  49. package/core/getIdentifierForSelection.js.flow +0 -68
  50. package/core/getLiteralArgumentValues.js.flow +0 -32
  51. package/core/getNormalizationOperationName.js.flow +0 -19
  52. package/core/inferRootArgumentDefinitions.js.flow +0 -322
  53. package/index.js.flow +0 -198
  54. package/language/RelayLanguagePluginInterface.js.flow +0 -283
  55. package/language/javascript/FindGraphQLTags.js.flow +0 -136
  56. package/language/javascript/RelayFlowBabelFactories.js.flow +0 -176
  57. package/language/javascript/RelayFlowGenerator.js.flow +0 -1096
  58. package/language/javascript/RelayFlowTypeTransformers.js.flow +0 -181
  59. package/language/javascript/RelayLanguagePluginJavaScript.js.flow +0 -33
  60. package/language/javascript/formatGeneratedModule.js.flow +0 -65
  61. package/lib/bin/RelayCompilerBin.js +0 -143
  62. package/lib/bin/RelayCompilerMain.js +0 -486
  63. package/lib/bin/__fixtures__/plugin-module.js +0 -16
  64. package/lib/codegen/CodegenDirectory.js +0 -335
  65. package/lib/codegen/CodegenRunner.js +0 -433
  66. package/lib/codegen/CodegenTypes.js +0 -11
  67. package/lib/codegen/CodegenWatcher.js +0 -271
  68. package/lib/codegen/NormalizationCodeGenerator.js +0 -487
  69. package/lib/codegen/ReaderCodeGenerator.js +0 -473
  70. package/lib/codegen/RelayCodeGenerator.js +0 -75
  71. package/lib/codegen/RelayFileWriter.js +0 -270
  72. package/lib/codegen/SourceControl.js +0 -60
  73. package/lib/codegen/compileRelayArtifacts.js +0 -157
  74. package/lib/codegen/createPrintRequireModuleDependency.js +0 -19
  75. package/lib/codegen/sortObjectByKey.js +0 -41
  76. package/lib/codegen/writeRelayGeneratedFile.js +0 -206
  77. package/lib/core/ASTCache.js +0 -70
  78. package/lib/core/ASTConvert.js +0 -198
  79. package/lib/core/CompilerContext.js +0 -165
  80. package/lib/core/CompilerError.js +0 -252
  81. package/lib/core/DotGraphQLParser.js +0 -40
  82. package/lib/core/GraphQLCompilerProfiler.js +0 -299
  83. package/lib/core/GraphQLDerivedFromMetadata.js +0 -31
  84. package/lib/core/GraphQLWatchmanClient.js +0 -150
  85. package/lib/core/IR.js +0 -11
  86. package/lib/core/IRPrinter.js +0 -388
  87. package/lib/core/IRTransformer.js +0 -345
  88. package/lib/core/IRValidator.js +0 -226
  89. package/lib/core/IRVisitor.js +0 -45
  90. package/lib/core/JSModuleParser.js +0 -18
  91. package/lib/core/RelayCompilerScope.js +0 -183
  92. package/lib/core/RelayFindGraphQLTags.js +0 -79
  93. package/lib/core/RelayGraphQLEnumsGenerator.js +0 -50
  94. package/lib/core/RelayIRTransforms.js +0 -109
  95. package/lib/core/RelayParser.js +0 -1381
  96. package/lib/core/RelaySourceModuleParser.js +0 -104
  97. package/lib/core/Schema.js +0 -1877
  98. package/lib/core/SchemaUtils.js +0 -98
  99. package/lib/core/filterContextForNode.js +0 -50
  100. package/lib/core/getFieldDefinition.js +0 -145
  101. package/lib/core/getIdentifierForArgumentValue.js +0 -54
  102. package/lib/core/getIdentifierForSelection.js +0 -49
  103. package/lib/core/getLiteralArgumentValues.js +0 -26
  104. package/lib/core/getNormalizationOperationName.js +0 -17
  105. package/lib/core/inferRootArgumentDefinitions.js +0 -351
  106. package/lib/index.js +0 -178
  107. package/lib/language/RelayLanguagePluginInterface.js +0 -26
  108. package/lib/language/javascript/FindGraphQLTags.js +0 -126
  109. package/lib/language/javascript/RelayFlowBabelFactories.js +0 -160
  110. package/lib/language/javascript/RelayFlowGenerator.js +0 -856
  111. package/lib/language/javascript/RelayFlowTypeTransformers.js +0 -119
  112. package/lib/language/javascript/RelayLanguagePluginJavaScript.js +0 -30
  113. package/lib/language/javascript/formatGeneratedModule.js +0 -36
  114. package/lib/reporters/ConsoleReporter.js +0 -61
  115. package/lib/reporters/MultiReporter.js +0 -45
  116. package/lib/reporters/Reporter.js +0 -11
  117. package/lib/runner/Artifacts.js +0 -323
  118. package/lib/runner/BufferedFilesystem.js +0 -262
  119. package/lib/runner/GraphQLASTNodeGroup.js +0 -256
  120. package/lib/runner/GraphQLASTUtils.js +0 -23
  121. package/lib/runner/GraphQLNodeMap.js +0 -81
  122. package/lib/runner/Sources.js +0 -271
  123. package/lib/runner/StrictMap.js +0 -134
  124. package/lib/runner/compileArtifacts.js +0 -39
  125. package/lib/runner/extractAST.js +0 -77
  126. package/lib/runner/getChangedNodeNames.js +0 -82
  127. package/lib/runner/getSchemaInstance.js +0 -30
  128. package/lib/runner/types.js +0 -12
  129. package/lib/transforms/ApplyFragmentArgumentTransform.js +0 -393
  130. package/lib/transforms/ClientExtensionsTransform.js +0 -221
  131. package/lib/transforms/ConnectionTransform.js +0 -639
  132. package/lib/transforms/DeclarativeConnectionMutationTransform.js +0 -218
  133. package/lib/transforms/DeferStreamTransform.js +0 -246
  134. package/lib/transforms/DisallowIdAsAlias.js +0 -40
  135. package/lib/transforms/DisallowTypenameOnRoot.js +0 -53
  136. package/lib/transforms/FieldHandleTransform.js +0 -79
  137. package/lib/transforms/FilterCompilerDirectivesTransform.js +0 -29
  138. package/lib/transforms/FilterDirectivesTransform.js +0 -42
  139. package/lib/transforms/FlattenTransform.js +0 -306
  140. package/lib/transforms/GenerateIDFieldTransform.js +0 -135
  141. package/lib/transforms/GenerateTypeNameTransform.js +0 -149
  142. package/lib/transforms/InlineDataFragmentTransform.js +0 -100
  143. package/lib/transforms/InlineFragmentsTransform.js +0 -61
  144. package/lib/transforms/MaskTransform.js +0 -117
  145. package/lib/transforms/MatchTransform.js +0 -434
  146. package/lib/transforms/ReactFlightComponentTransform.js +0 -158
  147. package/lib/transforms/RefetchableFragmentTransform.js +0 -249
  148. package/lib/transforms/RelayDirectiveTransform.js +0 -83
  149. package/lib/transforms/RequiredFieldTransform.js +0 -369
  150. package/lib/transforms/SkipClientExtensionsTransform.js +0 -46
  151. package/lib/transforms/SkipHandleFieldTransform.js +0 -45
  152. package/lib/transforms/SkipRedundantNodesTransform.js +0 -261
  153. package/lib/transforms/SkipSplitOperationTransform.js +0 -32
  154. package/lib/transforms/SkipUnreachableNodeTransform.js +0 -158
  155. package/lib/transforms/SkipUnusedVariablesTransform.js +0 -75
  156. package/lib/transforms/SplitModuleImportTransform.js +0 -82
  157. package/lib/transforms/TestOperationTransform.js +0 -144
  158. package/lib/transforms/TransformUtils.js +0 -21
  159. package/lib/transforms/ValidateGlobalVariablesTransform.js +0 -92
  160. package/lib/transforms/ValidateRequiredArgumentsTransform.js +0 -114
  161. package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +0 -108
  162. package/lib/transforms/ValidateUnusedVariablesTransform.js +0 -96
  163. package/lib/transforms/query-generators/FetchableQueryGenerator.js +0 -157
  164. package/lib/transforms/query-generators/NodeQueryGenerator.js +0 -166
  165. package/lib/transforms/query-generators/QueryQueryGenerator.js +0 -48
  166. package/lib/transforms/query-generators/ViewerQueryGenerator.js +0 -77
  167. package/lib/transforms/query-generators/index.js +0 -60
  168. package/lib/transforms/query-generators/utils.js +0 -92
  169. package/lib/util/CodeMarker.js +0 -80
  170. package/lib/util/DefaultHandleKey.js +0 -15
  171. package/lib/util/RelayCompilerCache.js +0 -97
  172. package/lib/util/Rollout.js +0 -40
  173. package/lib/util/TimeReporter.js +0 -83
  174. package/lib/util/areEqualArgValues.js +0 -135
  175. package/lib/util/argumentContainsVariables.js +0 -37
  176. package/lib/util/dedupeJSONStringify.js +0 -160
  177. package/lib/util/generateAbstractTypeRefinementKey.js +0 -24
  178. package/lib/util/getDefinitionNodeHash.js +0 -22
  179. package/lib/util/getModuleName.js +0 -32
  180. package/lib/util/joinArgumentDefinitions.js +0 -67
  181. package/lib/util/md5.js +0 -17
  182. package/lib/util/murmurHash.js +0 -86
  183. package/lib/util/nullthrowsOSS.js +0 -23
  184. package/lib/util/orList.js +0 -36
  185. package/lib/util/partitionArray.js +0 -35
  186. package/relay-compiler.js +0 -17
  187. package/relay-compiler.min.js +0 -22
  188. package/reporters/ConsoleReporter.js.flow +0 -81
  189. package/reporters/MultiReporter.js.flow +0 -43
  190. package/reporters/Reporter.js.flow +0 -19
  191. package/runner/Artifacts.js.flow +0 -215
  192. package/runner/BufferedFilesystem.js.flow +0 -194
  193. package/runner/GraphQLASTNodeGroup.js.flow +0 -174
  194. package/runner/GraphQLASTUtils.js.flow +0 -26
  195. package/runner/GraphQLNodeMap.js.flow +0 -55
  196. package/runner/Sources.js.flow +0 -227
  197. package/runner/StrictMap.js.flow +0 -96
  198. package/runner/compileArtifacts.js.flow +0 -75
  199. package/runner/extractAST.js.flow +0 -98
  200. package/runner/getChangedNodeNames.js.flow +0 -48
  201. package/runner/getSchemaInstance.js.flow +0 -36
  202. package/runner/types.js.flow +0 -37
  203. package/transforms/ApplyFragmentArgumentTransform.js.flow +0 -524
  204. package/transforms/ClientExtensionsTransform.js.flow +0 -224
  205. package/transforms/ConnectionTransform.js.flow +0 -850
  206. package/transforms/DeclarativeConnectionMutationTransform.js.flow +0 -245
  207. package/transforms/DeferStreamTransform.js.flow +0 -263
  208. package/transforms/DisallowIdAsAlias.js.flow +0 -46
  209. package/transforms/DisallowTypenameOnRoot.js.flow +0 -44
  210. package/transforms/FieldHandleTransform.js.flow +0 -77
  211. package/transforms/FilterCompilerDirectivesTransform.js.flow +0 -33
  212. package/transforms/FilterDirectivesTransform.js.flow +0 -45
  213. package/transforms/FlattenTransform.js.flow +0 -458
  214. package/transforms/GenerateIDFieldTransform.js.flow +0 -151
  215. package/transforms/GenerateTypeNameTransform.js.flow +0 -159
  216. package/transforms/InlineDataFragmentTransform.js.flow +0 -123
  217. package/transforms/InlineFragmentsTransform.js.flow +0 -70
  218. package/transforms/MaskTransform.js.flow +0 -124
  219. package/transforms/MatchTransform.js.flow +0 -587
  220. package/transforms/ReactFlightComponentTransform.js.flow +0 -194
  221. package/transforms/RefetchableFragmentTransform.js.flow +0 -266
  222. package/transforms/RelayDirectiveTransform.js.flow +0 -96
  223. package/transforms/RequiredFieldTransform.js.flow +0 -413
  224. package/transforms/SkipClientExtensionsTransform.js.flow +0 -54
  225. package/transforms/SkipHandleFieldTransform.js.flow +0 -44
  226. package/transforms/SkipRedundantNodesTransform.js.flow +0 -255
  227. package/transforms/SkipSplitOperationTransform.js.flow +0 -37
  228. package/transforms/SkipUnreachableNodeTransform.js.flow +0 -148
  229. package/transforms/SkipUnusedVariablesTransform.js.flow +0 -59
  230. package/transforms/SplitModuleImportTransform.js.flow +0 -97
  231. package/transforms/TestOperationTransform.js.flow +0 -142
  232. package/transforms/TransformUtils.js.flow +0 -26
  233. package/transforms/ValidateGlobalVariablesTransform.js.flow +0 -80
  234. package/transforms/ValidateRequiredArgumentsTransform.js.flow +0 -126
  235. package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +0 -111
  236. package/transforms/ValidateUnusedVariablesTransform.js.flow +0 -88
  237. package/transforms/query-generators/FetchableQueryGenerator.js.flow +0 -188
  238. package/transforms/query-generators/NodeQueryGenerator.js.flow +0 -217
  239. package/transforms/query-generators/QueryQueryGenerator.js.flow +0 -57
  240. package/transforms/query-generators/ViewerQueryGenerator.js.flow +0 -97
  241. package/transforms/query-generators/index.js.flow +0 -89
  242. package/transforms/query-generators/utils.js.flow +0 -76
  243. package/util/CodeMarker.js.flow +0 -79
  244. package/util/DefaultHandleKey.js.flow +0 -17
  245. package/util/RelayCompilerCache.js.flow +0 -86
  246. package/util/Rollout.js.flow +0 -39
  247. package/util/TimeReporter.js.flow +0 -79
  248. package/util/areEqualArgValues.js.flow +0 -126
  249. package/util/argumentContainsVariables.js.flow +0 -38
  250. package/util/dedupeJSONStringify.js.flow +0 -152
  251. package/util/generateAbstractTypeRefinementKey.js.flow +0 -29
  252. package/util/getDefinitionNodeHash.js.flow +0 -24
  253. package/util/getModuleName.js.flow +0 -39
  254. package/util/joinArgumentDefinitions.js.flow +0 -105
  255. package/util/md5.js.flow +0 -19
  256. package/util/murmurHash.js.flow +0 -94
  257. package/util/nullthrowsOSS.js.flow +0 -25
  258. package/util/orList.js.flow +0 -37
  259. package/util/partitionArray.js.flow +0 -37
@@ -1,97 +0,0 @@
1
- /**
2
- * Copyright (c) Facebook, Inc. and its affiliates.
3
- *
4
- * This source code is licensed under the MIT license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- *
8
- * @format
9
- */
10
- // flowlint ambiguous-object-type:error
11
- 'use strict';
12
-
13
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
14
-
15
- var _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
- fs.writeFileSync(cacheFile, JSON.stringify(value), 'utf8');
87
- } catch (_unused2) {// ignore
88
- }
89
-
90
- return value;
91
- });
92
- };
93
-
94
- return RelayCompilerCache;
95
- }();
96
-
97
- module.exports = RelayCompilerCache;
@@ -1,40 +0,0 @@
1
- /**
2
- * Copyright (c) Facebook, Inc. and its affiliates.
3
- *
4
- * This source code is licensed under the MIT license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- *
8
- * @format
9
- */
10
- // flowlint ambiguous-object-type:error
11
- 'use strict';
12
-
13
- var 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
- };
@@ -1,83 +0,0 @@
1
- /**
2
- * Copyright (c) Facebook, Inc. and its affiliates.
3
- *
4
- * This source code is licensed under the MIT license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- * @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
- };
@@ -1,135 +0,0 @@
1
- /**
2
- * Copyright (c) Facebook, Inc. and its affiliates.
3
- *
4
- * This source code is licensed under the MIT license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- *
8
- * @format
9
- */
10
- // 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;
@@ -1,37 +0,0 @@
1
- /**
2
- * Copyright (c) Facebook, Inc. and its affiliates.
3
- *
4
- * This source code is licensed under the MIT license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- *
8
- * @format
9
- */
10
- // flowlint ambiguous-object-type:error
11
- 'use strict';
12
-
13
- 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;
@@ -1,160 +0,0 @@
1
- /**
2
- * Copyright (c) Facebook, Inc. and its affiliates.
3
- *
4
- * This source code is licensed under the MIT license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- *
8
- * @format
9
- */
10
- // flowlint ambiguous-object-type:error
11
- 'use strict';
12
- /**
13
- * 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;
@@ -1,24 +0,0 @@
1
- /**
2
- * Copyright (c) Facebook, Inc. and its affiliates.
3
- *
4
- * This source code is licensed under the MIT license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- *
8
- * @format
9
- */
10
- // flowlint ambiguous-object-type:error
11
- 'use strict';
12
-
13
- var _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;
@@ -1,22 +0,0 @@
1
- /**
2
- * Copyright (c) Facebook, Inc. and its affiliates.
3
- *
4
- * This source code is licensed under the MIT license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- *
8
- * @format
9
- */
10
- // flowlint ambiguous-object-type:error
11
- 'use strict';
12
-
13
- var 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;
@@ -1,32 +0,0 @@
1
- /**
2
- * Copyright (c) Facebook, Inc. and its affiliates.
3
- *
4
- * This source code is licensed under the MIT license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- *
8
- * @format
9
- */
10
- // flowlint ambiguous-object-type:error
11
- 'use strict';
12
-
13
- var 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;
@@ -1,67 +0,0 @@
1
- /**
2
- * Copyright (c) Facebook, Inc. and its affiliates.
3
- *
4
- * This source code is licensed under the MIT license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- *
8
- * @format
9
- */
10
- // flowlint ambiguous-object-type:error
11
- 'use strict';
12
-
13
- var _require = require('../core/CompilerError'),
14
- createUserError = _require.createUserError;
15
- /**
16
- * Attempts to join the argument definitions for a root fragment
17
- * and any unmasked fragment spreads reachable from that root fragment,
18
- * returning a combined list of arguments or throwing if the same
19
- * variable(s) are used in incompatible ways in different fragments.
20
- */
21
-
22
-
23
- function joinArgumentDefinitions(schema, fragment, reachableArguments, directiveName) {
24
- var joinedArgumentDefinitions = new Map();
25
- fragment.argumentDefinitions.forEach(function (prevArgDef) {
26
- joinedArgumentDefinitions.set(prevArgDef.name, prevArgDef);
27
- });
28
- reachableArguments.forEach(function (nextArgDef) {
29
- var prevArgDef = joinedArgumentDefinitions.get(nextArgDef.name);
30
- var joinedArgDef = prevArgDef == null ? nextArgDef : joinArgumentDefinition(schema, prevArgDef, nextArgDef, directiveName);
31
- joinedArgumentDefinitions.set(joinedArgDef.name, joinedArgDef);
32
- });
33
- return Array.from(joinedArgumentDefinitions.values());
34
- }
35
- /**
36
- * @private
37
- *
38
- * Attempts to join two argument definitions, returning a single argument
39
- * definition that is compatible with both of the inputs:
40
- * - If the kind, name, or defaultValue is different then the arguments
41
- * cannot be joined, indicated by returning null.
42
- * - If either of next/prev is a subtype of the other, return the one
43
- * that is the subtype: a more narrow type can flow into a more general
44
- * type but not the inverse.
45
- * - Otherwise there is no subtyping relation between prev/next, so return
46
- * null to indicate they cannot be joined.
47
- */
48
-
49
-
50
- function joinArgumentDefinition(schema, prevArgDef, nextArgDef, directiveName) {
51
- if (prevArgDef.kind !== nextArgDef.kind) {
52
- throw createUserError('Cannot combine global and local variables when applying ' + "".concat(directiveName, "."), [prevArgDef.loc, nextArgDef.loc]);
53
- } else if (prevArgDef.kind === 'LocalArgumentDefinition' && nextArgDef.kind === 'LocalArgumentDefinition' && prevArgDef.defaultValue !== nextArgDef.defaultValue) {
54
- throw createUserError('Cannot combine local variables with different defaultValues when ' + "applying ".concat(directiveName, "."), [prevArgDef.loc, nextArgDef.loc]);
55
- } else if (schema.isTypeSubTypeOf(nextArgDef.type, prevArgDef.type)) {
56
- // prevArgDef is less strict than nextArgDef
57
- return nextArgDef;
58
- } else if (schema.isTypeSubTypeOf(prevArgDef.type, nextArgDef.type)) {
59
- return prevArgDef;
60
- } else {
61
- var prevArgType = prevArgDef.type != null ? schema.getTypeString(prevArgDef.type) : 'unknown';
62
- var nextArgType = nextArgDef.type != null ? schema.getTypeString(nextArgDef.type) : 'unknown';
63
- throw createUserError('Cannot combine variables with incompatible types ' + "".concat(prevArgType, " and ").concat(nextArgType, " ") + "when applying ".concat(directiveName, "."), [prevArgDef.loc, nextArgDef.loc]);
64
- }
65
- }
66
-
67
- module.exports = joinArgumentDefinitions;