unnecessary_
                  Avoid wrapping fields in getters and setters just to be "safe".
Details
#From Effective Dart:
AVOID wrapping fields in getters and setters just to be "safe".
In Java and C#, it's common to hide all fields behind getters and setters (or properties in C#), even if the implementation just forwards to the field. That way, if you ever need to do more work in those members, you can do it without needing to touch the callsites. This is because calling a getter method is different than accessing a field in Java, and accessing a property isn't binary-compatible with accessing a raw field in C#.
Dart doesn't have this limitation. Fields and getters/setters are completely indistinguishable. You can expose a field in a class and later wrap it in a getter and setter without having to touch any code that uses that field.
BAD:
class Box {
  var _contents;
  get contents => _contents;
  set contents(value) {
    _contents = value;
  }
}
GOOD:
class Box {
  var contents;
}
Enable
#
                  To enable the unnecessary_getters_setters rule, add unnecessary_getters_setters
                   under
                  linter > rules in your analysis_options.yaml
                   file:
                
linter:
  rules:
    - unnecessary_getters_setters
                  If you're instead using the YAML map syntax to configure linter rules,
                  add unnecessary_getters_setters: true under linter > rules:
                
linter:
  rules:
    unnecessary_getters_setters: true
Unless stated otherwise, the documentation on this site reflects Dart 3.9.2. Report an issue.