Designing a plug-in system
Posted
by
madflame991
on Programmers
See other posts from Programmers
or by madflame991
Published on 2012-11-23T09:17:19Z
Indexed on
2012/11/23
11:15 UTC
Read the original article
Hit count: 290
api-design
|plugins
I'm working on a Java project and I would like to add a plug-in system. More precisely, I would like to let the user design his own module, pack it into a jar, leave it in a "plugins/" subfolder of my application and be done with it. I've managed to get a child classloader to instantiate objects of classes located in external jars, but now I'm facing a design dilemma:
Say Joe makes a plug-in and he packs it in joeplugin.jar. I would really like Joe to have a class named "instantiation.Factory" and I would also like everyone to have this class with this exact location and name. (This factory class obviously implements a interface that I provide and through it I get what I want from the plug-in.) If Joe wouldn't be restricted in this way I would have to look into his entire jar for some class that implements my factory interface and I don't want to imagine how complicated things get.
So my question is: should I enforce a strict naming convention for this single class? I have no idea how plug-in systems work.
© Programmers or respective owner