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,262 +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
|
-
* @emails oncall+relay
|
8
|
-
*
|
9
|
-
* @format
|
10
|
-
*/
|
11
|
-
// flowlint ambiguous-object-type:error
|
12
|
-
'use strict';
|
13
|
-
|
14
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
15
|
-
|
16
|
-
var _asyncToGenerator = require("@babel/runtime/helpers/asyncToGenerator");
|
17
|
-
|
18
|
-
var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/createForOfIteratorHelper"));
|
19
|
-
|
20
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
21
|
-
|
22
|
-
var fs = require('fs');
|
23
|
-
|
24
|
-
var invariant = require('invariant');
|
25
|
-
/**
|
26
|
-
* A filesystem wrapper that buffers file reads and writes until `commit()` is
|
27
|
-
* called.
|
28
|
-
*/
|
29
|
-
|
30
|
-
|
31
|
-
var BufferedFilesystem = /*#__PURE__*/function () {
|
32
|
-
function BufferedFilesystem() {
|
33
|
-
(0, _defineProperty2["default"])(this, "buffer", new Map());
|
34
|
-
(0, _defineProperty2["default"])(this, "committed", false);
|
35
|
-
}
|
36
|
-
|
37
|
-
var _proto = BufferedFilesystem.prototype;
|
38
|
-
|
39
|
-
_proto._assertNotComitted = function _assertNotComitted() {
|
40
|
-
!!this.committed ? process.env.NODE_ENV !== "production" ? invariant(false, 'BufferedFilesystem: no operations allowed after commit().') : invariant(false) : void 0;
|
41
|
-
};
|
42
|
-
|
43
|
-
_proto.commit = /*#__PURE__*/function () {
|
44
|
-
var _commit = _asyncToGenerator(function* (sourceControl) {
|
45
|
-
this._assertNotComitted();
|
46
|
-
|
47
|
-
this.committed = true;
|
48
|
-
var removed = [];
|
49
|
-
var added = [];
|
50
|
-
|
51
|
-
var _iterator = (0, _createForOfIteratorHelper2["default"])(this.buffer),
|
52
|
-
_step;
|
53
|
-
|
54
|
-
try {
|
55
|
-
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
56
|
-
var _step$value = _step.value,
|
57
|
-
path = _step$value[0],
|
58
|
-
data = _step$value[1];
|
59
|
-
|
60
|
-
if (data == null) {
|
61
|
-
removed.push(path);
|
62
|
-
fs.unlinkSync(path);
|
63
|
-
} else {
|
64
|
-
var fileExisits = fs.existsSync(path);
|
65
|
-
var currentData = fileExisits ? fs.readFileSync(path, 'utf8') : null;
|
66
|
-
|
67
|
-
if (currentData !== data) {
|
68
|
-
added.push(path);
|
69
|
-
fs.writeFileSync(path, data, 'utf8');
|
70
|
-
}
|
71
|
-
}
|
72
|
-
}
|
73
|
-
} catch (err) {
|
74
|
-
_iterator.e(err);
|
75
|
-
} finally {
|
76
|
-
_iterator.f();
|
77
|
-
}
|
78
|
-
|
79
|
-
if (sourceControl) {
|
80
|
-
yield sourceControl.addRemove(added, removed);
|
81
|
-
}
|
82
|
-
});
|
83
|
-
|
84
|
-
function commit(_x) {
|
85
|
-
return _commit.apply(this, arguments);
|
86
|
-
}
|
87
|
-
|
88
|
-
return commit;
|
89
|
-
}();
|
90
|
-
|
91
|
-
_proto.hasChanges = function hasChanges() {
|
92
|
-
this._assertNotComitted();
|
93
|
-
|
94
|
-
return this.buffer.size > 0;
|
95
|
-
};
|
96
|
-
|
97
|
-
_proto.getChangesSummary = function getChangesSummary() {
|
98
|
-
this._assertNotComitted();
|
99
|
-
|
100
|
-
var added = [];
|
101
|
-
var updated = [];
|
102
|
-
var removed = [];
|
103
|
-
|
104
|
-
var _iterator2 = (0, _createForOfIteratorHelper2["default"])(this.buffer),
|
105
|
-
_step2;
|
106
|
-
|
107
|
-
try {
|
108
|
-
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
109
|
-
var _step2$value = _step2.value,
|
110
|
-
path = _step2$value[0],
|
111
|
-
data = _step2$value[1];
|
112
|
-
|
113
|
-
if (data == null) {
|
114
|
-
removed.push(path);
|
115
|
-
} else {
|
116
|
-
if (!fs.existsSync(path)) {
|
117
|
-
added.push(path);
|
118
|
-
} else {
|
119
|
-
updated.push(path);
|
120
|
-
}
|
121
|
-
}
|
122
|
-
}
|
123
|
-
} catch (err) {
|
124
|
-
_iterator2.e(err);
|
125
|
-
} finally {
|
126
|
-
_iterator2.f();
|
127
|
-
}
|
128
|
-
|
129
|
-
return [added.length > 0 ? "Added:\n".concat(added.map(formatFilepath).join('')) : '', updated.length > 0 ? "Updated:\n".concat(updated.map(formatFilepath).join('')) : '', removed.length > 0 ? "Removed:\n".concat(removed.map(formatFilepath).join('')) : ''].filter(Boolean).join('\n');
|
130
|
-
};
|
131
|
-
|
132
|
-
_proto.getAddedRemovedFiles = function getAddedRemovedFiles() {
|
133
|
-
this._assertNotComitted();
|
134
|
-
|
135
|
-
var added = [];
|
136
|
-
var removed = [];
|
137
|
-
|
138
|
-
var _iterator3 = (0, _createForOfIteratorHelper2["default"])(this.buffer),
|
139
|
-
_step3;
|
140
|
-
|
141
|
-
try {
|
142
|
-
for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
|
143
|
-
var _step3$value = _step3.value,
|
144
|
-
path = _step3$value[0],
|
145
|
-
data = _step3$value[1];
|
146
|
-
|
147
|
-
if (data == null) {
|
148
|
-
removed.push(path);
|
149
|
-
} else {
|
150
|
-
if (!fs.existsSync(path)) {
|
151
|
-
added.push(path);
|
152
|
-
}
|
153
|
-
}
|
154
|
-
}
|
155
|
-
} catch (err) {
|
156
|
-
_iterator3.e(err);
|
157
|
-
} finally {
|
158
|
-
_iterator3.f();
|
159
|
-
}
|
160
|
-
|
161
|
-
return {
|
162
|
-
added: added,
|
163
|
-
removed: removed
|
164
|
-
};
|
165
|
-
};
|
166
|
-
|
167
|
-
_proto.existsSync = function existsSync(path) {
|
168
|
-
this._assertNotComitted();
|
169
|
-
|
170
|
-
return this.buffer.has(path) ? Boolean(this.buffer.get(path)) : fs.existsSync(path);
|
171
|
-
};
|
172
|
-
|
173
|
-
_proto.mkdirSync = function mkdirSync(path) {
|
174
|
-
this._assertNotComitted();
|
175
|
-
|
176
|
-
fs.mkdirSync(path);
|
177
|
-
};
|
178
|
-
|
179
|
-
_proto.readdirSync = function readdirSync(path) {
|
180
|
-
this._assertNotComitted();
|
181
|
-
|
182
|
-
throw new Error('BufferedFilesystem: readdirSync is not implemented.');
|
183
|
-
};
|
184
|
-
|
185
|
-
_proto.readFileSync = function readFileSync(path, encoding) {
|
186
|
-
this._assertNotComitted();
|
187
|
-
|
188
|
-
if (this.buffer.has(path)) {
|
189
|
-
var data = this.buffer.get(path);
|
190
|
-
!(data != null) ? process.env.NODE_ENV !== "production" ? invariant(false, 'BufferedFilesystem: trying to read deleted file.') : invariant(false) : void 0;
|
191
|
-
return data;
|
192
|
-
}
|
193
|
-
|
194
|
-
return fs.readFileSync(path, encoding);
|
195
|
-
};
|
196
|
-
|
197
|
-
_proto.statSync = function statSync(path) {
|
198
|
-
this._assertNotComitted();
|
199
|
-
|
200
|
-
return fs.statSync(path);
|
201
|
-
};
|
202
|
-
|
203
|
-
_proto.unlinkSync = function unlinkSync(path) {
|
204
|
-
this._assertNotComitted();
|
205
|
-
|
206
|
-
this.buffer.set(path, null);
|
207
|
-
};
|
208
|
-
|
209
|
-
_proto.writeFileSync = function writeFileSync(filename, data, encoding) {
|
210
|
-
this._assertNotComitted();
|
211
|
-
|
212
|
-
this.buffer.set(filename, data);
|
213
|
-
};
|
214
|
-
|
215
|
-
_proto.changedFilesToJSON = function changedFilesToJSON() {
|
216
|
-
this._assertNotComitted();
|
217
|
-
|
218
|
-
var changed = [];
|
219
|
-
var removed = [];
|
220
|
-
|
221
|
-
var _iterator4 = (0, _createForOfIteratorHelper2["default"])(this.buffer),
|
222
|
-
_step4;
|
223
|
-
|
224
|
-
try {
|
225
|
-
for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
|
226
|
-
var _step4$value = _step4.value,
|
227
|
-
path = _step4$value[0],
|
228
|
-
data = _step4$value[1];
|
229
|
-
|
230
|
-
if (data == null) {
|
231
|
-
removed.push({
|
232
|
-
path: path
|
233
|
-
});
|
234
|
-
} else {
|
235
|
-
changed.push({
|
236
|
-
path: path,
|
237
|
-
data: data
|
238
|
-
});
|
239
|
-
}
|
240
|
-
}
|
241
|
-
} catch (err) {
|
242
|
-
_iterator4.e(err);
|
243
|
-
} finally {
|
244
|
-
_iterator4.f();
|
245
|
-
}
|
246
|
-
|
247
|
-
return {
|
248
|
-
removed: removed,
|
249
|
-
changed: changed
|
250
|
-
};
|
251
|
-
};
|
252
|
-
|
253
|
-
return BufferedFilesystem;
|
254
|
-
}();
|
255
|
-
|
256
|
-
function formatFilepath(filepath) {
|
257
|
-
var startIndex = filepath.length - 80;
|
258
|
-
var prefix = startIndex > 0 ? "\t - ".concat(filepath.substr(0, 8), "...") : '\t - ';
|
259
|
-
return prefix + filepath.substr(startIndex, filepath.length) + '\n';
|
260
|
-
}
|
261
|
-
|
262
|
-
module.exports = BufferedFilesystem;
|
@@ -1,256 +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
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
|
13
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
14
|
-
|
15
|
-
var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/createForOfIteratorHelper"));
|
16
|
-
|
17
|
-
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
18
|
-
|
19
|
-
var _require = require('./GraphQLASTUtils'),
|
20
|
-
getName = _require.getName;
|
21
|
-
|
22
|
-
var GraphQLNodeMap = require('./GraphQLNodeMap');
|
23
|
-
|
24
|
-
var _require2 = require('graphql'),
|
25
|
-
visit = _require2.visit;
|
26
|
-
|
27
|
-
function buildDependencyMap(nodes) {
|
28
|
-
var dependencyMap = new Map();
|
29
|
-
|
30
|
-
var _iterator = (0, _createForOfIteratorHelper2["default"])(nodes.values()),
|
31
|
-
_step;
|
32
|
-
|
33
|
-
try {
|
34
|
-
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
35
|
-
var node = _step.value;
|
36
|
-
var name = getName(node);
|
37
|
-
|
38
|
-
if (dependencyMap.has(name)) {
|
39
|
-
throw new Error("Duplicated definition for ".concat(name));
|
40
|
-
}
|
41
|
-
|
42
|
-
dependencyMap.set(name, findIncludedFragments(node));
|
43
|
-
}
|
44
|
-
} catch (err) {
|
45
|
-
_iterator.e(err);
|
46
|
-
} finally {
|
47
|
-
_iterator.f();
|
48
|
-
}
|
49
|
-
|
50
|
-
return dependencyMap;
|
51
|
-
}
|
52
|
-
|
53
|
-
function mergeMaps(maps) {
|
54
|
-
var result = new Map();
|
55
|
-
|
56
|
-
var _iterator2 = (0, _createForOfIteratorHelper2["default"])(maps),
|
57
|
-
_step2;
|
58
|
-
|
59
|
-
try {
|
60
|
-
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
61
|
-
var source = _step2.value;
|
62
|
-
|
63
|
-
var _iterator3 = (0, _createForOfIteratorHelper2["default"])(source.entries()),
|
64
|
-
_step3;
|
65
|
-
|
66
|
-
try {
|
67
|
-
for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
|
68
|
-
var _step3$value = _step3.value,
|
69
|
-
key = _step3$value[0],
|
70
|
-
value = _step3$value[1];
|
71
|
-
|
72
|
-
if (result.has(key)) {
|
73
|
-
throw new Error("Duplicate entry for '".concat(key, "'."));
|
74
|
-
}
|
75
|
-
|
76
|
-
result.set(key, value);
|
77
|
-
}
|
78
|
-
} catch (err) {
|
79
|
-
_iterator3.e(err);
|
80
|
-
} finally {
|
81
|
-
_iterator3.f();
|
82
|
-
}
|
83
|
-
}
|
84
|
-
} catch (err) {
|
85
|
-
_iterator2.e(err);
|
86
|
-
} finally {
|
87
|
-
_iterator2.f();
|
88
|
-
}
|
89
|
-
|
90
|
-
return result;
|
91
|
-
}
|
92
|
-
|
93
|
-
function forFullBuild(nodes, baseNodes) {
|
94
|
-
var dependencyMap = mergeMaps([nodes].concat((0, _toConsumableArray2["default"])(baseNodes)).map(buildDependencyMap));
|
95
|
-
var includedNames = includeReachable(new Set(nodes.keys()), dependencyMap);
|
96
|
-
return buildResult(includedNames, nodes, mergeMaps(baseNodes));
|
97
|
-
}
|
98
|
-
|
99
|
-
function forChanges(nodes, changedNames) {
|
100
|
-
var baseNodes = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
|
101
|
-
var projectDependencyMap = buildDependencyMap(nodes);
|
102
|
-
var baseDependencyMap = mergeMaps(baseNodes.map(buildDependencyMap));
|
103
|
-
var dependencyMap = mergeMaps([projectDependencyMap, baseDependencyMap]);
|
104
|
-
var invertedDependencyMap = inverseDependencyMap(dependencyMap);
|
105
|
-
var baseNameToNode = mergeMaps(baseNodes); // The first step of the process is to find all ancestors of changed nodes.
|
106
|
-
// And we perform this search on complete dependency map (project + base)
|
107
|
-
|
108
|
-
var directlyChangedAndAncestors = includeReachable(changedNames, invertedDependencyMap); // Now, we need to intersect obtained set with the project nodes
|
109
|
-
|
110
|
-
var directlyChangedRelatedToProject = new Set();
|
111
|
-
|
112
|
-
var _iterator4 = (0, _createForOfIteratorHelper2["default"])(directlyChangedAndAncestors),
|
113
|
-
_step4;
|
114
|
-
|
115
|
-
try {
|
116
|
-
for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
|
117
|
-
var node = _step4.value;
|
118
|
-
|
119
|
-
if (nodes.has(node)) {
|
120
|
-
directlyChangedRelatedToProject.add(node);
|
121
|
-
}
|
122
|
-
} // Finally, we need to find all descendants of project-related changed nodes
|
123
|
-
// in the complete dependency map (project + base)
|
124
|
-
|
125
|
-
} catch (err) {
|
126
|
-
_iterator4.e(err);
|
127
|
-
} finally {
|
128
|
-
_iterator4.f();
|
129
|
-
}
|
130
|
-
|
131
|
-
var allRelated = includeReachable(directlyChangedRelatedToProject, dependencyMap);
|
132
|
-
return buildResult(allRelated, nodes, baseNameToNode);
|
133
|
-
}
|
134
|
-
|
135
|
-
function buildResult(includedNames, nameToNode, baseNameToNode) {
|
136
|
-
var baseNames = new Set();
|
137
|
-
var nodes = [];
|
138
|
-
|
139
|
-
var _iterator5 = (0, _createForOfIteratorHelper2["default"])(includedNames),
|
140
|
-
_step5;
|
141
|
-
|
142
|
-
try {
|
143
|
-
for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) {
|
144
|
-
var name = _step5.value;
|
145
|
-
var baseNode = baseNameToNode.get(name);
|
146
|
-
|
147
|
-
if (baseNode != null) {
|
148
|
-
nodes.push(baseNode);
|
149
|
-
baseNames.add(name);
|
150
|
-
}
|
151
|
-
|
152
|
-
var node = nameToNode.get(name);
|
153
|
-
|
154
|
-
if (node != null) {
|
155
|
-
nodes.push(node);
|
156
|
-
}
|
157
|
-
}
|
158
|
-
} catch (err) {
|
159
|
-
_iterator5.e(err);
|
160
|
-
} finally {
|
161
|
-
_iterator5.f();
|
162
|
-
}
|
163
|
-
|
164
|
-
return {
|
165
|
-
baseNames: baseNames,
|
166
|
-
nodes: GraphQLNodeMap.from(nodes)
|
167
|
-
};
|
168
|
-
}
|
169
|
-
|
170
|
-
function includeReachable(changed, deps) {
|
171
|
-
var toVisit = Array.from(changed);
|
172
|
-
var visited = new Set();
|
173
|
-
|
174
|
-
while (toVisit.length > 0) {
|
175
|
-
var current = toVisit.pop();
|
176
|
-
visited.add(current);
|
177
|
-
|
178
|
-
var _iterator6 = (0, _createForOfIteratorHelper2["default"])(deps.get(current) || []),
|
179
|
-
_step6;
|
180
|
-
|
181
|
-
try {
|
182
|
-
for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) {
|
183
|
-
var dep = _step6.value;
|
184
|
-
|
185
|
-
if (!visited.has(dep)) {
|
186
|
-
toVisit.push(dep);
|
187
|
-
}
|
188
|
-
}
|
189
|
-
} catch (err) {
|
190
|
-
_iterator6.e(err);
|
191
|
-
} finally {
|
192
|
-
_iterator6.f();
|
193
|
-
}
|
194
|
-
}
|
195
|
-
|
196
|
-
return visited;
|
197
|
-
}
|
198
|
-
|
199
|
-
function findIncludedFragments(node) {
|
200
|
-
var result = [];
|
201
|
-
visit(node, {
|
202
|
-
FragmentSpread: function FragmentSpread(spread) {
|
203
|
-
result.push(spread.name.value);
|
204
|
-
}
|
205
|
-
});
|
206
|
-
return result;
|
207
|
-
}
|
208
|
-
|
209
|
-
function inverseDependencyMap(map) {
|
210
|
-
var invertedMap = new Map();
|
211
|
-
|
212
|
-
var _iterator7 = (0, _createForOfIteratorHelper2["default"])(map.entries()),
|
213
|
-
_step7;
|
214
|
-
|
215
|
-
try {
|
216
|
-
for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) {
|
217
|
-
var _step7$value = _step7.value,
|
218
|
-
source = _step7$value[0],
|
219
|
-
dests = _step7$value[1];
|
220
|
-
var inverseDest = source;
|
221
|
-
|
222
|
-
var _iterator8 = (0, _createForOfIteratorHelper2["default"])(dests),
|
223
|
-
_step8;
|
224
|
-
|
225
|
-
try {
|
226
|
-
for (_iterator8.s(); !(_step8 = _iterator8.n()).done;) {
|
227
|
-
var dest = _step8.value;
|
228
|
-
var inverseSource = dest;
|
229
|
-
var inverseDests = invertedMap.get(inverseSource);
|
230
|
-
|
231
|
-
if (inverseDests == null) {
|
232
|
-
inverseDests = [];
|
233
|
-
invertedMap.set(inverseSource, inverseDests);
|
234
|
-
}
|
235
|
-
|
236
|
-
inverseDests.push(inverseDest);
|
237
|
-
}
|
238
|
-
} catch (err) {
|
239
|
-
_iterator8.e(err);
|
240
|
-
} finally {
|
241
|
-
_iterator8.f();
|
242
|
-
}
|
243
|
-
}
|
244
|
-
} catch (err) {
|
245
|
-
_iterator7.e(err);
|
246
|
-
} finally {
|
247
|
-
_iterator7.f();
|
248
|
-
}
|
249
|
-
|
250
|
-
return invertedMap;
|
251
|
-
}
|
252
|
-
|
253
|
-
module.exports = {
|
254
|
-
forChanges: forChanges,
|
255
|
-
forFullBuild: forFullBuild
|
256
|
-
};
|
@@ -1,23 +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
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
|
13
|
-
function getName(node) {
|
14
|
-
if (node.name == null) {
|
15
|
-
throw new Error('All fragments and operations have to have names in Relay');
|
16
|
-
}
|
17
|
-
|
18
|
-
return node.name.value;
|
19
|
-
}
|
20
|
-
|
21
|
-
module.exports = {
|
22
|
-
getName: getName
|
23
|
-
};
|
@@ -1,81 +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
|
-
*/
|
10
|
-
// flowlint ambiguous-object-type:error
|
11
|
-
'use strict';
|
12
|
-
|
13
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
14
|
-
|
15
|
-
var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/createForOfIteratorHelper"));
|
16
|
-
|
17
|
-
var _inheritsLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/inheritsLoose"));
|
18
|
-
|
19
|
-
var _wrapNativeSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/wrapNativeSuper"));
|
20
|
-
|
21
|
-
var _require = require('../core/CompilerError'),
|
22
|
-
createCompilerError = _require.createCompilerError,
|
23
|
-
createUserError = _require.createUserError;
|
24
|
-
|
25
|
-
var _require2 = require('./GraphQLASTUtils'),
|
26
|
-
getName = _require2.getName;
|
27
|
-
|
28
|
-
var GraphQLNodeMap = /*#__PURE__*/function (_Map) {
|
29
|
-
(0, _inheritsLoose2["default"])(GraphQLNodeMap, _Map);
|
30
|
-
|
31
|
-
function GraphQLNodeMap() {
|
32
|
-
return _Map.apply(this, arguments) || this;
|
33
|
-
}
|
34
|
-
|
35
|
-
GraphQLNodeMap.from = function from(nodes) {
|
36
|
-
var result = new GraphQLNodeMap();
|
37
|
-
|
38
|
-
var _iterator = (0, _createForOfIteratorHelper2["default"])(nodes),
|
39
|
-
_step;
|
40
|
-
|
41
|
-
try {
|
42
|
-
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
43
|
-
var node = _step.value;
|
44
|
-
var name = getName(node);
|
45
|
-
var prevNode = result.get(name);
|
46
|
-
|
47
|
-
if (prevNode) {
|
48
|
-
throw createUserError("Duplicate node named '".concat(name, "'"), null, [node, prevNode]);
|
49
|
-
}
|
50
|
-
|
51
|
-
result.set(name, node);
|
52
|
-
}
|
53
|
-
} catch (err) {
|
54
|
-
_iterator.e(err);
|
55
|
-
} finally {
|
56
|
-
_iterator.f();
|
57
|
-
}
|
58
|
-
|
59
|
-
return result;
|
60
|
-
};
|
61
|
-
|
62
|
-
GraphQLNodeMap.fromSources = function fromSources(sources) {
|
63
|
-
return GraphQLNodeMap.from(sources.nodes());
|
64
|
-
};
|
65
|
-
|
66
|
-
var _proto = GraphQLNodeMap.prototype;
|
67
|
-
|
68
|
-
_proto.enforceGet = function enforceGet(name) {
|
69
|
-
var node = this.get(name);
|
70
|
-
|
71
|
-
if (!node) {
|
72
|
-
throw createCompilerError("GraphQLNodeMap: expected to have a node named ".concat(name, "."));
|
73
|
-
}
|
74
|
-
|
75
|
-
return node;
|
76
|
-
};
|
77
|
-
|
78
|
-
return GraphQLNodeMap;
|
79
|
-
}( /*#__PURE__*/(0, _wrapNativeSuper2["default"])(Map));
|
80
|
-
|
81
|
-
module.exports = GraphQLNodeMap;
|