-
Notifications
You must be signed in to change notification settings - Fork 65
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
Program hangs when I use trackPopupMenuEx #149
Comments
Hi @xafizoff can you give me a full source repro? Also did you try with Thanks. |
How to reproduce> git clone https://github.com/xafizoff/haskell-win32-example.git
> cd haskell-win32-example
> cabal new-run haskell-win32-example-exe Environment> cabal --version
cabal-install version 3.2.0.0
compiled using version 3.2.0.0 of the Cabal library > ghc --version
The Glorious Glasgow Haskell Compilation System, version 7.10.3 |
Also reproducible with Win32 v2.9.0.0. Sometimes you need to play with the cursor to freeze the program. |
That looks like it's because you're blocking the message pump.
That said I don't remember enough about these Window APIs to suggest a complete solution, my initial thought it the pump must be created on a different OS thread, or the menu. a C tutorial on how to use this should have the right approach. |
I don't know why it is blocking, probably due to Haskell RTS involvement, but similar C code works fine. So I ended up doing all GUI related stuff as a single foreign call. I just pushed it to github. |
This is almost certainly the fault of this unsafe foreign import: I surmise from this thread of issues that In multi-threaded runtime all capabilities must synchronise before GC can happen and those threads will block until synchronisation happens. Since the capability doing the unsafe foreign call can't synchronise this means all threads are blocked until the unsafe foreign call returns. This is not the only dangerous unsafe foreign import, I found this issue after someone on IRC mentioned deadlocking when they used The solution is to not import these unsafely. Or even better remove all unsafe foreign imports from the package except those that are 100%, definitely known to be safe (i.e. non-blocking and short running). |
Hello,
hm I was sure I tried that, but most likely changed the wrong one. In any case I'll look into these again.
Indeed, these UI bits were added as a mass import but clearly some slipped by. |
Current Behavior
Program hangs with trackPopupMenu(Ex).
Steps to Reproduce (for bugs)
My code is based on https://github.com/haskell/win32/blob/v2.6.1.0/examples/hello.lhs, except I do not do painting.
A pop-up menu appears, but the program ends up freezing after that. I've tried to remove
WM_COMMAND
branch fromwndProc
, but this does not help.Your Environment
The text was updated successfully, but these errors were encountered: