Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Revisit components APIs #30

Open
Voiteh opened this issue Aug 21, 2018 · 1 comment
Open

Revisit components APIs #30

Voiteh opened this issue Aug 21, 2018 · 1 comment
Assignees
Labels
API Change API change will be required Enhancement New feature or request P2 Priority 2

Comments

@Voiteh
Copy link
Owner

Voiteh commented Aug 21, 2018

  • Creator API cannot handle invariant type parameters
  • Creators won't be able to be findable using new Hashing algorithms it is bound to Matcher
  • Resolver API always requires Matcher
@Voiteh Voiteh added Enhancement New feature or request API Change API change will be required labels Aug 21, 2018
@Voiteh Voiteh added this to the Core 0.7.0 milestone Aug 21, 2018
@Voiteh Voiteh self-assigned this Aug 21, 2018
@Voiteh
Copy link
Owner Author

Voiteh commented Aug 23, 2018

There was an idea to create components using builder in some kind of like Validx has been using type parameters. The idea is not to create "generic" types perse so Converter<Integer,String> would be just Converter. Internally the provided types from Builder would be held and matched against if needed in Component class in some kind of Descriptor.

For example HashMapCreator

value hashMapCreator=Component.builder.parametrized.twice((TwoParametersBuilder<One,Two> builder) => builder.creator(() => 
...
}).build;

I don't think we can do such thing as there is no ability to constrain type parameters in such manner. so One would need to be constrain with given One satisfies Object


There is another proposition. There could be an internal API called Router. Routers would take part in finding of components. So before the whole finding algorithm would go on Routers would be matched against destination type declaration. If router would match, it would instantiate related Components with type parameters applied by reflection (clazz.memberApply...). Those components would be held till end of convertx.convert function execution for given convertion. In future it could be cached to improve performance (probably caching should be enabled through configuration of given Router). This approach would require that components are "provided" by type declaration rather than instantiated by the user itself, this would enforce thread safety of configurable components itself.

@Voiteh Voiteh modified the milestones: Core 0.7.0, API 0.8 Sep 7, 2018
@Voiteh Voiteh added the P2 Priority 2 label May 28, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
API Change API change will be required Enhancement New feature or request P2 Priority 2
Projects
None yet
Development

No branches or pull requests

1 participant