- Frugal Cafe
- Posts
- FC76: NDepend, with so much code analysis, code should be great?
FC76: NDepend, with so much code analysis, code should be great?
What kind of code quality you are really spending time on?
data:image/s3,"s3://crabby-images/cf89e/cf89eec0d0f4d49a5f7f206a987bf28f4296490b" alt=""
NDepend is supposed to offer “an in-depth .NET code quality management experience”. So you would expect itself to have great code quality, right?
Let’s take a look at NDepends.PowerTools source code which is open source. Here is from AppWordsPowerTool:
data:image/s3,"s3://crabby-images/81427/814279c41238b1052a1bba995799390dc713d449" alt=""
If you read Frugal Cafe newsletters, you can easily smell issues: the first five ToList calls are not needed, and there are lots of duplicating dictionary accesses in the inner foreach loop.
Now let’s check ExtraWordsFromIdentifier implementation:
data:image/s3,"s3://crabby-images/678b1/678b1acc6dbcf592ea72114f4196c253853ede59" alt=""
string.Split is not efficient, const char array is allocated every time, word list is not needed, the best solution is to use substrings.
Digging deeper:
data:image/s3,"s3://crabby-images/a8720/a87208ad996ce6e9eb10e27c5b6c27c14cd59cb2" alt=""
String list and StringBuilder are not needed. Notice StringBuilder is allocated multiple times here. There is no need to call string.ToCharArray. Goto statements can be easily avoided.
data:image/s3,"s3://crabby-images/64a1d/64a1da3ec787c6c54f1729b835372bb4b1d7f24d" alt=""
Multiple string.Replace(string, string) calls are expensive. The Pascal casing implementation is slow. Most of such casing can be avoided if you just use StringComparer.OrdinalIgnoreCase.
Next:
data:image/s3,"s3://crabby-images/f3c35/f3c35534ad15ecd381d5990f420ebf30b1da0003" alt=""
Notice this method is accepting IEnumerable<string> and returning it, but the actual type is List<string>.
Here is how the final dictionary is used:
data:image/s3,"s3://crabby-images/276af/276afe1bc76c2d0e7fa5b161df80c0539d032d90" alt=""
More inefficient LINQ usage. You just need a key value pair array and copy from the dictionary to it. The sorting can be implemented by using y.Weight.CompareTo(x.Weight).
More questionable methods:
data:image/s3,"s3://crabby-images/e241c/e241c6ce688e858458e12047523eb5e34d105755" alt=""
Isn’t it just i.ToString(“N0”).Replace(‘,’, ‘ ‘)?
What kind of code quality you are really spending time on?