Skip to content

Do not break on exceptions thrown in undebuggable code if caught in undebuggable code #5883

@brianquinlan

Description

@brianquinlan

There are several issues where users were confused by the the "Break on all exceptions" option when an exception is thrown in core library code and handled in core library code, e.g.
dart-lang/sdk#52615
dart-lang/sdk#52423

I proposed that, by default, if an exception is thrown in code that is not debuggable and will be caught in code that is not debuggable, then the debugger will not break even if "Break on all exceptions" is enabled.

For example:

part of dart.core

void _foo() {
  throw Exception('foo');
}

void bar() {
  try {
   _foo();
  } on Exception {};
}

Calling bar should not cause the debugger to break on throw Exception('foo'); because the exception is both throw and caught in undebuggable code i.e. it is just an implementation detail of bar.

Another example:

part of dart.core

void _foo() {
  throw Exception('foo');
}

void bar() {
   _foo();
}

// User code:
void main() {
  try {
    bar();
  } on Exception {}
}

Calling bar should cause the debugger to break on throw Exception('foo'); because the exception is caught in debuggable code.

This UX will require VM changes.

Metadata

Metadata

Assignees

No one assigned

    Labels

    P2important to work on, but not at the top of the work list.

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions