-
Notifications
You must be signed in to change notification settings - Fork 10
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
Mutex Lock crash when initialising RadialLight when linking static library. #10
Comments
Thought I'd update, the pointer idea might not be as effective as I thought, since exiting the application results in a different crash. |
Hi, gamepopper. |
I regret not writing down the exact function it crashed on, but I know it was another access violation, but instead, it took place from the sf::Texture destructor the moment I try to close the application. In my attempt to reproduce it, I found it work fine if you set up a lighting area beforehand, it will construct and destruct the texture without issue, even when you close the application. However, if you don't set up a lighting area, you get an assertion error. It's also in the sf::Texture destructor, unlike the static sf::Texture one I can't narrow this one down. A raw-pointer approach I figured out is to include a static integer to count the number of RadialLight instances. Anytime the constructor is called, the counter increments, and whenever the destructor is called it decrements. If the count is zero when the destructor is called, the textures get deleted.
At least with this approach, the textures won't be created until there is one RadialLight instance, and it will be destroyed when there are no more RadialLights. |
The problem with this is that each time the counter reaches 0, the textures are required to be reinstantiated in case a new light is created. For that, after setting the pointers to nullptr, the instantiation flag should be also set to false: l_texturesReady = false; It is better than crashing, though. |
Ok, I've replaced the textures I also implemented the counter of instances to remove the textures when they are not required. As you said, that would be a solution for raw-pointers, but I enabled that anyways because I'm not sure if a global I know this is not the best solution, and all this problems just are pointing to an underlying design problem... but for now, this may patch things up until a future version. @all-contributors please add @gamepopper for bug report and testing Let me know if you get it to work 😃 |
I've manged to build the demo from the source code without issues, however when trying to link the compiled lib into another project I get issues with the RadialLight class.
I define the RadialLight in the header of a game state class (using my own framework built on top of SFML) like so:
Also, implement a test example in the cpp like so:
It compiles in Visual Studio 2017, but when I try to run I get a crash from an Access Violation within MutexImpl::lock(). Going down the call stack, the source is the RadialLight class when calling the default constructor on the two sf::Texture objects within RadialLight.cpp:
I've found one way to resolve the crash, however. You can change these two to pointers (or better, smart unique pointers) and initialise the pointers in the initializeTextures function, that way the textures don't try to initialise before the main function is called.
If you want to avoid smart pointers for compatibility, you could use raw pointers but then you would need to add a way to delete the pointer when the user wants to close the application.
The text was updated successfully, but these errors were encountered: