relay-compiler 9.0.0 → 9.1.0
Sign up to get free protection for your applications and to get access to all the features.
- package/bin/RelayCompilerBin.js.flow +169 -0
- package/bin/RelayCompilerMain.js.flow +508 -0
- package/bin/__fixtures__/plugin-module.js.flow +17 -0
- package/bin/relay-compiler +2002 -1733
- package/codegen/CodegenDirectory.js.flow +375 -0
- package/codegen/CodegenRunner.js.flow +431 -0
- package/codegen/CodegenTypes.js.flow +28 -0
- package/codegen/CodegenWatcher.js.flow +254 -0
- package/codegen/NormalizationCodeGenerator.js.flow +499 -0
- package/codegen/ReaderCodeGenerator.js.flow +453 -0
- package/codegen/RelayCodeGenerator.js.flow +76 -0
- package/codegen/RelayFileWriter.js.flow +366 -0
- package/codegen/SourceControl.js.flow +58 -0
- package/codegen/compileRelayArtifacts.js.flow +182 -0
- package/codegen/createPrintRequireModuleDependency.js.flow +21 -0
- package/codegen/writeRelayGeneratedFile.js.flow +194 -0
- package/core/ASTCache.js.flow +73 -0
- package/core/ASTConvert.js.flow +233 -0
- package/core/CompilerContext.js.flow +190 -0
- package/core/CompilerError.js.flow +250 -0
- package/core/DotGraphQLParser.js.flow +39 -0
- package/core/GraphQLCompilerProfiler.js.flow +341 -0
- package/core/GraphQLDerivedFromMetadata.js.flow +48 -0
- package/core/GraphQLWatchmanClient.js.flow +111 -0
- package/core/IR.js.flow +329 -0
- package/core/IRPrinter.js.flow +488 -0
- package/core/IRTransformer.js.flow +377 -0
- package/core/IRValidator.js.flow +260 -0
- package/core/IRVisitor.js.flow +150 -0
- package/core/JSModuleParser.js.flow +24 -0
- package/core/RelayCompilerScope.js.flow +199 -0
- package/core/RelayFindGraphQLTags.js.flow +119 -0
- package/core/RelayGraphQLEnumsGenerator.js.flow +55 -0
- package/core/RelayIRTransforms.js.flow +130 -0
- package/core/RelayParser.js.flow +1759 -0
- package/core/RelaySourceModuleParser.js.flow +135 -0
- package/core/Schema.js.flow +1985 -0
- package/core/SchemaUtils.js.flow +109 -0
- package/core/filterContextForNode.js.flow +50 -0
- package/core/getFieldDefinition.js.flow +156 -0
- package/core/getIdentifierForArgumentValue.js.flow +49 -0
- package/core/getIdentifierForSelection.js.flow +69 -0
- package/core/getLiteralArgumentValues.js.flow +32 -0
- package/core/getNormalizationOperationName.js.flow +19 -0
- package/core/inferRootArgumentDefinitions.js.flow +323 -0
- package/index.js +1 -1
- package/index.js.flow +202 -0
- package/language/RelayLanguagePluginInterface.js.flow +283 -0
- package/language/javascript/FindGraphQLTags.js.flow +233 -0
- package/language/javascript/RelayFlowBabelFactories.js.flow +180 -0
- package/language/javascript/RelayFlowGenerator.js.flow +1040 -0
- package/language/javascript/RelayFlowTypeTransformers.js.flow +184 -0
- package/language/javascript/RelayLanguagePluginJavaScript.js.flow +34 -0
- package/language/javascript/formatGeneratedModule.js.flow +65 -0
- package/lib/bin/RelayCompilerBin.js +10 -0
- package/lib/bin/RelayCompilerMain.js +113 -119
- package/lib/codegen/CodegenDirectory.js +2 -6
- package/lib/codegen/CodegenRunner.js +34 -75
- package/lib/codegen/CodegenWatcher.js +13 -21
- package/lib/codegen/NormalizationCodeGenerator.js +43 -40
- package/lib/codegen/ReaderCodeGenerator.js +43 -35
- package/lib/codegen/RelayCodeGenerator.js +7 -5
- package/lib/codegen/RelayFileWriter.js +15 -36
- package/lib/codegen/compileRelayArtifacts.js +16 -30
- package/lib/codegen/writeRelayGeneratedFile.js +56 -98
- package/lib/core/ASTCache.js +1 -3
- package/lib/core/CompilerContext.js +1 -3
- package/lib/core/CompilerError.js +27 -54
- package/lib/core/GraphQLCompilerProfiler.js +8 -12
- package/lib/core/GraphQLWatchmanClient.js +4 -12
- package/lib/core/IRPrinter.js +5 -5
- package/lib/core/IRTransformer.js +8 -6
- package/lib/core/IRValidator.js +1 -3
- package/lib/core/RelayCompilerScope.js +4 -4
- package/lib/core/RelayGraphQLEnumsGenerator.js +12 -15
- package/lib/core/RelayIRTransforms.js +9 -5
- package/lib/core/RelayParser.js +44 -56
- package/lib/core/RelaySourceModuleParser.js +1 -3
- package/lib/core/Schema.js +78 -65
- package/lib/core/getFieldDefinition.js +12 -15
- package/lib/core/getIdentifierForSelection.js +1 -1
- package/lib/core/inferRootArgumentDefinitions.js +27 -36
- package/lib/language/javascript/RelayFlowGenerator.js +49 -78
- package/lib/language/javascript/RelayFlowTypeTransformers.js +1 -3
- package/lib/reporters/ConsoleReporter.js +1 -3
- package/lib/reporters/MultiReporter.js +1 -3
- package/lib/runner/Artifacts.js +69 -170
- package/lib/runner/BufferedFilesystem.js +32 -66
- package/lib/runner/GraphQLASTNodeGroup.js +54 -120
- package/lib/runner/GraphQLNodeMap.js +14 -19
- package/lib/runner/Sources.js +49 -78
- package/lib/runner/StrictMap.js +20 -36
- package/lib/runner/getChangedNodeNames.js +30 -62
- package/lib/transforms/ApplyFragmentArgumentTransform.js +33 -28
- package/lib/transforms/ClientExtensionsTransform.js +7 -12
- package/lib/transforms/ConnectionTransform.js +26 -24
- package/lib/transforms/DeferStreamTransform.js +20 -16
- package/lib/transforms/DisallowTypenameOnRoot.js +55 -0
- package/lib/transforms/FieldHandleTransform.js +6 -2
- package/lib/transforms/FlattenTransform.js +19 -14
- package/lib/transforms/GenerateIDFieldTransform.js +7 -3
- package/lib/transforms/GenerateTypeNameTransform.js +6 -2
- package/lib/transforms/InlineDataFragmentTransform.js +7 -3
- package/lib/transforms/MaskTransform.js +17 -17
- package/lib/transforms/MatchTransform.js +110 -32
- package/lib/transforms/RefetchableFragmentTransform.js +21 -17
- package/lib/transforms/RelayDirectiveTransform.js +11 -3
- package/lib/transforms/SkipClientExtensionsTransform.js +8 -0
- package/lib/transforms/SkipHandleFieldTransform.js +6 -2
- package/lib/transforms/SkipRedundantNodesTransform.js +6 -2
- package/lib/transforms/SkipSplitOperationTransform.js +32 -0
- package/lib/transforms/SkipUnreachableNodeTransform.js +9 -2
- package/lib/transforms/SkipUnusedVariablesTransform.js +18 -17
- package/lib/transforms/SplitModuleImportTransform.js +2 -2
- package/lib/transforms/TestOperationTransform.js +7 -3
- package/lib/transforms/ValidateGlobalVariablesTransform.js +18 -30
- package/lib/transforms/ValidateRequiredArgumentsTransform.js +12 -15
- package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +16 -30
- package/lib/transforms/ValidateUnusedVariablesTransform.js +18 -30
- package/lib/transforms/query-generators/FetchableQueryGenerator.js +161 -0
- package/lib/transforms/query-generators/NodeQueryGenerator.js +7 -2
- package/lib/transforms/query-generators/QueryQueryGenerator.js +1 -0
- package/lib/transforms/query-generators/ViewerQueryGenerator.js +1 -0
- package/lib/transforms/query-generators/index.js +23 -6
- package/lib/transforms/query-generators/utils.js +12 -15
- package/lib/util/RelayCompilerCache.js +1 -3
- package/lib/util/dedupeJSONStringify.js +15 -12
- package/lib/util/getModuleName.js +1 -1
- package/package.json +2 -2
- package/relay-compiler.js +4 -4
- package/relay-compiler.min.js +4 -4
- package/reporters/ConsoleReporter.js.flow +81 -0
- package/reporters/MultiReporter.js.flow +43 -0
- package/reporters/Reporter.js.flow +19 -0
- package/runner/Artifacts.js.flow +219 -0
- package/runner/BufferedFilesystem.js.flow +194 -0
- package/runner/GraphQLASTNodeGroup.js.flow +176 -0
- package/runner/GraphQLASTUtils.js.flow +26 -0
- package/runner/GraphQLNodeMap.js.flow +55 -0
- package/runner/Sources.js.flow +218 -0
- package/runner/StrictMap.js.flow +96 -0
- package/runner/compileArtifacts.js.flow +76 -0
- package/runner/extractAST.js.flow +100 -0
- package/runner/getChangedNodeNames.js.flow +48 -0
- package/runner/getSchemaInstance.js.flow +36 -0
- package/runner/types.js.flow +37 -0
- package/transforms/ApplyFragmentArgumentTransform.js.flow +474 -0
- package/transforms/ClientExtensionsTransform.js.flow +220 -0
- package/transforms/ConnectionTransform.js.flow +869 -0
- package/transforms/DeferStreamTransform.js.flow +258 -0
- package/transforms/DisallowIdAsAlias.js.flow +47 -0
- package/transforms/DisallowTypenameOnRoot.js.flow +45 -0
- package/transforms/FieldHandleTransform.js.flow +80 -0
- package/transforms/FilterDirectivesTransform.js.flow +45 -0
- package/transforms/FlattenTransform.js.flow +456 -0
- package/transforms/GenerateIDFieldTransform.js.flow +134 -0
- package/transforms/GenerateTypeNameTransform.js.flow +81 -0
- package/transforms/InlineDataFragmentTransform.js.flow +124 -0
- package/transforms/InlineFragmentsTransform.js.flow +71 -0
- package/transforms/MaskTransform.js.flow +126 -0
- package/transforms/MatchTransform.js.flow +583 -0
- package/transforms/RefetchableFragmentTransform.js.flow +272 -0
- package/transforms/RelayDirectiveTransform.js.flow +99 -0
- package/transforms/SkipClientExtensionsTransform.js.flow +54 -0
- package/transforms/SkipHandleFieldTransform.js.flow +44 -0
- package/transforms/SkipRedundantNodesTransform.js.flow +253 -0
- package/transforms/SkipSplitOperationTransform.js.flow +37 -0
- package/transforms/SkipUnreachableNodeTransform.js.flow +149 -0
- package/transforms/SkipUnusedVariablesTransform.js.flow +59 -0
- package/transforms/SplitModuleImportTransform.js.flow +98 -0
- package/transforms/TestOperationTransform.js.flow +138 -0
- package/transforms/TransformUtils.js.flow +26 -0
- package/transforms/ValidateGlobalVariablesTransform.js.flow +81 -0
- package/transforms/ValidateRequiredArgumentsTransform.js.flow +127 -0
- package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +112 -0
- package/transforms/ValidateUnusedVariablesTransform.js.flow +89 -0
- package/transforms/query-generators/FetchableQueryGenerator.js.flow +190 -0
- package/transforms/query-generators/NodeQueryGenerator.js.flow +206 -0
- package/transforms/query-generators/QueryQueryGenerator.js.flow +57 -0
- package/transforms/query-generators/ViewerQueryGenerator.js.flow +97 -0
- package/transforms/query-generators/index.js.flow +90 -0
- package/transforms/query-generators/utils.js.flow +72 -0
- package/util/CodeMarker.js.flow +79 -0
- package/util/DefaultHandleKey.js.flow +17 -0
- package/util/RelayCompilerCache.js.flow +88 -0
- package/util/Rollout.js.flow +39 -0
- package/util/TimeReporter.js.flow +79 -0
- package/util/areEqualOSS.js.flow +123 -0
- package/util/dedupeJSONStringify.js.flow +152 -0
- package/util/getDefinitionNodeHash.js.flow +25 -0
- package/util/getModuleName.js.flow +39 -0
- package/util/joinArgumentDefinitions.js.flow +99 -0
- package/util/md5.js.flow +22 -0
- package/util/murmurHash.js.flow +94 -0
- package/util/nullthrowsOSS.js.flow +25 -0
- package/util/orList.js.flow +37 -0
- package/util/partitionArray.js.flow +37 -0
@@ -16,6 +16,12 @@ var _asyncToGenerator = require("@babel/runtime/helpers/asyncToGenerator");
|
|
16
16
|
|
17
17
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
18
18
|
|
19
|
+
function _createForOfIteratorHelper(o) { if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (o = _unsupportedIterableToArray(o))) { var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var it, normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
|
20
|
+
|
21
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(n); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
22
|
+
|
23
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
24
|
+
|
19
25
|
var CodegenDirectory = require('./CodegenDirectory');
|
20
26
|
|
21
27
|
var CodegenWatcher = require('./CodegenWatcher');
|
@@ -35,9 +41,7 @@ var _require = require('../core/Schema'),
|
|
35
41
|
var _require2 = require('immutable'),
|
36
42
|
ImmutableMap = _require2.Map;
|
37
43
|
|
38
|
-
var CodegenRunner =
|
39
|
-
/*#__PURE__*/
|
40
|
-
function () {
|
44
|
+
var CodegenRunner = /*#__PURE__*/function () {
|
41
45
|
// parser => writers that are affected by it
|
42
46
|
function CodegenRunner(options) {
|
43
47
|
var _this = this;
|
@@ -71,9 +75,7 @@ function () {
|
|
71
75
|
|
72
76
|
var _proto = CodegenRunner.prototype;
|
73
77
|
|
74
|
-
_proto.compileAll =
|
75
|
-
/*#__PURE__*/
|
76
|
-
function () {
|
78
|
+
_proto.compileAll = /*#__PURE__*/function () {
|
77
79
|
var _compileAll = _asyncToGenerator(function* () {
|
78
80
|
// reset the parsers
|
79
81
|
this.parsers = {};
|
@@ -112,9 +114,7 @@ function () {
|
|
112
114
|
return compileAll;
|
113
115
|
}();
|
114
116
|
|
115
|
-
_proto.compile =
|
116
|
-
/*#__PURE__*/
|
117
|
-
function () {
|
117
|
+
_proto.compile = /*#__PURE__*/function () {
|
118
118
|
var _compile = _asyncToGenerator(function* (writerName) {
|
119
119
|
var _this2 = this;
|
120
120
|
|
@@ -146,19 +146,17 @@ function () {
|
|
146
146
|
_proto.getDirtyWriters = function getDirtyWriters(filePaths) {
|
147
147
|
var _this3 = this;
|
148
148
|
|
149
|
-
return Profiler.asyncContext('CodegenRunner:getDirtyWriters',
|
150
|
-
/*#__PURE__*/
|
151
|
-
_asyncToGenerator(function* () {
|
149
|
+
return Profiler.asyncContext('CodegenRunner:getDirtyWriters', /*#__PURE__*/_asyncToGenerator(function* () {
|
152
150
|
var dirtyWriters = new Set(); // Check if any files are in the output
|
153
151
|
|
154
152
|
for (var configName in _this3.writerConfigs) {
|
155
153
|
var config = _this3.writerConfigs[configName];
|
156
|
-
|
157
|
-
var
|
158
|
-
|
154
|
+
|
155
|
+
var _iterator = _createForOfIteratorHelper(filePaths),
|
156
|
+
_step;
|
159
157
|
|
160
158
|
try {
|
161
|
-
for (
|
159
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
162
160
|
var _filePath = _step.value;
|
163
161
|
|
164
162
|
if (config.isGeneratedFile(_filePath)) {
|
@@ -166,26 +164,15 @@ function () {
|
|
166
164
|
}
|
167
165
|
}
|
168
166
|
} catch (err) {
|
169
|
-
|
170
|
-
_iteratorError = err;
|
167
|
+
_iterator.e(err);
|
171
168
|
} finally {
|
172
|
-
|
173
|
-
if (!_iteratorNormalCompletion && _iterator["return"] != null) {
|
174
|
-
_iterator["return"]();
|
175
|
-
}
|
176
|
-
} finally {
|
177
|
-
if (_didIteratorError) {
|
178
|
-
throw _iteratorError;
|
179
|
-
}
|
180
|
-
}
|
169
|
+
_iterator.f();
|
181
170
|
}
|
182
171
|
} // Check for files in the input
|
183
172
|
|
184
173
|
|
185
174
|
yield Promise.all(Object.keys(_this3.parserConfigs).map(function (parserConfigName) {
|
186
|
-
return Profiler.waitFor('Watchman:query',
|
187
|
-
/*#__PURE__*/
|
188
|
-
_asyncToGenerator(function* () {
|
175
|
+
return Profiler.waitFor('Watchman:query', /*#__PURE__*/_asyncToGenerator(function* () {
|
189
176
|
var client = new GraphQLWatchmanClient();
|
190
177
|
var config = _this3.parserConfigs[parserConfigName];
|
191
178
|
var dirs = yield client.watchProject(config.baseDir);
|
@@ -211,9 +198,7 @@ function () {
|
|
211
198
|
}));
|
212
199
|
};
|
213
200
|
|
214
|
-
_proto.parseEverything =
|
215
|
-
/*#__PURE__*/
|
216
|
-
function () {
|
201
|
+
_proto.parseEverything = /*#__PURE__*/function () {
|
217
202
|
var _parseEverything = _asyncToGenerator(function* (parserName) {
|
218
203
|
if (this.parsers[parserName]) {
|
219
204
|
// no need to parse
|
@@ -263,9 +248,7 @@ function () {
|
|
263
248
|
_proto.write = function write(writerName) {
|
264
249
|
var _this5 = this;
|
265
250
|
|
266
|
-
return Profiler.asyncContext('CodegenRunner.write',
|
267
|
-
/*#__PURE__*/
|
268
|
-
_asyncToGenerator(function* () {
|
251
|
+
return Profiler.asyncContext('CodegenRunner.write', /*#__PURE__*/_asyncToGenerator(function* () {
|
269
252
|
try {
|
270
253
|
_this5._reporter.reportMessage("\nWriting ".concat(writerName));
|
271
254
|
|
@@ -310,20 +293,20 @@ function () {
|
|
310
293
|
sourceControl: _this5._sourceControl,
|
311
294
|
reporter: _this5._reporter
|
312
295
|
});
|
313
|
-
|
314
|
-
var
|
315
|
-
|
296
|
+
|
297
|
+
var _iterator2 = _createForOfIteratorHelper(outputDirectories.values()),
|
298
|
+
_step2;
|
316
299
|
|
317
300
|
try {
|
318
|
-
for (
|
301
|
+
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
319
302
|
var dir = _step2.value;
|
320
303
|
var all = [].concat((0, _toConsumableArray2["default"])(dir.changes.created), (0, _toConsumableArray2["default"])(dir.changes.updated), (0, _toConsumableArray2["default"])(dir.changes.deleted), (0, _toConsumableArray2["default"])(dir.changes.unchanged));
|
321
|
-
|
322
|
-
var
|
323
|
-
|
304
|
+
|
305
|
+
var _iterator3 = _createForOfIteratorHelper(all),
|
306
|
+
_step3;
|
324
307
|
|
325
308
|
try {
|
326
|
-
for (
|
309
|
+
for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
|
327
310
|
var filename = _step3.value;
|
328
311
|
|
329
312
|
var _filePath2 = dir.getPath(filename);
|
@@ -331,33 +314,15 @@ function () {
|
|
331
314
|
!isGeneratedFile(_filePath2) ? process.env.NODE_ENV !== "production" ? invariant(false, 'CodegenRunner: %s returned false for isGeneratedFile, ' + 'but was in generated directory', _filePath2) : invariant(false) : void 0;
|
332
315
|
}
|
333
316
|
} catch (err) {
|
334
|
-
|
335
|
-
_iteratorError3 = err;
|
317
|
+
_iterator3.e(err);
|
336
318
|
} finally {
|
337
|
-
|
338
|
-
if (!_iteratorNormalCompletion3 && _iterator3["return"] != null) {
|
339
|
-
_iterator3["return"]();
|
340
|
-
}
|
341
|
-
} finally {
|
342
|
-
if (_didIteratorError3) {
|
343
|
-
throw _iteratorError3;
|
344
|
-
}
|
345
|
-
}
|
319
|
+
_iterator3.f();
|
346
320
|
}
|
347
321
|
}
|
348
322
|
} catch (err) {
|
349
|
-
|
350
|
-
_iteratorError2 = err;
|
323
|
+
_iterator2.e(err);
|
351
324
|
} finally {
|
352
|
-
|
353
|
-
if (!_iteratorNormalCompletion2 && _iterator2["return"] != null) {
|
354
|
-
_iterator2["return"]();
|
355
|
-
}
|
356
|
-
} finally {
|
357
|
-
if (_didIteratorError2) {
|
358
|
-
throw _iteratorError2;
|
359
|
-
}
|
360
|
-
}
|
325
|
+
_iterator2.f();
|
361
326
|
}
|
362
327
|
|
363
328
|
var onCompleteCallback = _this5.onComplete;
|
@@ -381,9 +346,7 @@ function () {
|
|
381
346
|
}));
|
382
347
|
};
|
383
348
|
|
384
|
-
_proto.watchAll =
|
385
|
-
/*#__PURE__*/
|
386
|
-
function () {
|
349
|
+
_proto.watchAll = /*#__PURE__*/function () {
|
387
350
|
var _watchAll = _asyncToGenerator(function* () {
|
388
351
|
// get everything set up for watching
|
389
352
|
yield this.compileAll();
|
@@ -400,9 +363,7 @@ function () {
|
|
400
363
|
return watchAll;
|
401
364
|
}();
|
402
365
|
|
403
|
-
_proto.watch =
|
404
|
-
/*#__PURE__*/
|
405
|
-
function () {
|
366
|
+
_proto.watch = /*#__PURE__*/function () {
|
406
367
|
var _watch = _asyncToGenerator(function* (parserName) {
|
407
368
|
var _this6 = this;
|
408
369
|
|
@@ -416,9 +377,7 @@ function () {
|
|
416
377
|
|
417
378
|
|
418
379
|
var firstChange = true;
|
419
|
-
yield CodegenWatcher.watchCompile(parserConfig.baseDir, parserConfig.watchmanExpression, parserConfig.getFileFilter ? parserConfig.getFileFilter(parserConfig.baseDir) : anyFileFilter,
|
420
|
-
/*#__PURE__*/
|
421
|
-
function () {
|
380
|
+
yield CodegenWatcher.watchCompile(parserConfig.baseDir, parserConfig.watchmanExpression, parserConfig.getFileFilter ? parserConfig.getFileFilter(parserConfig.baseDir) : anyFileFilter, /*#__PURE__*/function () {
|
422
381
|
var _ref4 = _asyncToGenerator(function* (files) {
|
423
382
|
!(_this6.parsers[parserName] != null) ? process.env.NODE_ENV !== "production" ? invariant(false, 'Trying to watch an uncompiled parser config: %s', parserName) : invariant(false) : void 0;
|
424
383
|
|
@@ -31,14 +31,12 @@ function queryFiles(_x, _x2, _x3) {
|
|
31
31
|
|
32
32
|
function _queryFiles() {
|
33
33
|
_queryFiles = _asyncToGenerator(function* (baseDir, expression, filter) {
|
34
|
-
return yield Profiler.waitFor('Watchman:query',
|
35
|
-
/*#__PURE__*/
|
36
|
-
_asyncToGenerator(function* () {
|
34
|
+
return yield Profiler.waitFor('Watchman:query', /*#__PURE__*/_asyncToGenerator(function* () {
|
37
35
|
var client = new GraphQLWatchmanClient(QUERY_RETRIES);
|
38
36
|
|
39
|
-
var
|
40
|
-
watchResp =
|
41
|
-
fields =
|
37
|
+
var _await$Promise$all = yield Promise.all([client.watchProject(baseDir), getFields(client)]),
|
38
|
+
watchResp = _await$Promise$all[0],
|
39
|
+
fields = _await$Promise$all[1];
|
42
40
|
|
43
41
|
var resp = yield client.command('query', watchResp.root, {
|
44
42
|
expression: expression,
|
@@ -58,9 +56,7 @@ function queryDirectories(_x4, _x5) {
|
|
58
56
|
|
59
57
|
function _queryDirectories() {
|
60
58
|
_queryDirectories = _asyncToGenerator(function* (baseDir, expression) {
|
61
|
-
return yield Profiler.waitFor('Watchman:query',
|
62
|
-
/*#__PURE__*/
|
63
|
-
_asyncToGenerator(function* () {
|
59
|
+
return yield Profiler.waitFor('Watchman:query', /*#__PURE__*/_asyncToGenerator(function* () {
|
64
60
|
var client = new GraphQLWatchmanClient();
|
65
61
|
var watchResp = yield client.watchProject(baseDir);
|
66
62
|
var resp = yield client.command('query', watchResp.root, {
|
@@ -125,9 +121,7 @@ function watch(_x10, _x11, _x12) {
|
|
125
121
|
|
126
122
|
function _watch() {
|
127
123
|
_watch = _asyncToGenerator(function* (baseDir, expression, callback) {
|
128
|
-
return yield Profiler.waitFor('Watchman:subscribe',
|
129
|
-
/*#__PURE__*/
|
130
|
-
_asyncToGenerator(function* () {
|
124
|
+
return yield Profiler.waitFor('Watchman:subscribe', /*#__PURE__*/_asyncToGenerator(function* () {
|
131
125
|
var client = new GraphQLWatchmanClient();
|
132
126
|
var watchResp = yield client.watchProject(baseDir);
|
133
127
|
yield makeSubscription(client, watchResp.root, watchResp.relativePath, expression, callback);
|
@@ -202,10 +196,8 @@ function _watchCompile() {
|
|
202
196
|
var compiling = false;
|
203
197
|
var needsCompiling = false;
|
204
198
|
var latestFiles = null;
|
205
|
-
watchFiles(baseDir, expression, filter,
|
206
|
-
|
207
|
-
function () {
|
208
|
-
var _ref6 = _asyncToGenerator(function* (files) {
|
199
|
+
watchFiles(baseDir, expression, filter, /*#__PURE__*/function () {
|
200
|
+
var _ref5 = _asyncToGenerator(function* (files) {
|
209
201
|
needsCompiling = true;
|
210
202
|
latestFiles = files;
|
211
203
|
|
@@ -224,7 +216,7 @@ function _watchCompile() {
|
|
224
216
|
});
|
225
217
|
|
226
218
|
return function (_x26) {
|
227
|
-
return
|
219
|
+
return _ref5.apply(this, arguments);
|
228
220
|
};
|
229
221
|
}());
|
230
222
|
});
|
@@ -236,10 +228,10 @@ function updateFiles(files, baseDir, filter, fileChanges) {
|
|
236
228
|
files.forEach(function (file) {
|
237
229
|
file.exists && fileMap.set(file.relPath, file);
|
238
230
|
});
|
239
|
-
fileChanges.forEach(function (
|
240
|
-
var name =
|
241
|
-
exists =
|
242
|
-
hash =
|
231
|
+
fileChanges.forEach(function (_ref) {
|
232
|
+
var name = _ref.name,
|
233
|
+
exists = _ref.exists,
|
234
|
+
hash = _ref['content.sha1hex'];
|
243
235
|
var shouldRemove = !exists;
|
244
236
|
|
245
237
|
if (!shouldRemove) {
|
@@ -12,10 +12,14 @@
|
|
12
12
|
|
13
13
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
14
14
|
|
15
|
-
var
|
15
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
16
16
|
|
17
17
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
18
18
|
|
19
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
|
20
|
+
|
21
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
22
|
+
|
19
23
|
var _require = require('../core/CompilerError'),
|
20
24
|
createCompilerError = _require.createCompilerError,
|
21
25
|
createUserError = _require.createUserError;
|
@@ -39,9 +43,9 @@ function generate(schema, node) {
|
|
39
43
|
|
40
44
|
function generateRoot(schema, node) {
|
41
45
|
return {
|
46
|
+
argumentDefinitions: generateArgumentDefinitions(schema, node.argumentDefinitions),
|
42
47
|
kind: 'Operation',
|
43
48
|
name: node.name,
|
44
|
-
argumentDefinitions: generateArgumentDefinitions(schema, node.argumentDefinitions),
|
45
49
|
selections: generateSelections(schema, node.selections)
|
46
50
|
};
|
47
51
|
}
|
@@ -49,8 +53,8 @@ function generateRoot(schema, node) {
|
|
49
53
|
function generateSplitOperation(schema, node) {
|
50
54
|
return {
|
51
55
|
kind: 'SplitOperation',
|
52
|
-
name: node.name,
|
53
56
|
metadata: node.metadata,
|
57
|
+
name: node.name,
|
54
58
|
selections: generateSelections(schema, node.selections)
|
55
59
|
};
|
56
60
|
}
|
@@ -106,10 +110,10 @@ function generateSelections(schema, selections) {
|
|
106
110
|
function generateArgumentDefinitions(schema, nodes) {
|
107
111
|
return nodes.map(function (node) {
|
108
112
|
return {
|
113
|
+
defaultValue: node.defaultValue,
|
109
114
|
kind: 'LocalArgument',
|
110
115
|
name: node.name,
|
111
|
-
type: schema.getTypeString(node.type)
|
112
|
-
defaultValue: node.defaultValue
|
116
|
+
type: schema.getTypeString(node.type)
|
113
117
|
};
|
114
118
|
});
|
115
119
|
}
|
@@ -127,25 +131,24 @@ function generateCondition(schema, node) {
|
|
127
131
|
}
|
128
132
|
|
129
133
|
return {
|
134
|
+
condition: node.condition.variableName,
|
130
135
|
kind: 'Condition',
|
131
136
|
passingValue: node.passingValue,
|
132
|
-
condition: node.condition.variableName,
|
133
137
|
selections: generateSelections(schema, node.selections)
|
134
138
|
};
|
135
139
|
}
|
136
140
|
|
137
141
|
function generateDefer(schema, node) {
|
138
142
|
if (!(node["if"] == null || node["if"].kind === 'Variable' || node["if"].kind === 'Literal' && node["if"].value === true)) {
|
139
|
-
var
|
143
|
+
var _node$if$loc, _node$if;
|
140
144
|
|
141
|
-
throw createCompilerError('NormalizationCodeGenerator: Expected @defer `if` condition to be ' + 'a variable, unspecified, or the literal `true`.', [(
|
145
|
+
throw createCompilerError('NormalizationCodeGenerator: Expected @defer `if` condition to be ' + 'a variable, unspecified, or the literal `true`.', [(_node$if$loc = (_node$if = node["if"]) === null || _node$if === void 0 ? void 0 : _node$if.loc) !== null && _node$if$loc !== void 0 ? _node$if$loc : node.loc]);
|
142
146
|
}
|
143
147
|
|
144
148
|
return {
|
145
149
|
"if": node["if"] != null && node["if"].kind === 'Variable' ? node["if"].variableName : null,
|
146
150
|
kind: 'Defer',
|
147
151
|
label: node.label,
|
148
|
-
metadata: node.metadata,
|
149
152
|
selections: generateSelections(schema, node.selections)
|
150
153
|
};
|
151
154
|
}
|
@@ -153,8 +156,8 @@ function generateDefer(schema, node) {
|
|
153
156
|
function generateInlineFragment(schema, node) {
|
154
157
|
return {
|
155
158
|
kind: 'InlineFragment',
|
156
|
-
|
157
|
-
|
159
|
+
selections: generateSelections(schema, node.selections),
|
160
|
+
type: schema.getTypeString(node.typeCondition)
|
158
161
|
};
|
159
162
|
}
|
160
163
|
|
@@ -164,13 +167,13 @@ function generateLinkedField(schema, node) {
|
|
164
167
|
// which may have originally appeared in different orders across an app.
|
165
168
|
var handles = node.handles && node.handles.map(function (handle) {
|
166
169
|
var handleNode = {
|
167
|
-
kind: 'LinkedHandle',
|
168
170
|
alias: node.alias === node.name ? null : node.alias,
|
169
|
-
name: node.name,
|
170
171
|
args: generateArgs(node.args),
|
172
|
+
filters: handle.filters,
|
171
173
|
handle: handle.name,
|
172
174
|
key: handle.key,
|
173
|
-
|
175
|
+
kind: 'LinkedHandle',
|
176
|
+
name: node.name
|
174
177
|
}; // T45504512: new connection model
|
175
178
|
// NOTE: this intentionally adds a dynamic key in order to avoid
|
176
179
|
// triggering updates to existing queries that do not use dynamic
|
@@ -178,7 +181,7 @@ function generateLinkedField(schema, node) {
|
|
178
181
|
|
179
182
|
if (handle.dynamicKey != null) {
|
180
183
|
var dynamicKeyArgName = '__dynamicKey';
|
181
|
-
handleNode = (
|
184
|
+
handleNode = _objectSpread({}, handleNode, {
|
182
185
|
dynamicKey: {
|
183
186
|
kind: 'Variable',
|
184
187
|
name: dynamicKeyArgName,
|
@@ -191,20 +194,20 @@ function generateLinkedField(schema, node) {
|
|
191
194
|
}) || [];
|
192
195
|
var type = schema.getRawType(node.type);
|
193
196
|
var field = {
|
194
|
-
kind: 'LinkedField',
|
195
197
|
alias: node.alias === node.name ? null : node.alias,
|
196
|
-
name: node.name,
|
197
|
-
storageKey: null,
|
198
198
|
args: generateArgs(node.args),
|
199
199
|
concreteType: !schema.isAbstractType(type) ? schema.getTypeString(type) : null,
|
200
|
+
kind: 'LinkedField',
|
201
|
+
name: node.name,
|
200
202
|
plural: isPlural(schema, node.type),
|
201
|
-
selections: generateSelections(schema, node.selections)
|
203
|
+
selections: generateSelections(schema, node.selections),
|
204
|
+
storageKey: null
|
202
205
|
}; // Precompute storageKey if possible
|
203
206
|
|
204
207
|
var storageKey = getStaticStorageKey(field, node.metadata);
|
205
208
|
|
206
209
|
if (storageKey != null) {
|
207
|
-
field = (
|
210
|
+
field = _objectSpread({}, field, {
|
208
211
|
storageKey: storageKey
|
209
212
|
});
|
210
213
|
}
|
@@ -212,7 +215,7 @@ function generateLinkedField(schema, node) {
|
|
212
215
|
return [field].concat(handles);
|
213
216
|
}
|
214
217
|
|
215
|
-
function generateModuleImport(node
|
218
|
+
function generateModuleImport(node) {
|
216
219
|
var fragmentName = node.name;
|
217
220
|
var regExpMatch = fragmentName.match(/^([a-zA-Z][a-zA-Z0-9]*)(?:_([a-zA-Z][_a-zA-Z0-9]*))?$/);
|
218
221
|
|
@@ -227,10 +230,10 @@ function generateModuleImport(node, key) {
|
|
227
230
|
}
|
228
231
|
|
229
232
|
return {
|
230
|
-
|
231
|
-
documentName: node.documentName,
|
233
|
+
documentName: node.key,
|
232
234
|
fragmentName: fragmentName,
|
233
|
-
fragmentPropName: fragmentPropName
|
235
|
+
fragmentPropName: fragmentPropName,
|
236
|
+
kind: 'ModuleImport'
|
234
237
|
};
|
235
238
|
}
|
236
239
|
|
@@ -251,27 +254,27 @@ function generateScalarField(node) {
|
|
251
254
|
}
|
252
255
|
|
253
256
|
return {
|
254
|
-
kind: 'ScalarHandle',
|
255
257
|
alias: node.alias === node.name ? null : node.alias,
|
256
|
-
name: node.name,
|
257
258
|
args: generateArgs(node.args),
|
259
|
+
filters: handle.filters,
|
258
260
|
handle: handle.name,
|
259
261
|
key: handle.key,
|
260
|
-
|
262
|
+
kind: 'ScalarHandle',
|
263
|
+
name: node.name
|
261
264
|
};
|
262
265
|
}) || [];
|
263
266
|
var field = {
|
264
|
-
kind: 'ScalarField',
|
265
267
|
alias: node.alias === node.name ? null : node.alias,
|
266
|
-
name: node.name,
|
267
268
|
args: generateArgs(node.args),
|
269
|
+
kind: 'ScalarField',
|
270
|
+
name: node.name,
|
268
271
|
storageKey: null
|
269
272
|
}; // Precompute storageKey if possible
|
270
273
|
|
271
274
|
var storageKey = getStaticStorageKey(field, node.metadata);
|
272
275
|
|
273
276
|
if (storageKey != null) {
|
274
|
-
field = (
|
277
|
+
field = _objectSpread({}, field, {
|
275
278
|
storageKey: storageKey
|
276
279
|
});
|
277
280
|
}
|
@@ -281,18 +284,18 @@ function generateScalarField(node) {
|
|
281
284
|
|
282
285
|
function generateStream(schema, node) {
|
283
286
|
if (!(node["if"] == null || node["if"].kind === 'Variable' || node["if"].kind === 'Literal' && node["if"].value === true)) {
|
284
|
-
var
|
287
|
+
var _node$if$loc2, _node$if2;
|
285
288
|
|
286
|
-
throw createCompilerError('NormalizationCodeGenerator: Expected @stream `if` condition to be ' + 'a variable, unspecified, or the literal `true`.', [(
|
289
|
+
throw createCompilerError('NormalizationCodeGenerator: Expected @stream `if` condition to be ' + 'a variable, unspecified, or the literal `true`.', [(_node$if$loc2 = (_node$if2 = node["if"]) === null || _node$if2 === void 0 ? void 0 : _node$if2.loc) !== null && _node$if$loc2 !== void 0 ? _node$if$loc2 : node.loc]);
|
287
290
|
}
|
288
291
|
|
289
292
|
return {
|
290
293
|
"if": node["if"] != null && node["if"].kind === 'Variable' ? node["if"].variableName : null,
|
291
294
|
kind: 'Stream',
|
292
|
-
useCustomizedBatch: node.useCustomizedBatch != null && node.useCustomizedBatch.kind === 'Variable' ? node.useCustomizedBatch.variableName : null,
|
293
295
|
label: node.label,
|
294
296
|
metadata: node.metadata,
|
295
|
-
selections: generateSelections(schema, node.selections)
|
297
|
+
selections: generateSelections(schema, node.selections),
|
298
|
+
useCustomizedBatch: node.useCustomizedBatch != null && node.useCustomizedBatch.kind === 'Variable' ? node.useCustomizedBatch.variableName : null
|
296
299
|
};
|
297
300
|
}
|
298
301
|
|
@@ -321,8 +324,6 @@ function generateArgumentValue(name, value) {
|
|
321
324
|
return [field.name, field.value];
|
322
325
|
}));
|
323
326
|
return {
|
324
|
-
kind: 'ObjectValue',
|
325
|
-
name: name,
|
326
327
|
fields: objectKeys.map(function (fieldName) {
|
327
328
|
var _generateArgumentValu;
|
328
329
|
|
@@ -337,18 +338,20 @@ function generateArgumentValue(name, value) {
|
|
337
338
|
name: fieldName,
|
338
339
|
value: null
|
339
340
|
};
|
340
|
-
})
|
341
|
+
}),
|
342
|
+
kind: 'ObjectValue',
|
343
|
+
name: name
|
341
344
|
};
|
342
345
|
}
|
343
346
|
|
344
347
|
case 'ListValue':
|
345
348
|
{
|
346
349
|
return {
|
347
|
-
kind: 'ListValue',
|
348
|
-
name: name,
|
349
350
|
items: value.items.map(function (item, index) {
|
350
351
|
return generateArgumentValue("".concat(name, ".").concat(index), item);
|
351
|
-
})
|
352
|
+
}),
|
353
|
+
kind: 'ListValue',
|
354
|
+
name: name
|
352
355
|
};
|
353
356
|
}
|
354
357
|
|