-
Notifications
You must be signed in to change notification settings - Fork 4
Gendarme.Rules.Smells.AvoidSwitchStatementsRule(git)
Sebastien Pouliot edited this page Mar 2, 2011
·
1 revision
Assembly: Gendarme.Rules.Smells
Version: git
This rule checks for the Switch Statements smell. This can lead to code duplication, because the same switch could be repeated in various places in your program. Also, if need to do a little change, you may have to change every switch statement. The preferred way to do this is with virtual methods and polymorphism.
Bad example:
int balance = 0;
foreach (Movie movie in movies) {
switch (movie.GetTypeCode ()) {
case MovieType.OldMovie: {
balance += movie.DaysRented * movie.Price / 2;
break;
}
case MovieType.ChildMovie: {
//its an special bargain !!
balance += movie.Price;
break;
}
case MovieType.NewMovie: {
balance += (movie.DaysRented + 1) * movie.Price;
break:
}
}
}
Good example:
abstract class Movie {
abstract int GetPrice ();
}
class OldMovie : Movie {
public override int GetPrice ()
{
return DaysRented * Price / 2;
}
}
class ChildMovie : Movie {
public override int GetPrice ()
{
return movie.Price;
}
}
class NewMovie : Movie {
public override int GetPrice ()
{
return (DaysRented + 1) * Price;
}
}
int balance = 0;
foreach (Movie movie in movies) {
balance += movie.GetPrice ()
}
- This rule is available since Gendarme 2.4
You can browse the latest source code of this rule on github.com
Note that this page was autogenerated (3/17/2011 1:55:44 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!