relay-compiler 11.0.0-rc.0 → 12.0.0
Sign up to get free protection for your applications and to get access to all the features.
- package/bin/relay-compiler +136 -52
- package/codegen/CodegenDirectory.js.flow +1 -1
- package/codegen/NormalizationCodeGenerator.js.flow +1 -6
- package/codegen/createPrintRequireModuleDependency.js.flow +2 -4
- package/codegen/writeRelayGeneratedFile.js.flow +17 -1
- package/core/IRPrinter.js.flow +1 -0
- package/core/RelayParser.js.flow +3 -0
- package/index.js +1 -1
- package/language/javascript/RelayFlowGenerator.js.flow +1 -0
- package/language/javascript/RelayFlowTypeTransformers.js.flow +3 -3
- package/lib/bin/RelayCompilerMain.js +1 -1
- package/lib/codegen/CodegenDirectory.js +1 -1
- package/lib/codegen/CodegenRunner.js +1 -1
- package/lib/codegen/NormalizationCodeGenerator.js +2 -3
- package/lib/codegen/RelayFileWriter.js +1 -1
- package/lib/codegen/createPrintRequireModuleDependency.js +2 -2
- package/lib/codegen/writeRelayGeneratedFile.js +23 -7
- package/lib/core/CompilerContext.js +1 -1
- package/lib/core/GraphQLCompilerProfiler.js +1 -1
- package/lib/core/IRPrinter.js +3 -2
- package/lib/core/IRTransformer.js +1 -1
- package/lib/core/IRValidator.js +1 -1
- package/lib/core/RelayParser.js +5 -2
- package/lib/core/RelaySourceModuleParser.js +1 -1
- package/lib/core/getIdentifierForArgumentValue.js +1 -1
- package/lib/core/getIdentifierForSelection.js +1 -1
- package/lib/language/javascript/RelayFlowBabelFactories.js +1 -1
- package/lib/language/javascript/RelayFlowGenerator.js +3 -2
- package/lib/runner/BufferedFilesystem.js +1 -1
- package/lib/runner/Sources.js +1 -1
- package/lib/runner/StrictMap.js +1 -1
- package/lib/runner/extractAST.js +1 -1
- package/lib/transforms/ClientExtensionsTransform.js +1 -0
- package/lib/transforms/ConnectionTransform.js +6 -2
- package/lib/transforms/DeclarativeConnectionMutationTransform.js +5 -2
- package/lib/transforms/DeferStreamTransform.js +2 -1
- package/lib/transforms/DisallowIdAsAlias.js +2 -1
- package/lib/transforms/FieldHandleTransform.js +4 -2
- package/lib/transforms/FlattenTransform.js +10 -5
- package/lib/transforms/GenerateIDFieldTransform.js +3 -1
- package/lib/transforms/GenerateTypeNameTransform.js +9 -3
- package/lib/transforms/InlineDataFragmentTransform.js +6 -2
- package/lib/transforms/InlineFragmentsTransform.js +5 -3
- package/lib/transforms/MaskTransform.js +8 -4
- package/lib/transforms/MatchTransform.js +5 -1
- package/lib/transforms/ReactFlightComponentTransform.js +3 -0
- package/lib/transforms/RelayDirectiveTransform.js +4 -2
- package/lib/transforms/RequiredFieldTransform.js +6 -2
- package/lib/transforms/SkipClientExtensionsTransform.js +3 -0
- package/lib/transforms/SkipHandleFieldTransform.js +1 -0
- package/lib/transforms/SkipRedundantNodesTransform.js +5 -3
- package/lib/transforms/SkipUnreachableNodeTransform.js +1 -1
- package/lib/transforms/SplitModuleImportTransform.js +4 -1
- package/lib/transforms/TestOperationTransform.js +1 -0
- package/lib/transforms/ValidateRequiredArgumentsTransform.js +5 -1
- package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +4 -1
- package/lib/util/{areEqualOSS.js → areEqualArgValues.js} +6 -4
- package/package.json +8 -7
- package/relay-compiler.js +3 -3
- package/relay-compiler.min.js +3 -3
- package/runner/BufferedFilesystem.js.flow +1 -1
- package/transforms/ClientExtensionsTransform.js.flow +1 -0
- package/transforms/ConnectionTransform.js.flow +4 -0
- package/transforms/DeclarativeConnectionMutationTransform.js.flow +3 -0
- package/transforms/DeferStreamTransform.js.flow +1 -0
- package/transforms/DisallowIdAsAlias.js.flow +1 -0
- package/transforms/FieldHandleTransform.js.flow +2 -0
- package/transforms/FlattenTransform.js.flow +10 -2
- package/transforms/GenerateIDFieldTransform.js.flow +2 -0
- package/transforms/GenerateTypeNameTransform.js.flow +6 -0
- package/transforms/InlineDataFragmentTransform.js.flow +4 -0
- package/transforms/InlineFragmentsTransform.js.flow +2 -0
- package/transforms/MaskTransform.js.flow +4 -0
- package/transforms/MatchTransform.js.flow +4 -0
- package/transforms/ReactFlightComponentTransform.js.flow +3 -0
- package/transforms/RelayDirectiveTransform.js.flow +2 -0
- package/transforms/RequiredFieldTransform.js.flow +4 -0
- package/transforms/SkipClientExtensionsTransform.js.flow +3 -0
- package/transforms/SkipHandleFieldTransform.js.flow +1 -0
- package/transforms/SkipRedundantNodesTransform.js.flow +2 -0
- package/transforms/SplitModuleImportTransform.js.flow +3 -0
- package/transforms/TestOperationTransform.js.flow +1 -0
- package/transforms/ValidateRequiredArgumentsTransform.js.flow +4 -0
- package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +3 -0
- package/util/{areEqualOSS.js.flow → areEqualArgValues.js.flow} +6 -3
@@ -18,7 +18,7 @@ var IRTransformer = require('../core/IRTransformer');
|
|
18
18
|
|
19
19
|
var SchemaUtils = require('../core/SchemaUtils');
|
20
20
|
|
21
|
-
var invariant = require(
|
21
|
+
var invariant = require('invariant');
|
22
22
|
|
23
23
|
var nullthrows = require('nullthrows');
|
24
24
|
|
@@ -37,6 +37,7 @@ function fieldHandleTransform(context) {
|
|
37
37
|
|
38
38
|
|
39
39
|
function visitField(field) {
|
40
|
+
// $FlowFixMe[incompatible-use]
|
40
41
|
var nextField = field.kind === 'LinkedField' ? this.traverse(field) : field;
|
41
42
|
var handles = nextField.handles;
|
42
43
|
|
@@ -45,7 +46,8 @@ function visitField(field) {
|
|
45
46
|
} // ensure exactly one handle
|
46
47
|
|
47
48
|
|
48
|
-
!(handles.length === 1) ? process.env.NODE_ENV !== "production" ? invariant(false, 'FieldHandleTransform: Expected fields to have at most one ' + '"handle" property, got `%s`.', handles.join(', ')) : invariant(false) : void 0;
|
49
|
+
!(handles.length === 1) ? process.env.NODE_ENV !== "production" ? invariant(false, 'FieldHandleTransform: Expected fields to have at most one ' + '"handle" property, got `%s`.', handles.join(', ')) : invariant(false) : void 0; // $FlowFixMe[incompatible-use]
|
50
|
+
|
49
51
|
var context = this.getContext();
|
50
52
|
var schema = context.getSchema();
|
51
53
|
var alias = nextField.alias;
|
@@ -16,7 +16,7 @@ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/obje
|
|
16
16
|
|
17
17
|
var IRTransformer = require('../core/IRTransformer');
|
18
18
|
|
19
|
-
var
|
19
|
+
var areEqualArgValues = require('../util/areEqualArgValues');
|
20
20
|
|
21
21
|
var getIdentifierForSelection = require('../core/getIdentifierForSelection');
|
22
22
|
|
@@ -54,6 +54,7 @@ function flattenTransformImpl(context, options) {
|
|
54
54
|
|
55
55
|
function memoizedFlattenSelection(cache) {
|
56
56
|
return function flattenSelectionsFn(node, state) {
|
57
|
+
// $FlowFixMe[incompatible-use]
|
57
58
|
var context = this.getContext();
|
58
59
|
var nodeCache = cache.get(node);
|
59
60
|
|
@@ -84,7 +85,8 @@ function memoizedFlattenSelection(cache) {
|
|
84
85
|
var flattenedNode = hasFlattened ? (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, node), {}, {
|
85
86
|
selections: Array.from(nextSelections.values())
|
86
87
|
}) : node;
|
87
|
-
state.parentType = type;
|
88
|
+
state.parentType = type; // $FlowFixMe[incompatible-use]
|
89
|
+
|
88
90
|
var deeplyFlattenedNode = this.traverse(flattenedNode, state);
|
89
91
|
state.parentType = parentType;
|
90
92
|
nodeCache.set(parentType, deeplyFlattenedNode);
|
@@ -268,7 +270,7 @@ function areEqualFields(thisField, thatField) {
|
|
268
270
|
function areEqualArgs(thisArgs, thatArgs) {
|
269
271
|
return thisArgs.length === thatArgs.length && thisArgs.every(function (thisArg, index) {
|
270
272
|
var thatArg = thatArgs[index];
|
271
|
-
return thisArg.name === thatArg.name && thisArg.value.kind === thatArg.value.kind && thisArg.value.variableName === thatArg.value.variableName &&
|
273
|
+
return thisArg.name === thatArg.name && thisArg.value.kind === thatArg.value.kind && thisArg.value.variableName === thatArg.value.variableName && areEqualArgValues(thisArg.value.value, thatArg.value.value);
|
272
274
|
});
|
273
275
|
}
|
274
276
|
/**
|
@@ -286,9 +288,12 @@ function mergeHandles(nodeA, nodeB) {
|
|
286
288
|
}
|
287
289
|
|
288
290
|
var uniqueItems = new Map();
|
289
|
-
nodeA.handles
|
291
|
+
nodeA.handles // $FlowFixMe[incompatible-use]
|
292
|
+
.concat(nodeB.handles) // $FlowFixMe[incompatible-use]
|
293
|
+
.forEach(function (item) {
|
290
294
|
return uniqueItems.set(item.name + item.key, item);
|
291
|
-
});
|
295
|
+
}); // $FlowFixMe[incompatible-return]
|
296
|
+
|
292
297
|
return Array.from(uniqueItems.values());
|
293
298
|
}
|
294
299
|
|
@@ -80,11 +80,13 @@ function generateIDFieldTransform(context) {
|
|
80
80
|
}
|
81
81
|
|
82
82
|
function visitLinkedField(field, state) {
|
83
|
+
// $FlowFixMe[incompatible-use]
|
83
84
|
var transformedNode = this.traverse(field, state); // If the field already has an unaliased `id` field, do nothing
|
84
85
|
|
85
86
|
if (hasUnaliasedSelection(field, ID)) {
|
86
87
|
return transformedNode;
|
87
|
-
}
|
88
|
+
} // $FlowFixMe[incompatible-use]
|
89
|
+
|
88
90
|
|
89
91
|
var context = this.getContext();
|
90
92
|
var schema = context.getSchema();
|
@@ -58,8 +58,10 @@ function generateTypeNameTransform(context) {
|
|
58
58
|
}
|
59
59
|
|
60
60
|
function visitFragment(fragment, state) {
|
61
|
+
// $FlowFixMe[incompatible-use]
|
61
62
|
var schema = this.getContext().getSchema();
|
62
|
-
var rawType = schema.getRawType(fragment.type);
|
63
|
+
var rawType = schema.getRawType(fragment.type); // $FlowFixMe[incompatible-use]
|
64
|
+
|
63
65
|
var transformedNode = this.traverse(fragment, state);
|
64
66
|
var isClientType = !schema.isServerType(rawType);
|
65
67
|
|
@@ -88,6 +90,7 @@ function visitFragment(fragment, state) {
|
|
88
90
|
}
|
89
91
|
|
90
92
|
function visitInlineFragment(fragment, state) {
|
93
|
+
// $FlowFixMe[incompatible-use]
|
91
94
|
var schema = this.getContext().getSchema();
|
92
95
|
var transformedNode = cache.get(fragment);
|
93
96
|
|
@@ -95,7 +98,8 @@ function visitInlineFragment(fragment, state) {
|
|
95
98
|
return transformedNode;
|
96
99
|
}
|
97
100
|
|
98
|
-
var rawType = schema.getRawType(fragment.typeCondition);
|
101
|
+
var rawType = schema.getRawType(fragment.typeCondition); // $FlowFixMe[incompatible-use]
|
102
|
+
|
99
103
|
transformedNode = this.traverse(fragment, state);
|
100
104
|
var isClientType = !schema.isServerType(rawType);
|
101
105
|
|
@@ -125,12 +129,14 @@ function visitInlineFragment(fragment, state) {
|
|
125
129
|
}
|
126
130
|
|
127
131
|
function visitLinkedField(field, state) {
|
132
|
+
// $FlowFixMe[incompatible-use]
|
128
133
|
var schema = this.getContext().getSchema();
|
129
134
|
var transformedNode = cache.get(field);
|
130
135
|
|
131
136
|
if (transformedNode != null && transformedNode.kind === 'LinkedField') {
|
132
137
|
return transformedNode;
|
133
|
-
}
|
138
|
+
} // $FlowFixMe[incompatible-use]
|
139
|
+
|
134
140
|
|
135
141
|
transformedNode = this.traverse(field, state);
|
136
142
|
|
@@ -36,6 +36,7 @@ function inlineDataFragmentTransform(context) {
|
|
36
36
|
}
|
37
37
|
|
38
38
|
function visitFragment(fragment) {
|
39
|
+
// $FlowFixMe[incompatible-use]
|
39
40
|
var transformedFragment = this.traverse(fragment);
|
40
41
|
var inlineDirective = transformedFragment.directives.find(function (directive) {
|
41
42
|
return directive.name === 'inline';
|
@@ -56,7 +57,9 @@ function visitFragment(fragment) {
|
|
56
57
|
}
|
57
58
|
|
58
59
|
function visitFragmentSpread(fragmentSpread) {
|
59
|
-
|
60
|
+
// $FlowFixMe[incompatible-use]
|
61
|
+
var transformedFragmentSpread = this.traverse(fragmentSpread); // $FlowFixMe[incompatible-use]
|
62
|
+
|
60
63
|
var context = this.getContext();
|
61
64
|
var fragment = context.get(transformedFragmentSpread.name);
|
62
65
|
|
@@ -72,7 +75,8 @@ function visitFragmentSpread(fragmentSpread) {
|
|
72
75
|
|
73
76
|
if (transformedFragmentSpread.directives.length > 0) {
|
74
77
|
throw createUserError('Directives on fragment spreads for @inline fragments are not yet ' + 'supported', [transformedFragmentSpread.loc]);
|
75
|
-
}
|
78
|
+
} // $FlowFixMe[incompatible-use]
|
79
|
+
|
76
80
|
|
77
81
|
var transformedFragment = this.visit(fragment);
|
78
82
|
return {
|
@@ -12,7 +12,7 @@
|
|
12
12
|
|
13
13
|
var IRTransformer = require('../core/IRTransformer');
|
14
14
|
|
15
|
-
var invariant = require(
|
15
|
+
var invariant = require('invariant');
|
16
16
|
|
17
17
|
/**
|
18
18
|
* A transform that inlines all fragments and removes them.
|
@@ -37,7 +37,8 @@ function fragmentSpreadVisitor(cache) {
|
|
37
37
|
return traverseResult;
|
38
38
|
}
|
39
39
|
|
40
|
-
!(fragmentSpread.args.length === 0) ? process.env.NODE_ENV !== "production" ? invariant(false, 'InlineFragmentsTransform: Cannot flatten fragment spread `%s` with ' + 'arguments. Use the `ApplyFragmentArgumentTransform` before flattening', fragmentSpread.name) : invariant(false) : void 0;
|
40
|
+
!(fragmentSpread.args.length === 0) ? process.env.NODE_ENV !== "production" ? invariant(false, 'InlineFragmentsTransform: Cannot flatten fragment spread `%s` with ' + 'arguments. Use the `ApplyFragmentArgumentTransform` before flattening', fragmentSpread.name) : invariant(false) : void 0; // $FlowFixMe[incompatible-use]
|
41
|
+
|
41
42
|
var fragment = this.getContext().getFragment(fragmentSpread.name, fragmentSpread.loc);
|
42
43
|
var result = {
|
43
44
|
kind: 'InlineFragment',
|
@@ -49,7 +50,8 @@ function fragmentSpreadVisitor(cache) {
|
|
49
50
|
metadata: fragmentSpread.metadata,
|
50
51
|
selections: fragment.selections,
|
51
52
|
typeCondition: fragment.type
|
52
|
-
};
|
53
|
+
}; // $FlowFixMe[incompatible-use]
|
54
|
+
|
53
55
|
traverseResult = this.traverse(result);
|
54
56
|
cache.set(fragmentSpread, traverseResult);
|
55
57
|
return traverseResult;
|
@@ -18,7 +18,7 @@ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/obje
|
|
18
18
|
|
19
19
|
var IRTransformer = require('../core/IRTransformer');
|
20
20
|
|
21
|
-
var invariant = require(
|
21
|
+
var invariant = require('invariant');
|
22
22
|
|
23
23
|
var joinArgumentDefinitions = require('../util/joinArgumentDefinitions');
|
24
24
|
|
@@ -41,13 +41,15 @@ function maskTransform(context) {
|
|
41
41
|
}
|
42
42
|
|
43
43
|
function visitFragment(fragment, state) {
|
44
|
+
// $FlowFixMe[incompatible-use]
|
44
45
|
var result = this.traverse(fragment, state);
|
45
46
|
|
46
47
|
if (state.reachableArguments.length === 0) {
|
47
48
|
return result;
|
48
49
|
}
|
49
50
|
|
50
|
-
var joinedArgumentDefinitions = joinArgumentDefinitions(
|
51
|
+
var joinedArgumentDefinitions = joinArgumentDefinitions( // $FlowFixMe[incompatible-use]
|
52
|
+
this.getContext().getSchema(), fragment, state.reachableArguments, '@relay(unmask: true)');
|
51
53
|
return (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, result), {}, {
|
52
54
|
argumentDefinitions: joinedArgumentDefinitions
|
53
55
|
});
|
@@ -58,7 +60,8 @@ function visitFragmentSpread(fragmentSpread, state) {
|
|
58
60
|
return fragmentSpread;
|
59
61
|
}
|
60
62
|
|
61
|
-
!(fragmentSpread.args.length === 0) ? process.env.NODE_ENV !== "production" ? invariant(false, 'MaskTransform: Cannot unmask fragment spread `%s` with ' + 'arguments. Use the `ApplyFragmentArgumentTransform` before flattening', fragmentSpread.name) : invariant(false) : void 0;
|
63
|
+
!(fragmentSpread.args.length === 0) ? process.env.NODE_ENV !== "production" ? invariant(false, 'MaskTransform: Cannot unmask fragment spread `%s` with ' + 'arguments. Use the `ApplyFragmentArgumentTransform` before flattening', fragmentSpread.name) : invariant(false) : void 0; // $FlowFixMe[incompatible-use]
|
64
|
+
|
62
65
|
var context = this.getContext();
|
63
66
|
var fragment = context.getFragment(fragmentSpread.name);
|
64
67
|
var result = {
|
@@ -94,7 +97,8 @@ function visitFragmentSpread(fragmentSpread, state) {
|
|
94
97
|
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
95
98
|
var argDef = _step.value;
|
96
99
|
state.reachableArguments.push(argDef);
|
97
|
-
}
|
100
|
+
} // $FlowFixMe[incompatible-use]
|
101
|
+
|
98
102
|
} catch (err) {
|
99
103
|
_iterator.e(err);
|
100
104
|
} finally {
|
@@ -60,12 +60,14 @@ function matchTransform(context) {
|
|
60
60
|
}
|
61
61
|
|
62
62
|
function visitInlineFragment(node, state) {
|
63
|
+
// $FlowFixMe[incompatible-use]
|
63
64
|
return this.traverse(node, (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, state), {}, {
|
64
65
|
parentType: node.typeCondition
|
65
66
|
}));
|
66
67
|
}
|
67
68
|
|
68
69
|
function visitScalarField(field) {
|
70
|
+
// $FlowFixMe[incompatible-use]
|
69
71
|
var context = this.getContext();
|
70
72
|
var schema = context.getSchema();
|
71
73
|
|
@@ -85,6 +87,7 @@ function visitScalarField(field) {
|
|
85
87
|
}
|
86
88
|
|
87
89
|
function visitLinkedField(node, state) {
|
90
|
+
// $FlowFixMe[incompatible-use]
|
88
91
|
var context = this.getContext();
|
89
92
|
var schema = context.getSchema();
|
90
93
|
var matchDirective = node.directives.find(function (directive) {
|
@@ -106,7 +109,8 @@ function visitLinkedField(node, state) {
|
|
106
109
|
}
|
107
110
|
}
|
108
111
|
|
109
|
-
state.path.push(node);
|
112
|
+
state.path.push(node); // $FlowFixMe[incompatible-use]
|
113
|
+
|
110
114
|
var transformedNode = this.traverse(node, (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, state), {}, {
|
111
115
|
moduleKey: moduleKey,
|
112
116
|
parentType: node.type
|
@@ -62,6 +62,7 @@ function reactFlightComponentTransform(context) {
|
|
62
62
|
function visitInlineFragment(fragment, state) {
|
63
63
|
var _fragment$typeConditi;
|
64
64
|
|
65
|
+
// $FlowFixMe[incompatible-use]
|
65
66
|
return this.traverse(fragment, {
|
66
67
|
parentType: (_fragment$typeConditi = fragment.typeCondition) !== null && _fragment$typeConditi !== void 0 ? _fragment$typeConditi : state.parentType,
|
67
68
|
types: state.types
|
@@ -69,6 +70,7 @@ function visitInlineFragment(fragment, state) {
|
|
69
70
|
}
|
70
71
|
|
71
72
|
function visitLinkedField(field, state) {
|
73
|
+
// $FlowFixMe[incompatible-use]
|
72
74
|
return this.traverse(field, {
|
73
75
|
parentType: field.type,
|
74
76
|
types: state.types
|
@@ -77,6 +79,7 @@ function visitLinkedField(field, state) {
|
|
77
79
|
|
78
80
|
function visitScalarField(field, state) {
|
79
81
|
// use the return type to quickly determine if this is a flight field
|
82
|
+
// $FlowFixMe[incompatible-use]
|
80
83
|
var schema = this.getContext().getSchema();
|
81
84
|
|
82
85
|
if (schema.getRawType(field.type) !== state.types.componentType) {
|
@@ -18,7 +18,7 @@ var IRTransformer = require('../core/IRTransformer');
|
|
18
18
|
|
19
19
|
var getLiteralArgumentValues = require('../core/getLiteralArgumentValues');
|
20
20
|
|
21
|
-
var invariant = require(
|
21
|
+
var invariant = require('invariant');
|
22
22
|
|
23
23
|
var RELAY = 'relay';
|
24
24
|
var SCHEMA_EXTENSION = "\ndirective @relay(\n # Marks a fragment as being backed by a GraphQLList.\n plural: Boolean,\n\n # Marks a fragment spread which should be unmasked if provided false\n mask: Boolean = true,\n) on FRAGMENT_DEFINITION | FRAGMENT_SPREAD\n";
|
@@ -42,11 +42,13 @@ function visitRelayMetadata(metadataFn) {
|
|
42
42
|
});
|
43
43
|
|
44
44
|
if (!relayDirective) {
|
45
|
+
// $FlowFixMe[incompatible-use]
|
45
46
|
return this.traverse(node);
|
46
47
|
}
|
47
48
|
|
48
49
|
var argValues = getLiteralArgumentValues(relayDirective.args);
|
49
|
-
var metadata = metadataFn(argValues);
|
50
|
+
var metadata = metadataFn(argValues); // $FlowFixMe[incompatible-use]
|
51
|
+
|
50
52
|
return this.traverse((0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, node), {}, {
|
51
53
|
directives: node.directives.filter(function (directive) {
|
52
54
|
return directive !== relayDirective;
|
@@ -58,10 +58,12 @@ function requiredFieldTransform(context) {
|
|
58
58
|
}
|
59
59
|
|
60
60
|
function visitFragment(fragment, state) {
|
61
|
+
// $FlowFixMe[incompatible-use]
|
61
62
|
return addChildrenCanBubbleMetadata(this.traverse(fragment, state), state);
|
62
63
|
}
|
63
64
|
|
64
65
|
function visitRoot(root, state) {
|
66
|
+
// $FlowFixMe[incompatible-use]
|
65
67
|
return addChildrenCanBubbleMetadata(this.traverse(root, state), state);
|
66
68
|
}
|
67
69
|
|
@@ -71,7 +73,8 @@ function visitInlineFragment(fragment, state) {
|
|
71
73
|
// Ideally we could allow @required when the direct parent inline fragment was
|
72
74
|
// on a concrete type, but we would need to solve this bug in our Flow type
|
73
75
|
// generation first: T65695438
|
74
|
-
var parentAbstractInlineFragment = (_state$parentAbstract = state.parentAbstractInlineFragment) !== null && _state$parentAbstract !== void 0 ? _state$parentAbstract : getAbstractInlineFragment(fragment, state.schema);
|
76
|
+
var parentAbstractInlineFragment = (_state$parentAbstract = state.parentAbstractInlineFragment) !== null && _state$parentAbstract !== void 0 ? _state$parentAbstract : getAbstractInlineFragment(fragment, state.schema); // $FlowFixMe[incompatible-use]
|
77
|
+
|
75
78
|
return this.traverse(fragment, (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, state), {}, {
|
76
79
|
parentAbstractInlineFragment: parentAbstractInlineFragment
|
77
80
|
}));
|
@@ -111,7 +114,8 @@ function visitLinkedField(field, state) {
|
|
111
114
|
currentNodeRequiredChildren: new Map(),
|
112
115
|
path: path,
|
113
116
|
parentAbstractInlineFragment: null
|
114
|
-
});
|
117
|
+
}); // $FlowFixMe[incompatible-use]
|
118
|
+
|
115
119
|
var newField = this.traverse(field, newState);
|
116
120
|
var pathName = path.join('.');
|
117
121
|
assertCompatibleRequiredChildren(field, pathName, newState);
|
@@ -21,9 +21,11 @@ function skipClientExtensionTransform(context) {
|
|
21
21
|
}
|
22
22
|
|
23
23
|
function visitFragment(node) {
|
24
|
+
// $FlowFixMe[incompatible-use]
|
24
25
|
var context = this.getContext();
|
25
26
|
|
26
27
|
if (context.getSchema().isServerType(node.type)) {
|
28
|
+
// $FlowFixMe[incompatible-use]
|
27
29
|
return this.traverse(node);
|
28
30
|
}
|
29
31
|
|
@@ -31,6 +33,7 @@ function visitFragment(node) {
|
|
31
33
|
}
|
32
34
|
|
33
35
|
function vistFragmentSpread(node) {
|
36
|
+
// $FlowFixMe[incompatible-use]
|
34
37
|
var context = this.getContext();
|
35
38
|
var fragment = context.getFragment(node.name, node.loc);
|
36
39
|
var isServer = context.getSchema().isServerType(fragment.type);
|
@@ -24,7 +24,7 @@ var partitionArray = require('../util/partitionArray');
|
|
24
24
|
|
25
25
|
var getIdentifierForSelection = require('../core/getIdentifierForSelection');
|
26
26
|
|
27
|
-
var invariant = require(
|
27
|
+
var invariant = require('invariant');
|
28
28
|
|
29
29
|
/**
|
30
30
|
* A transform that removes redundant fields and fragment spreads. Redundancy is
|
@@ -128,7 +128,8 @@ function skipRedundantNodesTransform(context) {
|
|
128
128
|
var cache = new Map();
|
129
129
|
|
130
130
|
function visitNode(node) {
|
131
|
-
cache = new Map();
|
131
|
+
cache = new Map(); // $FlowFixMe[incompatible-use]
|
132
|
+
|
132
133
|
var context = this.getContext();
|
133
134
|
return transformNode(context.getSchema(), node, new IMap()).node;
|
134
135
|
}
|
@@ -227,7 +228,8 @@ function transformNode(schema, node, selectionMap) {
|
|
227
228
|
if (isEmptySelectionMap) {
|
228
229
|
// $FlowFixMe[escaped-generic]
|
229
230
|
cache.set(node, result);
|
230
|
-
}
|
231
|
+
} // $FlowFixMe[incompatible-return]
|
232
|
+
|
231
233
|
|
232
234
|
return result;
|
233
235
|
}
|
@@ -18,7 +18,7 @@ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers
|
|
18
18
|
|
19
19
|
var IRTransformer = require('../core/IRTransformer');
|
20
20
|
|
21
|
-
var invariant = require(
|
21
|
+
var invariant = require('invariant');
|
22
22
|
|
23
23
|
var FAIL = 'fail';
|
24
24
|
var PASS = 'pass';
|
@@ -33,6 +33,7 @@ function splitMatchTransform(context) {
|
|
33
33
|
}
|
34
34
|
|
35
35
|
function visitLinkedField(field, state) {
|
36
|
+
// $FlowFixMe[incompatible-use]
|
36
37
|
return this.traverse(field, {
|
37
38
|
parentType: field.type,
|
38
39
|
splitOperations: state.splitOperations
|
@@ -40,6 +41,7 @@ function visitLinkedField(field, state) {
|
|
40
41
|
}
|
41
42
|
|
42
43
|
function visitInlineFragment(fragment, state) {
|
44
|
+
// $FlowFixMe[incompatible-use]
|
43
45
|
return this.traverse(fragment, {
|
44
46
|
parentType: fragment.typeCondition,
|
45
47
|
splitOperations: state.splitOperations
|
@@ -56,7 +58,8 @@ function visitModuleImport(node, state) {
|
|
56
58
|
if (createdSplitOperation) {
|
57
59
|
createdSplitOperation.parentSources.add(node.sourceDocument);
|
58
60
|
return node;
|
59
|
-
}
|
61
|
+
} // $FlowFixMe[incompatible-use]
|
62
|
+
|
60
63
|
|
61
64
|
var transformedNode = this.traverse(node, state);
|
62
65
|
var splitOperation = {
|
@@ -48,6 +48,7 @@ function getTypeDetails(schema, fieldType) {
|
|
48
48
|
}
|
49
49
|
|
50
50
|
function visitRoot(node) {
|
51
|
+
// $FlowFixMe[incompatible-use]
|
51
52
|
var schema = this.getContext().getSchema();
|
52
53
|
var testDirective = node.directives.find(function (directive) {
|
53
54
|
return directive.name === 'relay_test_operation';
|
@@ -43,6 +43,7 @@ function validateRequiredArguments(context) {
|
|
43
43
|
|
44
44
|
function visitDirective(node, _ref) {
|
45
45
|
var rootNode = _ref.rootNode;
|
46
|
+
// $FlowFixMe[incompatible-use]
|
46
47
|
var context = this.getContext();
|
47
48
|
var directiveDef = context.getSchema().getDirective(node.name);
|
48
49
|
|
@@ -55,6 +56,7 @@ function visitDirective(node, _ref) {
|
|
55
56
|
|
56
57
|
function visitInlineFragment(fragment, _ref2) {
|
57
58
|
var rootNode = _ref2.rootNode;
|
59
|
+
// $FlowFixMe[incompatible-use]
|
58
60
|
this.traverse(fragment, {
|
59
61
|
rootNode: rootNode,
|
60
62
|
parentType: fragment.typeCondition
|
@@ -64,6 +66,7 @@ function visitInlineFragment(fragment, _ref2) {
|
|
64
66
|
function visitField(node, _ref3) {
|
65
67
|
var parentType = _ref3.parentType,
|
66
68
|
rootNode = _ref3.rootNode;
|
69
|
+
// $FlowFixMe[incompatible-use]
|
67
70
|
var context = this.getContext();
|
68
71
|
var schema = context.getSchema();
|
69
72
|
var definition = getFieldDefinitionStrict(schema, parentType, node.name);
|
@@ -78,7 +81,8 @@ function visitField(node, _ref3) {
|
|
78
81
|
}
|
79
82
|
} else {
|
80
83
|
validateRequiredArgumentsOnNode(schema, node, schema.getFieldConfig(definition).args, rootNode);
|
81
|
-
}
|
84
|
+
} // $FlowFixMe[incompatible-use]
|
85
|
+
|
82
86
|
|
83
87
|
this.traverse(node, {
|
84
88
|
rootNode: rootNode,
|
@@ -54,6 +54,7 @@ function visitLinkedField(node, state) {
|
|
54
54
|
try {
|
55
55
|
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
56
56
|
var selection = _step.value;
|
57
|
+
// $FlowFixMe[incompatible-use]
|
57
58
|
this.visit(selection, state);
|
58
59
|
}
|
59
60
|
} catch (err) {
|
@@ -70,6 +71,7 @@ function visitClientExtension(node, state) {
|
|
70
71
|
try {
|
71
72
|
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
72
73
|
var selection = _step2.value;
|
74
|
+
// $FlowFixMe[incompatible-use]
|
73
75
|
this.visit(selection, {
|
74
76
|
rootClientSelection: selection
|
75
77
|
});
|
@@ -94,7 +96,8 @@ function visitTransformedDirective(node, state) {
|
|
94
96
|
|
95
97
|
var clientExtension = node.selections[0];
|
96
98
|
throwError("@".concat(NODEKIND_DIRECTIVE_MAP[node.kind]), node.loc, clientExtension && clientExtension.kind === 'ClientExtension' ? (_clientExtension$sele = clientExtension.selections[0]) === null || _clientExtension$sele === void 0 ? void 0 : _clientExtension$sele.loc : null);
|
97
|
-
}
|
99
|
+
} // $FlowFixMe[incompatible-use]
|
100
|
+
|
98
101
|
|
99
102
|
this.traverse(node, state);
|
100
103
|
}
|
@@ -7,6 +7,7 @@
|
|
7
7
|
*
|
8
8
|
* @format
|
9
9
|
*/
|
10
|
+
// TODO: This is only used with `ArgumentValue` types, so it could be simpler.
|
10
11
|
// flowlint ambiguous-object-type:error
|
11
12
|
'use strict';
|
12
13
|
|
@@ -21,7 +22,7 @@ var bStackPool = [];
|
|
21
22
|
* @license MIT
|
22
23
|
*/
|
23
24
|
|
24
|
-
function
|
25
|
+
function areEqualArgValues(a, b) {
|
25
26
|
var aStack = aStackPool.length ? aStackPool.pop() : [];
|
26
27
|
var bStack = bStackPool.length ? bStackPool.pop() : [];
|
27
28
|
var result = eq(a, b, aStack, bStack);
|
@@ -45,7 +46,8 @@ function eq(a, b, aStack, bStack) {
|
|
45
46
|
|
46
47
|
if (typeof a !== 'object' || typeof b !== 'object') {
|
47
48
|
return false;
|
48
|
-
}
|
49
|
+
} // $FlowFixMe[method-unbinding] added when improving typing for this parameters
|
50
|
+
|
49
51
|
|
50
52
|
var objToStr = Object.prototype.toString;
|
51
53
|
var className = objToStr.call(a);
|
@@ -115,7 +117,7 @@ function eq(a, b, aStack, bStack) {
|
|
115
117
|
// HACK: Comparing deeply nested React trees is slow since you end up
|
116
118
|
// comparing the entire tree (all ancestors and all children) and
|
117
119
|
// likely not what you want if you're comparing two elements with
|
118
|
-
//
|
120
|
+
// areEqualArgValues. We bail out here for now.
|
119
121
|
continue;
|
120
122
|
}
|
121
123
|
|
@@ -130,4 +132,4 @@ function eq(a, b, aStack, bStack) {
|
|
130
132
|
return true;
|
131
133
|
}
|
132
134
|
|
133
|
-
module.exports =
|
135
|
+
module.exports = areEqualArgValues;
|
package/package.json
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
{
|
2
2
|
"name": "relay-compiler",
|
3
3
|
"description": "A compiler tool for building GraphQL-driven applications.",
|
4
|
-
"version": "
|
4
|
+
"version": "12.0.0",
|
5
5
|
"keywords": [
|
6
6
|
"graphql",
|
7
7
|
"relay"
|
@@ -15,20 +15,21 @@
|
|
15
15
|
"relay-compiler": "bin/relay-compiler"
|
16
16
|
},
|
17
17
|
"dependencies": {
|
18
|
-
"@babel/core": "^7.
|
19
|
-
"@babel/generator": "^7.
|
20
|
-
"@babel/parser": "^7.
|
18
|
+
"@babel/core": "^7.14.0",
|
19
|
+
"@babel/generator": "^7.14.0",
|
20
|
+
"@babel/parser": "^7.14.0",
|
21
21
|
"@babel/runtime": "^7.0.0",
|
22
|
-
"@babel/traverse": "^7.
|
22
|
+
"@babel/traverse": "^7.14.0",
|
23
23
|
"@babel/types": "^7.0.0",
|
24
|
-
"babel-preset-fbjs": "^3.
|
24
|
+
"babel-preset-fbjs": "^3.4.0",
|
25
25
|
"chalk": "^4.0.0",
|
26
26
|
"fb-watchman": "^2.0.0",
|
27
27
|
"fbjs": "^3.0.0",
|
28
28
|
"glob": "^7.1.1",
|
29
29
|
"immutable": "~3.7.6",
|
30
|
+
"invariant": "^2.2.4",
|
30
31
|
"nullthrows": "^1.1.1",
|
31
|
-
"relay-runtime": "
|
32
|
+
"relay-runtime": "12.0.0",
|
32
33
|
"signedsource": "^1.0.0",
|
33
34
|
"yargs": "^15.3.1"
|
34
35
|
},
|