@effect-ts/system
Version:
Effect-TS is a zero dependency set of libraries to write highly productive, purely functional TypeScript at scale.
65 lines (58 loc) • 1.39 kB
text/typescript
// ets_tracing: off
import type * as Chunk from "../core.js"
import { ArrTypeId, concrete, SingletonTypeId } from "../definition.js"
/**
* Folds over the elements in this chunk from the right.
*/
export function reduceRightWithIndex_<A, S>(
self: Chunk.Chunk<A>,
s: S,
f: (index: number, a: A, s: S) => S
): S {
concrete(self)
switch (self._typeId) {
case SingletonTypeId: {
return f(0, self.a, s)
}
case ArrTypeId: {
const arr = self.arrayLike()
const len = arr.length
let s1 = s
let i = len - 1
while (i >= 0) {
s1 = f(i, arr[i]!, s1)
i--
}
return s1
}
default: {
const iterator = self.reverseArrayLikeIterator()
let next
let s1 = s
let index = self.length - 1
while ((next = iterator.next()) && !next.done) {
const array = next.value
const len = array.length
let i = len - 1
while (i >= 0) {
const a = array[i]!
s1 = f(index, a, s1)
i--
index--
}
}
return s1
}
}
}
/**
* Folds over the elements in this chunk from the right.
*
* @ets_data_first reduceRightWithIndex_
*/
export function reduceRightWithIndex<A, S>(
s: S,
f: (index: number, a: A, s: S) => S
): (self: Chunk.Chunk<A>) => S {
return (self) => reduceRightWithIndex_(self, s, f)
}