From 74ac6ea26f3a43e36c4f935becd2e43d9cafb52b Mon Sep 17 00:00:00 2001 From: Walter Huf Date: Tue, 22 Oct 2024 19:32:07 -0700 Subject: [PATCH] Hopefully catch disconnection exceptions better --- .../java/me/hufman/androidautoidrive/CarThread.kt | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/app/src/main/java/me/hufman/androidautoidrive/CarThread.kt b/app/src/main/java/me/hufman/androidautoidrive/CarThread.kt index 79e893cd4..c03a00347 100644 --- a/app/src/main/java/me/hufman/androidautoidrive/CarThread.kt +++ b/app/src/main/java/me/hufman/androidautoidrive/CarThread.kt @@ -35,19 +35,23 @@ class CarThread(name: String, var runnable: () -> (Unit)): Thread(name) { } catch (e: IllegalStateException) { // posted to a dead handler Log.i(TAG, "Shutting down thread $name due to IllegalStateException: $e", e) - } catch (e: RuntimeException) { - // phone was unplugged during an RPC command - Log.i(TAG, "Shutting down thread $name due to RuntimeException: $e", e) } catch (e: org.apache.etch.util.TimeoutException) { // phone was unplugged during an RPC command Log.i(TAG, "Shutting down thread $name due to Etch TimeoutException") + } catch (e: RuntimeException) { + // phone was unplugged during an RPC command + Log.i(TAG, "Shutting down thread $name due to RuntimeException: $e", e) } catch (e: IOException) { - val bmwException = e.cause as? BMWRemoting.ServiceException + val cause = e.cause if (!iDriveConnectionObserver.isConnected) { // the car is no longer connected // so this is most likely a crash caused by the closed connection Log.i(TAG, "Shutting down thread $name due to disconnection") - } else if (bmwException?.errorMsg?.contains("RHMI application was already connected") == true) { + } else if (cause is org.apache.etch.util.TimeoutException) { + Log.i(TAG, "Shutting down thread $name due to Etch TimeoutException") + } else if (cause is RuntimeException) { + Log.i(TAG, "Shutting down thread $name due to RuntimeException: $cause", cause) + } else if (cause is BMWRemoting.ServiceException && cause.errorMsg.contains("RHMI application was already connected")) { // sometimes, the BCL tunnel blips during the start of the connection // and so previously-initialized apps are still "in the car" though the tunnel has since restarted // and so the car complains that the app is already connected