I am working on a program with a complex hierarchy of classes, and I want to subclass one of the objects a few steps down on that hierarchy. Do I have to create a parallel hierarchy to do this? Here is the problem:

AppController instantiates a Deduction object.
The Deduction object instantiates a DeductionLine object.
The DeductionLine object instantiates a Dependency object.

I want to subclass Dependency and override a few things. Can I do this without modifying DeductionLine?

If I understand it correctly, you already have a project that uses these classes, and now you have a second project that also wants to use the same code, but just for Dependency you want to use a specific subclass of it?

In this case I would consider to create a "factory" to create the Dependency object. A factory is a method that creates an instance of a class. Then you can define that this factory method has to be implemented for every project separately (therefore I would define it as a category in Obj-C). The factory then can return any subclass of Dependency as you like for that particular project.
But the original project has to be modified to use the factory also.

@interface Dependency (Factory)
- (Dependency *)createDependency;       // this is the factory
@end

The first project can provide an implementation of createDependency that just creates a Dependency object:

@implementation Dependency (Factory)
- (Dependency *)createDependency {
        return [[[Dependency alloc] init] autorelease];
}
@end

The second project can provide an implementation of createDependency that creates an instance of a subclass of Dependency:

@interface SubDependency : Dependency {
}
...
@end

@implementation Dependency (Factory)
- (Dependency *)createDependency {
        return [[[SubDependency alloc] init] autorelease];
}
@end

The code for your DeductionLine class has to be modified to always use that factory whenever it has to instantiate a Dependency object, of course.

Regards,
Mani
--
http://www.mani.de
iVolume - Loudness adjustment for iTunes.
LittleSecrets - The encrypted notepad.

_______________________________________________

Cocoa-dev mailing list (Cocoa-dev@lists.apple.com)

Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com

Help/Unsubscribe/Update your Subscription:
http://lists.apple.com/mailman/options/cocoa-dev/archive%40mail-archive.com

This email sent to [EMAIL PROTECTED]

Reply via email to