-
Notifications
You must be signed in to change notification settings - Fork 70
/
analysis_options.yaml
121 lines (117 loc) · 4.38 KB
/
analysis_options.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
# pedantic has a strong foundation, but right now they only enable a small set of lints
# we'll use them as a base, and add on the additional ones that our team has agreed upon.
include: package:pedantic/analysis_options.yaml
analyzer:
strong-mode:
implicit-dynamic: false
errors:
missing_required_param: warning
missing_return: warning
implementation_imports: warning
todo: ignore
exclude:
linter:
rules:
# These are specified by effective dart guidelines, but are not yet in pedantic
- avoid_classes_with_only_static_members
# - avoid_catches_without_on_clauses -- pedeantic dart disagrees for valid reasons
# - avoid_function_literals_in_foreach_calls
- avoid_null_checks_in_equality_operators
# - avoid_positional_boolean_parameters -- too many false positives, not enough of an issue
- avoid_private_typedef_functions
- avoid_returning_null
- avoid_returning_this
- avoid_setters_without_getters
- camel_case_types
- constant_identifier_names
- directives_ordering
- file_names
- hash_and_equals
- non_constant_identifier_names
# - omit_local_variable_types
- one_member_abstracts
- package_api_docs
- prefer_adjacent_string_concatenation
- prefer_collection_literals
- prefer_final_fields
- prefer_function_declarations_over_variables
- prefer_generic_function_type_aliases
- prefer_initializing_formals
- prefer_interpolation_to_compose_strings
- public_member_api_docs
- type_annotate_public_apis
- unnecessary_brace_in_string_interps
- unnecessary_getters_setters
- unnecessary_lambdas
- unnecessary_this
# - use_setters_to_change_properties -- too many false positives... pedantic chose to not enforce it as well
- use_to_and_as_if_applicable
# These are not specified by pedantic dart
- always_declare_return_types
- always_put_control_body_on_new_line
- always_require_non_null_named_parameters
- annotate_overrides
- avoid_field_initializers_in_const_classes
- avoid_renaming_method_parameters
- avoid_returning_null_for_void
- avoid_slow_async_io
- avoid_unused_constructor_parameters
- avoid_void_async
- cancel_subscriptions
- control_flow_in_finally
- empty_statements
- flutter_style_todos
- implementation_imports
- iterable_contains_unrelated_type
- list_remove_unrelated_type
- no_adjacent_strings_in_list
- overridden_fields
- package_names
- package_prefixed_library_names
- prefer_asserts_in_initializer_lists
- prefer_conditional_assignment
- prefer_const_constructors
- prefer_const_constructors_in_immutables
- prefer_const_declarations
- prefer_const_literals_to_create_immutables
- prefer_final_locals
- prefer_foreach
- prefer_single_quotes
- prefer_typing_uninitialized_variables
- prefer_void_to_null
- sort_constructors_first
- sort_pub_dependencies
- sort_unnamed_constructors_first
- test_types_in_equals
- throw_in_finally
- unnecessary_null_aware_assignments
- unnecessary_overrides
- unnecessary_parenthesis
- unnecessary_statements
#Possible new rules to add
- avoid_returning_null_for_future
- literal_only_boolean_expressions
# - always_put_required_named_parameters_first -- seems like a good idea, but requires adjusting a lot of code
- avoid_bool_literals_in_conditional_expressions
- avoid_catching_errors
# - avoid_types_on_closure_parameters -- is great most of the time, but is necessary often in tests... we should review
# - cascade_invocations -- is great for production code... causes a lot of noise with GWT in tests -- puts multiple thens in a single line
- join_return_with_assignment
- only_throw_errors
- parameter_assignments
- prefer_constructors_over_static_methods
# - prefer_expression_function_bodies -- LINTs on widget build methods...
- prefer_final_in_for_each
- prefer_for_elements_to_map_fromIterable
- prefer_if_elements_to_conditional_expressions
- prefer_if_null_operators
- prefer_inlined_adds
- prefer_null_aware_operators
- prefer_spread_collections
- provide_deprecation_message
- sort_child_properties_last
- unnecessary_await_in_return
- prefer_relative_imports
- avoid_equals_and_hash_code_on_mutable_classes
- avoid_unnecessary_containers
- prefer_is_not_operator