equatable_lint 0.3.1
equatable_lint: ^0.3.1 copied to clipboard
This is a set of rules to make classes using Equatable more maintainable. We make sure here that every fields in an Equatable class is linked to the Equatable props getter.
We analyzed this package 12 days ago, and awarded it 80 pub points (of a possible 160):
10/10 points: Provide a valid pubspec.yaml
5/5 points: Provide a valid README.md
5/5 points: Provide a valid CHANGELOG.md
10/10 points: Use an OSI-approved license
Detected license: MIT.
10/10 points: 20% or more of the public API has dartdoc comments
5 out of 8 API elements (62.5 %) have documentation comments.
Some symbols that are missing documentation: const, equatable_lint, equatable_lint.EquatableLint.EquatableLint.new.
10/10 points: Package has an example
20/20 points: Supports 5 of 6 possible platforms (iOS, Android, Web, Windows, macOS, Linux)
-
✓ Android
-
✓ iOS
-
✓ Windows
-
✓ Linux
-
✓ macOS
These platforms are not supported:
Package not compatible with platform Web
Because:
package:equatable_lint/equatable_lint.dartthat imports:package:equatable_lint/src/lints/missing_field_in_equatable_props/missing_field_in_equatable_props.dartthat imports:package:equatable_lint/src/lints/missing_field_in_equatable_props/helpers/add_equatable_class_field_declaration_listener.dartthat imports:package:equatable_lint/src/helpers/get_equatable_props_expression_infos.dartthat imports:package:analyzer/dart/ast/ast.dartthat imports:package:analyzer/src/dart/ast/ast.dartthat imports:package:analyzer/src/generated/utilities_dart.dartthat imports:package:analyzer/src/dart/element/element.dartthat imports:package:analyzer/src/summary2/reference.dartthat imports:package:analyzer/dart/element/element.dartthat imports:package:analyzer/src/generated/engine.dartthat imports:package:analyzer/error/listener.dartthat imports:package:analyzer/error/error.dartthat imports:package:analyzer/src/error/error_code_values.g.dartthat imports:package:analyzer/src/generated/parser.dartthat imports:package:analyzer/src/fasta/ast_builder.dartthat imports:package:analyzer/src/dart/ast/extensions.dartthat imports:package:analyzer/dart/element/type.dartthat imports:package:analyzer/src/dart/element/type.dartthat imports:package:analyzer/src/dart/element/type_system.dartthat imports:package:analyzer/src/dart/resolver/flow_analysis_visitor.dartthat imports:package:analyzer/src/dart/element/type_schema.dartthat imports:package:analyzer/src/dart/element/type_visitor.dartthat imports:package:analyzer/src/summary2/named_type_builder.dartthat imports:package:analyzer/src/summary2/link.dartthat imports:package:analyzer/src/summary2/types_builder.dartthat imports:package:analyzer/src/dart/element/member.dartthat imports:package:analyzer/dart/analysis/session.dartthat imports:package:analyzer/file_system/file_system.dartthat imports:package:analyzer/src/file_system/file_system.dartthat imports:package:analyzer/src/util/uri.dartthat imports:package:analyzer/src/summary/package_bundle_reader.dartthat imports:package:analyzer/src/generated/source.dartthat imports:package:analyzer/src/context/source.dartthat imports:package:analyzer/src/workspace/pub.dartthat imports:package:analyzer/src/workspace/workspace.dartthat imports:package:analyzer/src/workspace/blaze.dartthat imports:package:analyzer/src/workspace/blaze_watcher.dartthat imports:package:watcher/watcher.dartthat imports:package:watcher/src/file_watcher/polling.dartthat imports:package:watcher/src/polling.dartthat imports:dart:io
0/50 points: code has no errors, warnings, lints, or formatting issues
ERROR: The method 'atNode' isn't defined for the type 'ErrorReporter'.
lib/src/lints/always_call_super_props_when_overriding_equatable_props/always_call_super_props_when_overriding_equatable_props.dart:29:16
╷
29 │ reporter.atNode(equatablePropsClassMember, _code);
│ ^^^^^^
╵
To reproduce make sure you are using the lints_core and run dart analyze lib/src/lints/always_call_super_props_when_overriding_equatable_props/always_call_super_props_when_overriding_equatable_props.dart
ERROR: The method 'atNode' isn't defined for the type 'ErrorReporter'.
lib/src/lints/missing_field_in_equatable_props/missing_field_in_equatable_props.dart:39:18
╷
39 │ reporter.atNode(fieldNode, _code);
│ ^^^^^^
╵
To reproduce make sure you are using the lints_core and run dart analyze lib/src/lints/missing_field_in_equatable_props/missing_field_in_equatable_props.dart
0/10 points: All of the package dependencies are supported in the latest version
| Package | Constraint | Compatible | Latest | Notes |
|---|---|---|---|---|
analyzer |
^6.4.1 |
6.4.1 | 9.0.0 | |
analyzer_plugin |
^0.11.2 |
0.11.3 | 0.13.11 | |
collection |
^1.16.0 |
1.19.1 | 1.19.1 | |
custom_lint_builder |
^0.6.4 |
0.6.4 | 0.8.1 | |
equatable |
^2.0.5 |
2.0.7 | 2.0.7 | |
source_gen |
^1.3.2 |
1.5.0 | 4.1.1 |
Transitive dependencies
| Package | Constraint | Compatible | Latest | Notes |
|---|---|---|---|---|
_fe_analyzer_shared |
- | 67.0.0 | 92.0.0 | |
args |
- | 2.7.0 | 2.7.0 | |
async |
- | 2.13.0 | 2.13.0 | |
boolean_selector |
- | 2.1.2 | 2.1.2 | |
build |
- | 2.4.1 | 4.0.3 | |
checked_yaml |
- | 2.0.4 | 2.0.4 | |
ci |
- | 0.1.0 | 0.1.0 | |
cli_util |
- | 0.4.2 | 0.4.2 | |
convert |
- | 3.1.2 | 3.1.2 | |
crypto |
- | 3.0.7 | 3.0.7 | |
custom_lint |
- | 0.6.4 | 0.8.1 | |
custom_lint_core |
- | 0.6.3 | 0.8.1 | |
dart_style |
- | 2.3.6 | 3.1.3 | |
file |
- | 7.0.1 | 7.0.1 | |
fixnum |
- | 1.1.1 | 1.1.1 | |
freezed_annotation |
- | 2.4.4 | 3.1.0 | |
glob |
- | 2.1.3 | 2.1.3 | |
hotreloader |
- | 4.3.0 | 4.3.0 | |
json_annotation |
- | 4.9.0 | 4.9.0 | |
logging |
- | 1.3.0 | 1.3.0 | |
matcher |
- | 0.12.18 | 0.12.18 | |
meta |
- | 1.17.0 | 1.17.0 | |
package_config |
- | 2.2.0 | 2.2.0 | |
path |
- | 1.9.1 | 1.9.1 | |
pub_semver |
- | 2.2.0 | 2.2.0 | |
pubspec_parse |
- | 1.5.0 | 1.5.0 | |
rxdart |
- | 0.27.7 | 0.28.0 | |
source_span |
- | 1.10.1 | 1.10.1 | |
stack_trace |
- | 1.12.1 | 1.12.1 | |
stream_channel |
- | 2.1.4 | 2.1.4 | |
stream_transform |
- | 2.1.1 | 2.1.1 | |
string_scanner |
- | 1.4.1 | 1.4.1 | |
term_glyph |
- | 1.2.2 | 1.2.2 | |
test_api |
- | 0.7.8 | 0.7.8 | |
typed_data |
- | 1.4.0 | 1.4.0 | |
uuid |
- | 4.5.2 | 4.5.2 | |
vm_service |
- | 15.0.2 | 15.0.2 | |
watcher |
- | 1.2.0 | 1.2.0 | |
yaml |
- | 3.1.3 | 3.1.3 |
To reproduce run dart pub outdated --no-dev-dependencies --up-to-date --no-dependency-overrides.
Found 4 issues. Showing the first 2:
The constraint `^6.4.1` on analyzer does not support the stable version `7.0.0`.
Try running dart pub upgrade --major-versions analyzer to update the constraint.
The constraint `^0.11.2` on analyzer_plugin does not support the stable version `0.12.0`.
Try running dart pub upgrade --major-versions analyzer_plugin to update the constraint.
10/10 points: Package supports latest stable Dart and Flutter SDKs
0/20 points: Compatible with dependency constraint lower bounds
downgrade analysis failed failed with 2 errors:
UNDEFINED_METHOD-lib/src/lints/always_call_super_props_when_overriding_equatable_props/always_call_super_props_when_overriding_equatable_props.dart:29:16- The method 'atNode' isn't defined for the type 'ErrorReporter'.UNDEFINED_METHOD-lib/src/lints/missing_field_in_equatable_props/missing_field_in_equatable_props.dart:39:18- The method 'atNode' isn't defined for the type 'ErrorReporter'.
Run dart pub downgrade and then dart analyze to reproduce the above problem.
You may run dart pub upgrade --tighten to update your dependency constraints, see dart.dev/go/downgrade-testing for details.
Analyzed with Pana 0.23.3, Dart 3.10.4.
Check the analysis log for details.