* "where" and "be:view_where" are supposed to contain the same value; dunno

why the latter is then even added, but we do the same thing as BeOS now.
* This fixes bug #2075.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@24997 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2008-04-17 11:10:44 +00:00
parent ba575e420d
commit e0da34f5c0

View File

@ -3050,8 +3050,7 @@ BWindow::_UnpackMessage(unpack_cookie& cookie, BMessage** _message, BHandler** _
}
/*!
Some messages don't get to the window in a shape an application should see.
/*! Some messages don't get to the window in a shape an application should see.
This method is supposed to give a message the last grinding before
it's acceptable for the receiving application.
*/
@ -3070,13 +3069,12 @@ BWindow::_SanitizeMessage(BMessage* message, BHandler* target, bool usePreferred
if (message->FindPoint("screen_where", &where) != B_OK)
break;
// add local window coordinates
message->AddPoint("where", ConvertFromScreen(where));
BView* view = dynamic_cast<BView*>(target);
if (view != NULL) {
// add local view coordinates
message->AddPoint("be:view_where", view->ConvertFromScreen(where));
message->AddPoint("be:view_where",
view->ConvertFromScreen(where));
message->AddPoint("where", view->ConvertFromScreen(where));
if (message->what == B_MOUSE_MOVED) {
// is there a token of the view that is currently under the mouse?
@ -3106,6 +3104,9 @@ BWindow::_SanitizeMessage(BMessage* message, BHandler* target, bool usePreferred
if (usePreferred || viewUnderMouse == NULL)
fLastMouseMovedView = viewUnderMouse;
}
} else {
// add local window coordinates
message->AddPoint("where", ConvertFromScreen(where));
}
break;
}