From 316647554600cfe88362ebaf9837e8d1c18a1b4c Mon Sep 17 00:00:00 2001 From: Abestanis Date: Fri, 24 May 2024 03:17:51 +0200 Subject: [PATCH] Restore reporting uncaught async errors in the app --- lib/main.dart | 49 +++++++++++++++++++++++-------------------------- 1 file changed, 23 insertions(+), 26 deletions(-) diff --git a/lib/main.dart b/lib/main.dart index 01e3dfdec..5904907bc 100644 --- a/lib/main.dart +++ b/lib/main.dart @@ -66,30 +66,29 @@ class _WidgetsBindingObserver extends WidgetsBindingObserver { } Future main() async { - // Disabling automatic system UI adjustment, which causes system nav bar - // color to be reverted to black when the bottom player route is being expanded. - // - // Related to https://github.com/flutter/flutter/issues/40590 - final WidgetsBinding binding = WidgetsFlutterBinding.ensureInitialized(); - binding.renderView.automaticSystemUiAdjustment = false; - await NFPrefs.initialize(); - - await Firebase.initializeApp(); - if (kDebugMode) { - FirebaseFunctions.instance.useFunctionsEmulator('http://localhost/', 5001); - - // Force disable Crashlytics collection while doing every day development. - // Temporarily toggle this to true if you want to test crash reporting in your app. - await FirebaseCrashlytics.instance.setCrashlyticsCollectionEnabled(false); - } - - Isolate.current.addErrorListener(RawReceivePort((pair) async { - final List errorAndStacktrace = pair; - await reportError(errorAndStacktrace.first, errorAndStacktrace.last); - }).sendPort); - FlutterError.onError = reportFlutterError; + runZonedGuarded(() async { + // Disabling automatic system UI adjustment, which causes system nav bar + // color to be reverted to black when the bottom player route is being expanded. + // + // Related to https://github.com/flutter/flutter/issues/40590 + final WidgetsBinding binding = WidgetsFlutterBinding.ensureInitialized(); + binding.renderView.automaticSystemUiAdjustment = false; + await NFPrefs.initialize(); + + await Firebase.initializeApp(); + if (kDebugMode) { + FirebaseFunctions.instance.useFunctionsEmulator('http://localhost/', 5001); + + // Force disable Crashlytics collection while doing every day development. + // Temporarily toggle this to true if you want to test crash reporting in your app. + await FirebaseCrashlytics.instance.setCrashlyticsCollectionEnabled(false); + } - try { + Isolate.current.addErrorListener(RawReceivePort((pair) async { + final List errorAndStacktrace = pair; + await reportError(errorAndStacktrace.first, errorAndStacktrace.last); + }).sendPort); + FlutterError.onError = reportFlutterError; WidgetsBinding.instance.addObserver(_WidgetsBindingObserver()); await DeviceInfoControl.instance.init(); @@ -98,9 +97,7 @@ Future main() async { await Permissions.instance.init(); await ContentControl.instance.init(); runApp(const ProviderScope(child: App())); - } catch (error, stacktrace) { - await reportError(error, stacktrace); - } + }, reportError); } class App extends StatefulWidget {