mirror of
https://github.com/dart-lang/sdk
synced 2024-09-18 20:41:24 +00:00
30beab0f43
* Add team "groups" in tools/OWNERS_<group name>. * Add top-level OWNERS as a fallback. * Add OWNERS for all top-level directories. * Add OWNERS to all packages. For additional background information see go/dart-sdk-owners. TEST=No op until code-owners is enabled. Bug: b/200915407 Change-Id: I7fe6116cc599c749cd50ca16151d6d6a801d99d7 Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/229147 Reviewed-by: Jonas Termansen <sortie@google.com> |
||
---|---|---|
.. | ||
lib | ||
test | ||
analysis_options.yaml | ||
LICENSE | ||
OWNERS | ||
pubspec.yaml | ||
README.md |
telemetry
A library to facilitate reporting analytics and crash reports.
Analytics
This library is designed to allow all Dart SDK tools to easily send analytics information and crash reports. The tools share a common setting to configure sending analytics data. To use this library for a specific tool:
import 'package:telemetry/telemetry.dart';
import 'package:usage/usage.dart';
main() async {
final String myAppTrackingID = ...;
final String myAppName = ...;
Analytics analytics = createAnalyticsInstance(myAppTrackingID, myAppName);
...
analytics.sendScreenView('home');
...
await analytics.waitForLastPing();
}
The analytics object reads from the correct user configuration file automatically without any additional configuration. Analytics will not be sent if the user has opted-out.
Crash reporting
To use the crash reporting functionality, import crash_reporting.dart
, and
create a new CrashReportSender
instance:
import 'package:telemetry/crash_reporting.dart';
main() {
Analytics analytics = ...;
CrashReportSender sender = new CrashReportSender(analytics);
try {
...
} catch (e, st) {
sender.sendReport(e, st);
}
}
Crash reports will only be sent if the cooresponding [Analytics] object is configured to send analytics.