relay-compiler 11.0.2 → 13.0.0-rc.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (261) hide show
  1. package/README.md +108 -0
  2. package/cli.js +23 -0
  3. package/index.js +22 -4
  4. package/linux-x64/relay +0 -0
  5. package/macos-arm64/relay +0 -0
  6. package/macos-x64/relay +0 -0
  7. package/package.json +2 -26
  8. package/win-x64/relay.exe +0 -0
  9. package/bin/RelayCompilerBin.js.flow +0 -169
  10. package/bin/RelayCompilerMain.js.flow +0 -515
  11. package/bin/__fixtures__/plugin-module.js.flow +0 -17
  12. package/bin/relay-compiler +0 -19008
  13. package/codegen/CodegenDirectory.js.flow +0 -375
  14. package/codegen/CodegenRunner.js.flow +0 -432
  15. package/codegen/CodegenTypes.js.flow +0 -28
  16. package/codegen/CodegenWatcher.js.flow +0 -254
  17. package/codegen/NormalizationCodeGenerator.js.flow +0 -571
  18. package/codegen/ReaderCodeGenerator.js.flow +0 -512
  19. package/codegen/RelayCodeGenerator.js.flow +0 -85
  20. package/codegen/RelayFileWriter.js.flow +0 -367
  21. package/codegen/SourceControl.js.flow +0 -58
  22. package/codegen/compileRelayArtifacts.js.flow +0 -182
  23. package/codegen/createPrintRequireModuleDependency.js.flow +0 -21
  24. package/codegen/sortObjectByKey.js.flow +0 -25
  25. package/codegen/writeRelayGeneratedFile.js.flow +0 -239
  26. package/core/ASTCache.js.flow +0 -74
  27. package/core/ASTConvert.js.flow +0 -233
  28. package/core/CompilerContext.js.flow +0 -191
  29. package/core/CompilerError.js.flow +0 -255
  30. package/core/DotGraphQLParser.js.flow +0 -39
  31. package/core/GraphQLCompilerProfiler.js.flow +0 -341
  32. package/core/GraphQLDerivedFromMetadata.js.flow +0 -36
  33. package/core/GraphQLWatchmanClient.js.flow +0 -111
  34. package/core/IR.js.flow +0 -326
  35. package/core/IRPrinter.js.flow +0 -478
  36. package/core/IRTransformer.js.flow +0 -377
  37. package/core/IRValidator.js.flow +0 -260
  38. package/core/IRVisitor.js.flow +0 -150
  39. package/core/JSModuleParser.js.flow +0 -24
  40. package/core/RelayCompilerScope.js.flow +0 -199
  41. package/core/RelayFindGraphQLTags.js.flow +0 -119
  42. package/core/RelayGraphQLEnumsGenerator.js.flow +0 -55
  43. package/core/RelayIRTransforms.js.flow +0 -138
  44. package/core/RelayParser.js.flow +0 -1734
  45. package/core/RelaySourceModuleParser.js.flow +0 -135
  46. package/core/Schema.js.flow +0 -2037
  47. package/core/SchemaUtils.js.flow +0 -120
  48. package/core/filterContextForNode.js.flow +0 -50
  49. package/core/getFieldDefinition.js.flow +0 -156
  50. package/core/getIdentifierForArgumentValue.js.flow +0 -49
  51. package/core/getIdentifierForSelection.js.flow +0 -69
  52. package/core/getLiteralArgumentValues.js.flow +0 -32
  53. package/core/getNormalizationOperationName.js.flow +0 -19
  54. package/core/inferRootArgumentDefinitions.js.flow +0 -323
  55. package/index.js.flow +0 -200
  56. package/language/RelayLanguagePluginInterface.js.flow +0 -283
  57. package/language/javascript/FindGraphQLTags.js.flow +0 -137
  58. package/language/javascript/RelayFlowBabelFactories.js.flow +0 -176
  59. package/language/javascript/RelayFlowGenerator.js.flow +0 -1100
  60. package/language/javascript/RelayFlowTypeTransformers.js.flow +0 -184
  61. package/language/javascript/RelayLanguagePluginJavaScript.js.flow +0 -34
  62. package/language/javascript/formatGeneratedModule.js.flow +0 -65
  63. package/lib/bin/RelayCompilerBin.js +0 -143
  64. package/lib/bin/RelayCompilerMain.js +0 -486
  65. package/lib/bin/__fixtures__/plugin-module.js +0 -16
  66. package/lib/codegen/CodegenDirectory.js +0 -336
  67. package/lib/codegen/CodegenRunner.js +0 -433
  68. package/lib/codegen/CodegenTypes.js +0 -11
  69. package/lib/codegen/CodegenWatcher.js +0 -271
  70. package/lib/codegen/NormalizationCodeGenerator.js +0 -481
  71. package/lib/codegen/ReaderCodeGenerator.js +0 -472
  72. package/lib/codegen/RelayCodeGenerator.js +0 -68
  73. package/lib/codegen/RelayFileWriter.js +0 -270
  74. package/lib/codegen/SourceControl.js +0 -60
  75. package/lib/codegen/compileRelayArtifacts.js +0 -157
  76. package/lib/codegen/createPrintRequireModuleDependency.js +0 -19
  77. package/lib/codegen/sortObjectByKey.js +0 -41
  78. package/lib/codegen/writeRelayGeneratedFile.js +0 -208
  79. package/lib/core/ASTCache.js +0 -70
  80. package/lib/core/ASTConvert.js +0 -198
  81. package/lib/core/CompilerContext.js +0 -165
  82. package/lib/core/CompilerError.js +0 -251
  83. package/lib/core/DotGraphQLParser.js +0 -40
  84. package/lib/core/GraphQLCompilerProfiler.js +0 -299
  85. package/lib/core/GraphQLDerivedFromMetadata.js +0 -31
  86. package/lib/core/GraphQLWatchmanClient.js +0 -150
  87. package/lib/core/IR.js +0 -11
  88. package/lib/core/IRPrinter.js +0 -389
  89. package/lib/core/IRTransformer.js +0 -345
  90. package/lib/core/IRValidator.js +0 -226
  91. package/lib/core/IRVisitor.js +0 -45
  92. package/lib/core/JSModuleParser.js +0 -18
  93. package/lib/core/RelayCompilerScope.js +0 -149
  94. package/lib/core/RelayFindGraphQLTags.js +0 -79
  95. package/lib/core/RelayGraphQLEnumsGenerator.js +0 -50
  96. package/lib/core/RelayIRTransforms.js +0 -109
  97. package/lib/core/RelayParser.js +0 -1382
  98. package/lib/core/RelaySourceModuleParser.js +0 -104
  99. package/lib/core/Schema.js +0 -1877
  100. package/lib/core/SchemaUtils.js +0 -98
  101. package/lib/core/filterContextForNode.js +0 -49
  102. package/lib/core/getFieldDefinition.js +0 -145
  103. package/lib/core/getIdentifierForArgumentValue.js +0 -53
  104. package/lib/core/getIdentifierForSelection.js +0 -48
  105. package/lib/core/getLiteralArgumentValues.js +0 -26
  106. package/lib/core/getNormalizationOperationName.js +0 -17
  107. package/lib/core/inferRootArgumentDefinitions.js +0 -351
  108. package/lib/index.js +0 -178
  109. package/lib/language/RelayLanguagePluginInterface.js +0 -14
  110. package/lib/language/javascript/FindGraphQLTags.js +0 -126
  111. package/lib/language/javascript/RelayFlowBabelFactories.js +0 -160
  112. package/lib/language/javascript/RelayFlowGenerator.js +0 -857
  113. package/lib/language/javascript/RelayFlowTypeTransformers.js +0 -119
  114. package/lib/language/javascript/RelayLanguagePluginJavaScript.js +0 -30
  115. package/lib/language/javascript/formatGeneratedModule.js +0 -36
  116. package/lib/reporters/ConsoleReporter.js +0 -61
  117. package/lib/reporters/MultiReporter.js +0 -45
  118. package/lib/reporters/Reporter.js +0 -11
  119. package/lib/runner/Artifacts.js +0 -323
  120. package/lib/runner/BufferedFilesystem.js +0 -261
  121. package/lib/runner/GraphQLASTNodeGroup.js +0 -256
  122. package/lib/runner/GraphQLASTUtils.js +0 -23
  123. package/lib/runner/GraphQLNodeMap.js +0 -81
  124. package/lib/runner/Sources.js +0 -271
  125. package/lib/runner/StrictMap.js +0 -134
  126. package/lib/runner/compileArtifacts.js +0 -39
  127. package/lib/runner/extractAST.js +0 -77
  128. package/lib/runner/getChangedNodeNames.js +0 -82
  129. package/lib/runner/getSchemaInstance.js +0 -30
  130. package/lib/runner/types.js +0 -12
  131. package/lib/transforms/ApplyFragmentArgumentTransform.js +0 -393
  132. package/lib/transforms/ClientExtensionsTransform.js +0 -221
  133. package/lib/transforms/ConnectionTransform.js +0 -639
  134. package/lib/transforms/DeclarativeConnectionMutationTransform.js +0 -218
  135. package/lib/transforms/DeferStreamTransform.js +0 -246
  136. package/lib/transforms/DisallowIdAsAlias.js +0 -40
  137. package/lib/transforms/DisallowTypenameOnRoot.js +0 -53
  138. package/lib/transforms/FieldHandleTransform.js +0 -79
  139. package/lib/transforms/FilterCompilerDirectivesTransform.js +0 -29
  140. package/lib/transforms/FilterDirectivesTransform.js +0 -41
  141. package/lib/transforms/FlattenTransform.js +0 -306
  142. package/lib/transforms/GenerateIDFieldTransform.js +0 -135
  143. package/lib/transforms/GenerateTypeNameTransform.js +0 -149
  144. package/lib/transforms/InlineDataFragmentTransform.js +0 -100
  145. package/lib/transforms/InlineFragmentsTransform.js +0 -61
  146. package/lib/transforms/MaskTransform.js +0 -117
  147. package/lib/transforms/MatchTransform.js +0 -434
  148. package/lib/transforms/ReactFlightComponentTransform.js +0 -158
  149. package/lib/transforms/RefetchableFragmentTransform.js +0 -249
  150. package/lib/transforms/RelayDirectiveTransform.js +0 -83
  151. package/lib/transforms/RequiredFieldTransform.js +0 -369
  152. package/lib/transforms/SkipClientExtensionsTransform.js +0 -46
  153. package/lib/transforms/SkipHandleFieldTransform.js +0 -44
  154. package/lib/transforms/SkipRedundantNodesTransform.js +0 -254
  155. package/lib/transforms/SkipSplitOperationTransform.js +0 -32
  156. package/lib/transforms/SkipUnreachableNodeTransform.js +0 -158
  157. package/lib/transforms/SkipUnusedVariablesTransform.js +0 -74
  158. package/lib/transforms/SplitModuleImportTransform.js +0 -82
  159. package/lib/transforms/TestOperationTransform.js +0 -144
  160. package/lib/transforms/TransformUtils.js +0 -21
  161. package/lib/transforms/ValidateGlobalVariablesTransform.js +0 -91
  162. package/lib/transforms/ValidateRequiredArgumentsTransform.js +0 -114
  163. package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +0 -108
  164. package/lib/transforms/ValidateUnusedVariablesTransform.js +0 -96
  165. package/lib/transforms/query-generators/FetchableQueryGenerator.js +0 -157
  166. package/lib/transforms/query-generators/NodeQueryGenerator.js +0 -166
  167. package/lib/transforms/query-generators/QueryQueryGenerator.js +0 -48
  168. package/lib/transforms/query-generators/ViewerQueryGenerator.js +0 -77
  169. package/lib/transforms/query-generators/index.js +0 -60
  170. package/lib/transforms/query-generators/utils.js +0 -92
  171. package/lib/util/CodeMarker.js +0 -80
  172. package/lib/util/DefaultHandleKey.js +0 -15
  173. package/lib/util/RelayCompilerCache.js +0 -98
  174. package/lib/util/Rollout.js +0 -40
  175. package/lib/util/TimeReporter.js +0 -83
  176. package/lib/util/areEqualArgValues.js +0 -134
  177. package/lib/util/argumentContainsVariables.js +0 -37
  178. package/lib/util/dedupeJSONStringify.js +0 -160
  179. package/lib/util/generateAbstractTypeRefinementKey.js +0 -24
  180. package/lib/util/getDefinitionNodeHash.js +0 -22
  181. package/lib/util/getModuleName.js +0 -32
  182. package/lib/util/joinArgumentDefinitions.js +0 -66
  183. package/lib/util/md5.js +0 -17
  184. package/lib/util/murmurHash.js +0 -86
  185. package/lib/util/nullthrowsOSS.js +0 -23
  186. package/lib/util/orList.js +0 -36
  187. package/lib/util/partitionArray.js +0 -35
  188. package/relay-compiler.js +0 -17
  189. package/relay-compiler.min.js +0 -22
  190. package/reporters/ConsoleReporter.js.flow +0 -81
  191. package/reporters/MultiReporter.js.flow +0 -43
  192. package/reporters/Reporter.js.flow +0 -19
  193. package/runner/Artifacts.js.flow +0 -219
  194. package/runner/BufferedFilesystem.js.flow +0 -194
  195. package/runner/GraphQLASTNodeGroup.js.flow +0 -176
  196. package/runner/GraphQLASTUtils.js.flow +0 -26
  197. package/runner/GraphQLNodeMap.js.flow +0 -55
  198. package/runner/Sources.js.flow +0 -228
  199. package/runner/StrictMap.js.flow +0 -96
  200. package/runner/compileArtifacts.js.flow +0 -76
  201. package/runner/extractAST.js.flow +0 -100
  202. package/runner/getChangedNodeNames.js.flow +0 -48
  203. package/runner/getSchemaInstance.js.flow +0 -36
  204. package/runner/types.js.flow +0 -37
  205. package/transforms/ApplyFragmentArgumentTransform.js.flow +0 -526
  206. package/transforms/ClientExtensionsTransform.js.flow +0 -225
  207. package/transforms/ConnectionTransform.js.flow +0 -855
  208. package/transforms/DeclarativeConnectionMutationTransform.js.flow +0 -247
  209. package/transforms/DeferStreamTransform.js.flow +0 -265
  210. package/transforms/DisallowIdAsAlias.js.flow +0 -47
  211. package/transforms/DisallowTypenameOnRoot.js.flow +0 -45
  212. package/transforms/FieldHandleTransform.js.flow +0 -79
  213. package/transforms/FilterCompilerDirectivesTransform.js.flow +0 -33
  214. package/transforms/FilterDirectivesTransform.js.flow +0 -45
  215. package/transforms/FlattenTransform.js.flow +0 -460
  216. package/transforms/GenerateIDFieldTransform.js.flow +0 -152
  217. package/transforms/GenerateTypeNameTransform.js.flow +0 -161
  218. package/transforms/InlineDataFragmentTransform.js.flow +0 -125
  219. package/transforms/InlineFragmentsTransform.js.flow +0 -71
  220. package/transforms/MaskTransform.js.flow +0 -126
  221. package/transforms/MatchTransform.js.flow +0 -589
  222. package/transforms/ReactFlightComponentTransform.js.flow +0 -195
  223. package/transforms/RefetchableFragmentTransform.js.flow +0 -272
  224. package/transforms/RelayDirectiveTransform.js.flow +0 -97
  225. package/transforms/RequiredFieldTransform.js.flow +0 -415
  226. package/transforms/SkipClientExtensionsTransform.js.flow +0 -54
  227. package/transforms/SkipHandleFieldTransform.js.flow +0 -44
  228. package/transforms/SkipRedundantNodesTransform.js.flow +0 -258
  229. package/transforms/SkipSplitOperationTransform.js.flow +0 -37
  230. package/transforms/SkipUnreachableNodeTransform.js.flow +0 -149
  231. package/transforms/SkipUnusedVariablesTransform.js.flow +0 -59
  232. package/transforms/SplitModuleImportTransform.js.flow +0 -98
  233. package/transforms/TestOperationTransform.js.flow +0 -142
  234. package/transforms/TransformUtils.js.flow +0 -26
  235. package/transforms/ValidateGlobalVariablesTransform.js.flow +0 -81
  236. package/transforms/ValidateRequiredArgumentsTransform.js.flow +0 -127
  237. package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +0 -112
  238. package/transforms/ValidateUnusedVariablesTransform.js.flow +0 -89
  239. package/transforms/query-generators/FetchableQueryGenerator.js.flow +0 -189
  240. package/transforms/query-generators/NodeQueryGenerator.js.flow +0 -219
  241. package/transforms/query-generators/QueryQueryGenerator.js.flow +0 -57
  242. package/transforms/query-generators/ViewerQueryGenerator.js.flow +0 -97
  243. package/transforms/query-generators/index.js.flow +0 -90
  244. package/transforms/query-generators/utils.js.flow +0 -76
  245. package/util/CodeMarker.js.flow +0 -79
  246. package/util/DefaultHandleKey.js.flow +0 -17
  247. package/util/RelayCompilerCache.js.flow +0 -88
  248. package/util/Rollout.js.flow +0 -39
  249. package/util/TimeReporter.js.flow +0 -79
  250. package/util/areEqualArgValues.js.flow +0 -125
  251. package/util/argumentContainsVariables.js.flow +0 -38
  252. package/util/dedupeJSONStringify.js.flow +0 -152
  253. package/util/generateAbstractTypeRefinementKey.js.flow +0 -29
  254. package/util/getDefinitionNodeHash.js.flow +0 -25
  255. package/util/getModuleName.js.flow +0 -39
  256. package/util/joinArgumentDefinitions.js.flow +0 -105
  257. package/util/md5.js.flow +0 -22
  258. package/util/murmurHash.js.flow +0 -94
  259. package/util/nullthrowsOSS.js.flow +0 -25
  260. package/util/orList.js.flow +0 -37
  261. package/util/partitionArray.js.flow +0 -37
