relay-runtime 0.0.0-main-e0f88a3b → 0.0.0-main-2087b512

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.
Files changed (124) hide show
  1. package/handlers/RelayDefaultHandlerProvider.js.flow +2 -3
  2. package/handlers/connection/ConnectionHandler.js.flow +8 -10
  3. package/handlers/connection/MutationHandlers.js.flow +7 -8
  4. package/index.js +1 -1
  5. package/index.js.flow +29 -31
  6. package/lib/handlers/connection/ConnectionHandler.js +7 -7
  7. package/lib/index.js +45 -45
  8. package/lib/multi-actor-environment/ActorSpecificEnvironment.js +4 -4
  9. package/lib/multi-actor-environment/MultiActorEnvironment.js +8 -8
  10. package/lib/multi-actor-environment/index.js +2 -2
  11. package/lib/mutations/RelayRecordProxy.js +3 -2
  12. package/lib/mutations/RelayRecordSourceMutator.js +3 -2
  13. package/lib/mutations/RelayRecordSourceProxy.js +5 -4
  14. package/lib/mutations/RelayRecordSourceSelectorProxy.js +5 -4
  15. package/lib/mutations/applyOptimisticMutation.js +6 -6
  16. package/lib/mutations/commitMutation.js +10 -10
  17. package/lib/mutations/validateMutation.js +6 -6
  18. package/lib/network/ConvertToExecuteFunction.js +2 -1
  19. package/lib/network/RelayNetwork.js +3 -2
  20. package/lib/network/RelayQueryResponseCache.js +2 -2
  21. package/lib/network/wrapNetworkWithLogObserver.js +2 -1
  22. package/lib/query/GraphQLTag.js +2 -1
  23. package/lib/query/fetchQuery.js +6 -5
  24. package/lib/query/fetchQuery_DEPRECATED.js +2 -1
  25. package/lib/store/ClientID.js +4 -4
  26. package/lib/store/DataChecker.js +15 -15
  27. package/lib/store/OperationExecutor.js +13 -13
  28. package/lib/store/RelayConcreteVariables.js +3 -2
  29. package/lib/store/RelayModernEnvironment.js +11 -11
  30. package/lib/store/RelayModernFragmentSpecResolver.js +8 -8
  31. package/lib/store/RelayModernOperationDescriptor.js +2 -1
  32. package/lib/store/RelayModernRecord.js +12 -11
  33. package/lib/store/RelayModernSelector.js +7 -6
  34. package/lib/store/RelayModernStore.js +13 -13
  35. package/lib/store/RelayPublishQueue.js +4 -4
  36. package/lib/store/RelayReader.js +12 -12
  37. package/lib/store/RelayReferenceMarker.js +9 -9
  38. package/lib/store/RelayResponseNormalizer.js +19 -19
  39. package/lib/store/RelayStoreReactFlightUtils.js +3 -3
  40. package/lib/store/RelayStoreSubscriptions.js +4 -4
  41. package/lib/store/RelayStoreUtils.js +3 -3
  42. package/lib/store/ResolverCache.js +6 -6
  43. package/lib/store/ResolverFragments.js +6 -2
  44. package/lib/store/cloneRelayHandleSourceField.js +5 -4
  45. package/lib/store/cloneRelayScalarHandleSourceField.js +5 -4
  46. package/lib/store/createRelayContext.js +3 -1
  47. package/lib/store/readInlineData.js +6 -2
  48. package/lib/subscription/requestSubscription.js +4 -4
  49. package/lib/util/RelayFeatureFlags.js +1 -0
  50. package/lib/util/StringInterner.js +57 -0
  51. package/lib/util/getFragmentIdentifier.js +10 -10
  52. package/lib/util/getOperation.js +2 -1
  53. package/lib/util/getRelayHandleKey.js +2 -2
  54. package/lib/util/getRequestIdentifier.js +2 -2
  55. package/multi-actor-environment/ActorSpecificEnvironment.js.flow +14 -15
  56. package/multi-actor-environment/ActorUtils.js.flow +2 -2
  57. package/multi-actor-environment/MultiActorEnvironment.js.flow +9 -10
  58. package/multi-actor-environment/MultiActorEnvironmentTypes.js.flow +4 -4
  59. package/multi-actor-environment/index.js.flow +1 -2
  60. package/mutations/RelayDeclarativeMutationConfig.js.flow +3 -4
  61. package/mutations/RelayRecordProxy.js.flow +4 -5
  62. package/mutations/RelayRecordSourceMutator.js.flow +4 -6
  63. package/mutations/RelayRecordSourceProxy.js.flow +7 -9
  64. package/mutations/RelayRecordSourceSelectorProxy.js.flow +3 -4
  65. package/mutations/applyOptimisticMutation.js.flow +8 -10
  66. package/mutations/commitLocalUpdate.js.flow +1 -1
  67. package/mutations/commitMutation.js.flow +12 -19
  68. package/mutations/validateMutation.js.flow +14 -16
  69. package/network/ConvertToExecuteFunction.js.flow +2 -2
  70. package/network/RelayNetwork.js.flow +4 -5
  71. package/network/RelayQueryResponseCache.js.flow +3 -3
  72. package/network/wrapNetworkWithLogObserver.js.flow +3 -3
  73. package/package.json +1 -1
  74. package/query/GraphQLTag.js.flow +6 -7
  75. package/query/fetchQuery.js.flow +9 -11
  76. package/query/fetchQueryInternal.js.flow +4 -5
  77. package/query/fetchQuery_DEPRECATED.js.flow +4 -4
  78. package/relay-runtime.js +2 -2
  79. package/relay-runtime.min.js +2 -2
  80. package/store/ClientID.js.flow +8 -6
  81. package/store/DataChecker.js.flow +16 -18
  82. package/store/OperationExecutor.js.flow +24 -26
  83. package/store/RelayConcreteVariables.js.flow +4 -5
  84. package/store/RelayModernEnvironment.js.flow +17 -19
  85. package/store/RelayModernFragmentSpecResolver.js.flow +16 -18
  86. package/store/RelayModernOperationDescriptor.js.flow +10 -11
  87. package/store/RelayModernRecord.js.flow +19 -12
  88. package/store/RelayModernSelector.js.flow +11 -12
  89. package/store/RelayModernStore.js.flow +21 -23
  90. package/store/RelayOperationTracker.js.flow +2 -2
  91. package/store/RelayOptimisticRecordSource.js.flow +2 -2
  92. package/store/RelayPublishQueue.js.flow +8 -9
  93. package/store/RelayReader.js.flow +33 -35
  94. package/store/RelayRecordSource.js.flow +2 -2
  95. package/store/RelayReferenceMarker.js.flow +12 -14
  96. package/store/RelayResponseNormalizer.js.flow +36 -38
  97. package/store/RelayStoreReactFlightUtils.js.flow +3 -4
  98. package/store/RelayStoreSubscriptions.js.flow +7 -8
  99. package/store/RelayStoreTypes.js.flow +9 -3
  100. package/store/RelayStoreUtils.js.flow +7 -8
  101. package/store/ResolverCache.js.flow +11 -13
  102. package/store/ResolverFragments.js.flow +4 -5
  103. package/store/ViewerPattern.js.flow +2 -2
  104. package/store/cloneRelayHandleSourceField.js.flow +5 -6
  105. package/store/cloneRelayScalarHandleSourceField.js.flow +5 -6
  106. package/store/createFragmentSpecResolver.js.flow +3 -4
  107. package/store/createRelayContext.js.flow +2 -2
  108. package/store/normalizeRelayPayload.js.flow +6 -7
  109. package/store/readInlineData.js.flow +3 -4
  110. package/subscription/requestSubscription.js.flow +9 -11
  111. package/util/RelayFeatureFlags.js.flow +2 -0
  112. package/util/RelayReplaySubject.js.flow +2 -3
  113. package/util/StringInterner.js.flow +57 -0
  114. package/util/createPayloadFor3DField.js.flow +3 -3
  115. package/util/getFragmentIdentifier.js.flow +14 -10
  116. package/util/getOperation.js.flow +2 -2
  117. package/util/getPaginationMetadata.js.flow +3 -3
  118. package/util/getPaginationVariables.js.flow +3 -3
  119. package/util/getPendingOperationsForFragment.js.flow +2 -2
  120. package/util/getRefetchMetadata.js.flow +2 -2
  121. package/util/getRelayHandleKey.js.flow +1 -2
  122. package/util/getRequestIdentifier.js.flow +3 -3
  123. package/lib/util/shortString.js +0 -63
  124. package/util/shortString.js.flow +0 -62
@@ -16,25 +16,15 @@ var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime
16
16
 
17
17
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
18
18
 
19
- var RelayFeatureFlags = require('../util/RelayFeatureFlags');
20
-
21
- var RelayModernRecord = require('./RelayModernRecord');
22
-
23
- var areEqual = require("fbjs/lib/areEqual");
24
-
25
- var invariant = require('invariant');
26
-
27
- var warning = require("fbjs/lib/warning");
28
-
29
19
  var _require = require('../multi-actor-environment/ActorUtils'),
30
20
  ACTOR_IDENTIFIER_FIELD_NAME = _require.ACTOR_IDENTIFIER_FIELD_NAME,
31
21
  getActorIdentifierFromPayload = _require.getActorIdentifierFromPayload;
32
22
 
33
23
  var _require2 = require('../util/RelayConcreteNode'),
34
24
  ACTOR_CHANGE = _require2.ACTOR_CHANGE,
35
- CONDITION = _require2.CONDITION,
36
25
  CLIENT_COMPONENT = _require2.CLIENT_COMPONENT,
37
26
  CLIENT_EXTENSION = _require2.CLIENT_EXTENSION,
27
+ CONDITION = _require2.CONDITION,
38
28
  DEFER = _require2.DEFER,
39
29
  FLIGHT_FIELD = _require2.FLIGHT_FIELD,
40
30
  FRAGMENT_SPREAD = _require2.FRAGMENT_SPREAD,
@@ -47,6 +37,8 @@ var _require2 = require('../util/RelayConcreteNode'),
47
37
  STREAM = _require2.STREAM,
48
38
  TYPE_DISCRIMINATOR = _require2.TYPE_DISCRIMINATOR;
49
39
 
40
+ var RelayFeatureFlags = require('../util/RelayFeatureFlags');
41
+
50
42
  var _require3 = require('./ClientID'),
51
43
  generateClientID = _require3.generateClientID,
52
44
  isClientID = _require3.isClientID;
@@ -54,28 +46,36 @@ var _require3 = require('./ClientID'),
54
46
  var _require4 = require('./RelayConcreteVariables'),
55
47
  getLocalVariables = _require4.getLocalVariables;
56
48
 
49
+ var RelayModernRecord = require('./RelayModernRecord');
50
+
57
51
  var _require5 = require('./RelayModernSelector'),
58
52
  createNormalizationSelector = _require5.createNormalizationSelector;
59
53
 
60
54
  var _require6 = require('./RelayStoreReactFlightUtils'),
61
- refineToReactFlightPayloadData = _require6.refineToReactFlightPayloadData,
62
55
  REACT_FLIGHT_EXECUTABLE_DEFINITIONS_STORAGE_KEY = _require6.REACT_FLIGHT_EXECUTABLE_DEFINITIONS_STORAGE_KEY,
63
56
  REACT_FLIGHT_TREE_STORAGE_KEY = _require6.REACT_FLIGHT_TREE_STORAGE_KEY,
64
- REACT_FLIGHT_TYPE_NAME = _require6.REACT_FLIGHT_TYPE_NAME;
57
+ REACT_FLIGHT_TYPE_NAME = _require6.REACT_FLIGHT_TYPE_NAME,
58
+ refineToReactFlightPayloadData = _require6.refineToReactFlightPayloadData;
65
59
 
66
60
  var _require7 = require('./RelayStoreUtils'),
61
+ ROOT_ID = _require7.ROOT_ID,
62
+ ROOT_TYPE = _require7.ROOT_TYPE,
63
+ TYPENAME_KEY = _require7.TYPENAME_KEY,
67
64
  getArgumentValues = _require7.getArgumentValues,
68
65
  getHandleStorageKey = _require7.getHandleStorageKey,
69
66
  getModuleComponentKey = _require7.getModuleComponentKey,
70
67
  getModuleOperationKey = _require7.getModuleOperationKey,
71
- getStorageKey = _require7.getStorageKey,
72
- TYPENAME_KEY = _require7.TYPENAME_KEY,
73
- ROOT_ID = _require7.ROOT_ID,
74
- ROOT_TYPE = _require7.ROOT_TYPE;
68
+ getStorageKey = _require7.getStorageKey;
75
69
 
76
70
  var _require8 = require('./TypeID'),
77
- generateTypeID = _require8.generateTypeID,
78
- TYPE_SCHEMA_TYPE = _require8.TYPE_SCHEMA_TYPE;
71
+ TYPE_SCHEMA_TYPE = _require8.TYPE_SCHEMA_TYPE,
72
+ generateTypeID = _require8.generateTypeID;
73
+
74
+ var areEqual = require("fbjs/lib/areEqual");
75
+
76
+ var invariant = require('invariant');
77
+
78
+ var warning = require("fbjs/lib/warning");
79
79
 
80
80
  /**
81
81
  * Normalizes the results of a query and standard GraphQL response, writing the
@@ -10,13 +10,13 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var invariant = require('invariant');
14
-
15
13
  var _require = require('./RelayModernRecord'),
16
14
  getType = _require.getType;
17
15
 
18
- // Reachable (client) executable definitions encountered while server component
16
+ var invariant = require('invariant'); // Reachable (client) executable definitions encountered while server component
19
17
  // rendering
18
+
19
+
20
20
  var REACT_FLIGHT_EXECUTABLE_DEFINITIONS_STORAGE_KEY = 'executableDefinitions';
21
21
  var REACT_FLIGHT_TREE_STORAGE_KEY = 'tree';
22
22
  var REACT_FLIGHT_TYPE_NAME = 'ReactFlightComponent';
@@ -10,15 +10,15 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var RelayFeatureFlags = require('../util/RelayFeatureFlags');
13
+ var deepFreeze = require('../util/deepFreeze');
14
14
 
15
- var RelayReader = require('./RelayReader');
15
+ var recycleNodesInto = require('../util/recycleNodesInto');
16
16
 
17
- var deepFreeze = require('../util/deepFreeze');
17
+ var RelayFeatureFlags = require('../util/RelayFeatureFlags');
18
18
 
19
19
  var hasOverlappingIDs = require('./hasOverlappingIDs');
20
20
 
21
- var recycleNodesInto = require('../util/recycleNodesInto');
21
+ var RelayReader = require('./RelayReader');
22
22
 
23
23
  var RelayStoreSubscriptions = /*#__PURE__*/function () {
24
24
  function RelayStoreSubscriptions(log, resolverCache) {
@@ -14,14 +14,14 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
14
14
 
15
15
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
16
16
 
17
- var RelayConcreteNode = require('../util/RelayConcreteNode');
18
-
19
17
  var getRelayHandleKey = require('../util/getRelayHandleKey');
20
18
 
21
- var invariant = require('invariant');
19
+ var RelayConcreteNode = require('../util/RelayConcreteNode');
22
20
 
23
21
  var stableCopy = require('../util/stableCopy');
24
22
 
23
+ var invariant = require('invariant');
24
+
25
25
  var VARIABLE = RelayConcreteNode.VARIABLE,
26
26
  LITERAL = RelayConcreteNode.LITERAL,
27
27
  OBJECT_VALUE = RelayConcreteNode.OBJECT_VALUE,
@@ -14,22 +14,22 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
14
14
 
15
15
  var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/createForOfIteratorHelper"));
16
16
 
17
- var RelayModernRecord = require('./RelayModernRecord');
18
-
19
17
  var recycleNodesInto = require('../util/recycleNodesInto');
20
18
 
21
- var warning = require("fbjs/lib/warning");
22
-
23
19
  var _require = require('./ClientID'),
24
20
  generateClientID = _require.generateClientID;
25
21
 
22
+ var RelayModernRecord = require('./RelayModernRecord');
23
+
26
24
  var _require2 = require('./RelayStoreUtils'),
27
- RELAY_RESOLVER_VALUE_KEY = _require2.RELAY_RESOLVER_VALUE_KEY,
28
- RELAY_RESOLVER_INVALIDATION_KEY = _require2.RELAY_RESOLVER_INVALIDATION_KEY,
29
25
  RELAY_RESOLVER_INPUTS_KEY = _require2.RELAY_RESOLVER_INPUTS_KEY,
26
+ RELAY_RESOLVER_INVALIDATION_KEY = _require2.RELAY_RESOLVER_INVALIDATION_KEY,
30
27
  RELAY_RESOLVER_READER_SELECTOR_KEY = _require2.RELAY_RESOLVER_READER_SELECTOR_KEY,
28
+ RELAY_RESOLVER_VALUE_KEY = _require2.RELAY_RESOLVER_VALUE_KEY,
31
29
  getStorageKey = _require2.getStorageKey;
32
30
 
31
+ var warning = require("fbjs/lib/warning");
32
+
33
33
  // $FlowFixMe[unclear-type] - will always be empty
34
34
  var emptySet = new Set();
35
35
 
@@ -10,14 +10,18 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var invariant = require('invariant');
14
-
15
13
  var _require = require('../query/GraphQLTag'),
16
14
  getFragment = _require.getFragment;
17
15
 
18
16
  var _require2 = require('./RelayModernSelector'),
19
17
  getSelector = _require2.getSelector;
20
18
 
19
+ var invariant = require('invariant'); // When we call the user-supplied resolver function, it will in turn call
20
+ // `readFragment`, but that's a global function -- it needs information
21
+ // about what resolver is being executed, which is supplied by putting the
22
+ // info on this stack before we call the resolver function.
23
+
24
+
21
25
  var contextStack = [];
22
26
 
23
27
  function withResolverContext(context, cb) {
@@ -10,16 +10,15 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var areEqual = require("fbjs/lib/areEqual");
14
-
15
- var invariant = require('invariant');
16
-
17
13
  var _require = require('../util/RelayConcreteNode'),
18
14
  LINKED_FIELD = _require.LINKED_FIELD;
19
15
 
20
16
  var _require2 = require('./RelayStoreUtils'),
21
17
  getHandleStorageKey = _require2.getHandleStorageKey;
22
18
 
19
+ var areEqual = require("fbjs/lib/areEqual");
20
+
21
+ var invariant = require('invariant');
23
22
  /**
24
23
  * @private
25
24
  *
@@ -27,6 +26,8 @@ var _require2 = require('./RelayStoreUtils'),
27
26
  * field (on which the handle was declared) among the sibling `selections`, and
28
27
  * copying its selections into the clone.
29
28
  */
29
+
30
+
30
31
  function cloneRelayHandleSourceField(handleField, selections, variables) {
31
32
  var sourceField = selections.find(function (source) {
32
33
  return source.kind === LINKED_FIELD && source.name === handleField.name && source.alias === handleField.alias && areEqual(source.args, handleField.args);
@@ -10,22 +10,23 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var areEqual = require("fbjs/lib/areEqual");
14
-
15
- var invariant = require('invariant');
16
-
17
13
  var _require = require('../util/RelayConcreteNode'),
18
14
  SCALAR_FIELD = _require.SCALAR_FIELD;
19
15
 
20
16
  var _require2 = require('./RelayStoreUtils'),
21
17
  getHandleStorageKey = _require2.getHandleStorageKey;
22
18
 
19
+ var areEqual = require("fbjs/lib/areEqual");
20
+
21
+ var invariant = require('invariant');
23
22
  /**
24
23
  * @private
25
24
  *
26
25
  * Creates a clone of the supplied `handleField` by finding the original scalar
27
26
  * field (on which the handle was declared) among the sibling `selections`.
28
27
  */
28
+
29
+
29
30
  function cloneRelayScalarHandleSourceField(handleField, selections, variables) {
30
31
  var sourceField = selections.find(function (source) {
31
32
  return source.kind === SCALAR_FIELD && source.name === handleField.name && source.alias === handleField.alias && areEqual(source.args, handleField.args);
@@ -10,7 +10,9 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var invariant = require('invariant');
13
+ var invariant = require('invariant'); // Ideally, we'd just import the type of the react module, but this causes Flow
14
+ // problems.
15
+
14
16
 
15
17
  var relayContext;
16
18
  var firstReact;
@@ -10,14 +10,18 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var invariant = require('invariant');
14
-
15
13
  var _require = require('../query/GraphQLTag'),
16
14
  getInlineDataFragment = _require.getInlineDataFragment;
17
15
 
18
16
  var _require2 = require('./RelayStoreUtils'),
19
17
  FRAGMENTS_KEY = _require2.FRAGMENTS_KEY;
20
18
 
19
+ var invariant = require('invariant');
20
+ /**
21
+ * Reads an @inline data fragment that was spread into the parent fragment.
22
+ */
23
+
24
+
21
25
  function readInlineData(fragment, fragmentRef) {
22
26
  var _fragmentRef$FRAGMENT;
23
27
 
@@ -12,10 +12,6 @@
12
12
 
13
13
  var RelayDeclarativeMutationConfig = require('../mutations/RelayDeclarativeMutationConfig');
14
14
 
15
- var RelayFeatureFlags = require('../util/RelayFeatureFlags');
16
-
17
- var warning = require("fbjs/lib/warning");
18
-
19
15
  var _require = require('../query/GraphQLTag'),
20
16
  getRequest = _require.getRequest;
21
17
 
@@ -25,6 +21,10 @@ var _require2 = require('../store/RelayModernOperationDescriptor'),
25
21
  var _require3 = require('../store/RelayModernSelector'),
26
22
  createReaderSelector = _require3.createReaderSelector;
27
23
 
24
+ var RelayFeatureFlags = require('../util/RelayFeatureFlags');
25
+
26
+ var warning = require("fbjs/lib/warning");
27
+
28
28
  function requestSubscription(environment, config) {
29
29
  var subscription = getRequest(config.subscription);
30
30
 
@@ -11,6 +11,7 @@
11
11
  'use strict';
12
12
 
13
13
  var RelayFeatureFlags = {
14
+ DELAY_CLEANUP_OF_PENDING_PRELOAD_QUERIES: false,
14
15
  ENABLE_VARIABLE_CONNECTION_KEY: false,
15
16
  ENABLE_PARTIAL_RENDERING_DEFAULT: true,
16
17
  ENABLE_REACT_FLIGHT_COMPONENT_FIELD: false,
@@ -0,0 +1,57 @@
1
+ /**
2
+ * Copyright (c) Facebook, Inc. and its affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ *
8
+ * @format
9
+ */
10
+ 'use strict';
11
+
12
+ var internTable = new Map();
13
+ var nextIndex = 1;
14
+ var digits = new Set('0123456789'); // Character used as the prefix for interned strings. The specific character is
15
+ // chosen to reduce the likelihood that non-interned input strings need to be
16
+ // escaped (choosing eg a-Z would increase the likelihood we need to escape)
17
+
18
+ var INTERN_PREFIX = '\t'; // Character used as the prefix of escaped strings. As above, this is also
19
+ // chosen to be unlikely in normal input strings.
20
+
21
+ var ESCAPE_PREFIX = '\v'; // Escape a string so that it cannot conflict with an interned string
22
+
23
+ function escape(str) {
24
+ if ( // "\t<digit>..." -> "\v\t<digit>..."
25
+ str[0] === INTERN_PREFIX && digits.has(str[1]) || // "\v..." -> "\v\v..."
26
+ str[0] === ESCAPE_PREFIX) {
27
+ return ESCAPE_PREFIX + str;
28
+ }
29
+
30
+ return str;
31
+ } // Interns the input string if its length equals or exceeds the given `limit`,
32
+ // returning a shorter replacement string that is uniquely associated with the
33
+ // input: multiple calls to intern() for the equivalent input strings (and limit)
34
+ // will always return the exact same string.
35
+ // Strings shorter than the limit are not interned but are escaped if they
36
+ // could conflict with interned strings.
37
+
38
+
39
+ function intern(str, limit) {
40
+ if (limit == null || str.length < limit) {
41
+ return escape(str);
42
+ }
43
+
44
+ var internedString = internTable.get(str);
45
+
46
+ if (internedString != null) {
47
+ return internedString;
48
+ }
49
+
50
+ internedString = INTERN_PREFIX + nextIndex++;
51
+ internTable.set(str, internedString);
52
+ return internedString;
53
+ }
54
+
55
+ module.exports = {
56
+ intern: intern
57
+ };
@@ -11,19 +11,19 @@
11
11
  // flowlint ambiguous-object-type:error
12
12
  'use strict';
13
13
 
14
- var RelayFeatureFlags = require('./RelayFeatureFlags');
14
+ var _require = require('../store/RelayModernSelector'),
15
+ getDataIDsFromFragment = _require.getDataIDsFromFragment,
16
+ getSelector = _require.getSelector,
17
+ getVariablesFromFragment = _require.getVariablesFromFragment;
15
18
 
16
19
  var isEmptyObject = require('./isEmptyObject');
17
20
 
18
- var stableCopy = require('./stableCopy');
21
+ var RelayFeatureFlags = require('./RelayFeatureFlags');
19
22
 
20
- var _require = require('../store/RelayModernSelector'),
21
- getDataIDsFromFragment = _require.getDataIDsFromFragment,
22
- getVariablesFromFragment = _require.getVariablesFromFragment,
23
- getSelector = _require.getSelector;
23
+ var stableCopy = require('./stableCopy');
24
24
 
25
- var _require2 = require('./shortString'),
26
- shorten = _require2.shorten;
25
+ var _require2 = require('./StringInterner'),
26
+ intern = _require2.intern;
27
27
 
28
28
  function getFragmentIdentifier(fragmentNode, fragmentRef) {
29
29
  var selector = getSelector(fragmentNode, fragmentRef);
@@ -35,14 +35,14 @@ function getFragmentIdentifier(fragmentNode, fragmentRef) {
35
35
 
36
36
  if (RelayFeatureFlags.ENABLE_GETFRAGMENTIDENTIFIER_OPTIMIZATION) {
37
37
  var ids = typeof dataIDs === 'undefined' ? 'missing' : dataIDs == null ? 'null' : Array.isArray(dataIDs) ? '[' + dataIDs.join(',') + ']' : dataIDs;
38
- ids = RelayFeatureFlags.STRING_INTERN_LEVEL <= 1 ? ids : shorten(ids);
38
+ ids = RelayFeatureFlags.STRING_INTERN_LEVEL <= 1 ? ids : intern(ids, RelayFeatureFlags.MAX_DATA_ID_LENGTH);
39
39
  return fragmentOwnerIdentifier + '/' + fragmentNode.name + '/' + (fragmentVariables == null || isEmptyObject(fragmentVariables) ? '{}' : JSON.stringify(stableCopy(fragmentVariables))) + '/' + ids;
40
40
  } else {
41
41
  var _JSON$stringify;
42
42
 
43
43
  var _ids = (_JSON$stringify = JSON.stringify(dataIDs)) !== null && _JSON$stringify !== void 0 ? _JSON$stringify : 'missing';
44
44
 
45
- _ids = RelayFeatureFlags.STRING_INTERN_LEVEL <= 1 ? _ids : shorten(_ids);
45
+ _ids = RelayFeatureFlags.STRING_INTERN_LEVEL <= 1 ? _ids : intern(_ids, RelayFeatureFlags.MAX_DATA_ID_LENGTH);
46
46
  return fragmentOwnerIdentifier + '/' + fragmentNode.name + '/' + JSON.stringify(stableCopy(fragmentVariables)) + '/' + _ids;
47
47
  }
48
48
  }
@@ -14,11 +14,12 @@
14
14
  var _require = require('./RelayConcreteNode'),
15
15
  REQUEST = _require.REQUEST,
16
16
  SPLIT_OPERATION = _require.SPLIT_OPERATION;
17
-
18
17
  /**
19
18
  * OperationLoaders can return either a NormalizationSplitOperation or
20
19
  * ConcreteRequest.
21
20
  */
21
+
22
+
22
23
  function getOperation(node) {
23
24
  switch (node.kind) {
24
25
  case REQUEST:
@@ -10,10 +10,10 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var invariant = require('invariant');
14
-
15
13
  var _require = require('./RelayDefaultHandleKey'),
16
14
  DEFAULT_HANDLE_KEY = _require.DEFAULT_HANDLE_KEY;
15
+
16
+ var invariant = require('invariant');
17
17
  /**
18
18
  * @internal
19
19
  *
@@ -10,10 +10,10 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var invariant = require('invariant');
14
-
15
13
  var stableCopy = require('./stableCopy');
16
14
 
15
+ var invariant = require('invariant');
16
+
17
17
  /**
18
18
  * Returns a stable identifier for the given pair of `RequestParameters` +
19
19
  * variables.
@@ -11,31 +11,24 @@
11
11
 
12
12
  'use strict';
13
13
 
14
- const RelayOperationTracker = require('../store/RelayOperationTracker');
15
- const RelayPublishQueue = require('../store/RelayPublishQueue');
16
-
17
- const defaultGetDataID = require('../store/defaultGetDataID');
18
- const registerEnvironmentWithDevTools = require('../util/registerEnvironmentWithDevTools');
19
- const wrapNetworkWithLogObserver = require('../network/wrapNetworkWithLogObserver');
20
-
21
14
  import type {HandlerProvider} from '../handlers/RelayDefaultHandlerProvider';
22
15
  import type {GraphQLResponse, PayloadData} from '../network/RelayNetworkTypes';
23
16
  import type {INetwork} from '../network/RelayNetworkTypes';
24
17
  import type RelayObservable from '../network/RelayObservable';
25
18
  import type {
19
+ ExecuteMutationConfig,
20
+ LogFunction,
21
+ OperationAvailability,
22
+ OperationDescriptor,
23
+ OperationTracker,
26
24
  OptimisticResponseConfig,
27
25
  OptimisticUpdateFunction,
28
- OperationDescriptor,
29
- OperationAvailability,
30
- Snapshot,
26
+ RequiredFieldLogger,
31
27
  SelectorStoreUpdater,
32
28
  SingularReaderSelector,
33
- StoreUpdater,
34
- RequiredFieldLogger,
35
- ExecuteMutationConfig,
36
- LogFunction,
29
+ Snapshot,
37
30
  Store,
38
- OperationTracker,
31
+ StoreUpdater,
39
32
  } from '../store/RelayStoreTypes';
40
33
  import type {Disposable, RenderPolicy} from '../util/RelayRuntimeTypes';
41
34
  import type {ActorIdentifier} from './ActorIdentifier';
@@ -44,6 +37,12 @@ import type {
44
37
  IMultiActorEnvironment,
45
38
  } from './MultiActorEnvironmentTypes';
46
39
 
40
+ const wrapNetworkWithLogObserver = require('../network/wrapNetworkWithLogObserver');
41
+ const defaultGetDataID = require('../store/defaultGetDataID');
42
+ const RelayOperationTracker = require('../store/RelayOperationTracker');
43
+ const RelayPublishQueue = require('../store/RelayPublishQueue');
44
+ const registerEnvironmentWithDevTools = require('../util/registerEnvironmentWithDevTools');
45
+
47
46
  export type ActorSpecificEnvironmentConfig = $ReadOnly<{
48
47
  actorIdentifier: ActorIdentifier,
49
48
  configName: ?string,
@@ -13,10 +13,10 @@
13
13
 
14
14
  const ACTOR_IDENTIFIER_FIELD_NAME = 'actor_key';
15
15
 
16
- const {getActorIdentifier} = require('./ActorIdentifier');
17
-
18
16
  import type {ActorIdentifier} from './ActorIdentifier';
19
17
 
18
+ const {getActorIdentifier} = require('./ActorIdentifier');
19
+
20
20
  function getActorIdentifierFromPayload(payload: mixed): ?ActorIdentifier {
21
21
  if (
22
22
  payload != null &&
@@ -11,16 +11,6 @@
11
11
 
12
12
  'use strict';
13
13
 
14
- const ActorSpecificEnvironment = require('./ActorSpecificEnvironment');
15
- const OperationExecutor = require('../store/OperationExecutor');
16
- const RelayDefaultHandlerProvider = require('../handlers/RelayDefaultHandlerProvider');
17
- const RelayModernStore = require('../store/RelayModernStore');
18
- const RelayObservable = require('../network/RelayObservable');
19
- const RelayRecordSource = require('../store/RelayRecordSource');
20
-
21
- const defaultGetDataID = require('../store/defaultGetDataID');
22
- const defaultRequiredFieldLogger = require('../store/defaultRequiredFieldLogger');
23
-
24
14
  import type {HandlerProvider} from '../handlers/RelayDefaultHandlerProvider';
25
15
  import type {GraphQLResponse, PayloadData} from '../network/RelayNetworkTypes';
26
16
  import type {INetwork} from '../network/RelayNetworkTypes';
@@ -54,6 +44,15 @@ import type {
54
44
  MultiActorStoreUpdater,
55
45
  } from './MultiActorEnvironmentTypes';
56
46
 
47
+ const RelayDefaultHandlerProvider = require('../handlers/RelayDefaultHandlerProvider');
48
+ const RelayObservable = require('../network/RelayObservable');
49
+ const defaultGetDataID = require('../store/defaultGetDataID');
50
+ const defaultRequiredFieldLogger = require('../store/defaultRequiredFieldLogger');
51
+ const OperationExecutor = require('../store/OperationExecutor');
52
+ const RelayModernStore = require('../store/RelayModernStore');
53
+ const RelayRecordSource = require('../store/RelayRecordSource');
54
+ const ActorSpecificEnvironment = require('./ActorSpecificEnvironment');
55
+
57
56
  export type MultiActorEnvironmentConfig = $ReadOnly<{
58
57
  createConfigNameForActor?: ?(actorIdentifier: ActorIdentifier) => string,
59
58
  createNetworkForActor: (actorIdentifier: ActorIdentifier) => INetwork,
@@ -11,21 +11,21 @@
11
11
 
12
12
  'use strict';
13
13
 
14
- import type {PayloadData, GraphQLResponse} from '../network/RelayNetworkTypes';
14
+ import type {GraphQLResponse, PayloadData} from '../network/RelayNetworkTypes';
15
15
  import type RelayObservable from '../network/RelayObservable';
16
16
  import type RelayPublishQueue from '../store/RelayPublishQueue';
17
17
  import type {
18
+ ExecuteMutationConfig,
19
+ IEnvironment,
18
20
  OperationAvailability,
19
21
  OperationDescriptor,
20
22
  OptimisticResponseConfig,
21
23
  OptimisticUpdateFunction,
24
+ RecordSourceProxy,
22
25
  SelectorStoreUpdater,
23
26
  SingularReaderSelector,
24
27
  Snapshot,
25
28
  StoreUpdater,
26
- IEnvironment,
27
- ExecuteMutationConfig,
28
- RecordSourceProxy,
29
29
  } from '../store/RelayStoreTypes';
30
30
  import type {Disposable} from '../util/RelayRuntimeTypes';
31
31
  import type {ActorIdentifier} from './ActorIdentifier';
@@ -11,9 +11,8 @@
11
11
 
12
12
  'use strict';
13
13
 
14
- const MultiActorEnvironment = require('./MultiActorEnvironment');
15
-
16
14
  const {getActorIdentifier} = require('./ActorIdentifier');
15
+ const MultiActorEnvironment = require('./MultiActorEnvironment');
17
16
 
18
17
  export type {ActorIdentifier} from './ActorIdentifier';
19
18
  export type {
@@ -12,10 +12,6 @@
12
12
 
13
13
  'use strict';
14
14
 
15
- const ConnectionHandler = require('../handlers/connection/ConnectionHandler');
16
-
17
- const warning = require('warning');
18
-
19
15
  import type {
20
16
  RecordSourceSelectorProxy,
21
17
  SelectorData,
@@ -24,6 +20,9 @@ import type {
24
20
  import type {ConcreteRequest} from '../util/RelayConcreteNode';
25
21
  import type {Variables} from '../util/RelayRuntimeTypes';
26
22
 
23
+ const ConnectionHandler = require('../handlers/connection/ConnectionHandler');
24
+ const warning = require('warning');
25
+
27
26
  const MutationTypes = Object.freeze({
28
27
  RANGE_ADD: 'RANGE_ADD',
29
28
  RANGE_DELETE: 'RANGE_DELETE',
@@ -12,17 +12,16 @@
12
12
 
13
13
  'use strict';
14
14
 
15
- const invariant = require('invariant');
16
-
17
- const {generateClientID} = require('../store/ClientID');
18
- const {getStableStorageKey} = require('../store/RelayStoreUtils');
19
-
20
15
  import type {RecordProxy} from '../store/RelayStoreTypes';
21
16
  import type {Arguments} from '../store/RelayStoreUtils';
22
17
  import type {DataID} from '../util/RelayRuntimeTypes';
23
18
  import type RelayRecordSourceMutator from './RelayRecordSourceMutator';
24
19
  import type RelayRecordSourceProxy from './RelayRecordSourceProxy';
25
20
 
21
+ const {generateClientID} = require('../store/ClientID');
22
+ const {getStableStorageKey} = require('../store/RelayStoreUtils');
23
+ const invariant = require('invariant');
24
+
26
25
  /**
27
26
  * @internal
28
27
  *