-
Notifications
You must be signed in to change notification settings - Fork 4
Gendarme.Rules.Maintainability.AvoidUnnecessarySpecializationRule(2.10)
Sebastien Pouliot edited this page Jan 22, 2011
·
2 revisions
Assembly: Gendarme.Rules.Maintainability
Version: 2.10
This rule checks methods for over specialized parameters - i.e. parameter types that are unnecessarily specialized with respect to what the method needs to perform its job. This often impairs the reusability of the method. If a problem is found the rule will suggest the most general type, or interface, required for the method to work.
Bad example:
public class DefaultEqualityComparer : IEqualityComparer {
public int GetHashCode (object obj)
{
return o.GetHashCode ();
}
}
public int Bad (DefaultEqualityComparer ec, object o)
{
return ec.GetHashCode (o);
}
Good example:
public class DefaultEqualityComparer : IEqualityComparer {
public int GetHashCode (object obj)
{
return o.GetHashCode ();
}
}
public int Good (IEqualityComparer ec, object o)
{
return ec.GetHashCode (o);
}
- This rule is available since Gendarme 2.0
Note that this page was autogenerated (3/17/2011 9:31:58 PM) based on the xmldoc
comments inside the rules source code and cannot be edited from this wiki.
Please report any documentation errors, typos or suggestions to the
Gendarme Mailing List. Thanks!