mirror of
				https://github.com/TeamNewPipe/NewPipe
				synced 2025-10-26 21:07:38 +00:00 
			
		
		
		
	Use exception utils in network error detection throughout the app
This commit is contained in:
		| @@ -26,7 +26,6 @@ import org.schabi.newpipe.report.UserAction; | ||||
| import org.schabi.newpipe.util.ExceptionUtils; | ||||
| import org.schabi.newpipe.util.InfoCache; | ||||
|  | ||||
| import java.io.IOException; | ||||
| import java.util.Collections; | ||||
| import java.util.List; | ||||
| import java.util.concurrent.TimeUnit; | ||||
| @@ -213,7 +212,7 @@ public abstract class BaseStateFragment<I> extends BaseFragment implements ViewC | ||||
|         } else if (exception instanceof ContentNotAvailableException) { | ||||
|             showError(getString(R.string.content_not_available), false); | ||||
|             return true; | ||||
|         } else if (exception instanceof IOException) { | ||||
|         } else if (ExceptionUtils.isNetworkRelated(exception)) { | ||||
|             showError(getString(R.string.network_error), true); | ||||
|             return true; | ||||
|         } | ||||
|   | ||||
| @@ -41,7 +41,6 @@ import org.schabi.newpipe.extractor.StreamingService; | ||||
| import org.schabi.newpipe.extractor.exceptions.ParsingException; | ||||
| import org.schabi.newpipe.extractor.search.SearchExtractor; | ||||
| import org.schabi.newpipe.extractor.search.SearchInfo; | ||||
| import org.schabi.newpipe.util.ExceptionUtils; | ||||
| import org.schabi.newpipe.fragments.BackPressable; | ||||
| import org.schabi.newpipe.fragments.list.BaseListFragment; | ||||
| import org.schabi.newpipe.local.history.HistoryRecordManager; | ||||
| @@ -54,9 +53,6 @@ import org.schabi.newpipe.util.FireTvUtils; | ||||
| import org.schabi.newpipe.util.NavigationHelper; | ||||
| import org.schabi.newpipe.util.ServiceHelper; | ||||
|  | ||||
| import java.io.IOException; | ||||
| import java.io.InterruptedIOException; | ||||
| import java.net.SocketException; | ||||
| import java.util.ArrayList; | ||||
| import java.util.Arrays; | ||||
| import java.util.HashMap; | ||||
| @@ -764,12 +760,7 @@ public class SearchFragment extends BaseListFragment<SearchInfo, ListExtractor.I | ||||
|                     if (listNotification.isOnNext()) { | ||||
|                         handleSuggestions(listNotification.getValue()); | ||||
|                     } else if (listNotification.isOnError()) { | ||||
|                         Throwable error = listNotification.getError(); | ||||
|                         if (!ExceptionUtils.hasAssignableCause(error, | ||||
|                                 IOException.class, SocketException.class, | ||||
|                                 InterruptedException.class, InterruptedIOException.class)) { | ||||
|                             onSuggestionError(error); | ||||
|                         } | ||||
|                         onSuggestionError(listNotification.getError()); | ||||
|                     } | ||||
|                 }); | ||||
|     } | ||||
|   | ||||
| @@ -52,6 +52,7 @@ import org.schabi.newpipe.local.feed.FeedDatabaseManager | ||||
| import org.schabi.newpipe.local.feed.service.FeedEventManager.Event.* | ||||
| import org.schabi.newpipe.local.feed.service.FeedEventManager.postEvent | ||||
| import org.schabi.newpipe.local.subscription.SubscriptionManager | ||||
| import org.schabi.newpipe.util.ExceptionUtils | ||||
| import org.schabi.newpipe.util.ExtractorHelper | ||||
| import java.io.IOException | ||||
| import java.util.* | ||||
| @@ -333,11 +334,12 @@ class FeedLoadService : Service() { | ||||
|                 val cause = error.cause | ||||
|  | ||||
|                 when { | ||||
|                     error is IOException -> throw error | ||||
|                     cause is IOException -> throw cause | ||||
|  | ||||
|                     error is ReCaptchaException -> throw error | ||||
|                     cause is ReCaptchaException -> throw cause | ||||
|  | ||||
|                     error is IOException -> throw error | ||||
|                     cause is IOException -> throw cause | ||||
|                     ExceptionUtils.isNetworkRelated(error) -> throw IOException(error) | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|   | ||||
| @@ -38,9 +38,9 @@ import org.schabi.newpipe.extractor.subscription.SubscriptionExtractor; | ||||
| import org.schabi.newpipe.local.subscription.SubscriptionManager; | ||||
| import org.schabi.newpipe.report.ErrorActivity; | ||||
| import org.schabi.newpipe.report.UserAction; | ||||
| import org.schabi.newpipe.util.ExceptionUtils; | ||||
|  | ||||
| import java.io.FileNotFoundException; | ||||
| import java.io.IOException; | ||||
| import java.util.Collections; | ||||
| import java.util.concurrent.TimeUnit; | ||||
| import java.util.concurrent.atomic.AtomicInteger; | ||||
| @@ -227,7 +227,7 @@ public abstract class BaseImportExportService extends Service { | ||||
|             message = getString(R.string.invalid_source); | ||||
|         } else if (error instanceof FileNotFoundException) { | ||||
|             message = getString(R.string.invalid_file); | ||||
|         } else if (error instanceof IOException) { | ||||
|         } else if (ExceptionUtils.isNetworkRelated(error)) { | ||||
|             message = getString(R.string.network_error); | ||||
|         } | ||||
|         return message; | ||||
|   | ||||
| @@ -35,6 +35,7 @@ import org.schabi.newpipe.extractor.NewPipe; | ||||
| import org.schabi.newpipe.extractor.channel.ChannelInfo; | ||||
| import org.schabi.newpipe.extractor.subscription.SubscriptionItem; | ||||
| import org.schabi.newpipe.util.Constants; | ||||
| import org.schabi.newpipe.util.ExceptionUtils; | ||||
| import org.schabi.newpipe.util.ExtractorHelper; | ||||
|  | ||||
| import java.io.File; | ||||
| @@ -245,8 +246,10 @@ public class SubscriptionsImportService extends BaseImportExportService { | ||||
|                 final Throwable cause = error.getCause(); | ||||
|                 if (error instanceof IOException) { | ||||
|                     throw (IOException) error; | ||||
|                 } else if (cause != null && cause instanceof IOException) { | ||||
|                 } else if (cause instanceof IOException) { | ||||
|                     throw (IOException) cause; | ||||
|                 } else if (ExceptionUtils.isNetworkRelated(error)) { | ||||
|                     throw new IOException(error); | ||||
|                 } | ||||
|  | ||||
|                 eventListener.onItemCompleted(""); | ||||
|   | ||||
| @@ -51,7 +51,6 @@ import org.schabi.newpipe.extractor.suggestion.SuggestionExtractor; | ||||
| import org.schabi.newpipe.report.ErrorActivity; | ||||
| import org.schabi.newpipe.report.UserAction; | ||||
|  | ||||
| import java.io.IOException; | ||||
| import java.util.Collections; | ||||
| import java.util.List; | ||||
|  | ||||
| @@ -288,7 +287,7 @@ public final class ExtractorHelper { | ||||
|                 Intent intent = new Intent(context, ReCaptchaActivity.class); | ||||
|                 intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); | ||||
|                 context.startActivity(intent); | ||||
|             } else if (exception instanceof IOException) { | ||||
|             } else if (ExceptionUtils.isNetworkRelated(exception)) { | ||||
|                 Toast.makeText(context, R.string.network_error, Toast.LENGTH_LONG).show(); | ||||
|             } else if (exception instanceof ContentNotAvailableException) { | ||||
|                 Toast.makeText(context, R.string.content_not_available, Toast.LENGTH_LONG).show(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Mauricio Colli
					Mauricio Colli