As I look at the experiences I've had handling difficult code written by other people, some patterns seem to emerge. One of the most persistent patterns that seem to be causing most of the software maintenance issues I've encountered is
people making shit too fucking complicated! And by that I mean people not following the principle "Keep it simple, stupid" (aka, K.I.S.S.).
There is one way of making shit complicated that I am attacking and that is
taking care of unnecessary use cases. In my opinion, the code that is most difficult to maintain is code, which has a lot of
what-ifs in it, a lot of
just in case handling. This coding strategy is the root of all evil, and together with premature optimization forms the two
black pillars of death. So here I'm going to try to make a distinction between:
(1) unnecessary code to solve a
necessary problem, and
(2) code to solve an unnecessary problem (the code in this case is also, by definition unnecessary).
The first case is about proposing a solution that's unnecessarily difficult, the second case is about proposing a solution that's not necessary at all. The first case is about overcomplicating the
solution space, while the second is about overcomplicating the
problem space.
What if the hero in our game is hanging down from a helicopter, and a bullet enters his left eye? Should we simulate the eye movement on the right eye as the bullet gets closer? What if one of his eyes gets streamed out in the process? What if there's an eye-patch on the left eye? Should we simulate it with cloth physics?
OK OK, stop right there. How about let's consider if this combination of circumstances needs to be handled at all?!
Life of a coder is difficult enough as it is, we shouldn't have to solve
imaginary, or
potential problems before solving real ones. One of the most obvious signs that code is solving an imaginary problem, is large amounts of boiler-plate code, a lot of methods and files that seem to be doing very little, as if the original author of the code had something grander in mind, and put in some code just in case. What's makes matters worse is that the code for solving a non-existing problem is living right alongside the code that solves an
actual problem. Then, the reader of the code in question has to not only understand
how this code solves an actual problem, but also
what other than the actual problem is this code trying to solve?
Continued in this post:
http://refactoraholic.blogspot.com/2011/04/kiss-part-ii.html