@@ -1,98 +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
- // $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;
@@ -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,134 +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
- }
50
-
51
- var objToStr = Object.prototype.toString;
52
- var className = objToStr.call(a);
53
-
54
- if (className !== objToStr.call(b)) {
55
- return false;
56
- }
57
-
58
- switch (className) {
59
- case '[object String]':
60
- return a === String(b);
61
-
62
- case '[object Number]':
63
- return isNaN(a) || isNaN(b) ? false : a === Number(b);
64
-
65
- case '[object Date]':
66
- case '[object Boolean]':
67
- return +a === +b;
68
-
69
- case '[object RegExp]':
70
- return a.source === b.source && a.global === b.global && a.multiline === b.multiline && a.ignoreCase === b.ignoreCase;
71
- } // Assume equality for cyclic structures.
72
-
73
-
74
- var length = aStack.length;
75
-
76
- while (length--) {
77
- if (aStack[length] === a) {
78
- return bStack[length] === b;
79
- }
80
- }
81
-
82
- aStack.push(a);
83
- bStack.push(b);
84
- var size = 0; // Recursively compare objects and arrays.
85
-
86
- if (className === '[object Array]') {
87
- size = a.length;
88
-
89
- if (size !== b.length) {
90
- return false;
91
- } // Deep compare the contents, ignoring non-numeric properties.
92
-
93
-
94
- while (size--) {
95
- if (!eq(a[size], b[size], aStack, bStack)) {
96
- return false;
97
- }
98
- }
99
- } else {
100
- if (a.constructor !== b.constructor) {
101
- return false;
102
- }
103
-
104
- if (a.hasOwnProperty('valueOf') && b.hasOwnProperty('valueOf')) {
105
- return a.valueOf() === b.valueOf();
106
- }
107
-
108
- var keys = Object.keys(a);
109
-
110
- if (keys.length !== Object.keys(b).length) {
111
- return false;
112
- }
113
-
114
- for (var i = 0; i < keys.length; i++) {
115
- if (keys[i] === '_owner') {
116
- // HACK: Comparing deeply nested React trees is slow since you end up
117
- // comparing the entire tree (all ancestors and all children) and
118
- // likely not what you want if you're comparing two elements with
119
- // areEqualArgValues. We bail out here for now.
120
- continue;
121
- }
122
-
123
- if (!b.hasOwnProperty(keys[i]) || !eq(a[keys[i]], b[keys[i]], aStack, bStack)) {
124
- return false;
125
- }
126
- }
127
- }
128
-
129
- aStack.pop();
130
- bStack.pop();
131
- return true;
132
- }
133
-
134
- 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,66 +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
- /**
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;