Shotgun Surgery
Shotgun Surgery resembles Divergent Change but is actually the opposite smell. Divergent Change is when many changes are made to a single class. Shotgun Surgery refers to when a single change is made to multiple classes simultaneously.
Signs and Symptoms
Making any modifications requires that you make many small changes to many different classes.
data:image/s3,"s3://crabby-images/75998/7599886e1d2b86338f6fedd51672d5ed076ec14c" alt=""
Reasons for the Problem
A single responsibility has been split up among a large number of classes. This can happen after overzealous application of Divergent Change.
data:image/s3,"s3://crabby-images/a3c1d/a3c1d33f4550f4de375023d0c6accb4c3190c408" alt=""
Treatment
-
Use Move Method and Move Field to move existing class behaviors into a single class. If there's no class appropriate for this, create a new one.
-
If moving code to the same class leaves the original classes almost empty, try to get rid of these now-redundant classes via Inline Class.
data:image/s3,"s3://crabby-images/3f1e2/3f1e22ae01860ed4f83baf0f469948306e16a333" alt=""
Payoff
-
Better organization.
-
Less code duplication.
-
Easier maintenance.