添加debug

This commit is contained in:
LollipopKit
2021-09-13 14:58:08 +08:00
parent 4dd509a1d9
commit e804ade452
10 changed files with 287 additions and 28 deletions

View File

@@ -1,6 +1,60 @@
import 'package:flutter/material.dart';
import 'package:toolbox/app.dart';
import 'dart:async';
void main() {
runApp(const MyApp());
import 'package:flutter/material.dart';
import 'package:hive_flutter/hive_flutter.dart';
import 'package:provider/provider.dart';
import 'package:toolbox/app.dart';
import 'package:toolbox/core/analysis.dart';
import 'package:toolbox/data/provider/app.dart';
import 'package:toolbox/data/provider/debug.dart';
import 'package:toolbox/locator.dart';
Future<void> initApp() async {
await Hive.initFlutter();
await setupLocator();
}
void runInZone(dynamic Function() body) {
final zoneSpec = ZoneSpecification(
print: (Zone self, ZoneDelegate parent, Zone zone, String line) {
parent.print(zone, line);
// This is a hack to avoid
// `setState() or markNeedsBuild() called during build`
// error.
Future.delayed(const Duration(milliseconds: 1), () {
final debugProvider = locator<DebugProvider>();
debugProvider.addText(line);
});
},
);
runZonedGuarded(
body,
onError,
zoneSpecification: zoneSpec,
);
}
void onError(Object obj, StackTrace stack) {
print('error: $obj');
Analysis.recordException(obj);
final debugProvider = locator<DebugProvider>();
debugProvider.addError(obj);
debugProvider.addError(stack);
}
Future<void> main() async {
runInZone(() async {
await initApp();
runApp(
MultiProvider(
providers: [
ChangeNotifierProvider(create: (_) => locator<AppProvider>()),
ChangeNotifierProvider(create: (_) => locator<DebugProvider>()),
],
child: const MyApp(),
),
);
});
}