mirror of
https://github.com/Pinball3D/Rabbit-R1.git
synced 2025-01-09 13:43:22 +00:00
149 lines
5.7 KiB
Java
149 lines
5.7 KiB
Java
|
package com.google.android.exoplayer2.upstream;
|
||
|
|
||
|
import com.google.android.exoplayer2.extractor.ChunkIndex;
|
||
|
import com.google.android.exoplayer2.upstream.cache.Cache;
|
||
|
import com.google.android.exoplayer2.upstream.cache.CacheSpan;
|
||
|
import com.google.android.exoplayer2.util.Log;
|
||
|
import com.google.android.exoplayer2.util.Util;
|
||
|
import java.util.Arrays;
|
||
|
import java.util.Iterator;
|
||
|
import java.util.TreeSet;
|
||
|
|
||
|
/* loaded from: classes2.dex */
|
||
|
public final class CachedRegionTracker implements Cache.Listener {
|
||
|
public static final int CACHED_TO_END = -2;
|
||
|
public static final int NOT_CACHED = -1;
|
||
|
private static final String TAG = "CachedRegionTracker";
|
||
|
private final Cache cache;
|
||
|
private final String cacheKey;
|
||
|
private final ChunkIndex chunkIndex;
|
||
|
private final TreeSet<Region> regions = new TreeSet<>();
|
||
|
private final Region lookupRegion = new Region(0, 0);
|
||
|
|
||
|
@Override // com.google.android.exoplayer2.upstream.cache.Cache.Listener
|
||
|
public void onSpanTouched(Cache cache, CacheSpan cacheSpan, CacheSpan cacheSpan2) {
|
||
|
}
|
||
|
|
||
|
public CachedRegionTracker(Cache cache, String str, ChunkIndex chunkIndex) {
|
||
|
this.cache = cache;
|
||
|
this.cacheKey = str;
|
||
|
this.chunkIndex = chunkIndex;
|
||
|
synchronized (this) {
|
||
|
Iterator<CacheSpan> descendingIterator = cache.addListener(str, this).descendingIterator();
|
||
|
while (descendingIterator.hasNext()) {
|
||
|
mergeSpan(descendingIterator.next());
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public void release() {
|
||
|
this.cache.removeListener(this.cacheKey, this);
|
||
|
}
|
||
|
|
||
|
public synchronized int getRegionEndTimeMs(long j) {
|
||
|
this.lookupRegion.startOffset = j;
|
||
|
Region floor = this.regions.floor(this.lookupRegion);
|
||
|
if (floor != null && j <= floor.endOffset && floor.endOffsetIndex != -1) {
|
||
|
int i = floor.endOffsetIndex;
|
||
|
if (i == this.chunkIndex.length - 1) {
|
||
|
if (floor.endOffset == this.chunkIndex.offsets[i] + this.chunkIndex.sizes[i]) {
|
||
|
return -2;
|
||
|
}
|
||
|
}
|
||
|
return (int) ((this.chunkIndex.timesUs[i] + ((this.chunkIndex.durationsUs[i] * (floor.endOffset - this.chunkIndex.offsets[i])) / this.chunkIndex.sizes[i])) / 1000);
|
||
|
}
|
||
|
return -1;
|
||
|
}
|
||
|
|
||
|
@Override // com.google.android.exoplayer2.upstream.cache.Cache.Listener
|
||
|
public synchronized void onSpanAdded(Cache cache, CacheSpan cacheSpan) {
|
||
|
mergeSpan(cacheSpan);
|
||
|
}
|
||
|
|
||
|
@Override // com.google.android.exoplayer2.upstream.cache.Cache.Listener
|
||
|
public synchronized void onSpanRemoved(Cache cache, CacheSpan cacheSpan) {
|
||
|
Region region = new Region(cacheSpan.position, cacheSpan.position + cacheSpan.length);
|
||
|
Region floor = this.regions.floor(region);
|
||
|
if (floor == null) {
|
||
|
Log.e(TAG, "Removed a span we were not aware of");
|
||
|
return;
|
||
|
}
|
||
|
this.regions.remove(floor);
|
||
|
if (floor.startOffset < region.startOffset) {
|
||
|
Region region2 = new Region(floor.startOffset, region.startOffset);
|
||
|
int binarySearch = Arrays.binarySearch(this.chunkIndex.offsets, region2.endOffset);
|
||
|
if (binarySearch < 0) {
|
||
|
binarySearch = (-binarySearch) - 2;
|
||
|
}
|
||
|
region2.endOffsetIndex = binarySearch;
|
||
|
this.regions.add(region2);
|
||
|
}
|
||
|
if (floor.endOffset > region.endOffset) {
|
||
|
Region region3 = new Region(region.endOffset + 1, floor.endOffset);
|
||
|
region3.endOffsetIndex = floor.endOffsetIndex;
|
||
|
this.regions.add(region3);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
private void mergeSpan(CacheSpan cacheSpan) {
|
||
|
Region region = new Region(cacheSpan.position, cacheSpan.position + cacheSpan.length);
|
||
|
Region floor = this.regions.floor(region);
|
||
|
Region ceiling = this.regions.ceiling(region);
|
||
|
boolean regionsConnect = regionsConnect(floor, region);
|
||
|
if (regionsConnect(region, ceiling)) {
|
||
|
if (regionsConnect) {
|
||
|
floor.endOffset = ceiling.endOffset;
|
||
|
floor.endOffsetIndex = ceiling.endOffsetIndex;
|
||
|
} else {
|
||
|
region.endOffset = ceiling.endOffset;
|
||
|
region.endOffsetIndex = ceiling.endOffsetIndex;
|
||
|
this.regions.add(region);
|
||
|
}
|
||
|
this.regions.remove(ceiling);
|
||
|
return;
|
||
|
}
|
||
|
if (regionsConnect) {
|
||
|
floor.endOffset = region.endOffset;
|
||
|
int i = floor.endOffsetIndex;
|
||
|
while (i < this.chunkIndex.length - 1) {
|
||
|
int i2 = i + 1;
|
||
|
if (this.chunkIndex.offsets[i2] > floor.endOffset) {
|
||
|
break;
|
||
|
} else {
|
||
|
i = i2;
|
||
|
}
|
||
|
}
|
||
|
floor.endOffsetIndex = i;
|
||
|
return;
|
||
|
}
|
||
|
int binarySearch = Arrays.binarySearch(this.chunkIndex.offsets, region.endOffset);
|
||
|
if (binarySearch < 0) {
|
||
|
binarySearch = (-binarySearch) - 2;
|
||
|
}
|
||
|
region.endOffsetIndex = binarySearch;
|
||
|
this.regions.add(region);
|
||
|
}
|
||
|
|
||
|
private boolean regionsConnect(Region region, Region region2) {
|
||
|
return (region == null || region2 == null || region.endOffset != region2.startOffset) ? false : true;
|
||
|
}
|
||
|
|
||
|
/* JADX INFO: Access modifiers changed from: private */
|
||
|
/* loaded from: classes2.dex */
|
||
|
public static class Region implements Comparable<Region> {
|
||
|
public long endOffset;
|
||
|
public int endOffsetIndex;
|
||
|
public long startOffset;
|
||
|
|
||
|
public Region(long j, long j2) {
|
||
|
this.startOffset = j;
|
||
|
this.endOffset = j2;
|
||
|
}
|
||
|
|
||
|
@Override // java.lang.Comparable
|
||
|
public int compareTo(Region region) {
|
||
|
return Util.compareLong(this.startOffset, region.startOffset);
|
||
|
}
|
||
|
}
|
||
|
}
|