mirror of
https://github.com/Pinball3D/Rabbit-R1.git
synced 2025-01-09 13:43:22 +00:00
119 lines
3 KiB
Java
119 lines
3 KiB
Java
|
package androidx.media3.common.util;
|
||
|
|
||
|
import java.util.Arrays;
|
||
|
|
||
|
/* loaded from: classes2.dex */
|
||
|
public final class TimedValueQueue<V> {
|
||
|
private static final int INITIAL_BUFFER_SIZE = 10;
|
||
|
private int first;
|
||
|
private int size;
|
||
|
private long[] timestamps;
|
||
|
private V[] values;
|
||
|
|
||
|
public TimedValueQueue() {
|
||
|
this(10);
|
||
|
}
|
||
|
|
||
|
public TimedValueQueue(int i) {
|
||
|
this.timestamps = new long[i];
|
||
|
this.values = (V[]) newArray(i);
|
||
|
}
|
||
|
|
||
|
public synchronized void add(long j, V v) {
|
||
|
clearBufferOnTimeDiscontinuity(j);
|
||
|
doubleCapacityIfFull();
|
||
|
addUnchecked(j, v);
|
||
|
}
|
||
|
|
||
|
public synchronized void clear() {
|
||
|
this.first = 0;
|
||
|
this.size = 0;
|
||
|
Arrays.fill(this.values, (Object) null);
|
||
|
}
|
||
|
|
||
|
public synchronized int size() {
|
||
|
return this.size;
|
||
|
}
|
||
|
|
||
|
public synchronized V pollFirst() {
|
||
|
return this.size == 0 ? null : popFirst();
|
||
|
}
|
||
|
|
||
|
public synchronized V pollFloor(long j) {
|
||
|
return poll(j, true);
|
||
|
}
|
||
|
|
||
|
public synchronized V poll(long j) {
|
||
|
return poll(j, false);
|
||
|
}
|
||
|
|
||
|
private V poll(long j, boolean z) {
|
||
|
V v = null;
|
||
|
long j2 = Long.MAX_VALUE;
|
||
|
while (this.size > 0) {
|
||
|
long j3 = j - this.timestamps[this.first];
|
||
|
if (j3 < 0 && (z || (-j3) >= j2)) {
|
||
|
break;
|
||
|
}
|
||
|
v = popFirst();
|
||
|
j2 = j3;
|
||
|
}
|
||
|
return v;
|
||
|
}
|
||
|
|
||
|
private V popFirst() {
|
||
|
Assertions.checkState(this.size > 0);
|
||
|
V[] vArr = this.values;
|
||
|
int i = this.first;
|
||
|
V v = vArr[i];
|
||
|
vArr[i] = null;
|
||
|
this.first = (i + 1) % vArr.length;
|
||
|
this.size--;
|
||
|
return v;
|
||
|
}
|
||
|
|
||
|
private void clearBufferOnTimeDiscontinuity(long j) {
|
||
|
if (this.size > 0) {
|
||
|
if (j <= this.timestamps[((this.first + r0) - 1) % this.values.length]) {
|
||
|
clear();
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
private void doubleCapacityIfFull() {
|
||
|
int length = this.values.length;
|
||
|
if (this.size < length) {
|
||
|
return;
|
||
|
}
|
||
|
int i = length * 2;
|
||
|
long[] jArr = new long[i];
|
||
|
V[] vArr = (V[]) newArray(i);
|
||
|
int i2 = this.first;
|
||
|
int i3 = length - i2;
|
||
|
System.arraycopy(this.timestamps, i2, jArr, 0, i3);
|
||
|
System.arraycopy(this.values, this.first, vArr, 0, i3);
|
||
|
int i4 = this.first;
|
||
|
if (i4 > 0) {
|
||
|
System.arraycopy(this.timestamps, 0, jArr, i3, i4);
|
||
|
System.arraycopy(this.values, 0, vArr, i3, this.first);
|
||
|
}
|
||
|
this.timestamps = jArr;
|
||
|
this.values = vArr;
|
||
|
this.first = 0;
|
||
|
}
|
||
|
|
||
|
private void addUnchecked(long j, V v) {
|
||
|
int i = this.first;
|
||
|
int i2 = this.size;
|
||
|
V[] vArr = this.values;
|
||
|
int length = (i + i2) % vArr.length;
|
||
|
this.timestamps[length] = j;
|
||
|
vArr[length] = v;
|
||
|
this.size = i2 + 1;
|
||
|
}
|
||
|
|
||
|
private static <V> V[] newArray(int i) {
|
||
|
return (V[]) new Object[i];
|
||
|
}
|
||
|
}
|