relay-compiler 0.0.0-main-4d287de9 → 0.0.0-main-9a79039d
Sign up to get free protection for your applications and to get access to all the features.
- 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 -26
- package/win-x64/relay.exe +0 -0
- package/bin/RelayCompilerBin.js.flow +0 -168
- package/bin/RelayCompilerMain.js.flow +0 -513
- package/bin/__fixtures__/plugin-module.js.flow +0 -17
- package/bin/relay-compiler +0 -19066
- 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 -565
- 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 -1731
- 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 -486
- 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/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/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 -194
- 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 -255
- 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 -126
- package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +0 -111
- 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 -152
- 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,97 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
3
|
-
*
|
4
|
-
* This source code is licensed under the MIT license found in the
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
6
|
-
*
|
7
|
-
*
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
|
13
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
14
|
-
|
15
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
16
|
-
|
17
|
-
var Profiler = require('../core/GraphQLCompilerProfiler');
|
18
|
-
|
19
|
-
var crypto = require('crypto');
|
20
|
-
|
21
|
-
var fs = require('fs');
|
22
|
-
|
23
|
-
var os = require('os');
|
24
|
-
|
25
|
-
var path = require('path');
|
26
|
-
/**
|
27
|
-
* A file backed cache. Values are JSON encoded on disk, so only JSON
|
28
|
-
* serializable values should be used.
|
29
|
-
*/
|
30
|
-
|
31
|
-
|
32
|
-
var RelayCompilerCache = /*#__PURE__*/function () {
|
33
|
-
/**
|
34
|
-
* @param name Human readable identifier for the cache
|
35
|
-
* @param cacheBreaker This should be changed in order to invalidate existing
|
36
|
-
* caches.
|
37
|
-
*/
|
38
|
-
function RelayCompilerCache(name, cacheBreaker) {
|
39
|
-
(0, _defineProperty2["default"])(this, "_dir", null);
|
40
|
-
this._name = name;
|
41
|
-
this._cacheBreaker = cacheBreaker;
|
42
|
-
}
|
43
|
-
|
44
|
-
var _proto = RelayCompilerCache.prototype;
|
45
|
-
|
46
|
-
_proto._getFile = function _getFile(key) {
|
47
|
-
if (this._dir == null) {
|
48
|
-
// Include username in the cache dir to avoid issues with directories being
|
49
|
-
// owned by a different user.
|
50
|
-
var username = os.userInfo().username;
|
51
|
-
var cacheID = crypto.createHash('md5').update(this._cacheBreaker).update(username).digest('hex');
|
52
|
-
var dir = path.join(os.tmpdir(), "".concat(this._name, "-").concat(cacheID));
|
53
|
-
|
54
|
-
if (!fs.existsSync(dir)) {
|
55
|
-
try {
|
56
|
-
fs.mkdirSync(dir);
|
57
|
-
} catch (error) {
|
58
|
-
if (error.code !== 'EEXIST') {
|
59
|
-
throw error;
|
60
|
-
}
|
61
|
-
}
|
62
|
-
}
|
63
|
-
|
64
|
-
this._dir = dir;
|
65
|
-
}
|
66
|
-
|
67
|
-
return path.join(this._dir, key);
|
68
|
-
};
|
69
|
-
|
70
|
-
_proto.getOrCompute = function getOrCompute(key, compute) {
|
71
|
-
var _this = this;
|
72
|
-
|
73
|
-
return Profiler.run('RelayCompilerCache.getOrCompute', function () {
|
74
|
-
var cacheFile = _this._getFile(key);
|
75
|
-
|
76
|
-
if (fs.existsSync(cacheFile)) {
|
77
|
-
try {
|
78
|
-
return JSON.parse(fs.readFileSync(cacheFile, 'utf8'));
|
79
|
-
} catch (_unused) {// ignore
|
80
|
-
}
|
81
|
-
}
|
82
|
-
|
83
|
-
var value = compute();
|
84
|
-
|
85
|
-
try {
|
86
|
-
fs.writeFileSync(cacheFile, JSON.stringify(value), 'utf8');
|
87
|
-
} catch (_unused2) {// ignore
|
88
|
-
}
|
89
|
-
|
90
|
-
return value;
|
91
|
-
});
|
92
|
-
};
|
93
|
-
|
94
|
-
return RelayCompilerCache;
|
95
|
-
}();
|
96
|
-
|
97
|
-
module.exports = RelayCompilerCache;
|
package/lib/util/Rollout.js
DELETED
@@ -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
|
-
};
|
package/lib/util/TimeReporter.js
DELETED
@@ -1,83 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
3
|
-
*
|
4
|
-
* This source code is licensed under the MIT license found in the
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
6
|
-
*
|
7
|
-
* @format
|
8
|
-
*
|
9
|
-
* @emails oncall+relay
|
10
|
-
*/
|
11
|
-
// flowlint ambiguous-object-type:error
|
12
|
-
'use strict';
|
13
|
-
|
14
|
-
var _asyncToGenerator = require("@babel/runtime/helpers/asyncToGenerator");
|
15
|
-
|
16
|
-
var _require = require('relay-runtime'),
|
17
|
-
isPromise = _require.isPromise;
|
18
|
-
|
19
|
-
function reportTime(reporter, message, fn) {
|
20
|
-
return reportAndReturnTime(reporter, message, fn)[0];
|
21
|
-
}
|
22
|
-
|
23
|
-
function reportAndReturnTime(reporter, message, fn) {
|
24
|
-
var startTime = Date.now();
|
25
|
-
var result = fn();
|
26
|
-
|
27
|
-
if (isPromise(result)) {
|
28
|
-
throw new Error('reportAndReturnTime: fn(...) returned an unexpected promise.' + ' Please use `reportAndReturnAsyncTime` method instead.');
|
29
|
-
}
|
30
|
-
|
31
|
-
var elapsedTime = Date.now() - startTime;
|
32
|
-
reporter.reportTime(message, elapsedTime);
|
33
|
-
return [result, elapsedTime];
|
34
|
-
}
|
35
|
-
|
36
|
-
function reportAndReturnAsyncTime(_x, _x2, _x3) {
|
37
|
-
return _reportAndReturnAsyncTime.apply(this, arguments);
|
38
|
-
}
|
39
|
-
|
40
|
-
function _reportAndReturnAsyncTime() {
|
41
|
-
_reportAndReturnAsyncTime = _asyncToGenerator(function* (reporter, message, fn) {
|
42
|
-
var startTime = Date.now();
|
43
|
-
var promise = fn();
|
44
|
-
|
45
|
-
if (!isPromise(promise)) {
|
46
|
-
throw new Error('reportAsyncTime: fn(...) expected to return a promise.');
|
47
|
-
}
|
48
|
-
|
49
|
-
var result = yield promise;
|
50
|
-
var elapsedTime = Date.now() - startTime;
|
51
|
-
reporter.reportTime(message, elapsedTime);
|
52
|
-
return [result, elapsedTime];
|
53
|
-
});
|
54
|
-
return _reportAndReturnAsyncTime.apply(this, arguments);
|
55
|
-
}
|
56
|
-
|
57
|
-
function reportAsyncTime(_x4, _x5, _x6) {
|
58
|
-
return _reportAsyncTime.apply(this, arguments);
|
59
|
-
}
|
60
|
-
|
61
|
-
function _reportAsyncTime() {
|
62
|
-
_reportAsyncTime = _asyncToGenerator(function* (reporter, message, fn) {
|
63
|
-
var startTime = Date.now();
|
64
|
-
var promise = fn();
|
65
|
-
|
66
|
-
if (!isPromise(promise)) {
|
67
|
-
throw new Error('reportAsyncTime: fn(...) expected to return a promise.');
|
68
|
-
}
|
69
|
-
|
70
|
-
var result = yield promise;
|
71
|
-
var elapsedTime = Date.now() - startTime;
|
72
|
-
reporter.reportTime(message, elapsedTime);
|
73
|
-
return result;
|
74
|
-
});
|
75
|
-
return _reportAsyncTime.apply(this, arguments);
|
76
|
-
}
|
77
|
-
|
78
|
-
module.exports = {
|
79
|
-
reportTime: reportTime,
|
80
|
-
reportAndReturnTime: reportAndReturnTime,
|
81
|
-
reportAsyncTime: reportAsyncTime,
|
82
|
-
reportAndReturnAsyncTime: reportAndReturnAsyncTime
|
83
|
-
};
|
@@ -1,135 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
3
|
-
*
|
4
|
-
* This source code is licensed under the MIT license found in the
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
6
|
-
*
|
7
|
-
*
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
// TODO: This is only used with `ArgumentValue` types, so it could be simpler.
|
11
|
-
// flowlint ambiguous-object-type:error
|
12
|
-
'use strict';
|
13
|
-
|
14
|
-
var aStackPool = [];
|
15
|
-
var bStackPool = [];
|
16
|
-
/**
|
17
|
-
* Checks if two values are equal. Values may be primitives, arrays, or objects.
|
18
|
-
* Returns true if both arguments have the same keys and values.
|
19
|
-
*
|
20
|
-
* @see http://underscorejs.org
|
21
|
-
* @copyright 2009-2013 Jeremy Ashkenas, DocumentCloud Inc.
|
22
|
-
* @license MIT
|
23
|
-
*/
|
24
|
-
|
25
|
-
function areEqualArgValues(a, b) {
|
26
|
-
var aStack = aStackPool.length ? aStackPool.pop() : [];
|
27
|
-
var bStack = bStackPool.length ? bStackPool.pop() : [];
|
28
|
-
var result = eq(a, b, aStack, bStack);
|
29
|
-
aStack.length = 0;
|
30
|
-
bStack.length = 0;
|
31
|
-
aStackPool.push(aStack);
|
32
|
-
bStackPool.push(bStack);
|
33
|
-
return result;
|
34
|
-
}
|
35
|
-
|
36
|
-
function eq(a, b, aStack, bStack) {
|
37
|
-
if (a === b) {
|
38
|
-
// Identical objects are equal. `0 === -0`, but they aren't identical.
|
39
|
-
return a !== 0 || 1 / a === 1 / b;
|
40
|
-
}
|
41
|
-
|
42
|
-
if (a == null || b == null) {
|
43
|
-
// a or b can be `null` or `undefined`
|
44
|
-
return false;
|
45
|
-
}
|
46
|
-
|
47
|
-
if (typeof a !== 'object' || typeof b !== 'object') {
|
48
|
-
return false;
|
49
|
-
} // $FlowFixMe[method-unbinding] added when improving typing for this parameters
|
50
|
-
|
51
|
-
|
52
|
-
var objToStr = Object.prototype.toString;
|
53
|
-
var className = objToStr.call(a);
|
54
|
-
|
55
|
-
if (className !== objToStr.call(b)) {
|
56
|
-
return false;
|
57
|
-
}
|
58
|
-
|
59
|
-
switch (className) {
|
60
|
-
case '[object String]':
|
61
|
-
return a === String(b);
|
62
|
-
|
63
|
-
case '[object Number]':
|
64
|
-
return isNaN(a) || isNaN(b) ? false : a === Number(b);
|
65
|
-
|
66
|
-
case '[object Date]':
|
67
|
-
case '[object Boolean]':
|
68
|
-
return +a === +b;
|
69
|
-
|
70
|
-
case '[object RegExp]':
|
71
|
-
return a.source === b.source && a.global === b.global && a.multiline === b.multiline && a.ignoreCase === b.ignoreCase;
|
72
|
-
} // Assume equality for cyclic structures.
|
73
|
-
|
74
|
-
|
75
|
-
var length = aStack.length;
|
76
|
-
|
77
|
-
while (length--) {
|
78
|
-
if (aStack[length] === a) {
|
79
|
-
return bStack[length] === b;
|
80
|
-
}
|
81
|
-
}
|
82
|
-
|
83
|
-
aStack.push(a);
|
84
|
-
bStack.push(b);
|
85
|
-
var size = 0; // Recursively compare objects and arrays.
|
86
|
-
|
87
|
-
if (className === '[object Array]') {
|
88
|
-
size = a.length;
|
89
|
-
|
90
|
-
if (size !== b.length) {
|
91
|
-
return false;
|
92
|
-
} // Deep compare the contents, ignoring non-numeric properties.
|
93
|
-
|
94
|
-
|
95
|
-
while (size--) {
|
96
|
-
if (!eq(a[size], b[size], aStack, bStack)) {
|
97
|
-
return false;
|
98
|
-
}
|
99
|
-
}
|
100
|
-
} else {
|
101
|
-
if (a.constructor !== b.constructor) {
|
102
|
-
return false;
|
103
|
-
}
|
104
|
-
|
105
|
-
if (a.hasOwnProperty('valueOf') && b.hasOwnProperty('valueOf')) {
|
106
|
-
return a.valueOf() === b.valueOf();
|
107
|
-
}
|
108
|
-
|
109
|
-
var keys = Object.keys(a);
|
110
|
-
|
111
|
-
if (keys.length !== Object.keys(b).length) {
|
112
|
-
return false;
|
113
|
-
}
|
114
|
-
|
115
|
-
for (var i = 0; i < keys.length; i++) {
|
116
|
-
if (keys[i] === '_owner') {
|
117
|
-
// HACK: Comparing deeply nested React trees is slow since you end up
|
118
|
-
// comparing the entire tree (all ancestors and all children) and
|
119
|
-
// likely not what you want if you're comparing two elements with
|
120
|
-
// areEqualArgValues. We bail out here for now.
|
121
|
-
continue;
|
122
|
-
}
|
123
|
-
|
124
|
-
if (!b.hasOwnProperty(keys[i]) || !eq(a[keys[i]], b[keys[i]], aStack, bStack)) {
|
125
|
-
return false;
|
126
|
-
}
|
127
|
-
}
|
128
|
-
}
|
129
|
-
|
130
|
-
aStack.pop();
|
131
|
-
bStack.pop();
|
132
|
-
return true;
|
133
|
-
}
|
134
|
-
|
135
|
-
module.exports = areEqualArgValues;
|
@@ -1,37 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
3
|
-
*
|
4
|
-
* This source code is licensed under the MIT license found in the
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
6
|
-
*
|
7
|
-
*
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
|
13
|
-
function argumentContainsVariables(arg) {
|
14
|
-
if (arg == null) {
|
15
|
-
return false;
|
16
|
-
}
|
17
|
-
|
18
|
-
switch (arg.kind) {
|
19
|
-
case 'Variable':
|
20
|
-
return true;
|
21
|
-
|
22
|
-
case 'Literal':
|
23
|
-
return false;
|
24
|
-
|
25
|
-
case 'ListValue':
|
26
|
-
return arg.items.some(argumentContainsVariables);
|
27
|
-
|
28
|
-
case 'ObjectValue':
|
29
|
-
return arg.fields.some(argumentContainsVariables);
|
30
|
-
|
31
|
-
default:
|
32
|
-
arg.kind;
|
33
|
-
return false;
|
34
|
-
}
|
35
|
-
}
|
36
|
-
|
37
|
-
module.exports = argumentContainsVariables;
|
@@ -1,160 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
3
|
-
*
|
4
|
-
* This source code is licensed under the MIT license found in the
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
6
|
-
*
|
7
|
-
*
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
/**
|
13
|
-
* This function works similar to JSON.stringify except that for the case there
|
14
|
-
* are multiple common subtrees, it generates a string for a IIFE that re-uses
|
15
|
-
* the same objects for the duplicate subtrees.
|
16
|
-
*/
|
17
|
-
|
18
|
-
function dedupeJSONStringify(jsonValue) {
|
19
|
-
var metadataForHash = new Map();
|
20
|
-
var metadataForVal = new WeakMap();
|
21
|
-
var varDefs = [];
|
22
|
-
collectMetadata(jsonValue);
|
23
|
-
collectDuplicates(jsonValue);
|
24
|
-
var code = printJSCode(false, '', jsonValue);
|
25
|
-
return varDefs.length === 0 ? code : "(function(){\nvar ".concat(varDefs.join(',\n'), ";\nreturn ").concat(code, ";\n})()"); // Collect common metadata for each object in the value tree, ensuring that
|
26
|
-
// equivalent values have the *same reference* to the same metadata. Note that
|
27
|
-
// the hashes generated are not exactly JSON, but still identify equivalent
|
28
|
-
// values. Runs in linear time due to hashing in a bottom-up recursion.
|
29
|
-
|
30
|
-
function collectMetadata(value) {
|
31
|
-
if (value == null || typeof value !== 'object') {
|
32
|
-
// $FlowFixMe[incompatible-return] - JSON.stringify can return undefined
|
33
|
-
return JSON.stringify(value);
|
34
|
-
}
|
35
|
-
|
36
|
-
var hash;
|
37
|
-
|
38
|
-
if (Array.isArray(value)) {
|
39
|
-
hash = '[';
|
40
|
-
|
41
|
-
for (var i = 0; i < value.length; i++) {
|
42
|
-
hash += collectMetadata(value[i]) + ',';
|
43
|
-
}
|
44
|
-
} else {
|
45
|
-
hash = '{';
|
46
|
-
|
47
|
-
for (var k in value) {
|
48
|
-
if (value.hasOwnProperty(k) && value[k] !== undefined) {
|
49
|
-
hash += k + ':' + collectMetadata(value[k]) + ',';
|
50
|
-
}
|
51
|
-
}
|
52
|
-
}
|
53
|
-
|
54
|
-
var metadata = metadataForHash.get(hash);
|
55
|
-
|
56
|
-
if (!metadata) {
|
57
|
-
metadata = {
|
58
|
-
value: value,
|
59
|
-
hash: hash,
|
60
|
-
count: 0
|
61
|
-
};
|
62
|
-
metadataForHash.set(hash, metadata);
|
63
|
-
}
|
64
|
-
|
65
|
-
metadataForVal.set(value, metadata);
|
66
|
-
return hash;
|
67
|
-
} // Using top-down recursion, linearly scan the JSON tree to determine which
|
68
|
-
// values should be deduplicated.
|
69
|
-
|
70
|
-
|
71
|
-
function collectDuplicates(value) {
|
72
|
-
if (value == null || typeof value !== 'object') {
|
73
|
-
return;
|
74
|
-
}
|
75
|
-
|
76
|
-
var metadata = metadataForVal.get(value); // Only consider duplicates with hashes longer than 2 (excludes [] and {}).
|
77
|
-
|
78
|
-
if (metadata && metadata.hash.length > 2) {
|
79
|
-
metadata.count++;
|
80
|
-
|
81
|
-
if (metadata.count > 1) {
|
82
|
-
return;
|
83
|
-
}
|
84
|
-
}
|
85
|
-
|
86
|
-
if (Array.isArray(value)) {
|
87
|
-
for (var i = 0; i < value.length; i++) {
|
88
|
-
collectDuplicates(value[i]);
|
89
|
-
}
|
90
|
-
} else {
|
91
|
-
for (var k in value) {
|
92
|
-
if (value.hasOwnProperty(k) && value[k] !== undefined) {
|
93
|
-
collectDuplicates(value[k]);
|
94
|
-
}
|
95
|
-
}
|
96
|
-
}
|
97
|
-
} // Stringify JS, replacing duplicates with variable references.
|
98
|
-
|
99
|
-
|
100
|
-
function printJSCode(isDupedVar, depth, value) {
|
101
|
-
if (value == null || typeof value !== 'object') {
|
102
|
-
// $FlowFixMe[incompatible-return] : JSON.stringify can return undefined
|
103
|
-
return JSON.stringify(value);
|
104
|
-
} // Only use variable references at depth beyond the top level.
|
105
|
-
|
106
|
-
|
107
|
-
if (depth !== '') {
|
108
|
-
var metadata = metadataForVal.get(value);
|
109
|
-
|
110
|
-
if (metadata && metadata.count > 1) {
|
111
|
-
var varName = metadata.varName;
|
112
|
-
|
113
|
-
if (varName == null) {
|
114
|
-
var refCode = printJSCode(true, '', value);
|
115
|
-
varName = metadata.varName = 'v' + varDefs.length;
|
116
|
-
varDefs.push(metadata.varName + ' = ' + refCode);
|
117
|
-
}
|
118
|
-
|
119
|
-
return '(' + varName + '/*: any*/)';
|
120
|
-
}
|
121
|
-
}
|
122
|
-
|
123
|
-
var str;
|
124
|
-
var isEmpty = true;
|
125
|
-
var depth2 = depth + ' ';
|
126
|
-
|
127
|
-
if (Array.isArray(value)) {
|
128
|
-
// Empty arrays can only have one inferred flow type and then conflict if
|
129
|
-
// used in different places, this is unsound if we would write to them but
|
130
|
-
// this whole module is based on the idea of a read only JSON tree.
|
131
|
-
if (isDupedVar && value.length === 0) {
|
132
|
-
return '([]/*: any*/)';
|
133
|
-
}
|
134
|
-
|
135
|
-
str = '[';
|
136
|
-
|
137
|
-
for (var i = 0; i < value.length; i++) {
|
138
|
-
str += (isEmpty ? '\n' : ',\n') + depth2 + printJSCode(isDupedVar, depth2, value[i]);
|
139
|
-
isEmpty = false;
|
140
|
-
}
|
141
|
-
|
142
|
-
str += isEmpty ? ']' : "\n".concat(depth, "]");
|
143
|
-
} else {
|
144
|
-
str = '{';
|
145
|
-
|
146
|
-
for (var k in value) {
|
147
|
-
if (value.hasOwnProperty(k) && value[k] !== undefined) {
|
148
|
-
str += (isEmpty ? '\n' : ',\n') + depth2 + JSON.stringify(k) + ': ' + printJSCode(isDupedVar, depth2, value[k]);
|
149
|
-
isEmpty = false;
|
150
|
-
}
|
151
|
-
}
|
152
|
-
|
153
|
-
str += isEmpty ? '}' : "\n".concat(depth, "}");
|
154
|
-
}
|
155
|
-
|
156
|
-
return str;
|
157
|
-
}
|
158
|
-
}
|
159
|
-
|
160
|
-
module.exports = dedupeJSONStringify;
|
@@ -1,24 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
3
|
-
*
|
4
|
-
* This source code is licensed under the MIT license found in the
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
6
|
-
*
|
7
|
-
*
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
|
13
|
-
var _require = require('../core/CompilerError'),
|
14
|
-
createCompilerError = _require.createCompilerError;
|
15
|
-
|
16
|
-
function generateAbstractTypeRefinementKey(schema, type) {
|
17
|
-
if (!schema.isAbstractType(type)) {
|
18
|
-
throw createCompilerError('Expected an abstract type');
|
19
|
-
}
|
20
|
-
|
21
|
-
return "__is".concat(schema.getTypeString(type));
|
22
|
-
}
|
23
|
-
|
24
|
-
module.exports = generateAbstractTypeRefinementKey;
|
@@ -1,22 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
3
|
-
*
|
4
|
-
* This source code is licensed under the MIT license found in the
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
6
|
-
*
|
7
|
-
*
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
|
13
|
-
var md5 = require('./md5');
|
14
|
-
|
15
|
-
var _require = require('graphql'),
|
16
|
-
print = _require.print;
|
17
|
-
|
18
|
-
function getDefinitionNodeHash(node) {
|
19
|
-
return md5(print(node));
|
20
|
-
}
|
21
|
-
|
22
|
-
module.exports = getDefinitionNodeHash;
|
@@ -1,32 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
3
|
-
*
|
4
|
-
* This source code is licensed under the MIT license found in the
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
6
|
-
*
|
7
|
-
*
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
|
13
|
-
var path = require('path');
|
14
|
-
|
15
|
-
function getModuleName(filePath) {
|
16
|
-
// index.js -> index
|
17
|
-
// index.js.flow -> index.js
|
18
|
-
var filename = path.basename(filePath, path.extname(filePath)); // index.js -> index (when extension has multiple segments)
|
19
|
-
// index.react -> index (when extension has multiple segments)
|
20
|
-
|
21
|
-
filename = filename.replace(/(\.(?!ios|android)[_a-zA-Z0-9\\-]+)+/g, ''); // /path/to/button/index.js -> button
|
22
|
-
|
23
|
-
var moduleName = filename === 'index' ? path.basename(path.dirname(filePath)) : filename; // foo-bar -> fooBar
|
24
|
-
// Relay compatibility mode splits on _, so we can't use that here.
|
25
|
-
|
26
|
-
moduleName = moduleName.replace(/[^a-zA-Z0-9]+(\w?)/g, function (match, next) {
|
27
|
-
return next.toUpperCase();
|
28
|
-
});
|
29
|
-
return moduleName;
|
30
|
-
}
|
31
|
-
|
32
|
-
module.exports = getModuleName;
|
@@ -1,67 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
3
|
-
*
|
4
|
-
* This source code is licensed under the MIT license found in the
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
6
|
-
*
|
7
|
-
*
|
8
|
-
* @format
|
9
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
|
13
|
-
var _require = require('../core/CompilerError'),
|
14
|
-
createUserError = _require.createUserError;
|
15
|
-
/**
|
16
|
-
* Attempts to join the argument definitions for a root fragment
|
17
|
-
* and any unmasked fragment spreads reachable from that root fragment,
|
18
|
-
* returning a combined list of arguments or throwing if the same
|
19
|
-
* variable(s) are used in incompatible ways in different fragments.
|
20
|
-
*/
|
21
|
-
|
22
|
-
|
23
|
-
function joinArgumentDefinitions(schema, fragment, reachableArguments, directiveName) {
|
24
|
-
var joinedArgumentDefinitions = new Map();
|
25
|
-
fragment.argumentDefinitions.forEach(function (prevArgDef) {
|
26
|
-
joinedArgumentDefinitions.set(prevArgDef.name, prevArgDef);
|
27
|
-
});
|
28
|
-
reachableArguments.forEach(function (nextArgDef) {
|
29
|
-
var prevArgDef = joinedArgumentDefinitions.get(nextArgDef.name);
|
30
|
-
var joinedArgDef = prevArgDef == null ? nextArgDef : joinArgumentDefinition(schema, prevArgDef, nextArgDef, directiveName);
|
31
|
-
joinedArgumentDefinitions.set(joinedArgDef.name, joinedArgDef);
|
32
|
-
});
|
33
|
-
return Array.from(joinedArgumentDefinitions.values());
|
34
|
-
}
|
35
|
-
/**
|
36
|
-
* @private
|
37
|
-
*
|
38
|
-
* Attempts to join two argument definitions, returning a single argument
|
39
|
-
* definition that is compatible with both of the inputs:
|
40
|
-
* - If the kind, name, or defaultValue is different then the arguments
|
41
|
-
* cannot be joined, indicated by returning null.
|
42
|
-
* - If either of next/prev is a subtype of the other, return the one
|
43
|
-
* that is the subtype: a more narrow type can flow into a more general
|
44
|
-
* type but not the inverse.
|
45
|
-
* - Otherwise there is no subtyping relation between prev/next, so return
|
46
|
-
* null to indicate they cannot be joined.
|
47
|
-
*/
|
48
|
-
|
49
|
-
|
50
|
-
function joinArgumentDefinition(schema, prevArgDef, nextArgDef, directiveName) {
|
51
|
-
if (prevArgDef.kind !== nextArgDef.kind) {
|
52
|
-
throw createUserError('Cannot combine global and local variables when applying ' + "".concat(directiveName, "."), [prevArgDef.loc, nextArgDef.loc]);
|
53
|
-
} else if (prevArgDef.kind === 'LocalArgumentDefinition' && nextArgDef.kind === 'LocalArgumentDefinition' && prevArgDef.defaultValue !== nextArgDef.defaultValue) {
|
54
|
-
throw createUserError('Cannot combine local variables with different defaultValues when ' + "applying ".concat(directiveName, "."), [prevArgDef.loc, nextArgDef.loc]);
|
55
|
-
} else if (schema.isTypeSubTypeOf(nextArgDef.type, prevArgDef.type)) {
|
56
|
-
// prevArgDef is less strict than nextArgDef
|
57
|
-
return nextArgDef;
|
58
|
-
} else if (schema.isTypeSubTypeOf(prevArgDef.type, nextArgDef.type)) {
|
59
|
-
return prevArgDef;
|
60
|
-
} else {
|
61
|
-
var prevArgType = prevArgDef.type != null ? schema.getTypeString(prevArgDef.type) : 'unknown';
|
62
|
-
var nextArgType = nextArgDef.type != null ? schema.getTypeString(nextArgDef.type) : 'unknown';
|
63
|
-
throw createUserError('Cannot combine variables with incompatible types ' + "".concat(prevArgType, " and ").concat(nextArgType, " ") + "when applying ".concat(directiveName, "."), [prevArgDef.loc, nextArgDef.loc]);
|
64
|
-
}
|
65
|
-
}
|
66
|
-
|
67
|
-
module.exports = joinArgumentDefinitions;
|