export class RingBufferNew { private array: Array private size = 0 private current = 0 constructor(public readonly capacity: number) { this.array = Array.from({ length: capacity }, (_) => null) } head(): Maybe { return Maybe(this.array[this.current]) } lastorNull(): A | null { if (this.size === 0) { return null } const index = this.current === 0 ? this.array.length - 1 : this.current - 1 return this.array[index] ?? null } put(value: A): void { this.array[this.current] = value this.increment() } dropLast(): void { if (this.size > 0) { this.decrement() this.array[this.current] = null } } toChunk(): Chunk { const begin = this.current - this.size const newArray = begin < 0 ? this.array .slice(this.capacity + begin, this.capacity) .concat(this.array.slice(0, this.current)) : this.array.slice(begin, this.current) return Chunk.from(newArray) as Chunk } private increment(): void { if (this.size < this.capacity) { this.size += 1 } this.current = (this.current + 1) % this.capacity } private decrement(): void { this.size -= 1 if (this.current > 0) { this.current -= 1 } else { this.current = this.capacity - 1 } } }