server: Treat desktop as a top-level window.
diff --git a/dlls/user32/tests/msg.c b/dlls/user32/tests/msg.c
index d04028c..799c891 100644
--- a/dlls/user32/tests/msg.c
+++ b/dlls/user32/tests/msg.c
@@ -9250,7 +9250,7 @@
trace("SetForegroundWindow( GetDesktopWindow() )\n");
SetForegroundWindow( GetDesktopWindow() );
ok_sequence(SetForegroundWindowSeq, "SetForegroundWindow( desktop ) away from "
- "foreground top level window", TRUE);
+ "foreground top level window", FALSE);
trace("done\n");
DestroyWindow(hwnd);
diff --git a/dlls/user32/tests/win.c b/dlls/user32/tests/win.c
index b5d2ad5..6cbddeb 100644
--- a/dlls/user32/tests/win.c
+++ b/dlls/user32/tests/win.c
@@ -2213,12 +2213,9 @@
hwnd2 = GetForegroundWindow();
ok(hwnd2 == hwnd, "Wrong foreground window %p\n", hwnd2);
- todo_wine
- {
ok(SetForegroundWindow( GetDesktopWindow() ), "SetForegroundWindow(desktop) error: %d\n", GetLastError());
hwnd2 = GetForegroundWindow();
ok(hwnd2 != hwnd, "Wrong foreground window %p\n", hwnd2);
- }
ShowWindow(hwnd, SW_HIDE);
check_wnd_state(0, 0, 0, 0);
diff --git a/server/window.c b/server/window.c
index cbb4296..182213e 100644
--- a/server/window.c
+++ b/server/window.c
@@ -514,7 +514,7 @@
int is_top_level_window( user_handle_t window )
{
struct window *win = get_user_object( window, USER_WINDOW );
- return (win && win->parent && is_desktop_window(win->parent));
+ return (win && (is_desktop_window(win) || is_desktop_window(win->parent)));
}
/* make a window active if possible */