blob: 0aa3d7343a11a16740b9c8cd81f91e94e21e6811 [file] [log] [blame]
// Copyright (c) 2019, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
import 'package:analyzer/exception/exception.dart';
import 'package:analyzer/instrumentation/noop_service.dart';
import 'package:analyzer/instrumentation/plugin_data.dart';
import 'package:telemetry/crash_reporting.dart';
class CrashReportingInstrumentation extends NoopInstrumentationService {
final CrashReportSender reporter;
CrashReportingInstrumentation(this.reporter);
@override
void logException(dynamic exception, [StackTrace stackTrace]) {
if (exception is CaughtException) {
// Get the root CaughtException, which matters most for debugging.
CaughtException root = exception.rootCaughtException;
reporter
.sendReport(root.exception, root.stackTrace, comment: root.message)
.catchError((error) {
// We silently ignore errors sending crash reports (network issues, ...).
});
} else {
reporter
.sendReport(exception, stackTrace ?? StackTrace.current)
.catchError((error) {
// We silently ignore errors sending crash reports (network issues, ...).
});
}
}
@override
void logPluginException(
PluginData plugin,
dynamic exception,
StackTrace stackTrace,
) {
String comment = 'plugin: ${plugin.name}';
reporter
.sendReport(exception, stackTrace, comment: comment)
.catchError((error) {
// We silently ignore errors sending crash reports (network issues, ...).
});
}
}