-
Notifications
You must be signed in to change notification settings - Fork 808
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
Last error wrongly set by some modules #2302
Last error wrongly set by some modules #2302
Conversation
b08575e
to
bac97b8
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can't we use a function?
It has been some time since I started this. Are the changes OK, is it safe to propagate them to other modules that have the same problem? |
What I meant was that in this patch it seems that the new macro isn't really necessary and an (inline?) function seems cleaner. Is there a reason we can't do that? I'm not against the macro where it makes sense, but I don't see how it does in those 2 files. |
44b7cc0
to
2f5824c
Compare
That looks great, thanks! How do you feel about using the name |
I remembered why I used a macro: to avoid a direct call to *A functions and use the VStudio macros (e.g.: GetModuleHandle) instead. |
The changes seem fine - if you update the name and remove that stray clang comment, I'm fine with landing this now and doing the rest in another PR, or extending this PR for the rest - up to you! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
thanks - seeing this is a bug fix, could you please add a changes entry?
d483278
to
d246bcb
Compare
It was the (dumb) formatter again. Apparently, the Unfortunately I don't know how (if) could I do it manually (even in my fork). |
@CristiFati You can normally retrigger GitHub workflows by closing/reopening a PR (that's what I do for random test failure and what we have to do for some automated PRs in Typeshed). If you amend your last commit's name and force-push that should do it too. |
d246bcb
to
8982106
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks!
This is a proposed fix for #2301.
When searching for functions in libraries, GetModuleHandle is attempted 1st (most likely to avoid incrementing RefCount), and only if it fails LoadLibrary is used. Unfortunately, for libraries that aren't already loaded ("secur32* for win32api or msimg32 for win32gui) GetModuleHandle sets last error flag to 126: ERROR_MOD_NOT_FOUND. Since the flag is not cleared, for win32gui my EnumWindows changes seem to have no effect.
The proposed fix is in a form of a macro that does the library loading (following Py_BEGIN_ALLOW_THREADS model) and clears this particular error.
Notes:
A simpler way would be to simply clear the error once (just before module initialization end), but that's lame, and may swallow other errors that could come and bite in the ass at a later time (just like this one did)
I only fixed these 2 modules (as a POC). I will fix the others affected (a quick code search revealed them), once I have the green light, as this is basically monkey-work (that I don't want to do more than absolutely necessary)
My win32gui tests were not affected by it since I'm manually clearing the error flag. I remember that I ran into this error at the time, and clearing the flag fixed the problem which was good enough (I didn't dig deeper). But tests are perfectly fine, as they should start from a known (and deterministic) state
I don't know why this method with function pointers was chosen (instead of linking with the .lib files), as a vast majority of these functions are there since Windows 2000 (and exposed by VStudio)
I wouldn't be surprised if there were more open issues caused by this