Refactoring Replace Delegation with Inheritance
A class contains many simple methods that delegate to all methods of another class.
Make the class a delegate inheritor, which makes the delegating methods unnecessary.
Delegation is a more flexible approach than inheritance, since it allows changing how delegation is implemented and placing other classes there as well. Nonetheless, delegation stop being beneficial if you delegate actions to only one class and all of its public methods.
In such a case, if you replace delegation with inheritance, you cleanse the class of a large number of delegating methods and spare yourself from needing to create them for each new delegate class method.
- Reduces code length. All these delegating methods are no longer necessary.
When Not to Use
Do not use this technique if the class contains delegation to only a portion of the public methods of the delegate class. By doing so, you would violate the Liskov substitution principle.
This technique can be used only if the class still does not have parents.
How to Refactor
Make the class a subclass of the delegate class.
Place the current object in a field containing a reference to the delegate object.
Delete the methods with simple delegation one by one. If their names were different, use Rename Method to give all the methods a single name.
Replace all references to the delegate field with references to the current object.
Remove the delegate field.
Tired of reading?
No wonder, there are 7 hours worth of the text on this website.
Try our interactive course on refactoring. It offers less boring approach to learning new stuff.Let's see...