Author: jimtabor
Date: Fri May 25 19:52:24 2012
New Revision: 56658

URL: http://svn.reactos.org/svn/reactos?rev=56658&view=rev
Log:
[Win32k]
- Fix the remaining wine Win test_SetFocus to does.

Modified:
    trunk/reactos/win32ss/user/ntuser/winpos.c

Modified: trunk/reactos/win32ss/user/ntuser/winpos.c
URL: 
http://svn.reactos.org/svn/reactos/trunk/reactos/win32ss/user/ntuser/winpos.c?rev=56658&r1=56657&r2=56658&view=diff
==============================================================================
--- trunk/reactos/win32ss/user/ntuser/winpos.c [iso-8859-1] (original)
+++ trunk/reactos/win32ss/user/ntuser/winpos.c [iso-8859-1] Fri May 25 19:52:24 
2012
@@ -1711,7 +1711,7 @@
       }
    }
 
-   if (!(WinPos.flags & SWP_NOACTIVATE))//(SWP_NOACTIVATE|SWP_HIDEWINDOW)))
+   if (!(WinPos.flags & (SWP_NOACTIVATE|SWP_HIDEWINDOW)))
    {
       if ((Window->style & (WS_CHILD | WS_POPUP)) == WS_CHILD)
       {
@@ -1848,6 +1848,15 @@
             Swp |= SWP_NOACTIVATE;
             if (!(style & WS_MINIMIZE))
             {
+               // Fix wine Win test_SetFocus todo #1 & #2,
+               if (Cmd == SW_SHOWMINIMIZED)
+               {
+                  if ((style & (WS_CHILD | WS_POPUP)) == WS_CHILD)
+                     co_UserSetFocus(Wnd->spwndParent);
+                  else
+                     co_UserSetFocus(0);
+               }
+
                Swp |= co_WinPosMinMaximize(Wnd, SW_MINIMIZE, &NewPos) |
                       SWP_FRAMECHANGED;
             }
@@ -1965,7 +1974,7 @@
       {
          Parent = Wnd->spwndParent;
          if (Wnd->spwndParent == UserGetDesktopWindow()) Parent = 0;
-            co_UserSetFocus(Parent);
+         co_UserSetFocus(Parent);
       }
    }
 
@@ -1978,8 +1987,12 @@
    }
 
    /* if previous state was minimized Windows sets focus to the window */
-   if (style & WS_MINIMIZE) co_UserSetFocus(Wnd);
-
+   if (style & WS_MINIMIZE)
+   {
+      co_UserSetFocus(Wnd);
+      // Fix wine Win test_SetFocus todo #3,
+      if (!(style & WS_CHILD)) co_IntSendMessageNoWait(UserHMGetHandle(Wnd), 
WM_ACTIVATE, WA_ACTIVE, 0);
+   }
    return(WasVisible);
 }
 


Reply via email to