From 2bf82d2af506999e991edf717e4a7640878ca733 Mon Sep 17 00:00:00 2001 From: Haggai Eran Date: Fri, 2 Jun 2023 11:46:12 +0300 Subject: [PATCH] Pass media browser error as ErrorInfo --- .../mediabrowser/MediaBrowserConnector.java | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/org/schabi/newpipe/player/mediabrowser/MediaBrowserConnector.java b/app/src/main/java/org/schabi/newpipe/player/mediabrowser/MediaBrowserConnector.java index 379cad44d2a..7acd9cb8b16 100644 --- a/app/src/main/java/org/schabi/newpipe/player/mediabrowser/MediaBrowserConnector.java +++ b/app/src/main/java/org/schabi/newpipe/player/mediabrowser/MediaBrowserConnector.java @@ -26,6 +26,9 @@ import org.schabi.newpipe.database.history.model.StreamHistoryEntry; import org.schabi.newpipe.database.playlist.PlaylistMetadataEntry; import org.schabi.newpipe.database.playlist.PlaylistStreamEntry; +import org.schabi.newpipe.error.ErrorInfo; +import org.schabi.newpipe.error.UserAction; +import org.schabi.newpipe.extractor.exceptions.ContentNotAvailableException; import org.schabi.newpipe.local.playlist.LocalPlaylistManager; import org.schabi.newpipe.player.PlayerService; import org.schabi.newpipe.player.playqueue.PlayQueue; @@ -219,10 +222,14 @@ private void playbackError(@StringRes final int resId, final int code) { sessionConnector.setCustomErrorMessage(playerService.getString(resId), code); } + private void playbackError(@NonNull final ErrorInfo errorInfo) { + playbackError(errorInfo.getMessageStringId(), PlaybackStateCompat.ERROR_CODE_APP_ERROR); + } + private Single extractPlayQueueFromMediaId(final String mediaId) { final Uri mediaIdUri = Uri.parse(mediaId); if (mediaIdUri == null) { - return Single.error(new NullPointerException()); + return Single.error(new ContentNotAvailableException("Media ID cannot be parsed")); } if (mediaId.startsWith(ID_BOOKMARKS)) { final var path = mediaIdUri.getPathSegments(); @@ -256,7 +263,7 @@ private Single extractPlayQueueFromMediaId(final String mediaId) { } } - return Single.error(new NullPointerException()); + return Single.error(new ContentNotAvailableException("Media ID cannot be parsed")); } @Override @@ -294,8 +301,8 @@ public void onPrepareFromMediaId(@NonNull final String mediaId, final boolean pl NavigationHelper.playOnBackgroundPlayer(playerService, playQueue, playWhenReady); }, - throwable -> playbackError(R.string.error_http_not_found, - PlaybackStateCompat.ERROR_CODE_NOT_SUPPORTED) + throwable -> playbackError(new ErrorInfo(throwable, UserAction.PLAY_STREAM, + "Failed playback of media ID [" + mediaId + "]: ")) ); }