-
Notifications
You must be signed in to change notification settings - Fork 84
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
Eliminate complex typed static variables #35
Conversation
Would is also be possible to provide a minimum example allowing to reproduce the problem on windows ? |
It happens for us when we use it through the MITK Python console, compiled on Windows with VS2012. (We have not tried other VS versions.) The static map data members definitely cause a crash. Just moving them inside a getter function does not help, I had to turn them into pointers, assign NULL to them and do a NULL check. This was in PythonQtConversion and PythonQtMethondInfo. The other changes I made just to be consistent with the pattern but have not actually run into a crash. |
Since commontk/PythonQt is just a staging area to conveniently host patches before integrating them upstream, we should make sure we have a simple use case to integrate to the test suite. |
Python, PythonQt, CTK and MITK were all in release mode. Later I rebuilt PythonQt and CTK with adding debug symbols (/Zi) to the release build, so that I can step through the code to find the bug. I will try to reproduce the issue with ctkSimplePythonShell later. |
Complex typed static variables (e.g. maps) in dll-s are to avoid. On Windows they are not initialised in time (or at all) when the dll is dynamically loaded. The current use of static QHash data members results in crash on Windows when the PythonQt.dll is loaded. See details here: http://stackoverflow.com/questions/5114683/loading-dll-not-initializing-static-c-classes
6a29110
to
127d894
Compare
Great. Keep us posted of your findings. |
ctkSimplePythonShell works fine. |
Good. Then, could the issue be in how PythonQt/CTK is integrated in MITK ? It would be good if we can make a good case and get your changes upstreamed. |
I do not think so. I built MITK with the Python console plugin yesterday. The exact same plugin that we use in our MITK based application. PythonQt commit hash was the same as well. And it does not crash there. The only difference I see is that we make our release build with debug symbols, while the clean MITK build was without symbols. It does not make much sense, I know, but do not see any difference. I will rebuild MITK with debug symbols to see if it crashes. |
I got it. There are a few differences in the MITK plugin that we use compared to their latest release. We applied some later fixes from their master branch. The changes factor out the MitkPythonService code to a separate module that is loaded dynamically through an 'autoload' mechanism when the core library of the application (MitkCore.dll) is loaded. PythonQt is initialised from the activator of the MitkPythonService module, that is probably a called from a static initialiser. (It's a macro generated code, did not decypher it.) So, it seems that the crash occurs when PythonQt is called from a static initiliser of a library that is being loaded. (And PythonQt has not been loaded before.) Florian agreed to incorporate part of my patch that turns the static data members to pointers and initialises them lazily from a getter. |
Outstanding investigation 👍 Thanks for the detailed report
Sounds good. When you have a patch close to what you would contribute upstream, we will integrate it in the CTK fork. Let me know what you think, |
I pushed a new, slimmer PR, based on the discussion with Florian: |
Complex typed static variables (e.g. maps) in dll-s are to avoid.
On Windows they are not initialised in time (or at all) when the dll
is dynamically loaded. The current use of static QHash data members
results in crash on Windows when the PythonQt.dll is loaded.
See details here:
http://stackoverflow.com/questions/5114683/loading-dll-not-initializing-static-c-classes