1
0
mirror of https://github.com/TeamNewPipe/NewPipe synced 2025-01-10 17:30:31 +00:00

Apply code review suggestions.

This commit is contained in:
Isira Seneviratne 2023-01-04 05:42:09 +05:30
parent e3062d7c66
commit e8216b2e80
2 changed files with 35 additions and 29 deletions

View File

@ -2056,6 +2056,7 @@ public final class Player implements PlaybackListener, Listener {
setRecovery(); setRecovery();
}, () -> { }, () -> {
// This is executed when the current stream info is not available.
reloadPlayQueueManager(); reloadPlayQueueManager();
setRecovery(); setRecovery();
}); });

View File

@ -21,7 +21,6 @@ import org.schabi.newpipe.player.playqueue.events.MoveEvent;
import org.schabi.newpipe.player.playqueue.events.PlayQueueEvent; import org.schabi.newpipe.player.playqueue.events.PlayQueueEvent;
import org.schabi.newpipe.player.playqueue.events.RemoveEvent; import org.schabi.newpipe.player.playqueue.events.RemoveEvent;
import org.schabi.newpipe.player.playqueue.events.ReorderEvent; import org.schabi.newpipe.player.playqueue.events.ReorderEvent;
import org.schabi.newpipe.util.ServiceHelper;
import java.util.Collection; import java.util.Collection;
import java.util.Collections; import java.util.Collections;
@ -42,6 +41,7 @@ import io.reactivex.rxjava3.subjects.PublishSubject;
import static org.schabi.newpipe.player.mediasource.FailedMediaSource.MediaSourceResolutionException; import static org.schabi.newpipe.player.mediasource.FailedMediaSource.MediaSourceResolutionException;
import static org.schabi.newpipe.player.mediasource.FailedMediaSource.StreamInfoLoadException; import static org.schabi.newpipe.player.mediasource.FailedMediaSource.StreamInfoLoadException;
import static org.schabi.newpipe.player.playqueue.PlayQueue.DEBUG; import static org.schabi.newpipe.player.playqueue.PlayQueue.DEBUG;
import static org.schabi.newpipe.util.ServiceHelper.getCacheExpirationMillis;
public class MediaSourceManager { public class MediaSourceManager {
@NonNull @NonNull
@ -420,33 +420,38 @@ public class MediaSourceManager {
} }
private Single<ManagedMediaSource> getLoadedMediaSource(@NonNull final PlayQueueItem stream) { private Single<ManagedMediaSource> getLoadedMediaSource(@NonNull final PlayQueueItem stream) {
return stream.getStream().map(streamInfo -> { return stream.getStream()
final var source = playbackListener.sourceOf(stream, streamInfo); .map(streamInfo -> Optional
.ofNullable(playbackListener.sourceOf(stream, streamInfo))
return Optional.ofNullable(source) .<ManagedMediaSource>flatMap(source ->
.flatMap(source1 -> MediaItemTag.from(source1.getMediaItem())) MediaItemTag.from(source.getMediaItem())
.<ManagedMediaSource>map(tag -> { .map(tag -> {
final int serviceId = streamInfo.getServiceId();
final long expiration = System.currentTimeMillis() final long expiration = System.currentTimeMillis()
+ ServiceHelper.getCacheExpirationMillis(streamInfo.getServiceId()); + getCacheExpirationMillis(serviceId);
return new LoadedMediaSource(source, tag, stream, expiration); return new LoadedMediaSource(source, tag, stream,
expiration);
}) })
)
.orElseGet(() -> { .orElseGet(() -> {
final String message = "Unable to resolve source from stream info. " final String message = "Unable to resolve source from stream info. "
+ "URL: " + stream.getUrl() + ", " + "URL: " + stream.getUrl()
+ "audio count: " + streamInfo.getAudioStreams().size() + ", " + ", audio count: " + streamInfo.getAudioStreams().size()
+ "video count: " + streamInfo.getVideoOnlyStreams().size() + ", " + ", video count: " + streamInfo.getVideoOnlyStreams().size()
+ streamInfo.getVideoStreams().size(); + ", " + streamInfo.getVideoStreams().size();
return FailedMediaSource.of(stream, new MediaSourceResolutionException( return FailedMediaSource.of(stream,
message)); new MediaSourceResolutionException(message));
}); })
}).onErrorReturn(throwable -> { )
.onErrorReturn(throwable -> {
if (throwable instanceof ExtractionException) { if (throwable instanceof ExtractionException) {
return FailedMediaSource.of(stream, new StreamInfoLoadException(throwable)); return FailedMediaSource.of(stream, new StreamInfoLoadException(throwable));
} }
// Non-source related error expected here (e.g. network), // Non-source related error expected here (e.g. network),
// should allow retry shortly after the error. // should allow retry shortly after the error.
return FailedMediaSource.of(stream, new Exception(throwable), final long allowRetryIn = TimeUnit.MILLISECONDS.convert(3,
/*allowRetryIn=*/TimeUnit.MILLISECONDS.convert(3, TimeUnit.SECONDS)); TimeUnit.SECONDS);
return FailedMediaSource.of(stream, new Exception(throwable), allowRetryIn);
}); });
} }