Middle Man
Signs and Symptoms
If a class performs only one action, delegating work to another class, why does it exist at all?
data:image/s3,"s3://crabby-images/45242/452428f3e641efd6c3b139891b6ef76bc7de595b" alt=""
Reasons for the Problem
This smell can be the result of overzealous elimination of Message Chains.
In other cases, it can be the result of the useful work of a class being gradually moved to other classes. The class remains as an empty shell that does not do anything other than delegate.
Treatment
- If most of a method’s classes delegate to another class, Remove Middle Man is in order.
Payoff
- Less bulky code.
data:image/s3,"s3://crabby-images/582f0/582f06bc642700d093d66c9ac1eb5b5337cac612" alt=""
When to Ignore
Do not delete middle man that have been created for a reason: