-
Notifications
You must be signed in to change notification settings - Fork 38
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
Polymorphic service issue #118
Comments
We don't have first class support for non single polymorphic service, but you can definitely roll up your own service kind that does just that. You're not the first one to ask for such feature, but I haven't find a way to implement a generic solution for this just yet.
To fix this you can create a custom service definition that contains a factory method that calls the container for a new instance, and return by Let me know if you need additional support. |
Hi, Thanks for the explanation. |
I investigated the issue I had and the problem was that I added a virtual destructor - so apparently no problem with inheritance, etc. but the virtual destructor made my code to not compile. Here is the example if you want to try yourself:
|
What compiler do you use? With GCC 13 this code compiles correctly and runs. I got the output |
Ah okay, I haven't checked any other one. I use Visual Studio 17 2022. Then it seems like a bug in MSVC. |
Checked with Clang 17.0.6 on windows and it works. |
Let me see what I can do to help MSVC with this one |
There's a simple workaround for this problem. Simply probe the service map using const ref types: template <typename... Overrides> struct autowire_override
{
template <typename T>
struct Service : kgr::single_service<T, kgr::autowire>, kgr::overrides<kgr::mapped_service_t<Overrides const&>...>
{
};
template <typename T> using mapped_service = Service<std::decay_t<T>>;
}; The root cause seems similar to issue #113 which means little can be done on my side to fix this issue without major refactoring of how the service map works, and modern technique that would make it possible are simply not available in the compilers kangaru 4 is set to support. Since there is an easy workaround I will close this issue. Let me know if despite the workaround you still experience difficulties with autowire on msvc. |
Hi,
I am currently investigating possibilities of the kangaru and I have a problem defining a polymorphic service which shall not be a single one:
Error that pops up is about deleted function
emplace<PerspectiveCameraService>()
.What I am trying to get is that there is some interface class but in case anyone wants to use it, it must get a unique instance.
I haven't gone through details of the library, but I hope you can answer whether it is possible but I am doing something wrong or support for such case was not planned.
The text was updated successfully, but these errors were encountered: