/*** Copyright (c) Meta Platforms, Inc. and affiliates.** This source code is licensed under the MIT license found in the* LICENSE file in the root directory of this source tree.** @flow*/import isArray from 'shared/isArray';
/*** Accumulates items that must not be null or undefined into the first one. This* is used to conserve memory by avoiding array allocations, and thus sacrifices* API cleanness. Since `current` can be null before being passed in and not* null after this function, make sure to assign it back to `current`:** `a = accumulateInto(a, b);`** This API should be sparingly used. Try `accumulate` for something cleaner.** @return {*|array<*>} An accumulation of items.*/function accumulateInto<T>(
current: ?(Array<T> | T),
next: T | Array<T>,
): T | Array<T> {
if (next == null) {
throw new Error(
'accumulateInto(...): Accumulated items must not be null or undefined.',
);}if (current == null) {
return next;
}// Both are not empty. Warning: Never call x.concat(y) when you are not
// certain that x is an Array (x could be a string with concat method).
if (isArray(current)) {
if (isArray(next)) {
// $FlowFixMe[prop-missing] `isArray` does not ensure array is mutable
// $FlowFixMe[method-unbinding]
current.push.apply(current, next);
return current;}// $FlowFixMe[prop-missing] `isArray` does not ensure array is mutable
current.push(next);
return current;
}if (isArray(next)) {
// A bit too dangerous to mutate `next`.
/* $FlowFixMe[incompatible-return] unsound if `next` is `T` and `T` an array,
* `isArray` might refine to the array element type of `T` */return [current].concat(next);
}return [current, next];
}export default accumulateInto;