avoid-unused-parameters
Checks for unused parameters inside a function or method body.
For overridden methods suggests renaming unused parameters to _, __, etc.
info
Abstract classes are completely ignored by the rule to avoid redundant checks for potentially overridden methods.
⚙️ Config
Set ignore-inline-functions
(default is true
) to ignore inline functions (example). Default value is set to true
for backward compatibility and can be changed in the future.
analysis_options.yaml
dart_code_metrics:
rules:
- avoid-unused-parameters:
ignore-inline-functions: true
Example
❌ Bad:
// LINT: Parameter is not used.
// Try removing it, renaming to _ or referencing it in code.
void someFunction(String s) {
return;
}
class SomeClass {
// LINT: Parameter is not used.
// Try removing it, renaming to _ or referencing it in code.
void method(String s) {
return;
}
}
class SomeClass extends AnotherClass {
// LINT: Parameter is not used.
// Try removing it, renaming to _ or referencing it in code.
void method(String s) {}
}
✅ Good:
void someOtherFunction() {
return;
}
class SomeOtherClass {
void method() {
return;
}
}
void someOtherFunction(String s) {
print(s);
return;
}
class SomeOtherClass {
void method(String s) {
print(s);
return;
}
}
class SomeOtherClass extends AnotherClass {
void method(String _) {}
}
abstract class SomeOtherClass {
void method(String s);
}
Example with "ignore-inline-functions"
Config
analysis_options.yaml
dart_code_metrics:
rules:
- avoid-unused-parameters:
ignore-inline-functions: false
❌ Bad:
class TestClass {
void _someNamedCallback({required Function(String, int) callback}) {
callback();
}
void _anotherMethod() {
// LINT: Parameter is not used.
// Try removing it, renaming to _ or referencing it in code.
_someNamedCallback(callback: (value, counter) {
print(value);
});
}
}