Introducing package:flutter_lints
Summary
#The package:flutter_lints
defines the latest set of recommended lints
that encourage good coding practices for Flutter apps, packages, and plugins.
Projects created with flutter create
using Flutter version 2.5 or newer are
already enabled to use the latest set of recommended lints. Projects created
prior to that version can upgrade to it with the instructions in this guide.
Context
#Prior to the introduction of package:flutter_lints
, the Flutter framework
shipped with a set of lints defined in analysis_options_user.yaml
that was
used by the dart analyzer to identify code issues if a Flutter project
didn't define a custom analysis_options.yaml
file.
Since analysis_options_user.yaml
was tied to a particular framework version,
it was difficult to evolve without breaking
existing apps, packages, and plugins. As a result of that, the lints
defined in analysis_options_user.yaml
are heavily outdated. To fix this,
package:flutter_lints
was created. The package versions the lint set to enable
evolving it without breaking existing projects. Since the package builds on
Dart's package:lints
it also aligns the lints recommended for Flutter
projects with the rest of the Dart ecosystem.
Migration guide
#Follow these steps to migrate your Flutter project to use the latest recommended
lints from package:flutter_lints
:
Add a dev_dependency on package:flutter_lints
to your project's pubspec.yaml
by running flutter pub add --dev flutter_lints
in the root directory of the
project.
Create an analysis_options.yaml
file in the root directory of your project
(next to the pubspec.yaml
file) with the following content:
include: package:flutter_lints/flutter.yaml
The newly activated lint set may identify some new issues in your code. To find
them, open your project in an IDE with Dart support or run flutter analyze
on the command line. You may be able to fix some of the reported issues
automatically by running dart fix --apply
in the root directory of your
project.
Existing custom analysis_options.yaml file
#If your project already has a custom analysis_options.yaml
file at its root,
add include: package:flutter_lints/flutter.yaml
to it at the top to activate
the lints from package:flutter_lints
. If your analysis_options.yaml
already
contains an include:
directive you have to decide whether you want to keep
those lints or whether you want to replace it with the lints from
package:flutter_lints
because the Dart analyzer only supports one include:
directive per analysis_options.yaml
file.
Customizing the lints
#The lints activated for a given project can be further customized in the
analysis_options.yaml
file. This is shown in the example file below, which is
a reproduction of the analysis_options.yaml
file generated by flutter create
for new projects.
# This file configures the analyzer, which statically analyzes Dart code to
# check for errors, warnings, and lints.
#
# The issues identified by the analyzer are surfaced in the UI of Dart-enabled
# IDEs (https://dart.dev/tools#ides-and-editors). The analyzer can also be
# invoked from the command line by running `flutter analyze`.
# The following line activates a set of recommended lints for Flutter apps,
# packages, and plugins designed to encourage good coding practices.
include: package:flutter_lints/flutter.yaml
linter:
# The lint rules applied to this project can be customized in the
# section below to disable rules from the `package:flutter_lints/flutter.yaml`
# included above or to enable additional rules. A list of all available lints
# and their documentation is published at
# https://dart-lang.github.io/linter/lints/index.html.
#
# Instead of disabling a lint rule for the entire project in the
# section below, it can also be suppressed for a single line of code
# or a specific dart file by using the `// ignore: name_of_lint` and
# `// ignore_for_file: name_of_lint` syntax on the line or in the file
# producing the lint.
rules:
# avoid_print: false # Uncomment to disable the `avoid_print` rule
# prefer_single_quotes: true # Uncomment to enable the `prefer_single_quotes` rule
# Additional information about this file can be found at
# https://dart.dev/guides/language/analysis-options
Timeline
#Landed in version: 2.3.0-12.0.pre
In stable release: 2.5
References
#Documentation:
Relevant issue:
Relevant PRs:
除非另有说明,本文档之所提及适用于 Flutter 的最新稳定版本,本页面最后更新时间: 2024-09-09。 查看文档源码 或者 为本页面内容提出建议。