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

[all] Replace the complex canCreate with deductionRule #3992

Open
wants to merge 30 commits into
base: master
Choose a base branch
from

Conversation

damienmarchal
Copy link
Contributor

This is a follow up #3990 but now we focus on the complex use cases of canCreate.


By submitting this pull request, I acknowledge that
I have read, understand, and agree SOFA Developer Certificate of Origin (DCO).


Reviewers will merge this pull-request only if

  • it builds with SUCCESS for all platforms on the CI.
  • it does not generate new warnings.
  • it does not generate new unit test failures.
  • it does not generate new scene test failures.
  • it does not break API compatibility.
  • it is more than 1 week old (or has fast-merge label).
The function are implementing commonly found deduction strategies used in SOFA.
Currently object factory use the canCreate function for several purpose, one of them is to deduce
the template depending on the scene graph context. The new implementation allows to do the same
without the need of the canCreate "static overrides"
…teDeductionMethod

This method is used to implement a template deduction mechanisme for a whole
hierarchy of classes instead of having heave class setting its own during the registration
in the factory.

Eg: all CollisionModel implements the same TemplateDeductionMethod
If there is not provided template, then the collision model will be
created with the template returned by using the getTemplateFromMechanical().
…teDeductionMethod

This method is used to implement a template deduction mechanisme for a whole
hierarchy of classes instead of having heave class setting its own during the registration
in the factory.

Eg: all CollisionModel implements the same TemplateDeductionMethod
If there is not provided template, then the collision model will be
created with the template returned by using the getTemplateFromMechanical().
@damienmarchal damienmarchal added the pr: clean Cleaning the code label Jun 28, 2023
@damienmarchal
Copy link
Contributor Author

[ci-build][with-scene-tests][with-regression-tests]

@damienmarchal
Copy link
Contributor Author

[ci-build][with-scene-tests][with-regression-tests]

…pr-replace-can-create-with-deductionrule

# Conflicts:
#	Sofa/Component/LinearSolver/Preconditioner/src/sofa/component/linearsolver/preconditioner/PrecomputedWarpPreconditioner.inl
…ctionrule' into pr-replace-can-create-with-deductionrule-step2
…ctionrule-step2' into pr-replace-can-create-with-deductionrule-step3
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
pr: clean Cleaning the code
1 participant