relay-compiler 0.0.0-main-8ff54d69 → 0.0.0-main-38f1c96e
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cli.js +23 -0
- package/index.js +19 -3
- package/linux-x64/relay +0 -0
- package/macos-x64/relay +0 -0
- package/package.json +2 -24
- package/win-x64/relay.exe +0 -0
- package/bin/RelayCompilerBin.js.flow +0 -168
- package/bin/RelayCompilerMain.js.flow +0 -515
- package/bin/__fixtures__/plugin-module.js.flow +0 -17
- package/bin/relay-compiler +0 -19068
- package/codegen/CodegenDirectory.js.flow +0 -372
- package/codegen/CodegenRunner.js.flow +0 -424
- package/codegen/CodegenTypes.js.flow +0 -28
- package/codegen/CodegenWatcher.js.flow +0 -250
- package/codegen/NormalizationCodeGenerator.js.flow +0 -566
- package/codegen/ReaderCodeGenerator.js.flow +0 -510
- package/codegen/RelayCodeGenerator.js.flow +0 -85
- package/codegen/RelayFileWriter.js.flow +0 -365
- package/codegen/SourceControl.js.flow +0 -58
- package/codegen/compileRelayArtifacts.js.flow +0 -181
- package/codegen/createPrintRequireModuleDependency.js.flow +0 -19
- package/codegen/sortObjectByKey.js.flow +0 -25
- package/codegen/writeRelayGeneratedFile.js.flow +0 -235
- package/core/ASTCache.js.flow +0 -73
- package/core/ASTConvert.js.flow +0 -230
- package/core/CompilerContext.js.flow +0 -189
- package/core/CompilerError.js.flow +0 -255
- package/core/DotGraphQLParser.js.flow +0 -37
- package/core/GraphQLCompilerProfiler.js.flow +0 -341
- package/core/GraphQLDerivedFromMetadata.js.flow +0 -36
- package/core/GraphQLWatchmanClient.js.flow +0 -109
- package/core/IR.js.flow +0 -326
- package/core/IRPrinter.js.flow +0 -472
- package/core/IRTransformer.js.flow +0 -376
- package/core/IRValidator.js.flow +0 -259
- package/core/IRVisitor.js.flow +0 -150
- package/core/JSModuleParser.js.flow +0 -24
- package/core/RelayCompilerScope.js.flow +0 -199
- package/core/RelayFindGraphQLTags.js.flow +0 -118
- package/core/RelayGraphQLEnumsGenerator.js.flow +0 -55
- package/core/RelayIRTransforms.js.flow +0 -138
- package/core/RelayParser.js.flow +0 -1741
- package/core/RelaySourceModuleParser.js.flow +0 -133
- package/core/Schema.js.flow +0 -2035
- package/core/SchemaUtils.js.flow +0 -120
- package/core/filterContextForNode.js.flow +0 -49
- package/core/getFieldDefinition.js.flow +0 -156
- package/core/getIdentifierForArgumentValue.js.flow +0 -49
- package/core/getIdentifierForSelection.js.flow +0 -68
- package/core/getLiteralArgumentValues.js.flow +0 -32
- package/core/getNormalizationOperationName.js.flow +0 -19
- package/core/inferRootArgumentDefinitions.js.flow +0 -322
- package/index.js.flow +0 -198
- package/language/RelayLanguagePluginInterface.js.flow +0 -283
- package/language/javascript/FindGraphQLTags.js.flow +0 -136
- package/language/javascript/RelayFlowBabelFactories.js.flow +0 -176
- package/language/javascript/RelayFlowGenerator.js.flow +0 -1096
- package/language/javascript/RelayFlowTypeTransformers.js.flow +0 -181
- package/language/javascript/RelayLanguagePluginJavaScript.js.flow +0 -33
- package/language/javascript/formatGeneratedModule.js.flow +0 -65
- package/lib/bin/RelayCompilerBin.js +0 -143
- package/lib/bin/RelayCompilerMain.js +0 -488
- package/lib/bin/__fixtures__/plugin-module.js +0 -16
- package/lib/codegen/CodegenDirectory.js +0 -335
- package/lib/codegen/CodegenRunner.js +0 -433
- package/lib/codegen/CodegenTypes.js +0 -11
- package/lib/codegen/CodegenWatcher.js +0 -271
- package/lib/codegen/NormalizationCodeGenerator.js +0 -487
- package/lib/codegen/ReaderCodeGenerator.js +0 -473
- package/lib/codegen/RelayCodeGenerator.js +0 -75
- package/lib/codegen/RelayFileWriter.js +0 -270
- package/lib/codegen/SourceControl.js +0 -60
- package/lib/codegen/compileRelayArtifacts.js +0 -157
- package/lib/codegen/createPrintRequireModuleDependency.js +0 -19
- package/lib/codegen/sortObjectByKey.js +0 -41
- package/lib/codegen/writeRelayGeneratedFile.js +0 -206
- package/lib/core/ASTCache.js +0 -70
- package/lib/core/ASTConvert.js +0 -198
- package/lib/core/CompilerContext.js +0 -165
- package/lib/core/CompilerError.js +0 -252
- package/lib/core/DotGraphQLParser.js +0 -40
- package/lib/core/GraphQLCompilerProfiler.js +0 -299
- package/lib/core/GraphQLDerivedFromMetadata.js +0 -31
- package/lib/core/GraphQLWatchmanClient.js +0 -150
- package/lib/core/IR.js +0 -11
- package/lib/core/IRPrinter.js +0 -388
- package/lib/core/IRTransformer.js +0 -345
- package/lib/core/IRValidator.js +0 -226
- package/lib/core/IRVisitor.js +0 -45
- package/lib/core/JSModuleParser.js +0 -18
- package/lib/core/RelayCompilerScope.js +0 -183
- package/lib/core/RelayFindGraphQLTags.js +0 -79
- package/lib/core/RelayGraphQLEnumsGenerator.js +0 -50
- package/lib/core/RelayIRTransforms.js +0 -109
- package/lib/core/RelayParser.js +0 -1381
- package/lib/core/RelaySourceModuleParser.js +0 -104
- package/lib/core/Schema.js +0 -1877
- package/lib/core/SchemaUtils.js +0 -98
- package/lib/core/filterContextForNode.js +0 -50
- package/lib/core/getFieldDefinition.js +0 -145
- package/lib/core/getIdentifierForArgumentValue.js +0 -54
- package/lib/core/getIdentifierForSelection.js +0 -49
- package/lib/core/getLiteralArgumentValues.js +0 -26
- package/lib/core/getNormalizationOperationName.js +0 -17
- package/lib/core/inferRootArgumentDefinitions.js +0 -351
- package/lib/index.js +0 -178
- package/lib/language/RelayLanguagePluginInterface.js +0 -26
- package/lib/language/javascript/FindGraphQLTags.js +0 -126
- package/lib/language/javascript/RelayFlowBabelFactories.js +0 -160
- package/lib/language/javascript/RelayFlowGenerator.js +0 -856
- package/lib/language/javascript/RelayFlowTypeTransformers.js +0 -119
- package/lib/language/javascript/RelayLanguagePluginJavaScript.js +0 -30
- package/lib/language/javascript/formatGeneratedModule.js +0 -36
- package/lib/reporters/ConsoleReporter.js +0 -61
- package/lib/reporters/MultiReporter.js +0 -45
- package/lib/reporters/Reporter.js +0 -11
- package/lib/runner/Artifacts.js +0 -323
- package/lib/runner/BufferedFilesystem.js +0 -262
- package/lib/runner/GraphQLASTNodeGroup.js +0 -256
- package/lib/runner/GraphQLASTUtils.js +0 -23
- package/lib/runner/GraphQLNodeMap.js +0 -81
- package/lib/runner/Sources.js +0 -271
- package/lib/runner/StrictMap.js +0 -134
- package/lib/runner/compileArtifacts.js +0 -39
- package/lib/runner/extractAST.js +0 -77
- package/lib/runner/getChangedNodeNames.js +0 -82
- package/lib/runner/getSchemaInstance.js +0 -30
- package/lib/runner/types.js +0 -12
- package/lib/test-utils/TestSchema.js +0 -27
- package/lib/test-utils/parseGraphQLText.js +0 -30
- package/lib/transforms/ApplyFragmentArgumentTransform.js +0 -393
- package/lib/transforms/ClientExtensionsTransform.js +0 -221
- package/lib/transforms/ConnectionTransform.js +0 -639
- package/lib/transforms/DeclarativeConnectionMutationTransform.js +0 -218
- package/lib/transforms/DeferStreamTransform.js +0 -246
- package/lib/transforms/DisallowIdAsAlias.js +0 -40
- package/lib/transforms/DisallowTypenameOnRoot.js +0 -53
- package/lib/transforms/FieldHandleTransform.js +0 -79
- package/lib/transforms/FilterCompilerDirectivesTransform.js +0 -29
- package/lib/transforms/FilterDirectivesTransform.js +0 -42
- package/lib/transforms/FlattenTransform.js +0 -306
- package/lib/transforms/GenerateIDFieldTransform.js +0 -135
- package/lib/transforms/GenerateTypeNameTransform.js +0 -149
- package/lib/transforms/InlineDataFragmentTransform.js +0 -100
- package/lib/transforms/InlineFragmentsTransform.js +0 -61
- package/lib/transforms/MaskTransform.js +0 -117
- package/lib/transforms/MatchTransform.js +0 -434
- package/lib/transforms/ReactFlightComponentTransform.js +0 -158
- package/lib/transforms/RefetchableFragmentTransform.js +0 -249
- package/lib/transforms/RelayDirectiveTransform.js +0 -83
- package/lib/transforms/RequiredFieldTransform.js +0 -369
- package/lib/transforms/SkipClientExtensionsTransform.js +0 -46
- package/lib/transforms/SkipHandleFieldTransform.js +0 -45
- package/lib/transforms/SkipRedundantNodesTransform.js +0 -261
- package/lib/transforms/SkipSplitOperationTransform.js +0 -32
- package/lib/transforms/SkipUnreachableNodeTransform.js +0 -158
- package/lib/transforms/SkipUnusedVariablesTransform.js +0 -75
- package/lib/transforms/SplitModuleImportTransform.js +0 -82
- package/lib/transforms/TestOperationTransform.js +0 -144
- package/lib/transforms/TransformUtils.js +0 -21
- package/lib/transforms/ValidateGlobalVariablesTransform.js +0 -92
- package/lib/transforms/ValidateRequiredArgumentsTransform.js +0 -114
- package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +0 -108
- package/lib/transforms/ValidateUnusedVariablesTransform.js +0 -96
- package/lib/transforms/query-generators/FetchableQueryGenerator.js +0 -157
- package/lib/transforms/query-generators/NodeQueryGenerator.js +0 -166
- package/lib/transforms/query-generators/QueryQueryGenerator.js +0 -48
- package/lib/transforms/query-generators/ViewerQueryGenerator.js +0 -77
- package/lib/transforms/query-generators/index.js +0 -60
- package/lib/transforms/query-generators/utils.js +0 -92
- package/lib/util/CodeMarker.js +0 -80
- package/lib/util/DefaultHandleKey.js +0 -15
- package/lib/util/RelayCompilerCache.js +0 -97
- package/lib/util/Rollout.js +0 -40
- package/lib/util/TimeReporter.js +0 -83
- package/lib/util/areEqualArgValues.js +0 -135
- package/lib/util/argumentContainsVariables.js +0 -37
- package/lib/util/dedupeJSONStringify.js +0 -160
- package/lib/util/generateAbstractTypeRefinementKey.js +0 -24
- package/lib/util/getDefinitionNodeHash.js +0 -22
- package/lib/util/getModuleName.js +0 -32
- package/lib/util/joinArgumentDefinitions.js +0 -67
- package/lib/util/md5.js +0 -17
- package/lib/util/murmurHash.js +0 -86
- package/lib/util/nullthrowsOSS.js +0 -23
- package/lib/util/orList.js +0 -36
- package/lib/util/partitionArray.js +0 -35
- package/relay-compiler.js +0 -17
- package/relay-compiler.min.js +0 -22
- package/reporters/ConsoleReporter.js.flow +0 -81
- package/reporters/MultiReporter.js.flow +0 -43
- package/reporters/Reporter.js.flow +0 -19
- package/runner/Artifacts.js.flow +0 -215
- package/runner/BufferedFilesystem.js.flow +0 -194
- package/runner/GraphQLASTNodeGroup.js.flow +0 -174
- package/runner/GraphQLASTUtils.js.flow +0 -26
- package/runner/GraphQLNodeMap.js.flow +0 -55
- package/runner/Sources.js.flow +0 -227
- package/runner/StrictMap.js.flow +0 -96
- package/runner/compileArtifacts.js.flow +0 -75
- package/runner/extractAST.js.flow +0 -98
- package/runner/getChangedNodeNames.js.flow +0 -48
- package/runner/getSchemaInstance.js.flow +0 -36
- package/runner/types.js.flow +0 -37
- package/test-utils/TestSchema.js.flow +0 -30
- package/test-utils/parseGraphQLText.js.flow +0 -41
- package/transforms/ApplyFragmentArgumentTransform.js.flow +0 -524
- package/transforms/ClientExtensionsTransform.js.flow +0 -224
- package/transforms/ConnectionTransform.js.flow +0 -850
- package/transforms/DeclarativeConnectionMutationTransform.js.flow +0 -245
- package/transforms/DeferStreamTransform.js.flow +0 -263
- package/transforms/DisallowIdAsAlias.js.flow +0 -46
- package/transforms/DisallowTypenameOnRoot.js.flow +0 -44
- package/transforms/FieldHandleTransform.js.flow +0 -77
- package/transforms/FilterCompilerDirectivesTransform.js.flow +0 -33
- package/transforms/FilterDirectivesTransform.js.flow +0 -45
- package/transforms/FlattenTransform.js.flow +0 -458
- package/transforms/GenerateIDFieldTransform.js.flow +0 -151
- package/transforms/GenerateTypeNameTransform.js.flow +0 -159
- package/transforms/InlineDataFragmentTransform.js.flow +0 -123
- package/transforms/InlineFragmentsTransform.js.flow +0 -70
- package/transforms/MaskTransform.js.flow +0 -124
- package/transforms/MatchTransform.js.flow +0 -587
- package/transforms/ReactFlightComponentTransform.js.flow +0 -207
- package/transforms/RefetchableFragmentTransform.js.flow +0 -266
- package/transforms/RelayDirectiveTransform.js.flow +0 -96
- package/transforms/RequiredFieldTransform.js.flow +0 -413
- package/transforms/SkipClientExtensionsTransform.js.flow +0 -54
- package/transforms/SkipHandleFieldTransform.js.flow +0 -44
- package/transforms/SkipRedundantNodesTransform.js.flow +0 -277
- package/transforms/SkipSplitOperationTransform.js.flow +0 -37
- package/transforms/SkipUnreachableNodeTransform.js.flow +0 -148
- package/transforms/SkipUnusedVariablesTransform.js.flow +0 -59
- package/transforms/SplitModuleImportTransform.js.flow +0 -97
- package/transforms/TestOperationTransform.js.flow +0 -142
- package/transforms/TransformUtils.js.flow +0 -26
- package/transforms/ValidateGlobalVariablesTransform.js.flow +0 -80
- package/transforms/ValidateRequiredArgumentsTransform.js.flow +0 -130
- package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +0 -128
- package/transforms/ValidateUnusedVariablesTransform.js.flow +0 -88
- package/transforms/query-generators/FetchableQueryGenerator.js.flow +0 -188
- package/transforms/query-generators/NodeQueryGenerator.js.flow +0 -217
- package/transforms/query-generators/QueryQueryGenerator.js.flow +0 -57
- package/transforms/query-generators/ViewerQueryGenerator.js.flow +0 -97
- package/transforms/query-generators/index.js.flow +0 -89
- package/transforms/query-generators/utils.js.flow +0 -76
- package/util/CodeMarker.js.flow +0 -79
- package/util/DefaultHandleKey.js.flow +0 -17
- package/util/RelayCompilerCache.js.flow +0 -86
- package/util/Rollout.js.flow +0 -39
- package/util/TimeReporter.js.flow +0 -79
- package/util/areEqualArgValues.js.flow +0 -126
- package/util/argumentContainsVariables.js.flow +0 -38
- package/util/dedupeJSONStringify.js.flow +0 -156
- package/util/generateAbstractTypeRefinementKey.js.flow +0 -29
- package/util/getDefinitionNodeHash.js.flow +0 -24
- package/util/getModuleName.js.flow +0 -39
- package/util/joinArgumentDefinitions.js.flow +0 -105
- package/util/md5.js.flow +0 -19
- package/util/murmurHash.js.flow +0 -94
- package/util/nullthrowsOSS.js.flow +0 -25
- package/util/orList.js.flow +0 -37
- package/util/partitionArray.js.flow +0 -37
@@ -1,341 +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 invariant = require('invariant');
|
16
|
-
|
17
|
-
/**
|
18
|
-
* The compiler profiler builds a "call graph" of high level operations as a
|
19
|
-
* means of tracking time spent over the course of running the compiler.
|
20
|
-
*/
|
21
|
-
|
22
|
-
type Trace =
|
23
|
-
| MetadataTrace
|
24
|
-
| BeginDurationTrace
|
25
|
-
| EndDurationTrace
|
26
|
-
| EventTrace
|
27
|
-
| BeginAsyncTrace
|
28
|
-
| EndAsyncTrace;
|
29
|
-
|
30
|
-
type MetadataTrace = {|
|
31
|
-
ph: 'M',
|
32
|
-
pid: number, // Process ID
|
33
|
-
tid: number, // Thread ID
|
34
|
-
name: 'process_name' | 'thread_name',
|
35
|
-
args: {|name: string|},
|
36
|
-
|};
|
37
|
-
|
38
|
-
type BeginDurationTrace = {|
|
39
|
-
ph: 'B',
|
40
|
-
name: string, // Event name
|
41
|
-
pid: number, // Process ID
|
42
|
-
tid: number, // Thread ID
|
43
|
-
ts: number, // Relative timestamp integer microseconds
|
44
|
-
|};
|
45
|
-
|
46
|
-
type EndDurationTrace = {|
|
47
|
-
ph: 'E',
|
48
|
-
name: string, // Event name
|
49
|
-
pid: number, // Process ID
|
50
|
-
tid: number, // Thread ID
|
51
|
-
ts: number, // Relative timestamp integer microseconds
|
52
|
-
|};
|
53
|
-
|
54
|
-
type EventTrace = {|
|
55
|
-
ph: 'X',
|
56
|
-
name: string, // Event name
|
57
|
-
pid: number, // Process ID
|
58
|
-
tid: number, // Thread ID
|
59
|
-
ts: number, // Relative timestamp integer in microseconds
|
60
|
-
dur: number, // Duration timestamp integer in microseconds
|
61
|
-
|};
|
62
|
-
|
63
|
-
type BeginAsyncTrace = {|
|
64
|
-
ph: 'b',
|
65
|
-
name: string, // Async event name
|
66
|
-
cat: string, // Async category
|
67
|
-
id: number, // Async tree ID
|
68
|
-
pid: number, // Process ID
|
69
|
-
tid: number, // Thread ID
|
70
|
-
ts: number, // Relative timestamp integer microseconds
|
71
|
-
|};
|
72
|
-
|
73
|
-
type EndAsyncTrace = {|
|
74
|
-
ph: 'e',
|
75
|
-
name: string, // Async event name
|
76
|
-
cat: string, // Async category
|
77
|
-
id: number, // Async tree ID
|
78
|
-
pid: number, // Process ID
|
79
|
-
tid: number, // Thread ID
|
80
|
-
ts: number, // Relative timestamp integer microseconds
|
81
|
-
|};
|
82
|
-
|
83
|
-
let enabled = false;
|
84
|
-
const traces: Array<Trace> = [
|
85
|
-
{
|
86
|
-
ph: 'M',
|
87
|
-
pid: 0,
|
88
|
-
tid: 0,
|
89
|
-
name: 'process_name',
|
90
|
-
args: {name: 'relay-compiler'},
|
91
|
-
},
|
92
|
-
{
|
93
|
-
ph: 'M',
|
94
|
-
pid: 0,
|
95
|
-
tid: 0,
|
96
|
-
name: 'thread_name',
|
97
|
-
args: {name: 'relay-compiler'},
|
98
|
-
},
|
99
|
-
];
|
100
|
-
const stack: Array<BeginDurationTrace> = [];
|
101
|
-
|
102
|
-
function enable(): void {
|
103
|
-
enabled = true;
|
104
|
-
}
|
105
|
-
|
106
|
-
function getTraces(): Array<Trace> {
|
107
|
-
return traces;
|
108
|
-
}
|
109
|
-
|
110
|
-
/**
|
111
|
-
* Run the provided function as part of a stack profile.
|
112
|
-
*/
|
113
|
-
function run<T>(name: string, fn: () => T): T {
|
114
|
-
return instrument(fn, name)();
|
115
|
-
}
|
116
|
-
|
117
|
-
/**
|
118
|
-
* Run the provided async function as part context in a stack profile.
|
119
|
-
* See instrumentAsyncContext() for limitations and usage notes.
|
120
|
-
*/
|
121
|
-
function asyncContext<T: Promise<$FlowFixMe>>(name: string, fn: () => T): T {
|
122
|
-
return instrumentAsyncContext(fn, name)();
|
123
|
-
}
|
124
|
-
|
125
|
-
/**
|
126
|
-
* Wait for the provided async operation as an async profile.
|
127
|
-
*/
|
128
|
-
function waitFor<T: Promise<$FlowFixMe>>(name: string, fn: () => T): T {
|
129
|
-
return instrumentWait(fn, name)();
|
130
|
-
}
|
131
|
-
|
132
|
-
/**
|
133
|
-
* Return a new instrumented sync function to be part of a stack profile.
|
134
|
-
*
|
135
|
-
* This instruments synchronous functions to be displayed in a stack
|
136
|
-
* visualization. To instrument async functions, see instrumentAsyncContext()
|
137
|
-
* and instrumentWait().
|
138
|
-
*/
|
139
|
-
function instrument<F: (...$FlowFixMe) => mixed>(fn: F, name?: string): F {
|
140
|
-
if (!enabled) {
|
141
|
-
return fn;
|
142
|
-
}
|
143
|
-
const profileName =
|
144
|
-
name ??
|
145
|
-
// $FlowFixMe[prop-missing] - Flow no longer considers statics of functions as any
|
146
|
-
fn.displayName ??
|
147
|
-
fn.name;
|
148
|
-
const instrumented = function () {
|
149
|
-
const traceId = start(profileName);
|
150
|
-
try {
|
151
|
-
return fn.apply(this, arguments);
|
152
|
-
} finally {
|
153
|
-
end(traceId);
|
154
|
-
}
|
155
|
-
};
|
156
|
-
instrumented.displayName = profileName;
|
157
|
-
return (instrumented: $FlowFixMe);
|
158
|
-
}
|
159
|
-
|
160
|
-
/**
|
161
|
-
* Return a new instrumented async function which provides context for a stack.
|
162
|
-
*
|
163
|
-
* Because the resulting profiling information will be incorporated into a
|
164
|
-
* stack visualization, the instrumented function must represent a distinct
|
165
|
-
* region of time which does not overlap with any other async context.
|
166
|
-
*
|
167
|
-
* In other words, functions instrumented with instrumentAsyncContext must not
|
168
|
-
* run in parallel via Promise.all().
|
169
|
-
*
|
170
|
-
* To instrument functions which will run in parallel, use instrumentWait().
|
171
|
-
*/
|
172
|
-
function instrumentAsyncContext<F: (...$FlowFixMe) => Promise<$FlowFixMe>>(
|
173
|
-
fn: F,
|
174
|
-
name?: string,
|
175
|
-
): F {
|
176
|
-
if (!enabled) {
|
177
|
-
return fn;
|
178
|
-
}
|
179
|
-
|
180
|
-
const profileName: string =
|
181
|
-
name ??
|
182
|
-
// $FlowFixMe[prop-missing] - Flow no longer considers statics of functions as any
|
183
|
-
fn.displayName ??
|
184
|
-
fn.name;
|
185
|
-
const instrumented = async function () {
|
186
|
-
const traceId = start(profileName);
|
187
|
-
try {
|
188
|
-
return await fn.apply(this, arguments);
|
189
|
-
} finally {
|
190
|
-
end(traceId);
|
191
|
-
}
|
192
|
-
};
|
193
|
-
instrumented.displayName = profileName;
|
194
|
-
return (instrumented: $FlowFixMe);
|
195
|
-
}
|
196
|
-
|
197
|
-
/**
|
198
|
-
* Return a new instrumented function which performs an awaited async operation.
|
199
|
-
*
|
200
|
-
* The instrumented function is not included in the overall run time of the
|
201
|
-
* compiler, instead it captures the time waiting on some asynchronous external
|
202
|
-
* resource such as network or filesystem which are often run in parallel.
|
203
|
-
*/
|
204
|
-
function instrumentWait<F: (...$FlowFixMe) => Promise<$FlowFixMe>>(
|
205
|
-
fn: F,
|
206
|
-
name?: string,
|
207
|
-
): F {
|
208
|
-
if (!enabled) {
|
209
|
-
return fn;
|
210
|
-
}
|
211
|
-
const profileName: string =
|
212
|
-
name ??
|
213
|
-
// $FlowFixMe[prop-missing] - Flow no longer considers statics of functions as any
|
214
|
-
fn.displayName ??
|
215
|
-
fn.name;
|
216
|
-
const instrumented = async function () {
|
217
|
-
const traceId = startWait(profileName);
|
218
|
-
try {
|
219
|
-
return await fn.apply(this, arguments);
|
220
|
-
} finally {
|
221
|
-
end(traceId);
|
222
|
-
}
|
223
|
-
};
|
224
|
-
instrumented.displayName = profileName;
|
225
|
-
return (instrumented: $FlowFixMe);
|
226
|
-
}
|
227
|
-
|
228
|
-
const T_ZERO = process.hrtime();
|
229
|
-
|
230
|
-
// Return a Uint32 of microtime duration since program start.
|
231
|
-
function microtime(): number {
|
232
|
-
const hrtime = process.hrtime(T_ZERO);
|
233
|
-
// eslint-disable-next-line no-bitwise
|
234
|
-
return 0 | (hrtime[0] * 1e6 + Math.round(hrtime[1] / 1e3));
|
235
|
-
}
|
236
|
-
|
237
|
-
/**
|
238
|
-
* Start a stack profile with a particular name, returns an ID to pass to end().
|
239
|
-
*
|
240
|
-
* Other profiles may start before this one ends, which will be represented as
|
241
|
-
* nested operations, however all nested operations must end before this ends.
|
242
|
-
*
|
243
|
-
* In particular, be careful to end after errors.
|
244
|
-
*/
|
245
|
-
function start(name: string): number {
|
246
|
-
const beginTrace = {
|
247
|
-
ph: 'B',
|
248
|
-
name,
|
249
|
-
pid: 0,
|
250
|
-
tid: 0,
|
251
|
-
ts: microtime(),
|
252
|
-
};
|
253
|
-
traces.push(beginTrace);
|
254
|
-
stack.push(beginTrace);
|
255
|
-
return traces.length - 1;
|
256
|
-
}
|
257
|
-
|
258
|
-
let asyncID = 0;
|
259
|
-
|
260
|
-
/**
|
261
|
-
* Start an async wait profile with a particular name, returns an ID to pass
|
262
|
-
* to end().
|
263
|
-
*
|
264
|
-
* Other profiles may start before this one ends, which will be represented as
|
265
|
-
* nested operations, however all nested operations must end before this ends.
|
266
|
-
*
|
267
|
-
* In particular, be careful to end after errors.
|
268
|
-
*/
|
269
|
-
function startWait(name: string): number {
|
270
|
-
traces.push({
|
271
|
-
ph: 'b',
|
272
|
-
name,
|
273
|
-
cat: 'wait',
|
274
|
-
id: asyncID++,
|
275
|
-
pid: 0,
|
276
|
-
tid: 0,
|
277
|
-
ts: microtime(),
|
278
|
-
});
|
279
|
-
return traces.length - 1;
|
280
|
-
}
|
281
|
-
|
282
|
-
function end(traceIdx: number): void {
|
283
|
-
const trace = traces[traceIdx];
|
284
|
-
|
285
|
-
if (trace.ph === 'b') {
|
286
|
-
traces.push({
|
287
|
-
ph: 'e',
|
288
|
-
cat: trace.cat,
|
289
|
-
name: trace.name,
|
290
|
-
id: trace.id,
|
291
|
-
pid: trace.pid,
|
292
|
-
tid: trace.tid,
|
293
|
-
ts: microtime(),
|
294
|
-
});
|
295
|
-
return;
|
296
|
-
}
|
297
|
-
|
298
|
-
invariant(trace.ph === 'B', 'Begin trace phase');
|
299
|
-
invariant(
|
300
|
-
stack.pop() === trace,
|
301
|
-
'GraphQLCompilerProfiler: The profile trace %s ended before nested traces. ' +
|
302
|
-
'If it is async, try using Profile.waitFor or Profile.profileWait.',
|
303
|
-
trace.name,
|
304
|
-
);
|
305
|
-
|
306
|
-
const prevTrace = traces[traces.length - 1];
|
307
|
-
|
308
|
-
if (trace === prevTrace) {
|
309
|
-
traces[traceIdx] = {
|
310
|
-
ph: 'X',
|
311
|
-
name: trace.name,
|
312
|
-
pid: trace.pid,
|
313
|
-
tid: trace.tid,
|
314
|
-
ts: trace.ts,
|
315
|
-
dur: microtime() - trace.ts,
|
316
|
-
};
|
317
|
-
return;
|
318
|
-
}
|
319
|
-
|
320
|
-
traces.push({
|
321
|
-
ph: 'E',
|
322
|
-
name: trace.name,
|
323
|
-
pid: trace.pid,
|
324
|
-
tid: trace.tid,
|
325
|
-
ts: microtime(),
|
326
|
-
});
|
327
|
-
}
|
328
|
-
|
329
|
-
module.exports = {
|
330
|
-
enable,
|
331
|
-
getTraces,
|
332
|
-
run,
|
333
|
-
asyncContext,
|
334
|
-
waitFor,
|
335
|
-
instrument,
|
336
|
-
instrumentAsyncContext,
|
337
|
-
instrumentWait,
|
338
|
-
start,
|
339
|
-
startWait,
|
340
|
-
end,
|
341
|
-
};
|
@@ -1,36 +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 {GeneratedNode} from 'relay-runtime';
|
16
|
-
|
17
|
-
/**
|
18
|
-
* Helpers to retieve the name of the document from which the input derives:
|
19
|
-
* this is either the name of the input itself (if it is not a derived node)
|
20
|
-
* or the metadata.derivedFrom property for derived nodes.
|
21
|
-
*/
|
22
|
-
|
23
|
-
// Version for generated nodes
|
24
|
-
function getReaderSourceDefinitionName(node: GeneratedNode): string {
|
25
|
-
const [name, derivedFrom] =
|
26
|
-
node.kind === 'Request'
|
27
|
-
? [node.params.name, node.params.metadata?.derivedFrom]
|
28
|
-
: node.kind === 'SplitOperation'
|
29
|
-
? [node.name, node.metadata?.derivedFrom]
|
30
|
-
: [node.name, null];
|
31
|
-
return typeof derivedFrom === 'string' ? derivedFrom : name;
|
32
|
-
}
|
33
|
-
|
34
|
-
module.exports = {
|
35
|
-
getReaderSourceDefinitionName,
|
36
|
-
};
|
@@ -1,109 +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
|
-
* @emails oncall+relay
|
10
|
-
*/
|
11
|
-
|
12
|
-
// flowlint ambiguous-object-type:error
|
13
|
-
|
14
|
-
'use strict';
|
15
|
-
|
16
|
-
const childProcess = require('child_process');
|
17
|
-
const watchman = require('fb-watchman');
|
18
|
-
|
19
|
-
const MAX_ATTEMPT_LIMIT = 5;
|
20
|
-
|
21
|
-
function delay(delayMs: number): Promise<void> {
|
22
|
-
return new Promise(resolve => setTimeout(resolve, delayMs));
|
23
|
-
}
|
24
|
-
|
25
|
-
class GraphQLWatchmanClient {
|
26
|
-
_client: any;
|
27
|
-
_attemptLimit: number;
|
28
|
-
|
29
|
-
static isAvailable(): Promise<boolean> {
|
30
|
-
return new Promise(resolve => {
|
31
|
-
// This command not only will verify that watchman CLI is available
|
32
|
-
// More than that `watchman version` is a command that runs on the server.
|
33
|
-
// And it can tell us that watchman is up and running
|
34
|
-
// Also `watchman version` check ``relative_root`` capability
|
35
|
-
// under the covers
|
36
|
-
const proc = childProcess.spawn('watchman', ['version']);
|
37
|
-
proc.on('error', () => {
|
38
|
-
resolve(false);
|
39
|
-
});
|
40
|
-
proc.on('close', code => {
|
41
|
-
resolve(code === 0);
|
42
|
-
});
|
43
|
-
});
|
44
|
-
}
|
45
|
-
|
46
|
-
constructor(attemptLimit: number = 0) {
|
47
|
-
this._client = new watchman.Client();
|
48
|
-
this._attemptLimit = Math.max(Math.min(MAX_ATTEMPT_LIMIT, attemptLimit), 0);
|
49
|
-
}
|
50
|
-
|
51
|
-
_command(...args: Array<mixed>): Promise<any> {
|
52
|
-
return new Promise((resolve, reject) => {
|
53
|
-
this._client.command(args, (error, response) => {
|
54
|
-
if (error) {
|
55
|
-
reject(error);
|
56
|
-
} else {
|
57
|
-
resolve(response);
|
58
|
-
}
|
59
|
-
});
|
60
|
-
});
|
61
|
-
}
|
62
|
-
|
63
|
-
async command(...args: Array<mixed>): Promise<any> {
|
64
|
-
let attempt = 0;
|
65
|
-
while (true) {
|
66
|
-
try {
|
67
|
-
attempt++;
|
68
|
-
return await this._command(...args);
|
69
|
-
} catch (error) {
|
70
|
-
if (attempt > this._attemptLimit) {
|
71
|
-
throw error;
|
72
|
-
}
|
73
|
-
await delay(Math.pow(2, attempt) * 500);
|
74
|
-
this._client.end();
|
75
|
-
this._client = new watchman.Client();
|
76
|
-
}
|
77
|
-
}
|
78
|
-
}
|
79
|
-
|
80
|
-
async hasCapability(capability: string): Promise<boolean> {
|
81
|
-
const resp = await this.command('list-capabilities');
|
82
|
-
return resp.capabilities.includes(capability);
|
83
|
-
}
|
84
|
-
|
85
|
-
async watchProject(baseDir: string): Promise<{
|
86
|
-
root: string,
|
87
|
-
relativePath: string,
|
88
|
-
...
|
89
|
-
}> {
|
90
|
-
const resp = await this.command('watch-project', baseDir);
|
91
|
-
if ('warning' in resp) {
|
92
|
-
console.error('Warning:', resp.warning);
|
93
|
-
}
|
94
|
-
return {
|
95
|
-
root: resp.watch,
|
96
|
-
relativePath: resp.relative_path,
|
97
|
-
};
|
98
|
-
}
|
99
|
-
|
100
|
-
on(event: string, callback: Function): void {
|
101
|
-
this._client.on(event, callback);
|
102
|
-
}
|
103
|
-
|
104
|
-
end(): void {
|
105
|
-
this._client.end();
|
106
|
-
}
|
107
|
-
}
|
108
|
-
|
109
|
-
module.exports = GraphQLWatchmanClient;
|