veilidchat/lib/main.dart
Christien Rioux 0e4606f35e debugging
2024-06-06 07:49:42 -04:00

65 lines
1.9 KiB
Dart

import 'dart:async';
import 'dart:io';
import 'package:ansicolor/ansicolor.dart';
import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:flutter_translate/flutter_translate.dart';
import 'package:intl/date_symbol_data_local.dart';
import 'package:stack_trace/stack_trace.dart';
import 'app.dart';
import 'settings/preferences_repository.dart';
import 'theme/theme.dart';
import 'tools/tools.dart';
void main() async {
// Disable all debugprints in release mode
if (kReleaseMode) {
debugPrint = (message, {wrapWidth}) {};
}
// Print our PID for debugging
if (!kIsWeb) {
debugPrint('VeilidChat PID: $pid');
}
// Ansi colors
ansiColorDisabled = false;
Future<void> mainFunc() async {
// Logs
initLoggy();
// Prepare preferences from SharedPreferences and theme
WidgetsFlutterBinding.ensureInitialized();
await PreferencesRepository.instance.init();
final initialThemeData =
PreferencesRepository.instance.value.themePreferences.themeData();
// Manage window on desktop platforms
await initializeWindowControl();
// Make localization delegate
final localizationDelegate = await LocalizationDelegate.create(
fallbackLocale: 'en_US', supportedLocales: ['en_US']);
await initializeDateFormatting();
// Run the app
// Hot reloads will only restart this part, not Veilid
runApp(LocalizedApp(localizationDelegate,
VeilidChatApp(initialThemeData: initialThemeData)));
}
if (kDebugMode) {
// In debug mode, run the app without catching exceptions for debugging
// but do a much deeper async stack trace capture
await Chain.capture(mainFunc);
} else {
// Catch errors in production without killing the app
await runZonedGuarded(mainFunc, (error, stackTrace) {
log.error('Dart Runtime: {$error}\n{$stackTrace}');
});
}
}