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,76 +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
- * @flow strict-local
8
- * @format
9
- */
10
-
11
- // flowlint ambiguous-object-type:error
12
-
13
- 'use strict';
14
-
15
- import type {
16
- ArgumentDefinition,
17
- Fragment,
18
- FragmentSpread,
19
- LocalArgumentDefinition,
20
- } from '../../core/IR';
21
-
22
- function buildFragmentSpread(fragment: Fragment): FragmentSpread {
23
- const args = [];
24
- for (const argDef of fragment.argumentDefinitions) {
25
- if (argDef.kind !== 'LocalArgumentDefinition') {
26
- continue;
27
- }
28
- args.push({
29
- kind: 'Argument',
30
- loc: {kind: 'Derived', source: argDef.loc},
31
- name: argDef.name,
32
- type: argDef.type,
33
- value: {
34
- kind: 'Variable',
35
- loc: {kind: 'Derived', source: argDef.loc},
36
- variableName: argDef.name,
37
- type: argDef.type,
38
- },
39
- });
40
- }
41
- return {
42
- args,
43
- directives: [],
44
- kind: 'FragmentSpread',
45
- loc: {kind: 'Derived', source: fragment.loc},
46
- metadata: null,
47
- name: fragment.name,
48
- };
49
- }
50
-
51
- function buildOperationArgumentDefinitions(
52
- argumentDefinitions: $ReadOnlyArray<ArgumentDefinition>,
53
- ): $ReadOnlyArray<LocalArgumentDefinition> {
54
- const localArgumentDefinitions = argumentDefinitions.map(argDef => {
55
- if (argDef.kind === 'LocalArgumentDefinition') {
56
- return argDef;
57
- } else {
58
- return {
59
- kind: 'LocalArgumentDefinition',
60
- name: argDef.name,
61
- type: argDef.type,
62
- defaultValue: null,
63
- loc: argDef.loc,
64
- };
65
- }
66
- });
67
- localArgumentDefinitions.sort((a, b) => {
68
- return a.name < b.name ? -1 : a.name > b.name ? 1 : 0;
69
- });
70
- return localArgumentDefinitions;
71
- }
72
-
73
- module.exports = {
74
- buildFragmentSpread,
75
- buildOperationArgumentDefinitions,
76
- };
@@ -1,79 +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
- * @flow strict
8
- * @format
9
- */
10
-
11
- // flowlint ambiguous-object-type:error
12
-
13
- 'use strict';
14
-
15
- /**
16
- * Marks a string of code as code to be replaced later.
17
- */
18
- function moduleDependency(code: string): string {
19
- return `@@MODULE_START@@${code}@@MODULE_END@@`;
20
- }
21
-
22
- /**
23
- * After JSON.stringify'ing some code that contained parts marked with `mark()`,
24
- * this post-processes the JSON to convert the marked code strings to raw code.
25
- *
26
- * Example:
27
- * CodeMarker.postProcess(
28
- * JSON.stringify({code: CodeMarker.mark('alert(1)')})
29
- * )
30
- */
31
- function postProcess(json: string, printModule: string => string): string {
32
- return json.replace(
33
- /"@@MODULE_START@@(.*?)@@MODULE_END@@"/g,
34
- (_, moduleName) => printModule(moduleName),
35
- );
36
- }
37
-
38
- /**
39
- * Transforms a value such that any transitive CodeMarker strings are replaced
40
- * with the value of the named module in the given module map.
41
- */
42
- function transform(node: mixed, moduleMap: {[string]: mixed, ...}): mixed {
43
- if (node == null) {
44
- return node;
45
- } else if (Array.isArray(node)) {
46
- return node.map(item => transform(item, moduleMap));
47
- } else if (typeof node === 'object') {
48
- const next = {};
49
- Object.keys(node).forEach(key => {
50
- next[key] = transform(node[key], moduleMap);
51
- });
52
- return next;
53
- } else if (typeof node === 'string') {
54
- const match = /^@@MODULE_START@@(.*?)@@MODULE_END@@$/.exec(node);
55
- if (match != null) {
56
- const moduleName = match[1];
57
- if (moduleMap.hasOwnProperty(moduleName)) {
58
- return moduleMap[moduleName];
59
- } else {
60
- throw new Error(
61
- `Could not find a value for CodeMarker value '${moduleName}', ` +
62
- 'make sure to supply one in the module mapping.',
63
- );
64
- }
65
- } else if (node.indexOf('@@MODULE_START') >= 0) {
66
- throw new Error(`Found unprocessed CodeMarker value '${node}'.`);
67
- }
68
- return node;
69
- } else {
70
- // mixed
71
- return node;
72
- }
73
- }
74
-
75
- module.exports = {
76
- moduleDependency,
77
- postProcess,
78
- transform,
79
- };
@@ -1,17 +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
- * @flow strict
8
- * @format
9
- */
10
-
11
- // flowlint ambiguous-object-type:error
12
-
13
- 'use strict';
14
-
15
- module.exports = {
16
- DEFAULT_HANDLE_KEY: '',
17
- };
@@ -1,86 +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
- * @flow strict
8
- * @format
9
- */
10
-
11
- // flowlint ambiguous-object-type:error
12
-
13
- 'use strict';
14
-
15
- const Profiler = require('../core/GraphQLCompilerProfiler');
16
- const crypto = require('crypto');
17
- const fs = require('fs');
18
- const os = require('os');
19
- const path = require('path');
20
-
21
- /**
22
- * A file backed cache. Values are JSON encoded on disk, so only JSON
23
- * serializable values should be used.
24
- */
25
- class RelayCompilerCache<T> {
26
- _name: string;
27
- _cacheBreaker: string;
28
- _dir: ?string = null;
29
-
30
- /**
31
- * @param name Human readable identifier for the cache
32
- * @param cacheBreaker This should be changed in order to invalidate existing
33
- * caches.
34
- */
35
- constructor(name: string, cacheBreaker: string) {
36
- this._name = name;
37
- this._cacheBreaker = cacheBreaker;
38
- }
39
-
40
- _getFile(key: string): string {
41
- if (this._dir == null) {
42
- // Include username in the cache dir to avoid issues with directories being
43
- // owned by a different user.
44
- const username = os.userInfo().username;
45
- const cacheID = crypto
46
- .createHash('md5')
47
- .update(this._cacheBreaker)
48
- .update(username)
49
- .digest('hex');
50
- const dir = path.join(os.tmpdir(), `${this._name}-${cacheID}`);
51
- if (!fs.existsSync(dir)) {
52
- try {
53
- fs.mkdirSync(dir);
54
- } catch (error) {
55
- if (error.code !== 'EEXIST') {
56
- throw error;
57
- }
58
- }
59
- }
60
- this._dir = dir;
61
- }
62
- return path.join(this._dir, key);
63
- }
64
-
65
- getOrCompute(key: string, compute: () => T): T {
66
- return Profiler.run('RelayCompilerCache.getOrCompute', () => {
67
- const cacheFile = this._getFile(key);
68
- if (fs.existsSync(cacheFile)) {
69
- try {
70
- return JSON.parse(fs.readFileSync(cacheFile, 'utf8'));
71
- } catch {
72
- // ignore
73
- }
74
- }
75
- const value = compute();
76
- try {
77
- fs.writeFileSync(cacheFile, JSON.stringify(value), 'utf8');
78
- } catch {
79
- // ignore
80
- }
81
- return value;
82
- });
83
- }
84
- }
85
-
86
- module.exports = RelayCompilerCache;
@@ -1,39 +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
- * @flow strict
8
- * @format
9
- */
10
-
11
- // flowlint ambiguous-object-type:error
12
-
13
- 'use strict';
14
-
15
- let whitelistsByProject: ?Map<string, Set<string>> = null;
16
-
17
- /**
18
- * This module helps gradually rolling out changes to the code generation by
19
- * gradually enabling more buckets representing randomly distributed artifacts.
20
- */
21
- function set(newWhitelistsByProject: Map<string, Set<string>>) {
22
- whitelistsByProject = newWhitelistsByProject;
23
- }
24
-
25
- function check(project: string, key: string): boolean {
26
- if (whitelistsByProject == null) {
27
- return true;
28
- }
29
- const whitelist = whitelistsByProject.get(project);
30
- if (whitelist == null) {
31
- return true;
32
- }
33
- return whitelist.has(key);
34
- }
35
-
36
- module.exports = {
37
- set,
38
- check,
39
- };
@@ -1,79 +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
- * @flow strict-local
9
- * @emails oncall+relay
10
- */
11
-
12
- // flowlint ambiguous-object-type:error
13
-
14
- 'use strict';
15
-
16
- import type {Reporter} from '../reporters/Reporter';
17
-
18
- const {isPromise} = require('relay-runtime');
19
-
20
- function reportTime<T>(reporter: Reporter, message: string, fn: () => T): T {
21
- return reportAndReturnTime(reporter, message, fn)[0];
22
- }
23
-
24
- function reportAndReturnTime<T>(
25
- reporter: Reporter,
26
- message: string,
27
- fn: () => T,
28
- ): [T, number] {
29
- const startTime = Date.now();
30
- const result = fn();
31
- if (isPromise(result)) {
32
- throw new Error(
33
- 'reportAndReturnTime: fn(...) returned an unexpected promise.' +
34
- ' Please use `reportAndReturnAsyncTime` method instead.',
35
- );
36
- }
37
- const elapsedTime = Date.now() - startTime;
38
- reporter.reportTime(message, elapsedTime);
39
- return [result, elapsedTime];
40
- }
41
-
42
- async function reportAndReturnAsyncTime<T>(
43
- reporter: Reporter,
44
- message: string,
45
- fn: () => ?Promise<T>,
46
- ): Promise<[T, number]> {
47
- const startTime = Date.now();
48
- const promise = fn();
49
- if (!isPromise(promise)) {
50
- throw new Error('reportAsyncTime: fn(...) expected to return a promise.');
51
- }
52
- const result = await promise;
53
- const elapsedTime = Date.now() - startTime;
54
- reporter.reportTime(message, elapsedTime);
55
- return [result, elapsedTime];
56
- }
57
-
58
- async function reportAsyncTime<T>(
59
- reporter: Reporter,
60
- message: string,
61
- fn: () => ?Promise<T>,
62
- ): Promise<T> {
63
- const startTime = Date.now();
64
- const promise = fn();
65
- if (!isPromise(promise)) {
66
- throw new Error('reportAsyncTime: fn(...) expected to return a promise.');
67
- }
68
- const result = await promise;
69
- const elapsedTime = Date.now() - startTime;
70
- reporter.reportTime(message, elapsedTime);
71
- return result;
72
- }
73
-
74
- module.exports = {
75
- reportTime,
76
- reportAndReturnTime,
77
- reportAsyncTime,
78
- reportAndReturnAsyncTime,
79
- };
@@ -1,126 +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
- * @flow
8
- * @format
9
- */
10
-
11
- // TODO: This is only used with `ArgumentValue` types, so it could be simpler.
12
-
13
- // flowlint ambiguous-object-type:error
14
- 'use strict';
15
-
16
- const aStackPool = [];
17
- const bStackPool = [];
18
-
19
- /**
20
- * Checks if two values are equal. Values may be primitives, arrays, or objects.
21
- * Returns true if both arguments have the same keys and values.
22
- *
23
- * @see http://underscorejs.org
24
- * @copyright 2009-2013 Jeremy Ashkenas, DocumentCloud Inc.
25
- * @license MIT
26
- */
27
- function areEqualArgValues(a: any, b: any): boolean {
28
- const aStack = aStackPool.length ? aStackPool.pop() : [];
29
- const bStack = bStackPool.length ? bStackPool.pop() : [];
30
- const result = eq(a, b, aStack, bStack);
31
- aStack.length = 0;
32
- bStack.length = 0;
33
- aStackPool.push(aStack);
34
- bStackPool.push(bStack);
35
- return result;
36
- }
37
-
38
- function eq(a: any, b: any, aStack: Array<any>, bStack: Array<any>): boolean {
39
- if (a === b) {
40
- // Identical objects are equal. `0 === -0`, but they aren't identical.
41
- return a !== 0 || 1 / a === 1 / b;
42
- }
43
- if (a == null || b == null) {
44
- // a or b can be `null` or `undefined`
45
- return false;
46
- }
47
- if (typeof a !== 'object' || typeof b !== 'object') {
48
- return false;
49
- }
50
- // $FlowFixMe[method-unbinding] added when improving typing for this parameters
51
- const objToStr = Object.prototype.toString;
52
- const className = objToStr.call(a);
53
- if (className !== objToStr.call(b)) {
54
- return false;
55
- }
56
- switch (className) {
57
- case '[object String]':
58
- return a === String(b);
59
- case '[object Number]':
60
- return isNaN(a) || isNaN(b) ? false : a === Number(b);
61
- case '[object Date]':
62
- case '[object Boolean]':
63
- return +a === +b;
64
- case '[object RegExp]':
65
- return (
66
- a.source === b.source &&
67
- a.global === b.global &&
68
- a.multiline === b.multiline &&
69
- a.ignoreCase === b.ignoreCase
70
- );
71
- }
72
- // Assume equality for cyclic structures.
73
- let length = aStack.length;
74
- while (length--) {
75
- if (aStack[length] === a) {
76
- return bStack[length] === b;
77
- }
78
- }
79
- aStack.push(a);
80
- bStack.push(b);
81
- let size = 0;
82
- // Recursively compare objects and arrays.
83
- if (className === '[object Array]') {
84
- size = a.length;
85
- if (size !== b.length) {
86
- return false;
87
- }
88
- // Deep compare the contents, ignoring non-numeric properties.
89
- while (size--) {
90
- if (!eq(a[size], b[size], aStack, bStack)) {
91
- return false;
92
- }
93
- }
94
- } else {
95
- if (a.constructor !== b.constructor) {
96
- return false;
97
- }
98
- if (a.hasOwnProperty('valueOf') && b.hasOwnProperty('valueOf')) {
99
- return a.valueOf() === b.valueOf();
100
- }
101
- const keys = Object.keys(a);
102
- if (keys.length !== Object.keys(b).length) {
103
- return false;
104
- }
105
- for (let i = 0; i < keys.length; i++) {
106
- if (keys[i] === '_owner') {
107
- // HACK: Comparing deeply nested React trees is slow since you end up
108
- // comparing the entire tree (all ancestors and all children) and
109
- // likely not what you want if you're comparing two elements with
110
- // areEqualArgValues. We bail out here for now.
111
- continue;
112
- }
113
- if (
114
- !b.hasOwnProperty(keys[i]) ||
115
- !eq(a[keys[i]], b[keys[i]], aStack, bStack)
116
- ) {
117
- return false;
118
- }
119
- }
120
- }
121
- aStack.pop();
122
- bStack.pop();
123
- return true;
124
- }
125
-
126
- module.exports = areEqualArgValues;
@@ -1,38 +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
- * @flow
8
- * @format
9
- */
10
-
11
- // flowlint ambiguous-object-type:error
12
-
13
- 'use strict';
14
-
15
- import type {NormalizationArgument, ReaderArgument} from 'relay-runtime';
16
-
17
- function argumentContainsVariables(
18
- arg: ?(ReaderArgument | NormalizationArgument),
19
- ): boolean {
20
- if (arg == null) {
21
- return false;
22
- }
23
- switch (arg.kind) {
24
- case 'Variable':
25
- return true;
26
- case 'Literal':
27
- return false;
28
- case 'ListValue':
29
- return arg.items.some(argumentContainsVariables);
30
- case 'ObjectValue':
31
- return arg.fields.some(argumentContainsVariables);
32
- default:
33
- (arg.kind: empty);
34
- return false;
35
- }
36
- }
37
-
38
- module.exports = argumentContainsVariables;
@@ -1,152 +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
- * @flow
8
- * @format
9
- */
10
-
11
- // flowlint ambiguous-object-type:error
12
-
13
- 'use strict';
14
-
15
- /**
16
- * This function works similar to JSON.stringify except that for the case there
17
- * are multiple common subtrees, it generates a string for a IIFE that re-uses
18
- * the same objects for the duplicate subtrees.
19
- */
20
- function dedupeJSONStringify(jsonValue: mixed): string {
21
- const metadataForHash = new Map();
22
- const metadataForVal = new WeakMap();
23
- const varDefs = [];
24
- collectMetadata(jsonValue);
25
- collectDuplicates(jsonValue);
26
- const code = printJSCode(false, '', jsonValue);
27
- return varDefs.length === 0
28
- ? code
29
- : `(function(){\nvar ${varDefs.join(',\n')};\nreturn ${code};\n})()`;
30
-
31
- // Collect common metadata for each object in the value tree, ensuring that
32
- // equivalent values have the *same reference* to the same metadata. Note that
33
- // the hashes generated are not exactly JSON, but still identify equivalent
34
- // values. Runs in linear time due to hashing in a bottom-up recursion.
35
- function collectMetadata(value): string {
36
- if (value == null || typeof value !== 'object') {
37
- // $FlowFixMe[incompatible-return] - JSON.stringify can return undefined
38
- return JSON.stringify(value);
39
- }
40
- let hash;
41
- if (Array.isArray(value)) {
42
- hash = '[';
43
- for (let i = 0; i < value.length; i++) {
44
- hash += collectMetadata(value[i]) + ',';
45
- }
46
- } else {
47
- hash = '{';
48
- for (const k in value) {
49
- if (value.hasOwnProperty(k) && value[k] !== undefined) {
50
- hash += k + ':' + collectMetadata(value[k]) + ',';
51
- }
52
- }
53
- }
54
- let metadata = metadataForHash.get(hash);
55
- if (!metadata) {
56
- metadata = ({value, hash, count: 0}: {|
57
- value: mixed,
58
- hash: string,
59
- count: number,
60
- varName?: string,
61
- |});
62
- metadataForHash.set(hash, metadata);
63
- }
64
- metadataForVal.set(value, metadata);
65
- return hash;
66
- }
67
-
68
- // Using top-down recursion, linearly scan the JSON tree to determine which
69
- // values should be deduplicated.
70
- function collectDuplicates(value) {
71
- if (value == null || typeof value !== 'object') {
72
- return;
73
- }
74
- const metadata = metadataForVal.get(value);
75
- // Only consider duplicates with hashes longer than 2 (excludes [] and {}).
76
- if (metadata && metadata.hash.length > 2) {
77
- metadata.count++;
78
- if (metadata.count > 1) {
79
- return;
80
- }
81
- }
82
- if (Array.isArray(value)) {
83
- for (let i = 0; i < value.length; i++) {
84
- collectDuplicates(value[i]);
85
- }
86
- } else {
87
- for (const k in value) {
88
- if (value.hasOwnProperty(k) && value[k] !== undefined) {
89
- collectDuplicates(value[k]);
90
- }
91
- }
92
- }
93
- }
94
-
95
- // Stringify JS, replacing duplicates with variable references.
96
- function printJSCode(isDupedVar, depth, value): string {
97
- if (value == null || typeof value !== 'object') {
98
- // $FlowFixMe[incompatible-return] : JSON.stringify can return undefined
99
- return JSON.stringify(value);
100
- }
101
- // Only use variable references at depth beyond the top level.
102
- if (depth !== '') {
103
- const metadata = metadataForVal.get(value);
104
- if (metadata && metadata.count > 1) {
105
- let varName = metadata.varName;
106
- if (varName == null) {
107
- const refCode = printJSCode(true, '', value);
108
- varName = metadata.varName = 'v' + varDefs.length;
109
- varDefs.push(metadata.varName + ' = ' + refCode);
110
- }
111
- return '(' + varName + '/*: any*/)';
112
- }
113
- }
114
- let str;
115
- let isEmpty = true;
116
- const depth2 = depth + ' ';
117
- if (Array.isArray(value)) {
118
- // Empty arrays can only have one inferred flow type and then conflict if
119
- // used in different places, this is unsound if we would write to them but
120
- // this whole module is based on the idea of a read only JSON tree.
121
- if (isDupedVar && value.length === 0) {
122
- return '([]/*: any*/)';
123
- }
124
- str = '[';
125
- for (let i = 0; i < value.length; i++) {
126
- str +=
127
- (isEmpty ? '\n' : ',\n') +
128
- depth2 +
129
- printJSCode(isDupedVar, depth2, value[i]);
130
- isEmpty = false;
131
- }
132
- str += isEmpty ? ']' : `\n${depth}]`;
133
- } else {
134
- str = '{';
135
- for (const k in value) {
136
- if (value.hasOwnProperty(k) && value[k] !== undefined) {
137
- str +=
138
- (isEmpty ? '\n' : ',\n') +
139
- depth2 +
140
- JSON.stringify(k) +
141
- ': ' +
142
- printJSCode(isDupedVar, depth2, value[k]);
143
- isEmpty = false;
144
- }
145
- }
146
- str += isEmpty ? '}' : `\n${depth}}`;
147
- }
148
- return str;
149
- }
150
- }
151
-
152
- module.exports = dedupeJSONStringify;