Contents

avoid_as

Contents

Avoid using as.

This rule has been removed as of the latest Dart releases.

Details

#

NOTE: This rule was removed from the SDK in Dart 3; it is no longer functional. Its advice is compiler-specific and mostly obsolete with null safety.

AVOID using as.

If you know the type is correct, use an assertion or assign to a more narrowly-typed variable (this avoids the type check in release mode; as is not compiled out in release mode). If you don't know whether the type is correct, check using is (this avoids the exception that as raises).

BAD:

dart
(pm as Person).firstName = 'Seth';

GOOD:

dart
if (pm is Person)
  pm.firstName = 'Seth';

but certainly not

BAD:

dart
try {
   (pm as Person).firstName = 'Seth';
} on CastError { }

Note that an exception is made in the case of dynamic since the cast has no performance impact.

OK:

dart
HasScrollDirection scrollable = renderObject as dynamic;

Usage

#

To enable the avoid_as rule, add avoid_as under linter > rules in your analysis_options.yaml file:

analysis_options.yaml
yaml
linter:
  rules:
    - avoid_as