fix referencing bug (ros crashed during setup if mousemove) in co_WinPosSearchChildren

svn path=/trunk/; revision=17809
This commit is contained in:
Gunnar Dalsnes 2005-09-11 21:05:32 +00:00
parent 3a98addd02
commit f5449547b6
4 changed files with 17 additions and 14 deletions

View file

@ -14,9 +14,10 @@ PMENU_OBJECT FASTCALL UserGetMenuObject(HMENU hMenu);
DPRINT1("obj 0x%x dereffed to %i refs\n",_obj_, USER_BODY_TO_HEADER(_obj_)->RefCount-1); \ DPRINT1("obj 0x%x dereffed to %i refs\n",_obj_, USER_BODY_TO_HEADER(_obj_)->RefCount-1); \
ObmDereferenceObject2(_obj_); \ ObmDereferenceObject2(_obj_); \
} }
#endif #endif
#define ObmDereferenceObject(_obj_) ObmDereferenceObject2(_obj_)
@ -59,7 +60,7 @@ PMENU_OBJECT FASTCALL UserGetMenuObject(HMENU hMenu);
VOID FASTCALL ObmReferenceObject(PVOID obj); VOID FASTCALL ObmReferenceObject(PVOID obj);
BOOL FASTCALL ObmDereferenceObject(PVOID obj); BOOL FASTCALL ObmDereferenceObject2(PVOID obj);
PWINDOW_OBJECT FASTCALL IntGetWindowObject(HWND hWnd); PWINDOW_OBJECT FASTCALL IntGetWindowObject(HWND hWnd);
PVOID FASTCALL PVOID FASTCALL

View file

@ -275,7 +275,7 @@ VOID FASTCALL ObmReferenceObject(PVOID obj)
} }
BOOL FASTCALL ObmDereferenceObject(PVOID obj) BOOL FASTCALL ObmDereferenceObject2(PVOID obj)
{ {
PUSER_OBJECT_HEADER hdr = USER_BODY_TO_HEADER(obj); PUSER_OBJECT_HEADER hdr = USER_BODY_TO_HEADER(obj);

View file

@ -1483,7 +1483,10 @@ PWINDOW_OBJECT child_window_from_point(PWINDOW_OBJECT parent, int x, int y )
} }
#endif #endif
/* wine server: child_window_from_point
Caller must dereference the "returned" Window
*/
static static
VOID FASTCALL VOID FASTCALL
co_WinPosSearchChildren( co_WinPosSearchChildren(
@ -1519,22 +1522,22 @@ co_WinPosSearchChildren(
if (!IntPtInWindow(Current, Point->x, Point->y)) if (!IntPtInWindow(Current, Point->x, Point->y))
{ {
continue; continue;
} }
if (*Window) UserDerefObject(*Window);
*Window = Current; *Window = Current;
UserRefObject(*Window);
if (Current->Style & WS_MINIMIZE) if (Current->Style & WS_MINIMIZE)
{ {
*HitTest = HTCAPTION; *HitTest = HTCAPTION;
UserRefObject(Current);
break; break;
} }
if (Current->Style & WS_DISABLED) if (Current->Style & WS_DISABLED)
{ {
*HitTest = HTERROR; *HitTest = HTERROR;
UserRefObject(Current);
break; break;
} }
@ -1561,7 +1564,6 @@ co_WinPosSearchChildren(
co_WinPosSearchChildren(Current, OnlyHitTests, Point, Window, HitTest); co_WinPosSearchChildren(Current, OnlyHitTests, Point, Window, HitTest);
} }
UserRefObject(Current);
UserDerefObjectCo(Current); UserDerefObjectCo(Current);
break; break;