| Index: pkg/stack_trace/README.md
|
| diff --git a/pkg/stack_trace/README.md b/pkg/stack_trace/README.md
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..6a8112a5523db72dfc96c0c45060729faa6e6c76
|
| --- /dev/null
|
| +++ b/pkg/stack_trace/README.md
|
| @@ -0,0 +1,57 @@
|
| +This library provides the ability to parse, inspect, and manipulate stack traces
|
| +produced by the underlying Dart implementation. It also provides functions to
|
| +produce string representations of stack traces in a more readable format than
|
| +the native [StackTrace] implementation.
|
| +
|
| +`Trace`s can be parsed from native [StackTrace]s using `Trace.from`, or captured
|
| +using `Trace.current`. Native [StackTrace]s can also be directly converted to
|
| +human-readable strings using `Trace.format`.
|
| +
|
| +[StackTrace]: http://api.dartlang.org/docs/releases/latest/dart_core/StackTrace.html
|
| +
|
| +Here's an example native stack trace from debugging this library:
|
| +
|
| + #0 Object.noSuchMethod (dart:core-patch:1884:25)
|
| + #1 Trace.terse.<anonymous closure> (file:///usr/local/google-old/home/goog/dart/dart/pkg/stack_trace/lib/src/trace.dart:47:21)
|
| + #2 IterableMixinWorkaround.reduce (dart:collection:29:29)
|
| + #3 List.reduce (dart:core-patch:1247:42)
|
| + #4 Trace.terse (file:///usr/local/google-old/home/goog/dart/dart/pkg/stack_trace/lib/src/trace.dart:40:35)
|
| + #5 format (file:///usr/local/google-old/home/goog/dart/dart/pkg/stack_trace/lib/stack_trace.dart:24:28)
|
| + #6 main.<anonymous closure> (file:///usr/local/google-old/home/goog/dart/dart/test.dart:21:29)
|
| + #7 _CatchErrorFuture._sendError (dart:async:525:24)
|
| + #8 _FutureImpl._setErrorWithoutAsyncTrace (dart:async:393:26)
|
| + #9 _FutureImpl._setError (dart:async:378:31)
|
| + #10 _ThenFuture._sendValue (dart:async:490:16)
|
| + #11 _FutureImpl._handleValue.<anonymous closure> (dart:async:349:28)
|
| + #12 Timer.run.<anonymous closure> (dart:async:2402:21)
|
| + #13 Timer.Timer.<anonymous closure> (dart:async-patch:15:15)
|
| +
|
| +and its human-readable representation:
|
| +
|
| + dart:core-patch Object.noSuchMethod
|
| + pkg/stack_trace/lib/src/trace.dart 47:21 Trace.terse.<fn>
|
| + dart:collection IterableMixinWorkaround.reduce
|
| + dart:core-patch List.reduce
|
| + pkg/stack_trace/lib/src/trace.dart 40:35 Trace.terse
|
| + pkg/stack_trace/lib/stack_trace.dart 24:28 format
|
| + test.dart 21:29 main.<fn>
|
| + dart:async _CatchErrorFuture._sendError
|
| + dart:async _FutureImpl._setErrorWithoutAsyncTrace
|
| + dart:async _FutureImpl._setError
|
| + dart:async _ThenFuture._sendValue
|
| + dart:async _FutureImpl._handleValue.<fn>
|
| + dart:async Timer.run.<fn>
|
| + dart:async-patch Timer.Timer.<fn>
|
| +
|
| +You can further clean up the stack trace using `Trace.terse`. This folds
|
| +together multiple stack frames from the Dart core libraries, so that only the
|
| +core library method that was directly called from user code is visible. For
|
| +example:
|
| +
|
| + dart:core Object.noSuchMethod
|
| + pkg/stack_trace/lib/src/trace.dart 47:21 Trace.terse.<fn>
|
| + dart:core List.reduce
|
| + pkg/stack_trace/lib/src/trace.dart 40:35 Trace.terse
|
| + pkg/stack_trace/lib/stack_trace.dart 24:28 format
|
| + test.dart 21:29 main.<fn>
|
| + dart:async Timer.Timer.<fn>
|
|
|