-
Notifications
You must be signed in to change notification settings - Fork 1.7k
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Add 'customRuleFactory' config option for pluggable RuleFactory #211
Conversation
Hi David. Thanks for putting this together. Apologies for the delay, I've been on vacation. I see the problem you have with this 'FactoryFactory'. My first thought was just to call this a RuleFactoryCreator then I re-read your comment above and saw that you suggested exactly the same thing :) I also thought we could take some inspiration from the strategy pattern and think of this thing as the 'RuleFactoryContext'. I agree the FactoryFactory is a rather embarrassing type to create, but leaving the name aside for a moment I also don't like that introducing this type makes it harder for people to understand how to use this new feature you've added. I can think of two options to push these dependencies into the RuleFactory interface so that they are made explicit:
void init(GenerationConfig generationConfig, Annotator annotator, SchemaStore schemaStore);
void setGenerationConfig(GenerationConfig generationConfig);
void setAnnotator (Annotator annotator);
void setSchemaStore(SchemaStore schemaStore); The latter would allow easier additions. Obviously there's no way of indicating in the type definition that these will be called before the RuleFactory is used, this would need to be done in the javadocs. However I think these are very easy to understand when people want to implement their own RuleFactory. What do you think? |
@davidpadbury Hi, are you still interested in including this in 0.4.5? |
Yes. Sorry. Been rather side tracked by real work. Should get to shortly. I expect to follow your recommendation. Likely with setters against an On Fri, Jul 25, 2014 at 9:02 AM, Joe Littlejohn notifications@github.com
|
Just pushed in an update to use custom instances of RuleFactory rather than a separate factory. Actually makes implementation of custom RuleFactories far prettier. What do you think? |
This looks great. Could you squash all these commits? I'll merge for Thanks again for contributing. I think a lot of people will find this
|
Has now been squashed. Any rough idea when you'll cut 0.4.5? Glad to have helped. The design of jsonschema2pojo seems very well done, a pleasure contributing too. |
Thanks, glad this is the case. I have no need to hold up 0.4.5, I'll release soon. |
As discussed in #210, this request adds supports for specifying a custom RuleFactory enabling consumers to hook in custom rules to modify generation behavior.
Please consider this initial request only an invitation to opine on the approach. Although the implemented behavior and IT successfully demonstrates the extension is possible, I'm rather horrified to have actually used a FactoryFactory.
The problem resides with that current a RuleFactory implementation depends on being passed the config, annotator, and schema store. Rather than invoke a particular constructor via reflection that feels awfully messy, I opted for creating something to have an interface with those dependencies and returning a RuleFactory. However we now have our FactoryFactory. I considered naming the thing a "creator" or something, but that seems to skirt around the issue.
What do you think? Is this exposing a design issue, or should we just name something less embarrassing and move on?