control_flow_in_finally   
            
            Avoid control flow in finally blocks.
This rule is available as of Dart 2.0.0.
Rule sets: recommended, flutter
Details
AVOID control flow leaving finally blocks.
Using control flow in finally blocks will inevitably cause unexpected behavior that is hard to debug.
BAD:
class BadReturn {
  double nonCompliantMethod() {
    try {
      return 1 / 0;
    } catch (e) {
      print(e);
    } finally {
      return 1.0; // LINT
    }
  }
}
BAD:
class BadContinue {
  double nonCompliantMethod() {
    for (var o in [1, 2]) {
      try {
        print(o / 0);
      } catch (e) {
        print(e);
      } finally {
        continue; // LINT
      }
    }
    return 1.0;
  }
}
BAD:
class BadBreak {
  double nonCompliantMethod() {
    for (var o in [1, 2]) {
      try {
        print(o / 0);
      } catch (e) {
        print(e);
      } finally {
        break; // LINT
      }
    }
    return 1.0;
  }
}
GOOD:
class Ok {
  double compliantMethod() {
    var i = 5;
    try {
      i = 1 / 0;
    } catch (e) {
      print(e); // OK
    }
    return i;
  }
}
Usage
To enable the control_flow_in_finally rule,
add control_flow_in_finally under linter > rules in your
analysis_options.yaml
file:
linter:
  rules:
    - control_flow_in_finally