relay-compiler 9.0.0 → 9.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (197) hide show
  1. package/bin/RelayCompilerBin.js.flow +169 -0
  2. package/bin/RelayCompilerMain.js.flow +508 -0
  3. package/bin/__fixtures__/plugin-module.js.flow +17 -0
  4. package/bin/relay-compiler +2002 -1733
  5. package/codegen/CodegenDirectory.js.flow +375 -0
  6. package/codegen/CodegenRunner.js.flow +431 -0
  7. package/codegen/CodegenTypes.js.flow +28 -0
  8. package/codegen/CodegenWatcher.js.flow +254 -0
  9. package/codegen/NormalizationCodeGenerator.js.flow +499 -0
  10. package/codegen/ReaderCodeGenerator.js.flow +453 -0
  11. package/codegen/RelayCodeGenerator.js.flow +76 -0
  12. package/codegen/RelayFileWriter.js.flow +366 -0
  13. package/codegen/SourceControl.js.flow +58 -0
  14. package/codegen/compileRelayArtifacts.js.flow +182 -0
  15. package/codegen/createPrintRequireModuleDependency.js.flow +21 -0
  16. package/codegen/writeRelayGeneratedFile.js.flow +194 -0
  17. package/core/ASTCache.js.flow +73 -0
  18. package/core/ASTConvert.js.flow +233 -0
  19. package/core/CompilerContext.js.flow +190 -0
  20. package/core/CompilerError.js.flow +250 -0
  21. package/core/DotGraphQLParser.js.flow +39 -0
  22. package/core/GraphQLCompilerProfiler.js.flow +341 -0
  23. package/core/GraphQLDerivedFromMetadata.js.flow +48 -0
  24. package/core/GraphQLWatchmanClient.js.flow +111 -0
  25. package/core/IR.js.flow +329 -0
  26. package/core/IRPrinter.js.flow +488 -0
  27. package/core/IRTransformer.js.flow +377 -0
  28. package/core/IRValidator.js.flow +260 -0
  29. package/core/IRVisitor.js.flow +150 -0
  30. package/core/JSModuleParser.js.flow +24 -0
  31. package/core/RelayCompilerScope.js.flow +199 -0
  32. package/core/RelayFindGraphQLTags.js.flow +119 -0
  33. package/core/RelayGraphQLEnumsGenerator.js.flow +55 -0
  34. package/core/RelayIRTransforms.js.flow +130 -0
  35. package/core/RelayParser.js.flow +1759 -0
  36. package/core/RelaySourceModuleParser.js.flow +135 -0
  37. package/core/Schema.js.flow +1985 -0
  38. package/core/SchemaUtils.js.flow +109 -0
  39. package/core/filterContextForNode.js.flow +50 -0
  40. package/core/getFieldDefinition.js.flow +156 -0
  41. package/core/getIdentifierForArgumentValue.js.flow +49 -0
  42. package/core/getIdentifierForSelection.js.flow +69 -0
  43. package/core/getLiteralArgumentValues.js.flow +32 -0
  44. package/core/getNormalizationOperationName.js.flow +19 -0
  45. package/core/inferRootArgumentDefinitions.js.flow +323 -0
  46. package/index.js +1 -1
  47. package/index.js.flow +202 -0
  48. package/language/RelayLanguagePluginInterface.js.flow +283 -0
  49. package/language/javascript/FindGraphQLTags.js.flow +233 -0
  50. package/language/javascript/RelayFlowBabelFactories.js.flow +180 -0
  51. package/language/javascript/RelayFlowGenerator.js.flow +1040 -0
  52. package/language/javascript/RelayFlowTypeTransformers.js.flow +184 -0
  53. package/language/javascript/RelayLanguagePluginJavaScript.js.flow +34 -0
  54. package/language/javascript/formatGeneratedModule.js.flow +65 -0
  55. package/lib/bin/RelayCompilerBin.js +10 -0
  56. package/lib/bin/RelayCompilerMain.js +113 -119
  57. package/lib/codegen/CodegenDirectory.js +2 -6
  58. package/lib/codegen/CodegenRunner.js +34 -75
  59. package/lib/codegen/CodegenWatcher.js +13 -21
  60. package/lib/codegen/NormalizationCodeGenerator.js +43 -40
  61. package/lib/codegen/ReaderCodeGenerator.js +43 -35
  62. package/lib/codegen/RelayCodeGenerator.js +7 -5
  63. package/lib/codegen/RelayFileWriter.js +15 -36
  64. package/lib/codegen/compileRelayArtifacts.js +16 -30
  65. package/lib/codegen/writeRelayGeneratedFile.js +56 -98
  66. package/lib/core/ASTCache.js +1 -3
  67. package/lib/core/CompilerContext.js +1 -3
  68. package/lib/core/CompilerError.js +27 -54
  69. package/lib/core/GraphQLCompilerProfiler.js +8 -12
  70. package/lib/core/GraphQLWatchmanClient.js +4 -12
  71. package/lib/core/IRPrinter.js +5 -5
  72. package/lib/core/IRTransformer.js +8 -6
  73. package/lib/core/IRValidator.js +1 -3
  74. package/lib/core/RelayCompilerScope.js +4 -4
  75. package/lib/core/RelayGraphQLEnumsGenerator.js +12 -15
  76. package/lib/core/RelayIRTransforms.js +9 -5
  77. package/lib/core/RelayParser.js +44 -56
  78. package/lib/core/RelaySourceModuleParser.js +1 -3
  79. package/lib/core/Schema.js +78 -65
  80. package/lib/core/getFieldDefinition.js +12 -15
  81. package/lib/core/getIdentifierForSelection.js +1 -1
  82. package/lib/core/inferRootArgumentDefinitions.js +27 -36
  83. package/lib/language/javascript/RelayFlowGenerator.js +49 -78
  84. package/lib/language/javascript/RelayFlowTypeTransformers.js +1 -3
  85. package/lib/reporters/ConsoleReporter.js +1 -3
  86. package/lib/reporters/MultiReporter.js +1 -3
  87. package/lib/runner/Artifacts.js +69 -170
  88. package/lib/runner/BufferedFilesystem.js +32 -66
  89. package/lib/runner/GraphQLASTNodeGroup.js +54 -120
  90. package/lib/runner/GraphQLNodeMap.js +14 -19
  91. package/lib/runner/Sources.js +49 -78
  92. package/lib/runner/StrictMap.js +20 -36
  93. package/lib/runner/getChangedNodeNames.js +30 -62
  94. package/lib/transforms/ApplyFragmentArgumentTransform.js +33 -28
  95. package/lib/transforms/ClientExtensionsTransform.js +7 -12
  96. package/lib/transforms/ConnectionTransform.js +26 -24
  97. package/lib/transforms/DeferStreamTransform.js +20 -16
  98. package/lib/transforms/DisallowTypenameOnRoot.js +55 -0
  99. package/lib/transforms/FieldHandleTransform.js +6 -2
  100. package/lib/transforms/FlattenTransform.js +19 -14
  101. package/lib/transforms/GenerateIDFieldTransform.js +7 -3
  102. package/lib/transforms/GenerateTypeNameTransform.js +6 -2
  103. package/lib/transforms/InlineDataFragmentTransform.js +7 -3
  104. package/lib/transforms/MaskTransform.js +17 -17
  105. package/lib/transforms/MatchTransform.js +110 -32
  106. package/lib/transforms/RefetchableFragmentTransform.js +21 -17
  107. package/lib/transforms/RelayDirectiveTransform.js +11 -3
  108. package/lib/transforms/SkipClientExtensionsTransform.js +8 -0
  109. package/lib/transforms/SkipHandleFieldTransform.js +6 -2
  110. package/lib/transforms/SkipRedundantNodesTransform.js +6 -2
  111. package/lib/transforms/SkipSplitOperationTransform.js +32 -0
  112. package/lib/transforms/SkipUnreachableNodeTransform.js +9 -2
  113. package/lib/transforms/SkipUnusedVariablesTransform.js +18 -17
  114. package/lib/transforms/SplitModuleImportTransform.js +2 -2
  115. package/lib/transforms/TestOperationTransform.js +7 -3
  116. package/lib/transforms/ValidateGlobalVariablesTransform.js +18 -30
  117. package/lib/transforms/ValidateRequiredArgumentsTransform.js +12 -15
  118. package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +16 -30
  119. package/lib/transforms/ValidateUnusedVariablesTransform.js +18 -30
  120. package/lib/transforms/query-generators/FetchableQueryGenerator.js +161 -0
  121. package/lib/transforms/query-generators/NodeQueryGenerator.js +7 -2
  122. package/lib/transforms/query-generators/QueryQueryGenerator.js +1 -0
  123. package/lib/transforms/query-generators/ViewerQueryGenerator.js +1 -0
  124. package/lib/transforms/query-generators/index.js +23 -6
  125. package/lib/transforms/query-generators/utils.js +12 -15
  126. package/lib/util/RelayCompilerCache.js +1 -3
  127. package/lib/util/dedupeJSONStringify.js +15 -12
  128. package/lib/util/getModuleName.js +1 -1
  129. package/package.json +2 -2
  130. package/relay-compiler.js +4 -4
  131. package/relay-compiler.min.js +4 -4
  132. package/reporters/ConsoleReporter.js.flow +81 -0
  133. package/reporters/MultiReporter.js.flow +43 -0
  134. package/reporters/Reporter.js.flow +19 -0
  135. package/runner/Artifacts.js.flow +219 -0
  136. package/runner/BufferedFilesystem.js.flow +194 -0
  137. package/runner/GraphQLASTNodeGroup.js.flow +176 -0
  138. package/runner/GraphQLASTUtils.js.flow +26 -0
  139. package/runner/GraphQLNodeMap.js.flow +55 -0
  140. package/runner/Sources.js.flow +218 -0
  141. package/runner/StrictMap.js.flow +96 -0
  142. package/runner/compileArtifacts.js.flow +76 -0
  143. package/runner/extractAST.js.flow +100 -0
  144. package/runner/getChangedNodeNames.js.flow +48 -0
  145. package/runner/getSchemaInstance.js.flow +36 -0
  146. package/runner/types.js.flow +37 -0
  147. package/transforms/ApplyFragmentArgumentTransform.js.flow +474 -0
  148. package/transforms/ClientExtensionsTransform.js.flow +220 -0
  149. package/transforms/ConnectionTransform.js.flow +869 -0
  150. package/transforms/DeferStreamTransform.js.flow +258 -0
  151. package/transforms/DisallowIdAsAlias.js.flow +47 -0
  152. package/transforms/DisallowTypenameOnRoot.js.flow +45 -0
  153. package/transforms/FieldHandleTransform.js.flow +80 -0
  154. package/transforms/FilterDirectivesTransform.js.flow +45 -0
  155. package/transforms/FlattenTransform.js.flow +456 -0
  156. package/transforms/GenerateIDFieldTransform.js.flow +134 -0
  157. package/transforms/GenerateTypeNameTransform.js.flow +81 -0
  158. package/transforms/InlineDataFragmentTransform.js.flow +124 -0
  159. package/transforms/InlineFragmentsTransform.js.flow +71 -0
  160. package/transforms/MaskTransform.js.flow +126 -0
  161. package/transforms/MatchTransform.js.flow +583 -0
  162. package/transforms/RefetchableFragmentTransform.js.flow +272 -0
  163. package/transforms/RelayDirectiveTransform.js.flow +99 -0
  164. package/transforms/SkipClientExtensionsTransform.js.flow +54 -0
  165. package/transforms/SkipHandleFieldTransform.js.flow +44 -0
  166. package/transforms/SkipRedundantNodesTransform.js.flow +253 -0
  167. package/transforms/SkipSplitOperationTransform.js.flow +37 -0
  168. package/transforms/SkipUnreachableNodeTransform.js.flow +149 -0
  169. package/transforms/SkipUnusedVariablesTransform.js.flow +59 -0
  170. package/transforms/SplitModuleImportTransform.js.flow +98 -0
  171. package/transforms/TestOperationTransform.js.flow +138 -0
  172. package/transforms/TransformUtils.js.flow +26 -0
  173. package/transforms/ValidateGlobalVariablesTransform.js.flow +81 -0
  174. package/transforms/ValidateRequiredArgumentsTransform.js.flow +127 -0
  175. package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +112 -0
  176. package/transforms/ValidateUnusedVariablesTransform.js.flow +89 -0
  177. package/transforms/query-generators/FetchableQueryGenerator.js.flow +190 -0
  178. package/transforms/query-generators/NodeQueryGenerator.js.flow +206 -0
  179. package/transforms/query-generators/QueryQueryGenerator.js.flow +57 -0
  180. package/transforms/query-generators/ViewerQueryGenerator.js.flow +97 -0
  181. package/transforms/query-generators/index.js.flow +90 -0
  182. package/transforms/query-generators/utils.js.flow +72 -0
  183. package/util/CodeMarker.js.flow +79 -0
  184. package/util/DefaultHandleKey.js.flow +17 -0
  185. package/util/RelayCompilerCache.js.flow +88 -0
  186. package/util/Rollout.js.flow +39 -0
  187. package/util/TimeReporter.js.flow +79 -0
  188. package/util/areEqualOSS.js.flow +123 -0
  189. package/util/dedupeJSONStringify.js.flow +152 -0
  190. package/util/getDefinitionNodeHash.js.flow +25 -0
  191. package/util/getModuleName.js.flow +39 -0
  192. package/util/joinArgumentDefinitions.js.flow +99 -0
  193. package/util/md5.js.flow +22 -0
  194. package/util/murmurHash.js.flow +94 -0
  195. package/util/nullthrowsOSS.js.flow +25 -0
  196. package/util/orList.js.flow +37 -0
  197. package/util/partitionArray.js.flow +37 -0
@@ -0,0 +1,99 @@
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
+ const {createUserError} = require('../core/CompilerError');
16
+
17
+ import type {ArgumentDefinition, Fragment} from '../core/IR';
18
+ import type {Schema} from '../core/Schema';
19
+
20
+ /**
21
+ * Attempts to join the argument definitions for a root fragment
22
+ * and any unmasked fragment spreads reachable from that root fragment,
23
+ * returning a combined list of arguments or throwing if the same
24
+ * variable(s) are used in incompatible ways in different fragments.
25
+ */
26
+ function joinArgumentDefinitions(
27
+ schema: Schema,
28
+ fragment: Fragment,
29
+ reachableArguments: $ReadOnlyArray<ArgumentDefinition>,
30
+ directiveName: string,
31
+ ): $ReadOnlyArray<ArgumentDefinition> {
32
+ const joinedArgumentDefinitions = new Map();
33
+ fragment.argumentDefinitions.forEach(prevArgDef => {
34
+ joinedArgumentDefinitions.set(prevArgDef.name, prevArgDef);
35
+ });
36
+ reachableArguments.forEach(nextArgDef => {
37
+ const prevArgDef = joinedArgumentDefinitions.get(nextArgDef.name);
38
+ const joinedArgDef =
39
+ prevArgDef == null
40
+ ? nextArgDef
41
+ : joinArgumentDefinition(schema, prevArgDef, nextArgDef, directiveName);
42
+ joinedArgumentDefinitions.set(joinedArgDef.name, joinedArgDef);
43
+ });
44
+ return Array.from(joinedArgumentDefinitions.values());
45
+ }
46
+
47
+ /**
48
+ * @private
49
+ *
50
+ * Attempts to join two argument definitions, returning a single argument
51
+ * definition that is compatible with both of the inputs:
52
+ * - If the kind, name, or defaultValue is different then the arguments
53
+ * cannot be joined, indicated by returning null.
54
+ * - If either of next/prev is a subtype of the other, return the one
55
+ * that is the subtype: a more narrow type can flow into a more general
56
+ * type but not the inverse.
57
+ * - Otherwise there is no subtyping relation between prev/next, so return
58
+ * null to indicate they cannot be joined.
59
+ */
60
+ function joinArgumentDefinition(
61
+ schema: Schema,
62
+ prevArgDef: ArgumentDefinition,
63
+ nextArgDef: ArgumentDefinition,
64
+ directiveName: string,
65
+ ): ArgumentDefinition {
66
+ if (prevArgDef.kind !== nextArgDef.kind) {
67
+ throw createUserError(
68
+ 'Cannot combine global and local variables when applying ' +
69
+ `${directiveName}.`,
70
+ [prevArgDef.loc, nextArgDef.loc],
71
+ );
72
+ } else if (
73
+ prevArgDef.kind === 'LocalArgumentDefinition' &&
74
+ nextArgDef.kind === 'LocalArgumentDefinition' &&
75
+ prevArgDef.defaultValue !== nextArgDef.defaultValue
76
+ ) {
77
+ throw createUserError(
78
+ 'Cannot combine local variables with different defaultValues when ' +
79
+ `applying ${directiveName}.`,
80
+ [prevArgDef.loc, nextArgDef.loc],
81
+ );
82
+ } else if (schema.isTypeSubTypeOf(nextArgDef.type, prevArgDef.type)) {
83
+ // prevArgDef is less strict than nextArgDef
84
+ return nextArgDef;
85
+ } else if (schema.isTypeSubTypeOf(prevArgDef.type, nextArgDef.type)) {
86
+ return prevArgDef;
87
+ } else {
88
+ throw createUserError(
89
+ 'Cannot combine variables with incompatible types ' +
90
+ `${schema.getTypeString(prevArgDef.type)} and ${schema.getTypeString(
91
+ nextArgDef.type,
92
+ )} ` +
93
+ `when applying ${directiveName}.`,
94
+ [prevArgDef.loc, nextArgDef.loc],
95
+ );
96
+ }
97
+ }
98
+
99
+ module.exports = joinArgumentDefinitions;
@@ -0,0 +1,22 @@
1
+ /**
2
+ * Copyright (c) Facebook, Inc. and its affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ * @flow strict
8
+ * @format
9
+ */
10
+
11
+ // flowlint ambiguous-object-type:error
12
+
13
+ 'use strict';
14
+
15
+ function md5(str: string): string {
16
+ return require('crypto')
17
+ .createHash('md5')
18
+ .update(str, 'utf8')
19
+ .digest('hex');
20
+ }
21
+
22
+ module.exports = md5;
@@ -0,0 +1,94 @@
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
+ /**
14
+ * Based on implementations by Gary Court and Austin Appleby, 2011, MIT.
15
+ * @preserve-header
16
+ */
17
+
18
+ 'use strict';
19
+
20
+ const BASE62 = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
21
+
22
+ /**
23
+ * @param {string} key A UTF-16 or ASCII string
24
+ * @return {string} a base62 murmur hash
25
+ */
26
+ function murmurHash(str: string): string {
27
+ /* eslint-disable no-bitwise */
28
+ const length = str.length;
29
+ const rem = length & 3;
30
+ const len = length ^ rem;
31
+
32
+ let h = 0;
33
+ let i = 0;
34
+ let k;
35
+
36
+ while (i !== len) {
37
+ const ch4 = str.charCodeAt(i + 3);
38
+
39
+ k =
40
+ str.charCodeAt(i) ^
41
+ (str.charCodeAt(i + 1) << 8) ^
42
+ (str.charCodeAt(i + 2) << 16) ^
43
+ ((ch4 & 0xff) << 24) ^
44
+ ((ch4 & 0xff00) >> 8);
45
+
46
+ i += 4;
47
+
48
+ k = (k * 0x2d51 + (k & 0xffff) * 0xcc9e0000) >>> 0;
49
+ k = (k << 15) | (k >>> 17);
50
+ k = (k * 0x3593 + (k & 0xffff) * 0x1b870000) >>> 0;
51
+ h ^= k;
52
+ h = (h << 13) | (h >>> 19);
53
+ h = (h * 5 + 0xe6546b64) >>> 0;
54
+ }
55
+
56
+ k = 0;
57
+ switch (rem) {
58
+ /* eslint-disable no-fallthrough */
59
+ case 3:
60
+ k ^= str.charCodeAt(len + 2) << 16;
61
+ case 2:
62
+ k ^= str.charCodeAt(len + 1) << 8;
63
+ case 1:
64
+ k ^= str.charCodeAt(len);
65
+
66
+ k = (k * 0x2d51 + (k & 0xffff) * 0xcc9e0000) >>> 0;
67
+ k = (k << 15) | (k >>> 17);
68
+ k = (k * 0x3593 + (k & 0xffff) * 0x1b870000) >>> 0;
69
+ h ^= k;
70
+ }
71
+
72
+ h ^= length;
73
+ h ^= h >>> 16;
74
+ h = (h * 0xca6b + (h & 0xffff) * 0x85eb0000) >>> 0;
75
+ h ^= h >>> 13;
76
+ h = (h * 0xae35 + (h & 0xffff) * 0xc2b20000) >>> 0;
77
+ h ^= h >>> 16;
78
+
79
+ h >>>= 0;
80
+
81
+ if (!h) {
82
+ return '0';
83
+ }
84
+
85
+ let s = '';
86
+ while (h) {
87
+ const d = h % 62;
88
+ s = BASE62[d] + s;
89
+ h = (h - d) / 62;
90
+ }
91
+ return s;
92
+ }
93
+
94
+ module.exports = murmurHash;
@@ -0,0 +1,25 @@
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
+ function nullthrows<T>(
16
+ x: ?T,
17
+ message?: string = 'Got unexpected null or undefined',
18
+ ): T {
19
+ if (x == null) {
20
+ throw new Error(message);
21
+ }
22
+ return x;
23
+ }
24
+
25
+ module.exports = nullthrows;
@@ -0,0 +1,37 @@
1
+ /**
2
+ * Copyright (c) Facebook, Inc. and its affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ * @flow strict
8
+ * @format
9
+ */
10
+
11
+ // flowlint ambiguous-object-type:error
12
+
13
+ 'use strict';
14
+
15
+ const OR_LIST_MAX_LENGTH = 5;
16
+
17
+ const {createCompilerError} = require('../core/CompilerError');
18
+
19
+ function orList(items: $ReadOnlyArray<string>): string {
20
+ if (items.length === 0) {
21
+ throw createCompilerError('Expected an array of strings. Got empty array');
22
+ }
23
+
24
+ if (items.length === 1) {
25
+ return items[0];
26
+ }
27
+
28
+ if (items.length > OR_LIST_MAX_LENGTH) {
29
+ return items.slice(0, OR_LIST_MAX_LENGTH).join(', ') + ', ...';
30
+ }
31
+
32
+ const selected = items.slice();
33
+ const lastItem = selected.pop();
34
+ return selected.join(', ') + ' or ' + lastItem;
35
+ }
36
+
37
+ module.exports = orList;
@@ -0,0 +1,37 @@
1
+ /**
2
+ * Copyright (c) Facebook, Inc. and its affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ * @flow strict
8
+ * @format
9
+ */
10
+
11
+ // flowlint ambiguous-object-type:error
12
+
13
+ 'use strict';
14
+
15
+ /**
16
+ * Partitions an array given a predicate. All elements satisfying the predicate
17
+ * are part of the first returned array, and all elements that don't are in the
18
+ * second.
19
+ */
20
+ function partitionArray<Tv>(
21
+ array: $ReadOnlyArray<Tv>,
22
+ predicate: (value: Tv) => boolean,
23
+ ): [$ReadOnlyArray<Tv>, $ReadOnlyArray<Tv>] {
24
+ const first = [];
25
+ const second = [];
26
+ for (let i = 0; i < array.length; i++) {
27
+ const item = array[i];
28
+ if (predicate(item)) {
29
+ first.push(item);
30
+ } else {
31
+ second.push(item);
32
+ }
33
+ }
34
+ return [first, second];
35
+ }
36
+
37
+ module.exports = partitionArray;