Hi,

Rein Klazes wrote:
[...]
This patch is causing a problem in Pegasus Mail. Closing some dialogs
cause termination of the complete program.
Here is a part of SPY++ log when run under win2000, when I close the
edit new mail dialog:

|<00202> 00130A82 S ..........................WM_SYSCOMMAND uCmdType:SC_CLOSE 
xPos:672 yPos:121 [wParam:0000F060 lParam:007902A0]
|<00203> 00130A82 S ...........................WM_CLOSE wParam:00000000 
lParam:00000000
|<00204> 00130A82 S ............................WM_QUERYENDSESSION nSource:1 
(End Task from Task List dialog) [wParam:00000001 lParam:00000000]
|<00951> 00130A82 R ............................WM_QUERYENDSESSION 
fShutdownIsOk:True [lResult:00000001]
...
|<00952> 00130A82 S ............................WM_ENDSESSION fEndSession:True 
[wParam:00000001 lParam:00000000]
|<00953> 00130A82 R ............................WM_ENDSESSION lResult:00000000

The WM_QUERYENDSESSION and WM_ENDSESSION are sent by the program:

|0009:Call user32.SendMessageA(00030024,00000011,00000001,00000000) ret=0040641d

It's pretty weird that the application is sending a WM_QUERYENDSESSION/WM_ENDSESSION to itself.


How did you check the behavior of the Windows DefWindowProc? If I put a
DefWindowProc(hwnd, WM_ENDSESSION, 1, 0); some where in a windows
program nothing happens, while a PostQuitMesage certainly closes the
app.

I used a modified poppad sample app from Petzold and used Spy++ to check that a WM_ENDSESSION caused the app to exit eventhough that application's main loop did not contain any special handling for WM_ENDSESSION.

So, since the decision to exit on WM_ENDSESSION is not made in the application's main loop I placed it in the DefWindowProc. But I must have gotten some detail wrong. Unfortunately I'm away from my computer for the next week, so I can't investigate right now.


--
Francois Gouget
[EMAIL PROTECTED]



Reply via email to