relay-compiler 0.0.0-main-f0b65f0b → 0.0.0-main-e0026a71
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,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;
|